craete seed function phase 1
This commit is contained in:
parent
54703a8825
commit
6380a199b3
7 changed files with 118 additions and 73 deletions
|
@ -234,6 +234,7 @@ class Service(db.Model):
|
||||||
daysleft = db.Column(db.Integer)
|
daysleft = db.Column(db.Integer)
|
||||||
warning = db.Column(db.Boolean, default=False)
|
warning = db.Column(db.Boolean, default=False)
|
||||||
enabled = db.Column(db.Boolean, default=False)
|
enabled = db.Column(db.Boolean, default=False)
|
||||||
|
cancelled = db.Column(db.Boolean, default=False)
|
||||||
|
|
||||||
category = db.Column(db.String)
|
category = db.Column(db.String)
|
||||||
description = db.Column(db.Unicode)
|
description = db.Column(db.Unicode)
|
||||||
|
@ -248,7 +249,9 @@ class Deployment(db.Model):
|
||||||
period = db.Column(db.Integer)
|
period = db.Column(db.Integer)
|
||||||
daysleft = db.Column(db.Integer)
|
daysleft = db.Column(db.Integer)
|
||||||
warning = db.Column(db.Boolean, default=False)
|
warning = db.Column(db.Boolean, default=False)
|
||||||
enabled = db.Column(db.Boolean, default=False)
|
enabled = db.Column(db.Boolean, default=True)
|
||||||
|
protected = db.Column(db.Boolean, default=False) #machines with this False will be autodeleted after the warning period is over.
|
||||||
|
cancelled = db.Column(db.Boolean, default=False)
|
||||||
|
|
||||||
machine_id = db.Column(db.BigInteger) #cubeid
|
machine_id = db.Column(db.BigInteger) #cubeid
|
||||||
machine_alias = db.Column(db.String) #dns name
|
machine_alias = db.Column(db.String) #dns name
|
||||||
|
@ -308,6 +311,7 @@ class Domain(db.Model):
|
||||||
daysleft = db.Column(db.Integer)
|
daysleft = db.Column(db.Integer)
|
||||||
warning = db.Column(db.Boolean, default=False)
|
warning = db.Column(db.Boolean, default=False)
|
||||||
enabled = db.Column(db.Boolean, default=False)
|
enabled = db.Column(db.Boolean, default=False)
|
||||||
|
cancelled = db.Column(db.Boolean, default=False)
|
||||||
|
|
||||||
user_id = db.Column(db.Integer, db.ForeignKey('users.pid')) #FK
|
user_id = db.Column(db.Integer, db.ForeignKey('users.pid')) #FK
|
||||||
date_created = db.Column(db.DateTime, index=True, default=datetime.utcnow)
|
date_created = db.Column(db.DateTime, index=True, default=datetime.utcnow)
|
||||||
|
|
|
@ -19,6 +19,11 @@ def after_request(response):
|
||||||
current_app.logger.warning('Slow query: %s\nParameters: %s\nDuration: %fs\nContext: %s\n' % (query.statement, query.parameters, query.duration, query.context))
|
current_app.logger.warning('Slow query: %s\nParameters: %s\nDuration: %fs\nContext: %s\n' % (query.statement, query.parameters, query.duration, query.context))
|
||||||
return response
|
return response
|
||||||
|
|
||||||
|
@smanager.route('/requestservice', methods=['GET', 'POST'])
|
||||||
|
@login_required
|
||||||
|
def requestservice():
|
||||||
|
abort(403)
|
||||||
|
|
||||||
@smanager.route('/activate/<int:itemid>', methods=['GET', 'POST'])
|
@smanager.route('/activate/<int:itemid>', methods=['GET', 'POST'])
|
||||||
@login_required
|
@login_required
|
||||||
def activate(itemid=0):
|
def activate(itemid=0):
|
||||||
|
|
|
@ -3,13 +3,13 @@
|
||||||
<div class="panel-heading">Admin Pages</div>
|
<div class="panel-heading">Admin Pages</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<center>
|
<center>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_deployments') }}','_self')"><span class="glyphicon glyphicon-hdd" aria-hidden="true"></span> Deployments</button>
|
<button class="btn btn-success btn-lg" onclick="window.open('{{ url_for('admin.list_deployments') }}','_self')"><span class="glyphicon glyphicon-hdd" aria-hidden="true"></span> Deployments</button>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_addresses') }}','_self')"><span class="glyphicon glyphicon-tag" aria-hidden="true"></span> Addresses</button>
|
<button class="btn btn-success btn-lg" onclick="window.open('{{ url_for('admin.list_addresses') }}','_self')"><span class="glyphicon glyphicon-tag" aria-hidden="true"></span> Addresses</button>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_services') }}','_self')"><span class="glyphicon glyphicon-star" aria-hidden="true"></span> Services</button>
|
<button class="btn btn-success btn-lg" onclick="window.open('{{ url_for('admin.list_services') }}','_self')"><span class="glyphicon glyphicon-star" aria-hidden="true"></span> Services</button>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_domains') }}','_self')"><span class="glyphicon glyphicon-home" aria-hidden="true"></span> Domains</button>
|
<button class="btn btn-success btn-lg" onclick="window.open('{{ url_for('admin.list_domains') }}','_self')"><span class="glyphicon glyphicon-home" aria-hidden="true"></span> Domains</button>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_users') }}','_self')"><span class="glyphicon glyphicon-user" aria-hidden="true"></span> Users</button>
|
<button class="btn btn-primary btn-lg" onclick="window.open('{{ url_for('admin.list_users') }}','_self')"><span class="glyphicon glyphicon-user" aria-hidden="true"></span> Users</button>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('admin.list_transactions') }}','_self')"><span class="glyphicon glyphicon-usd" aria-hidden="true"></span> Transactions</button>
|
<button class="btn btn-primary btn-lg" onclick="window.open('{{ url_for('admin.list_transactions') }}','_self')"><span class="glyphicon glyphicon-usd" aria-hidden="true"></span> Transactions</button>
|
||||||
<button class="btn btn-default" onclick="alert('Как ще си събираш зъбите със счупени ръце?')"><span class="glyphicon glyphicon-cd" aria-hidden="true"></span> Nothing</button>
|
<button class="btn btn-danger btn-lg" onclick="alert('Как ще си събираш зъбите със счупени ръце?')"><span class="glyphicon glyphicon-cd" aria-hidden="true"></span> Nothing</button>
|
||||||
</center>
|
</center>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -128,6 +128,7 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
<div class="panel panel-info" id="deployments">
|
<div class="panel panel-info" id="deployments">
|
||||||
<div class="panel-heading">Deployments</div>
|
<div class="panel-heading">Deployments</div>
|
||||||
<div class="panel-body"><p>
|
<div class="panel-body"><p>
|
||||||
|
<!-- Individual Server icon by Icons8 -->
|
||||||
<div id="no-more-tables">
|
<div id="no-more-tables">
|
||||||
<table class="table table-hover table-striped table-condensed cf">
|
<table class="table table-hover table-striped table-condensed cf">
|
||||||
<thead>
|
<thead>
|
||||||
|
@ -153,7 +154,7 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
<td data-title="Network">{% for addr in deploy.machine_addresses %} {{ addr.ip }}<br /> {% endfor %}</td>
|
<td data-title="Network">{% for addr in deploy.machine_addresses %} {{ addr.ip }}<br /> {% endfor %}</td>
|
||||||
<td data-title="Control"> </td>
|
<td data-title="Control"> </td>
|
||||||
<td data-title="Remote"> </td>
|
<td data-title="Remote"> </td>
|
||||||
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/vmanager/activate/{{ deploy.machine_id }}');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</td>
|
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/vmanager/activate/{{ deploy.machine_id }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</td>
|
||||||
{% else %}
|
{% else %}
|
||||||
{% if deploy.warning == True %}
|
{% if deploy.warning == True %}
|
||||||
<tr class="warning">
|
<tr class="warning">
|
||||||
|
@ -185,7 +186,8 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Create</button>
|
<!-- 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>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -220,10 +222,10 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
<td data-title="Description" >{{ service.description }}</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>
|
<td data-title="Last Charged">{{ moment(service.date_last_charge).format('lll') }} ({{ moment(service.date_last_charge).fromNow() }})</td>
|
||||||
{% if service.enabled == False %}
|
{% if service.enabled == False %}
|
||||||
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</button></td>
|
<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 %}
|
{% else %}
|
||||||
{% if service.warning == True %}
|
{% if service.warning == True %}
|
||||||
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew ({{ service.daysleft }} days left)</button></td>
|
<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 %}
|
{% else %}
|
||||||
<td data-title="Time Left">{{ service.daysleft }} day(s)</td>
|
<td data-title="Time Left">{{ service.daysleft }} day(s)</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -233,7 +235,8 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Order</button>
|
<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>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -261,7 +264,7 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
<td data-title="Time Left">EXPIRED</td>
|
<td data-title="Time Left">EXPIRED</td>
|
||||||
{% else %}
|
{% else %}
|
||||||
{% if domain.warning == True %}
|
{% if domain.warning == True %}
|
||||||
<td data-title="Time Left"><button class="btn btn-default btn-warning" onclick="window.open('/dmanager/activate/{{ domain.pid }}');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew </button></td>
|
<td data-title="Time Left"><button class="btn btn-default btn-warning" onclick="window.open('/dmanager/activate/{{ domain.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew </button></td>
|
||||||
{% else %}
|
{% else %}
|
||||||
<td data-title="Time Left">{{ domain.daysleft }} day(s)</td>
|
<td data-title="Time Left">{{ domain.daysleft }} day(s)</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -272,7 +275,9 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Order</button>
|
<!-- Address Book icon by Icons8 -->
|
||||||
|
<img class="icon icons8-Address-Book" width="40" height="40" src="">
|
||||||
|
<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}','_self')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Order</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -304,7 +309,9 @@ addEventListener("DOMContentLoaded", function() {
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
<!--<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Assign</button> -->
|
<!-- GPS Signal icon by Icons8 -->
|
||||||
|
<img class="icon icons8-GPS-Signal" width="40" height="40" src="">
|
||||||
|
<!--<button class="btn btn-default" onclick="window.open('{{ url_for('main.dashboard') }}','_self')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Assign</button> -->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
|
<br /><br >
|
||||||
<div class="page_wrap">
|
<div class="page_wrap">
|
||||||
<p class="copyright">© Copyright 2017 <a href="https://deflax.net">_sys</a>, All Rights Reserved.</p>
|
<p class="copyright" style="color:#708d3f;">© Copyright 2017 <a style="color:#88af46" href="https://deflax.net">_sys</a>, All Rights Reserved.</p>
|
||||||
<p class="design_by"></p>
|
<p class="design_by" style="color:#708d3f;">Icons by <a style="color:#88af46" href="https://icons8.com">icons8.com</a></p>
|
||||||
</div><!--/page wrap-->
|
</div><!--/page wrap-->
|
||||||
|
|
53
app/templates/vmanager/recipe.html
Normal file
53
app/templates/vmanager/recipe.html
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block head %}
|
||||||
|
{{ super() }}
|
||||||
|
<script type="text/javascript">
|
||||||
|
function getRecipeName()
|
||||||
|
{
|
||||||
|
var rselect = document.getElementById('recipe');
|
||||||
|
recipe = rselect.value;
|
||||||
|
return recipe;
|
||||||
|
}
|
||||||
|
|
||||||
|
function previewDetails()
|
||||||
|
{
|
||||||
|
var period = getRecipeName();
|
||||||
|
var divobj = document.getElementById('recipedetails');
|
||||||
|
divobj.innerHTML = "not implemented";
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block title %}Apply Recipe{% endblock %}
|
||||||
|
|
||||||
|
{% block page_content %}
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
|
||||||
|
<div class="col-md-12">
|
||||||
|
<div class="panel panel-info">
|
||||||
|
<div class="panel-heading">Apply Recipe {{ deploy.machine_alias }}</div>
|
||||||
|
<div class="panel-body">
|
||||||
|
|
||||||
|
<form method="POST" action"{{ url_for('vmanager.recipe', itemid=deploy.machine_id) }}">
|
||||||
|
<h3>
|
||||||
|
{{ form.recipe.label }} {{ form.recipe(**{"onchange":"previewDetails()"}) }}<br />
|
||||||
|
{% for error in form.recipe.errors %}
|
||||||
|
{{ error }}<br />
|
||||||
|
{% endfor %}
|
||||||
|
---<br />
|
||||||
|
<div id="recipedetails">Preview</div>
|
||||||
|
</h3>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
{{ form.csrf_token() }}
|
||||||
|
{{ form.submit }}
|
||||||
|
</p>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
|
|
|
@ -19,11 +19,6 @@ import ast
|
||||||
def randstr(n):
|
def randstr(n):
|
||||||
return ''.join(random.SystemRandom().choice(string.ascii_lowercase + string.digits) for _ in range(n))
|
return ''.join(random.SystemRandom().choice(string.ascii_lowercase + string.digits) for _ in range(n))
|
||||||
|
|
||||||
#@vmanager.before_app_request
|
|
||||||
#def before_request():
|
|
||||||
# g.user = current_user
|
|
||||||
# print('current_user: %s, g.user: %s, leaving bef_req' % (current_user, g.user))
|
|
||||||
|
|
||||||
@vmanager.after_app_request
|
@vmanager.after_app_request
|
||||||
def after_request(response):
|
def after_request(response):
|
||||||
for query in get_debug_queries():
|
for query in get_debug_queries():
|
||||||
|
@ -31,58 +26,19 @@ def after_request(response):
|
||||||
current_app.logger.warning('Slow query: %s\nParameters: %s\nDuration: %fs\nContext: %s\n' % (query.statement, query.parameters, query.duration, query.context))
|
current_app.logger.warning('Slow query: %s\nParameters: %s\nDuration: %fs\nContext: %s\n' % (query.statement, query.parameters, query.duration, query.context))
|
||||||
return response
|
return response
|
||||||
|
|
||||||
#APP STORE
|
|
||||||
@vmanager.route('/market/<int:group_id>', methods=['GET'])
|
@vmanager.route('/createvm', methods=['GET', 'POST'])
|
||||||
@login_required
|
@login_required
|
||||||
def market(group_id=0):
|
def createvm():
|
||||||
page = { 'title': 'Market' }
|
|
||||||
allproducts = Product.get_products()
|
|
||||||
allgroups = current_app.config['GROUPS']
|
|
||||||
|
|
||||||
if group_id == 0:
|
|
||||||
return render_template('vmanager/market.html', groups=allgroups, products=allproducts)
|
|
||||||
|
|
||||||
filtered_products = {}
|
|
||||||
for key, value in allproducts.items():
|
|
||||||
if value['group'] == group_id:
|
|
||||||
filtered_products[key] = value
|
|
||||||
|
|
||||||
if filtered_products == {}:
|
|
||||||
abort(404)
|
|
||||||
return render_template('vmanager/marketgroup.html', groupname=allgroups[group_id], products=filtered_products)
|
|
||||||
|
|
||||||
|
|
||||||
@vmanager.route('/deploy/<int:product_id>', methods=['GET', 'POST'])
|
|
||||||
@login_required
|
|
||||||
def deploy(product_id=None):
|
|
||||||
#if current_user.wallet < 20:
|
|
||||||
# flash('Недостатъчно средства в сметката за тази операция')
|
|
||||||
# return redirect(url_for('uinvoice.addfunds'))
|
|
||||||
|
|
||||||
if current_user.name is None:
|
if current_user.name is None:
|
||||||
flash('Please update profile info for this operation.')
|
flash('Please update profile info for this operation.')
|
||||||
return redirect(url_for('uinvoice.profile'))
|
return redirect(url_for('settings.profile'))
|
||||||
|
|
||||||
page = { 'title': 'Deploy' }
|
deployment_seeds = Deployment.query.filter_by(protected=False).all()
|
||||||
try:
|
if deployment_seeds != []:
|
||||||
product = Product.get_products()[product_id]
|
flash('Offline deployments exist.')
|
||||||
except:
|
return redirect(url_for('main.dashboard'))
|
||||||
current_app.logger.error('unknown product {}'.format(product_id))
|
|
||||||
abort(404)
|
|
||||||
product_pic = '..' + product['img']
|
|
||||||
product_name = product['name']
|
|
||||||
product_description = product['description']
|
|
||||||
|
|
||||||
product_cpu = product['cpu']
|
|
||||||
product_mem = product['mem']
|
|
||||||
product_hdd = product['hdd']
|
|
||||||
product_recipe = product['recipe']
|
|
||||||
|
|
||||||
hostname = 'deploy-{}.local'.format(randstr(6))
|
|
||||||
|
|
||||||
form = DeployForm(servername=hostname, cpu=product_cpu, mem=product_mem, hdd=product_hdd, recipe=product_recipe)
|
|
||||||
form.region.choices = current_app.config['REGIONS']
|
|
||||||
form.recipe.choices = current_app.config['RECIPES']
|
|
||||||
|
|
||||||
if current_user.confirmed and form.validate_on_submit():
|
if current_user.confirmed and form.validate_on_submit():
|
||||||
client_id = current_user.pid
|
client_id = current_user.pid
|
||||||
|
@ -93,7 +49,6 @@ def deploy(product_id=None):
|
||||||
'vmpass': form.vmpassword.data,
|
'vmpass': form.vmpassword.data,
|
||||||
'region': form.region.data,
|
'region': form.region.data,
|
||||||
'vps_type': 'kvm',
|
'vps_type': 'kvm',
|
||||||
'vps_recipe': form.recipe.data,
|
|
||||||
'vps_cpu': form.cpu.data,
|
'vps_cpu': form.cpu.data,
|
||||||
'vps_mem': form.mem.data,
|
'vps_mem': form.mem.data,
|
||||||
'vps_hdd': form.hdd.data,
|
'vps_hdd': form.hdd.data,
|
||||||
|
@ -117,7 +72,6 @@ def deploy(product_id=None):
|
||||||
|
|
||||||
return redirect(url_for('main.dashboard'))
|
return redirect(url_for('main.dashboard'))
|
||||||
|
|
||||||
return render_template('vmanager/deploy.html', page=page, form=form, product_id=product_id, product_pic=product_pic, product_name=product_name, product_description=product_description, product_recipe=product_recipe)
|
|
||||||
|
|
||||||
@vmanager.route('/activate/<int:itemid>', methods=['GET', 'POST'])
|
@vmanager.route('/activate/<int:itemid>', methods=['GET', 'POST'])
|
||||||
@login_required
|
@login_required
|
||||||
|
@ -173,6 +127,7 @@ def activate(itemid=0):
|
||||||
return redirect(url_for('main.dashboard'))
|
return redirect(url_for('main.dashboard'))
|
||||||
return render_template('vmanager/activate.html', form=form, deploy=deploy, cpu_cost=cpu_cost, mem_cost=mem_cost, hdd_cost=hdd_cost, ppm=ppm, total=(ppm * deploy.period), currency=owner.currency)
|
return render_template('vmanager/activate.html', form=form, deploy=deploy, cpu_cost=cpu_cost, mem_cost=mem_cost, hdd_cost=hdd_cost, ppm=ppm, total=(ppm * deploy.period), currency=owner.currency)
|
||||||
|
|
||||||
|
|
||||||
@vmanager.route('/<cmd>/<int:vmid>')
|
@vmanager.route('/<cmd>/<int:vmid>')
|
||||||
@login_required
|
@login_required
|
||||||
def command(cmd=None, vmid=0):
|
def command(cmd=None, vmid=0):
|
||||||
|
@ -205,3 +160,23 @@ def command(cmd=None, vmid=0):
|
||||||
return redirect(db_result['url'])
|
return redirect(db_result['url'])
|
||||||
abort(404)
|
abort(404)
|
||||||
|
|
||||||
|
#APP STORE
|
||||||
|
@vmanager.route('/market/<int:group_id>', methods=['GET'])
|
||||||
|
@login_required
|
||||||
|
def market(group_id=0):
|
||||||
|
page = { 'title': 'Market' }
|
||||||
|
allproducts = Product.get_products()
|
||||||
|
allgroups = current_app.config['GROUPS']
|
||||||
|
|
||||||
|
if group_id == 0:
|
||||||
|
return render_template('vmanager/market.html', groups=allgroups, products=allproducts)
|
||||||
|
|
||||||
|
filtered_products = {}
|
||||||
|
for key, value in allproducts.items():
|
||||||
|
if value['group'] == group_id:
|
||||||
|
filtered_products[key] = value
|
||||||
|
|
||||||
|
if filtered_products == {}:
|
||||||
|
abort(404)
|
||||||
|
return render_template('vmanager/marketgroup.html', groupname=allgroups[group_id], products=filtered_products)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue