|
|
|
from flask import Blueprint
|
|
|
|
from flask_restful import reqparse, Resource, Api
|
|
|
|
from flask_apscheduler import APScheduler
|
|
|
|
#import sys
|
|
|
|
#sys.path.append("..")
|
|
|
|
from units import token_auth,consul_kv,gen_config,consul_svc
|
|
|
|
|
|
|
|
blueprint = Blueprint('nodes',__name__)
|
|
|
|
api = Api(blueprint)
|
|
|
|
|
|
|
|
parser = reqparse.RequestParser()
|
|
|
|
parser.add_argument('job_id',type=str)
|
|
|
|
parser.add_argument('services_dict',type=dict)
|
|
|
|
parser.add_argument('cst_ecs_dict',type=dict)
|
|
|
|
parser.add_argument('iid',type=str)
|
|
|
|
parser.add_argument('jobecs_name',type=str)
|
|
|
|
parser.add_argument('checked',type=str)
|
|
|
|
|
|
|
|
class Nodes(Resource):
|
|
|
|
decorators = [token_auth.auth.login_required]
|
|
|
|
def get(self, stype):
|
|
|
|
job_id = parser.parse_args()['job_id']
|
|
|
|
if stype == 'group':
|
|
|
|
cloud,account,itype = job_id.split('/')
|
|
|
|
group_dict = consul_kv.get_value(f'ConsulManager/assets/{cloud}/group/{account}')
|
|
|
|
group_list = [{'gid':k,'gname':v}for k,v in group_dict.items()]
|
|
|
|
return {'code': 20000,'group':group_list}
|
|
|
|
elif stype == 'res':
|
|
|
|
if job_id == '' or job_id == None:
|
|
|
|
return {'code': 20000,'res_list': [] }
|
|
|
|
else:
|
|
|
|
return consul_kv.get_res_services(job_id)
|
|
|
|
elif stype == 'jobecs':
|
|
|
|
jobecs = consul_kv.get_keys_list('ConsulManager/jobs')
|
|
|
|
jobecs_list = [i.split('/jobs/')[1] for i in jobecs if '/ecs/' in i]
|
|
|
|
return {'code': 20000,'jobecs':jobecs_list}
|
|
|
|
elif stype == 'jobrds':
|
|
|
|
jobrds = consul_kv.get_keys_list('ConsulManager/jobs')
|
|
|
|
jobrds_list = [i.split('/jobs/')[1] for i in jobrds if '/rds/' in i]
|
|
|
|
return {'code': 20000,'jobrds':jobrds_list}
|
|
|
|
elif stype == 'ecs_services':
|
|
|
|
jobecs = consul_kv.get_keys_list('ConsulManager/jobs')
|
|
|
|
jobecs_list = [i.split('/jobs/')[1] for i in jobecs if '/ecs/' in i]
|
|
|
|
services_list = []
|
|
|
|
for i in jobecs_list:
|
|
|
|
serivces = i.split("/")
|
|
|
|
services_list.append(f'{serivces[0]}_{serivces[1]}_{serivces[2]}')
|
|
|
|
return {'code': 20000,'services_list': sorted(set(services_list))}
|
|
|
|
elif stype == 'rules':
|
|
|
|
return gen_config.get_rules()
|
|
|
|
elif stype == 'cstecsconf':
|
|
|
|
args = parser.parse_args()
|
|
|
|
iid = args['iid']
|
|
|
|
cst_ecs_config = consul_kv.get_value(f'ConsulManager/assets/sync_ecs_custom/{iid}')
|
|
|
|
cst_ecs_config.update({'iid': iid,'ipswitch': False,'portswitch': False})
|
|
|
|
if 'ip' in cst_ecs_config and cst_ecs_config['ip'] != '':
|
|
|
|
cst_ecs_config['ipswitch'] = True
|
|
|
|
if 'port' in cst_ecs_config and cst_ecs_config['port'] != '':
|
|
|
|
cst_ecs_config['portswitch'] = True
|
|
|
|
return {'code': 20000, 'cst_ecs': cst_ecs_config}
|
|
|
|
elif stype == 'cstecslist':
|
|
|
|
args = parser.parse_args()
|
|
|
|
jobecs_name = args['jobecs_name']
|
|
|
|
checked = args['checked']
|
|
|
|
cst_ecs_dict = consul_kv.get_kv_dict('ConsulManager/assets/sync_ecs_custom/')
|
|
|
|
cst_ecs_keylist = [k.split('/')[-1] for k,v in cst_ecs_dict.items() if v != {}]
|
|
|
|
ecs_info = consul_kv.get_res_services(jobecs_name)
|
|
|
|
if checked == 'false':
|
|
|
|
return ecs_info
|
|
|
|
else:
|
|
|
|
cst_ecs_list = [i for i in ecs_info['res_list'] if i['iid'] in cst_ecs_keylist]
|
|
|
|
return {'code': 20000, 'res_list': cst_ecs_list}
|
|
|
|
|
|
|
|
def post(self, stype):
|
|
|
|
if stype == 'config':
|
|
|
|
args = parser.parse_args()
|
|
|
|
services_dict = args['services_dict']
|
|
|
|
return gen_config.ecs_config(services_dict['services_list'],services_dict['ostype_list'])
|
|
|
|
elif stype == 'cstecs':
|
|
|
|
args = parser.parse_args()
|
|
|
|
cst_ecs_dict = args['cst_ecs_dict']
|
|
|
|
consul_ecs_cst = {}
|
|
|
|
iid = cst_ecs_dict['iid']
|
|
|
|
try:
|
|
|
|
sid_dict = consul_svc.get_sid(iid)['instance']
|
|
|
|
if cst_ecs_dict['portswitch'] and cst_ecs_dict['port'] != '':
|
|
|
|
consul_ecs_cst['port'] = int(cst_ecs_dict['port'])
|
|
|
|
sid_dict['Port'] = consul_ecs_cst['port']
|
|
|
|
if cst_ecs_dict['ipswitch'] and cst_ecs_dict['ip'] != '':
|
|
|
|
consul_ecs_cst['ip'] = cst_ecs_dict['ip']
|
|
|
|
sid_dict['Address'] = consul_ecs_cst['ip']
|
|
|
|
consul_kv.put_kv(f'ConsulManager/assets/sync_ecs_custom/{iid}',consul_ecs_cst)
|
|
|
|
del sid_dict['TaggedAddresses']
|
|
|
|
del sid_dict['Weights']
|
|
|
|
del sid_dict['ContentHash']
|
|
|
|
del sid_dict['Datacenter']
|
|
|
|
sid_dict['name'] = sid_dict.pop('Service')
|
|
|
|
sid_dict['Meta']['instance'] = f"{sid_dict['Address']}:{sid_dict['Port']}"
|
|
|
|
sid_dict["check"] = { "tcp": sid_dict['Meta']['instance'],"interval": "60s" }
|
|
|
|
consul_svc.del_sid(iid)
|
|
|
|
consul_svc.add_sid(sid_dict)
|
|
|
|
return {'code': 20000, 'data': '自定义实例信息修改成功!'}
|
|
|
|
except Exception as e:
|
|
|
|
print(e,flush=True)
|
|
|
|
return {'code': 50000, "data": '提交自定义实例信息格式错误!'}
|
|
|
|
|
|
|
|
|
|
|
|
api.add_resource(Nodes, '/api/nodes/<stype>')
|