@ -0,0 +1,31 @@ | |||||
#! /usr/bin/env python | |||||
import sys | |||||
import main_backuper as mainscr | |||||
def f_main(): | |||||
conf, errorcode = mainscr.conf_read() | |||||
hosts, errorcode = mainscr.hosts_read(conf["hosts"]) | |||||
inp = [] | |||||
for host in hosts: | |||||
if host[2] == "up" : | |||||
inp.append(host[0]) | |||||
f_json_print(inp) | |||||
def f_json_print(inp): | |||||
first = True | |||||
print("{") | |||||
print("\t\"data\":[") | |||||
for key in inp: | |||||
if not first: | |||||
sys.stdout.write(",") | |||||
else: | |||||
first = False | |||||
sys.stdout.write("\n\t\t{\"{#HOST}\":\"" + key + "\"}") | |||||
print("\n\t]") | |||||
print("}") | |||||
if __name__ == '__main__': | |||||
f_main() |
@ -0,0 +1,146 @@ | |||||
#!/usr/bin/python | |||||
# coding=utf-8 | |||||
import paramiko | |||||
import time | |||||
import sys | |||||
def get_data(host, user, password, commands): # вытаскиваем из циски данные | |||||
errorcode = '' | |||||
client = paramiko.SSHClient() | |||||
client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # если нет хоста - добавляем | |||||
out = [] # выхлоп будет в этом списке | |||||
try: | |||||
client.connect(hostname=host, username=user, password=password, look_for_keys=False, | |||||
allow_agent=False) # пытаемся подключиться, look_for_keys=False, allow_agent=False - зачем-то нужны циске. | |||||
except Exception as exept: # в случае исключения - | |||||
errorcode = exept # возвращаем код и описание исключения | |||||
else: # усли все в порядке | |||||
conn = client.invoke_shell() # врубаем интерактивный шелл - с цисками только так. | |||||
time.sleep(1) # задержка | |||||
conn.recv(1000) # хаваем все, что выплюнула цика, дабы не отсвечивало | |||||
for command in commands: # Читаем и исполняем команды | |||||
if command[0] == "$username": | |||||
command[0] = user | |||||
if command[0] == "$password": | |||||
command[0] = password | |||||
conn.send(command[0] + '\n') # засылаем команду | |||||
time.sleep(int(command[1])) # ждем указанный таймаут | |||||
if command[2]: # если сказано сохранять - сохраняем выхлоп | |||||
conn_out = conn.recv(99999999999).splitlines() # жрем выхлоп в список, разбивая по строкам | |||||
out_line = "" # пустая строка для сохранения | |||||
if len(conn_out) > 2: | |||||
conn_out.pop() # обрезаем последнюю строку строку | |||||
conn_out.pop(0) # Обрезаем первую строку | |||||
if command[3]: # если сказано комментить - комментим | |||||
for line in conn_out: # перебираем все строки | |||||
line = "!" + line # Добавляем в начало ! | |||||
out_line = out_line + line + '\n' # Собираем все мимо строк, прямо в одну строковую переменную | |||||
else: # Если не сказано коментить - не коментим | |||||
for line in conn_out: # перебираем все строки | |||||
out_line = out_line + line + '\n' # Собираем все мимо строк, прямо в одну строковую переменную | |||||
out.append(out_line) # Добавляем все толпой в выхлоп | |||||
else: # если выхлоп нам ненужон | |||||
conn.recv(99999999999) # хаваем его в никуда | |||||
finally: # по окончании всех процедур | |||||
client.close() # закрываем коннектий | |||||
return out, errorcode # Вертаем все, что наковыряли | |||||
def read_file(in_file): | |||||
errorcode = "" # устанавливаем переменные | |||||
out = [] | |||||
try: # Пробуем открыть файл | |||||
f = open(in_file, 'r') | |||||
except Exception as exept: | |||||
errorcode = exept # не получилось - запиливаем исключение | |||||
else: # Если все норм - начинаем читать | |||||
for line in f: # Каждую линию | |||||
sp_line = line.split(',') # бомбим линию по разделителю в переменную | |||||
command = [] # устанавливаем список, в котором будет храниться команда с атрибутами | |||||
if len(sp_line) > 0: # если элементов больше 0 | |||||
command.append(sp_line[0]) # добавляем элемент в список (это будет команда) | |||||
if len(sp_line) > 1: # если больше одного | |||||
if sp_line[1].strip().isdigit(): # если 1-й элемент из цыфарок | |||||
command.append(int(sp_line[1].strip())) # добавляем цыфарку, это таймаут | |||||
else: # если не цыфарки | |||||
command.append("1") # то таймаут - 1 секунд | |||||
if len(sp_line) > 2: # если более 2 | |||||
if sp_line[2].strip() == "0" or sp_line[2].strip() == "False": # 2 элемент равен фалсе или 0 | |||||
command.append(False) # добавляем фалсе | |||||
else: # если там чтой-то другое | |||||
command.append(True) # добавляем трую | |||||
if len(sp_line) > 3: # если элементов больше 3 | |||||
if sp_line[3].strip() == "0" or sp_line[3].strip() == "False": # 3 элемент равен фалсе или 0 | |||||
command.append(False) # добавляем фалсе | |||||
else: # если там чтой-то другое | |||||
command.append(True) # добавляем трую | |||||
if 0 < len(command) < 4: # если элементов не хватает, добиваем фалсой | |||||
for i in [0, 1, 2, 3]: | |||||
try: | |||||
command[i] | |||||
except IndexError: | |||||
command.append(False) | |||||
out.append(command) | |||||
return out, errorcode # вертаем, что наковыряли | |||||
def arg_parse(args): # парсим коммандную строку | |||||
user = "" # устанавливаем переменные | |||||
password = "" | |||||
cmdfile = "" | |||||
host = "" | |||||
errorcode = "" | |||||
for arg in args[1:]: # Перебираем элементы, присваивая списку все подряд | |||||
if "\"" in arg or "\'" in arg: # обрезаем кавычки, если есть | |||||
arg = arg[1:-1] | |||||
sp_arg = arg.split("=") | |||||
if sp_arg[0].strip() not in ["host", "user", "password", "cmdfile"]: | |||||
errorcode = errorcode + " " + arg + " Недопустимый аргумент, допустимые аргументы:" \ | |||||
"user=, host=, password=, cmdfile=" | |||||
elif sp_arg[0].strip() == "user": | |||||
user = sp_arg[1].strip() | |||||
elif sp_arg[0].strip() == "password": | |||||
password = sp_arg[1].strip() | |||||
elif sp_arg[0].strip() == "host": | |||||
host = sp_arg[1].strip() | |||||
elif sp_arg[0].strip() == "cmdfile": | |||||
cmdfile = sp_arg[1].strip() | |||||
if str(user) == "": # дальше все подряд ясно | |||||
errorcode = errorcode + "пользователь пустой " | |||||
if str(password) == "": | |||||
errorcode = errorcode + "пароль пустой " | |||||
if str(cmdfile) == "": | |||||
errorcode = errorcode + "не указан cmdfile " | |||||
if str(host) == "": | |||||
errorcode = errorcode + "хост пустой " | |||||
return user, password, host, cmdfile, errorcode | |||||
if __name__ == '__main__': | |||||
user = '' | |||||
host = '' | |||||
password = '' | |||||
cmdfile = '' | |||||
errorcode = '' | |||||
if len(sys.argv) > 1: | |||||
user, password, host, cmdfile, errorcode = arg_parse(sys.argv) | |||||
commands, errorcode = read_file(cmdfile) | |||||
if errorcode: | |||||
exit(errorcode) | |||||
try: | |||||
commands | |||||
except NameError: | |||||
commands = [['login', 0, False, True], | |||||
[user, 0, False, True], | |||||
[password, 0, False, True], | |||||
['terminal pager 0', 1, False, True], | |||||
['show version', 5, True, True], | |||||
['show flash', 5, True, True], | |||||
['show configuration', 10, True, False]] | |||||
output, errorcode = get_data(host, user, password, commands) | |||||
if errorcode == "0": | |||||
for out in output: | |||||
print out | |||||
else: | |||||
print("errorcode = " + str(errorcode)) |
@ -0,0 +1,7 @@ | |||||
login, 1, 0, 0 | |||||
$username, 1, 0, 0 | |||||
$password, 1, 0, 0 | |||||
terminal pager 0, 1, 0, 0 | |||||
show version, 5, 1, 1 | |||||
show flash, 5, 1, 1 | |||||
show configuration, 10, 1, 0 |
@ -0,0 +1,4 @@ | |||||
terminal length 0, 1, 0, 0 | |||||
show version, 5, 1, 1 | |||||
show flash, 5, 1, 1 | |||||
more flash:config.text, 10, 1, 0 |
@ -0,0 +1,4 @@ | |||||
terminal length 0, 1, 0, 0 | |||||
show version, 5, 1, 1 | |||||
show flash, 5, 1, 1 | |||||
more flash:config.txt, 10, 1, 0 |
@ -0,0 +1,7 @@ | |||||
login, 0, 0, 0 | |||||
$username, 0, 0, 0 | |||||
$password, 0, 0, 0 | |||||
terminal pager 0, 0, 0, 0 | |||||
show version, 5, 1, 1 | |||||
show flash, 5, 1, 1 | |||||
show configuration, 10, 1, 0 |
@ -0,0 +1,6 @@ | |||||
inside.f-warehouse.yaroslavl.jentry.ru, cisco-asa.conf, up | |||||
inside.f-office.yaroslavl.jentry.ru, cisco-asa.conf, up | |||||
inside.f-warehouse2.yaroslavl.jentry.ru, cisco-asa.conf, up | |||||
inside.f-office.tutaev.jentry.ru, cisco-asa.conf, down | |||||
inside.f-office.rybinsk.jentry.ru, cisco-asa.conf, up | |||||
@ -0,0 +1,5 @@ | |||||
# commmentos | |||||
hosts=/opt/backuper/hosts/hosts.db | |||||
typedir=/opt/backuper/type/ # commento | |||||
cmddir=/opt/backuper/cmd/ | |||||
outdir=/opt/backuper/config/ |
@ -0,0 +1,186 @@ | |||||
#!/usr/bin/python | |||||
# coding=utf-8 | |||||
import os | |||||
import cisco_backuper as cisco | |||||
import datetime | |||||
import logging | |||||
import send_to_zabbix as sender | |||||
def conf_read(): # читаем конфиг | |||||
errorcode = "" # Устанавливаем переменные | |||||
out = {} | |||||
try: # Пробуем открыть конфиг | |||||
f = open("/opt/backuper/main_backuper.conf", 'r') # ОПАСНОСТЕ! БЫДЛОКОД!!! ЗАХАРДКОДИЛ КОНФИГ!!! | |||||
except Exception as exept: # ЭКСЕПШЕН!!!! | |||||
errorcode = exept | |||||
else: # если все в норме, то вперед, к победе | |||||
for line in f: # перебираем лайн по одной | |||||
if line[0] == "#": # если начинаетя с решетки - коммент | |||||
continue # пропускаем | |||||
sp_line = line.split("=") # разделяем строку | |||||
if len(sp_line) == 2: # если параметров - сколько надо | |||||
if sp_line[0] not in ['hosts', 'typedir', 'cmddir', 'outdir']: # и если это не один из параметров | |||||
errorcode = "unknown arg " + str(sp_line) # говорим, что всё говно | |||||
break # и вываливаемся | |||||
if "#" in sp_line[1]: # если во втором аргументе есть решеточка | |||||
param = sp_line[1].split("#")[0].strip() # то обрезаем все, кроме решетки | |||||
else: # а если нет | |||||
param = sp_line[1].strip() # то не обрезаем | |||||
out[sp_line[0]] = param # добавляем параметр | |||||
return out, errorcode # вертаем всё | |||||
def hosts_read(hosts): # читаем файл с хостами | |||||
errorcode = "" # Устанавливаем переменные | |||||
out = [] | |||||
args = [] | |||||
try: # пробуем открыть файл | |||||
f = open(hosts, 'r') | |||||
except Exception as exept: # ловим исключение | |||||
errorcode = exept | |||||
else: # если все в порядке | |||||
for line in f: # читаем линии | |||||
if line[0] == "#": # если начинаетя с решетки - коммент | |||||
continue | |||||
if "#" in line: # если в строке решетка | |||||
sp_line = line.split("#")[0].split( | |||||
",") # то бомбим строку по решетке, и первый элемент снова бомбим, уже по запятой | |||||
else: | |||||
sp_line = line.split(",") # а если нет решетки, то просто бомбим по запятой | |||||
for arg in sp_line: # а потом перебираем элементы | |||||
args.append(arg.strip()) # и добавляем в список | |||||
out.append(args) # а потом добавляем список в список | |||||
args = [] # сбрасываем ненужные уже значения | |||||
return out, errorcode # вертаем в зад что наковыряли | |||||
def type_read(type_dir, type_file): # читаем тип хоста надоело комментить все как в предыдущей | |||||
errorcode = "" | |||||
out = {} | |||||
try: | |||||
f = open((type_dir + type_file), 'r') | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
else: | |||||
for line in f: | |||||
if line[0] == "#": | |||||
continue | |||||
sp_line = line.split("=") | |||||
if len(sp_line) == 2: | |||||
if sp_line[0] not in ['cmd', 'user', 'password']: | |||||
errorcode = "unknown arg " + str(sp_line) | |||||
break | |||||
if "#" in sp_line[1]: | |||||
param = sp_line[1].split("#")[1].strip() | |||||
else: | |||||
param = sp_line[1].strip() | |||||
if "\"" in param or "\'" in param: | |||||
param = param[1:-1] | |||||
out[sp_line[0]] = param | |||||
return out, errorcode | |||||
def out_write(write_dir, name, out): | |||||
errorcode = "" | |||||
now_date = datetime.date.today() | |||||
dir_to_write = write_dir + str(now_date) + "/" | |||||
logging.debug("dir = " + str(dir_to_write)) | |||||
outfile = dir_to_write + name | |||||
logging.debug("file = " + outfile) | |||||
if not os.path.exists(dir_to_write): | |||||
try: | |||||
os.mkdir(dir_to_write) | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
return errorcode | |||||
if not os.path.isdir(dir_to_write): | |||||
errorcode = "Dir to write is not dir" | |||||
return errorcode | |||||
if not os.path.exists(outfile): | |||||
try: | |||||
f = open(outfile, "w") | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
return errorcode | |||||
else: | |||||
in_file = "" | |||||
for outed in out: | |||||
in_file = in_file + outed | |||||
f.write(in_file) | |||||
logging.debug("writed") | |||||
finally: | |||||
f.close() | |||||
else: | |||||
errorcode = "file exist" | |||||
return errorcode | |||||
return errorcode | |||||
def main(): | |||||
logging.basicConfig(format = u'%(filename)s[LINE:%(lineno)d]# %(levelname)-8s [%(asctime)s] %(message)s', | |||||
level=logging.DEBUG, filename="./backuper.log") | |||||
errorcode = "" | |||||
conf = {} | |||||
out = [] | |||||
conf, errorcode = conf_read() | |||||
hosts = [] | |||||
if errorcode != "": | |||||
logging.critical(errorcode) | |||||
keys = {"backuper[backuper_error]" : "1", } | |||||
sender.sendkey(keys) | |||||
exit(errorcode) | |||||
else: | |||||
hosts, errorcode = hosts_read(conf["hosts"]) | |||||
if errorcode != "": | |||||
logging.critical(errorcode) | |||||
keys = {"backuper[backuper_error]" : "2", } | |||||
sender.sendkey(keys) | |||||
exit(errorcode) | |||||
else: | |||||
keys = {"backuper[backuper_error]" : "0", } | |||||
sender.sendkey(keys) | |||||
for host in hosts: | |||||
logging.debug(str(host) + "-" + str(errorcode)) | |||||
for host in hosts: | |||||
if host[2] != "up": | |||||
logging.debug(host[0] + " down") | |||||
continue | |||||
logging.debug(host[0] + " up") | |||||
logging.debug("reading type") | |||||
type_attr, errorcode = type_read(conf["typedir"], host[1]) | |||||
if errorcode != "": | |||||
logging.warn(errorcode) | |||||
keys = {"backuper[" + host[0] + "]" : "1"} | |||||
sender.sendkey(keys) | |||||
continue | |||||
logging.debug(type_attr) | |||||
logging.debug("reading cmd") | |||||
commands, errorcode = cisco.read_file((conf["cmddir"] + type_attr["cmd"])) | |||||
if errorcode != "": | |||||
logging.warn(errorcode) | |||||
logging.warn(errorcode) | |||||
keys = {"backuper[" + host[0] + "]" : "2", } | |||||
sender.sendkey(keys) | |||||
continue | |||||
logging.debug(commands) | |||||
logging.debug(commands) | |||||
out, errorcode = cisco.get_data(host[0], type_attr["user"], type_attr["password"], commands) | |||||
if errorcode != "": | |||||
logging.warn(errorcode) | |||||
logging.warn(errorcode) | |||||
keys = {"backuper[" + host[0] + "]" : "3", } | |||||
sender.sendkey(keys) | |||||
continue | |||||
errorcode = out_write(conf['outdir'], host[0], out) | |||||
if errorcode != "": | |||||
logging.warn(errorcode) | |||||
keys = {"backuper[" + host[0] + "]" : "4", } | |||||
sender.sendkey(keys) | |||||
else: | |||||
keys = {"backuper[" + host[0] + "]" : "0", } | |||||
sender.sendkey(keys) | |||||
if __name__ == '__main__': | |||||
main() |
@ -0,0 +1,89 @@ | |||||
#!/usr/bin/python | |||||
# coding=utf-8 | |||||
import subprocess | |||||
import logging | |||||
import datetime | |||||
import random | |||||
import os | |||||
def writedata(data, path="/tmp"): | |||||
errorcode = "" | |||||
now_date = datetime.date.today() | |||||
outfile = path + str(str(now_date)+ str(random.randint(1, 1000))) | |||||
logging.debug("file = " + outfile) | |||||
if not os.path.exists(path): | |||||
try: | |||||
os.mkdir(path) | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
return errorcode | |||||
if not os.path.isdir(path): | |||||
errorcode = "Dir to write is not dir" | |||||
return errorcode | |||||
if not os.path.exists(outfile): | |||||
try: | |||||
f = open(outfile, "w") | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
return errorcode | |||||
else: | |||||
in_file = "" | |||||
for line in data: | |||||
in_file = in_file + line | |||||
f.write(in_file) | |||||
logging.debug("zabbix-file writed") | |||||
finally: | |||||
f.close() | |||||
else: | |||||
errorcode = "file exist" | |||||
return errorcode | |||||
return outfile, errorcode | |||||
def sendfile(file, server="", host=""): | |||||
errorcode = "" | |||||
if not os.path.exists(file) and not os.path.isfile(file): | |||||
errorcode = "can't send. No such file" | |||||
return errorcode | |||||
args = " --input-file " + file | |||||
if (not server) or (not host): | |||||
args = args + " --config /etc/zabbix/zabbix_agentd.conf" | |||||
else: | |||||
args = args + "--host " + host + "--zabbix-server " + server | |||||
cmd = "/usr/bin/zabbix_sender " + "args" | |||||
try: | |||||
os.system(cmd) | |||||
except Exception as exept: | |||||
errorcode = exept | |||||
return errorcode | |||||
def sendkey(keys, server="", host=""): | |||||
errorcode = "" | |||||
args = "" | |||||
string = "" | |||||
if (not server) or (not host): | |||||
args = args + "--config /etc/zabbix/zabbix_agentd.conf" | |||||
else: | |||||
args = args + "--host " + host + " --zabbix-server " + server + " -vv " | |||||
cmd = "/usr/bin/zabbix_sender" | |||||
startargs = "" | |||||
print keys | |||||
for key in keys: | |||||
startargs = args + " --key " +str(key) + " --value " + str(keys[key]) | |||||
print(startargs) | |||||
p = subprocess.Popen([cmd + " " + startargs], stdout=subprocess.PIPE, shell=True) | |||||
for line in p.stdout.readlines(): | |||||
print line | |||||
def main(): | |||||
print "main function" | |||||
if __name__ == '__main__': | |||||
main() | |||||
sendkey({"key1": "val1", "key2": "val2", }, "192.168.4.141", "mix") |
@ -0,0 +1,3 @@ | |||||
cmd=cisco-asa.cmd | |||||
user=backupoperator | |||||
password="asdfasd" |
@ -0,0 +1,3 @@ | |||||
cmd=cisco-catalyst.cmd | |||||
user=backupoperator | |||||
password="asdfasdf" |
@ -0,0 +1,3 @@ | |||||
cmd=cisco-wap.cmd | |||||
user=backupoperator | |||||
password="asdfsdaf" |
Powered by TurnKey Linux.