代码拉取完成,页面将自动刷新
同步操作将从 sjgops/flask-ansible 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
from flask import Blueprint, request
import json, tool_db, subprocess, threading, time
playbook = Blueprint("playbook", __name__)
@playbook.route('/delete_by_id')
def delete_by_id():
id = int( request.args.get('id') )
sql = 'delete from playbook where id = %s'
tool_db.updateByParameters( sql, (id, ) )
return "Servers!"
@playbook.route('/get_by_page', methods=['get', 'post'])
def get_by_page():
info = request.get_data()
info = json.loads(info)
pagenow = info['pagenow']
pagesize = info['pagesize']
search = info['search']
search = "%{0}%".format(search)
sql = 'select * from playbook where name like %s limit %s,%s'
params = (search, (pagenow - 1) * pagesize, pagesize)
result = tool_db.selectByParameters(sql, params=params)
countsql = 'select count(1) as allcount from playbook where name like %s'
allcount = tool_db.selectByParameters(countsql, params=(search,))[0]['allcount']
return json.dumps( {"result": result, "allcount": allcount} )
def shellRun(command):
(status, output) = subprocess.getstatusoutput(command)
return (status, output)
@playbook.route('/insert', methods=['get', 'post'])
def insert():
info = request.get_data()
info = json.loads(info)
sql = 'replace into playbook (name,hosts_path, playbook_path, forks) VALUES(%s, %s, %s, %s);'
params = ( info['name'], info['hosts_path'], info['playbook_path'], info['forks'])
tool_db.updateByParameters( sql, params )
return "Success"
@playbook.route('/deploy_by_id')
def deploy_by_id():
id = int(request.args.get('id'))
sql = "select * from playbook where id = %s"
result = tool_db.selectByParameters(sql, params=(id,))[0]
tmpnumber = int(time.time() * 1000)
# name, hosts_path, playbook_path, forks
displaycommand = """ ansible-playbook -i {0} {1} -f {2} """.format(
result['hosts_path'],
result['playbook_path'],
result['forks']
)
command = """ ansible-playbook -i {0} {1} -f {2} >static/logs/{3} 2>&1; printf '\n\t\t\t' >>static/logs/{4} """.format(
result['hosts_path'],
result['playbook_path'],
result['forks'], tmpnumber, tmpnumber
)
t1 = threading.Thread(target=shellRun, args=(command,))
t1.start()
return json.dumps({"command": displaycommand, "logpath": tmpnumber})
@playbook.route('/get_by_id')
def get_by_id():
id = int(request.args.get('id'))
sql = "select * from playbook where id = %s"
result = tool_db.selectByParameters(sql, params=(id,))
return json.dumps(result)
@playbook.route('/update', methods=['get', 'post'])
def update():
info = request.get_data()
info = json.loads(info)
# name, hosts_path, playbook_path, forks
sql = 'replace into playbook (id,name,hosts_path, playbook_path, forks) VALUES(%s, %s, %s, %s, %s);'
params = (info['id'], info['name'], info['hosts_path'], info['playbook_path'], info['forks'])
tool_db.updateByParameters(sql, params)
return "Success"
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。