craete seed function phase 2

This commit is contained in:
deflax 2017-07-31 00:10:08 +03:00
parent 6380a199b3
commit c970f0d82a
4 changed files with 59 additions and 66 deletions

View file

@ -77,7 +77,8 @@ def dashboard():
rrd[cubeid] = {} rrd[cubeid] = {}
try: try:
query = contact_proxmaster({}, 'vmrrd', cubeid) query = contact_proxmaster({}, 'vmrrd', cubeid)
except: except Exception as e:
current_app.logger.error(e)
flash('Deploy #{} unreachable. Support is notified'.format(str(cubeid))) flash('Deploy #{} unreachable. Support is notified'.format(str(cubeid)))
send_email(current_app.config['MAIL_USERNAME'], 'Cube {} is unreachable'.format(cubeid), send_email(current_app.config['MAIL_USERNAME'], 'Cube {} is unreachable'.format(cubeid),
'vmanager/email/adm_unreachable', user=current_user, cubeid=cubeid) 'vmanager/email/adm_unreachable', user=current_user, cubeid=cubeid)

View file

@ -208,15 +208,12 @@ def contact_proxmaster(data, method, cubeid=0):
url = current_app.config['PROXMASTER_URL'] url = current_app.config['PROXMASTER_URL']
data['apikey'] = current_app.config['APIKEY'] data['apikey'] = current_app.config['APIKEY']
data_json = json.dumps(data) data_json = json.dumps(data)
#print('--> {}'.format(data))
if method == 'vmcreate': if method == 'vmcreate':
url = '{}/{}'.format(url, method) url = '{}/{}'.format(url, method)
else: else:
url = '{}/{}/{}'.format(url, method, cubeid) url = '{}/{}/{}'.format(url, method, cubeid)
db_result = requests.post( url, data=data_json, headers={"content-type": "application/json"}, timeout=30 )
try: try:
proxjson = db_result.json() proxjson = db_result.json()
#print('proxmaster query {}'.format(str(proxjson))) #print('proxmaster query {}'.format(str(proxjson)))

View file

@ -187,60 +187,12 @@ addEventListener("DOMContentLoaded", function() {
</table> </table>
</div> </div>
<!-- Cloud Storage icon by Icons8 --> <!-- Cloud Storage icon by Icons8 -->
<button class="btn btn-default" onclick="window.open('{{ url_for('vmanager.createvm') }}','_self')"><img class="icon icons8-Cloud-Storage" width="40" height="40" src=""> Create</button> <button class="btn btn-default" onclick="window.open('{{ url_for('vmanager.createvm') }}','_self')"><img class="icon icons8-Cloud-Storage" width="32" height="32" src=""> Create</button>
</div> </div>
</div> </div>
</div> </div>
{% endif %} {% endif %}
{% if inv_services != [] %}
<div class="col-md-12">
<div class="panel panel-info" id="services">
<div class="panel-heading">Services</div>
<div class="panel-body"><p>
<div id="no-more-tables">
<table class="table table-hover table-striped table-condensed cf">
<thead>
<tr>
<th>Category</th>
<th>Description</th>
<th>Last Charged</th>
<th>Time Left</th>
</tr>
<tbody>
{% for service in inv_services %}
{% if service.enabled == False %}
<tr class="danger">
{% else %}
{% if service.warning == True %}
<tr class="warning">
{% else %}
<tr>
{% endif %}
{% endif %}
<td data-title="Category">{{ service.category }}</td>
<td data-title="Description" >{{ service.description }}</td>
<td data-title="Last Charged">{{ moment(service.date_last_charge).format('lll') }} ({{ moment(service.date_last_charge).fromNow() }})</td>
{% if service.enabled == False %}
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</button></td>
{% else %}
{% if service.warning == True %}
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew ({{ service.daysleft }} days left)</button></td>
{% else %}
<td data-title="Time Left">{{ service.daysleft }} day(s)</td>
{% endif %}
{% endif %}
</tr >
{% endfor %}
</tbody>
</table>
</div>
<img class="icon icons8-Key-2" width="40" height="40" src="">
<button class="btn btn-default" onclick="window.open('{{ url_for('smanager.requestservice') }}','_self')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Send Request</button>
</div>
</div>
</div>
{% endif %}
{% if inv_domains != [] %} {% if inv_domains != [] %}
<div class="col-md-12"> <div class="col-md-12">
@ -317,6 +269,54 @@ addEventListener("DOMContentLoaded", function() {
</div> </div>
{% endif %} {% endif %}
{% if inv_services != [] %}
<div class="col-md-12">
<div class="panel panel-info" id="services">
<div class="panel-heading">Services</div>
<div class="panel-body"><p>
<div id="no-more-tables">
<table class="table table-hover table-striped table-condensed cf">
<thead>
<tr>
<th>Category</th>
<th>Description</th>
<th>Last Charged</th>
<th>Time Left</th>
</tr>
<tbody>
{% for service in inv_services %}
{% if service.enabled == False %}
<tr class="danger">
{% else %}
{% if service.warning == True %}
<tr class="warning">
{% else %}
<tr>
{% endif %}
{% endif %}
<td data-title="Category">{{ service.category }}</td>
<td data-title="Description" >{{ service.description }}</td>
<td data-title="Last Charged">{{ moment(service.date_last_charge).format('lll') }} ({{ moment(service.date_last_charge).fromNow() }})</td>
{% if service.enabled == False %}
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</button></td>
{% else %}
{% if service.warning == True %}
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew ({{ service.daysleft }} days left)</button></td>
{% else %}
<td data-title="Time Left">{{ service.daysleft }} day(s)</td>
{% endif %}
{% endif %}
</tr >
{% endfor %}
</tbody>
</table>
</div>
<button class="btn btn-default" onclick="window.open('{{ url_for('smanager.requestservice') }}','_self')"><img class="icon icons8-Key-2" width="32" height="32" src="">Request</button>
</div>
</div>
</div>
{% endif %}
</div> </div>

View file

@ -39,22 +39,17 @@ def createvm():
flash('Offline deployments exist.') flash('Offline deployments exist.')
return redirect(url_for('main.dashboard')) return redirect(url_for('main.dashboard'))
if current_user.confirmed and form.validate_on_submit(): if current_user.confirmed and form.validate_on_submit():
client_id = current_user.pid data = { 'clientid': str(current_user.pid),
data = { 'clientid': str(client_id),
'clientname': str(current_user.name), 'clientname': str(current_user.name),
'clientemail': str(current_user.email), 'clientemail': str(current_user.email),
'hostname': str(form.servername.data), 'hostname': str(form.deployname.data),
'vmpass': form.vmpassword.data,
'region': form.region.data, 'region': form.region.data,
'vps_type': 'kvm', 'type': 'kvm',
'vps_cpu': form.cpu.data, 'cpu': '1',
'vps_mem': form.mem.data, 'mem': '512',
'vps_hdd': form.hdd.data, 'hdd': '20'
'vps_ipv4': form.ipv4.data, }
'vps_mac': form.mac.data }
try: try:
query = contact_proxmaster(data, 'vmcreate') query = contact_proxmaster(data, 'vmcreate')
except: except:
@ -137,7 +132,7 @@ def command(cmd=None, vmid=0):
current_app.logger.warning(cmd + ' is not a valid command!') current_app.logger.warning(cmd + ' is not a valid command!')
abort(404) abort(404)
#work with enabled deploys only #work with enabled deploys only that you own.
result = current_user.inv_deployments.filter_by(enabled=True) result = current_user.inv_deployments.filter_by(enabled=True)
inventory = [] inventory = []
for invcls in result: for invcls in result: