simplify create-activate again
This commit is contained in:
parent
4c3739da20
commit
f616f2c2e1
7 changed files with 32 additions and 128 deletions
|
@ -137,7 +137,7 @@ def list_transactions():
|
|||
@admin_required
|
||||
def transaction(user_pid=0):
|
||||
cuser = User.query.filter_by(pid=user_pid).first()
|
||||
transactions = cuser.inv_transactions.order_by(Transaction.date_created.desc()).all()
|
||||
transactions = cuser.inv_transactions.order_by(Transaction.date_created.desc()).limit(20)
|
||||
|
||||
labelslist = ['today']
|
||||
translist = [cuser.wallet]
|
||||
|
|
|
@ -7,13 +7,14 @@
|
|||
|
||||
<div class="col-md-12">
|
||||
<div class="panel panel-info">
|
||||
<div class="panel-heading">Transactions</div>
|
||||
<div class="panel-heading">All Transactions</div>
|
||||
<div class="panel-body">
|
||||
|
||||
<div class="table-responsive">
|
||||
<table class="table table-hover table-striped table-condensed cf">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>ID</th>
|
||||
<th>Description</th>
|
||||
<th>Amount</th>
|
||||
<th>Date</th>
|
||||
|
@ -25,12 +26,14 @@
|
|||
{% for transaction in transactions %}
|
||||
{% if transaction.value > 0 %}
|
||||
<tr class="default">
|
||||
<td>{{ transaction.pid }}</td>
|
||||
<td>{{ transaction.description }}</td>
|
||||
<td>{{ transaction.value }} {{ transaction.currency }}</td>
|
||||
<td>{{ moment(transaction.date_created).format('lll') }}</td>
|
||||
<td><a href="{{ url_for('admin.transaction', user_pid=transaction.owner.pid) }}">{{ transaction.owner.email }}</a></td>
|
||||
{% else %}
|
||||
<tr class="default">
|
||||
<td>{{ transaction.pid }}</td>
|
||||
<td>{{ transaction.description }}</td>
|
||||
<td>{{ transaction.value }} {{ transaction.currency }}</td>
|
||||
<td>{{ moment(transaction.date_created).format('lll') }}</td>
|
||||
|
|
|
@ -90,28 +90,23 @@
|
|||
<h2 class="media-heading">Оборудване</h2>
|
||||
<p>Благодарение на внедрените нови технологии ние предлагаме изчислителна мощ, надеждно съхранение на данни и гъвкаво разпределение на ресурсите. Предвиждаме възможности нашата система да бъде неразделна част от текущата ви инфраструктура.</p>
|
||||
</div>
|
||||
</div>
|
||||
i </div>
|
||||
</div>
|
||||
|
||||
<div class="col-md-6">
|
||||
<div class="panel panel-primary panel-transparent">
|
||||
<div class="panel-body">
|
||||
<img src="../../static/images/VPS-Support.png" width="128" height="128" />
|
||||
<h2 class="media-heading">Поддръжка</h2>
|
||||
<p>Ще Ви помогнем във всички неприятни ситуации, по всяко време. </p>
|
||||
<a href="/chat"><button type="button" class="btn btn-lg btn-success">Support</button></a>
|
||||
<img src="../../static/images/VPS-Mission.png" width="128" height="128" />
|
||||
<h2 class="media-heading">Мисия</h2>
|
||||
<p>Желанието ни е да предоставим елегантна платформа за управление на изчислителни процеси, която цели да бъде използваема от всеки, а не само от тесен кръг специалисти, без да се прави компромис със качеството и възможностите й.</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<div class="row">
|
||||
|
||||
<div class="col-md-6">
|
||||
<div class="panel panel-primary panel-transparent">
|
||||
<div class="panel-body">
|
||||
<img src="../../static/images/VPS-Mission.png" width="128" height="128" />
|
||||
<h2 class="media-heading">Мисия</h2>
|
||||
<p>Желанието ни е да предоставим елегантна платформа за управление на изчислителни процеси, която цели да бъде използваема от всеки, а не само от тесен кръг специалисти, без да се прави компромис със качеството и възможностите й.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="panel panel-primary panel-transparent">
|
||||
<div class="panel-body">
|
||||
<img src="../../static/images/VPS-Security.png" width="128" height="128" />
|
||||
|
@ -120,6 +115,18 @@
|
|||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="col-md-6">
|
||||
<div class="panel panel-primary panel-transparent">
|
||||
<div class="panel-body">
|
||||
<img src="../../static/images/VPS-Support.png" width="128" height="128" />
|
||||
<h2 class="media-heading">Поддръжка</h2>
|
||||
<p>Ще Ви помогнем във всички неприятни ситуации, по всяко време. </p>
|
||||
<a href="/chat"><button type="button" class="btn btn-lg btn-success">Support</button></a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
|
|
@ -229,26 +229,6 @@ addEventListener("DOMContentLoaded", function() {
|
|||
<div class="panel panel-info" id="addresses">
|
||||
<div class="panel-heading">Communications</div>
|
||||
<div class="panel-body"><p>
|
||||
<img width="32" height="32" src=""> Private<br />
|
||||
<div id="bridges" class="no-more-tables">
|
||||
<table class="table table-hover table-striped table-condensed cf">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Unit</th>
|
||||
<th>Network</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
{% for bridge in inv_bridges %}
|
||||
<tr>
|
||||
<td data-title="Unit">{{ bridge.bridge_id }}</td>
|
||||
<td data-title="Network">192.168.9.0</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<img width="32" height="32" src=""> Public<br />
|
||||
<div id="routers" class="no-more-tables">
|
||||
<table class="table table-hover table-striped table-condensed cf">
|
||||
|
|
|
@ -60,7 +60,7 @@ var myChart = new Chart(ctx, {
|
|||
|
||||
<div class="col-md-12">
|
||||
<div class="panel panel-info">
|
||||
<div class="panel-heading">Transactions</div>
|
||||
<div class="panel-heading">Last 20 Transactions</div>
|
||||
<div class="panel-body">
|
||||
|
||||
<div class="table-responsive">
|
||||
|
|
|
@ -14,7 +14,7 @@ from ..models import User, Transaction
|
|||
def transactions():
|
||||
page = { 'title': 'Payment Transaction' }
|
||||
cuser = current_user
|
||||
transactions = Transaction.query.filter_by(user_id=cuser.pid).order_by(Transaction.date_created.desc()).limit(100)
|
||||
transactions = Transaction.query.filter_by(user_id=cuser.pid).order_by(Transaction.date_created.desc()).limit(20)
|
||||
|
||||
labelslist = ['today']
|
||||
translist = [cuser.wallet]
|
||||
|
|
|
@ -56,49 +56,9 @@ def createvm():
|
|||
|
||||
form = CreateForm()
|
||||
if current_user.confirmed and form.validate_on_submit():
|
||||
#selects the chosen region
|
||||
selected_region = Region.query.filter_by(pid=int(form.region.data)).first()
|
||||
|
||||
#TODO: Filter bridges for the selected region only. switch should return slave name
|
||||
selected_bridge = current_user.inv_bridges.filter_by(deleted=False).first()
|
||||
if selected_bridge is None:
|
||||
#no bridges in the account. create one...
|
||||
data = { 'clientid': str(current_user.pid),
|
||||
'clientemail': str(current_user.email),
|
||||
'region': str(selected_region.name),
|
||||
'type': 'br'
|
||||
}
|
||||
#create bridge unit
|
||||
query = contact_proxmaster(data, 'create')
|
||||
if query['status'] == 'bridge_created':
|
||||
newbridge = True
|
||||
#machine will be installed where the bridge physically is
|
||||
region_name = query['region']
|
||||
slave_name = query['slave']
|
||||
bridge_id = query['unit_id']
|
||||
bridge_phy_id = query['phy_id']
|
||||
selected_bridge = Bridge(user_id=int(current_user.pid), bridge_id=bridge_id)
|
||||
db.session.add(selected_bridge)
|
||||
db.session.commit()
|
||||
flash('New point created successfully in region "{}".'.format(str(selected_region.description)))
|
||||
else:
|
||||
flash('Point could not be created! Please try again later...')
|
||||
return redirect(url_for('panel.dashboard'))
|
||||
else:
|
||||
#bridge found. lets see on which slave it is so we can create the instance on the same slave.
|
||||
data = { 'unit_id': int(selected_bridge.bridge_id),
|
||||
'type': 'br' }
|
||||
query = contact_proxmaster(data, 'query')
|
||||
if query['status'] == 'query_success':
|
||||
newbridge = False
|
||||
#machine will be installed where the switch physically is
|
||||
region_name = query['region']
|
||||
slave_name = query['slave']
|
||||
bridge_phy_id = query['phy_id']
|
||||
else:
|
||||
flash('Point found but cannot be used!')
|
||||
return redirect(url_for('panel.dashboard'))
|
||||
|
||||
###
|
||||
#create new machine...
|
||||
data = { 'clientid': str(current_user.pid),
|
||||
'clientemail': str(current_user.email),
|
||||
|
@ -109,7 +69,7 @@ def createvm():
|
|||
'cpu': '1',
|
||||
'mem': '512',
|
||||
'hdd': '20',
|
||||
'net0if': 'vmbr' + str(bridge_phy_id)
|
||||
'net0if': 'vmbr7'
|
||||
}
|
||||
try:
|
||||
query = contact_proxmaster(data, 'create')
|
||||
|
@ -121,10 +81,10 @@ def createvm():
|
|||
deployment = Deployment(user_id=int(current_user.pid), machine_alias=str(form.servername.data), machine_id=query['unit_id'], machine_cpu=data['cpu'], machine_mem=data['mem'], machine_hdd=data['hdd'], enabled=True, protected=False, daysleft=15, warning=True, discount=0, bridge_id=int(selected_bridge.pid))
|
||||
db.session.add(deployment)
|
||||
db.session.commit()
|
||||
flash('New device created successfully in region "{}".'.format(str(selected_region.description)))
|
||||
flash('A new deployment is created successfully in region "{}".'.format(str(selected_region.description)))
|
||||
return redirect(url_for('panel.dashboard'))
|
||||
else:
|
||||
flash('Device could not be created! Please try again later...')
|
||||
flash('Deployment could not be created! Please try again later...')
|
||||
|
||||
#TODO: cleanup bridge if the machine is new and we were not be able to create it
|
||||
|
||||
|
@ -174,52 +134,6 @@ def activate(itemid=0):
|
|||
else:
|
||||
return redirect(url_for('uinvoice.transactions'))
|
||||
current_app.logger.info('[{}] Charge deployment: {}'.format(owner.email, deploy.machine_id))
|
||||
|
||||
#TODO: Filter routers for the selected region only. switch should return slave name
|
||||
selected_router = owner.inv_routers.filter_by(deleted=False).first()
|
||||
if selected_router is None:
|
||||
#TODO: Filter bridges for the selected region only. switch should return slave name
|
||||
selected_bridge = owner.inv_bridges.filter_by(deleted=False).first()
|
||||
if selected_bridge is None:
|
||||
flash('No private network found.')
|
||||
else:
|
||||
#bridge found. lets see on which slave it is so we can create the instance on the same slave.
|
||||
data = { 'unit_id': int(selected_bridge.bridge_id),
|
||||
'type': 'br' }
|
||||
query = contact_proxmaster(data, 'query')
|
||||
if query['status'] == 'query_success':
|
||||
#TODO: selected random ip address from the pool.
|
||||
selected_ip = '87.120.110.41'
|
||||
#machine will be installed where the switch physically is
|
||||
region_name = query['region']
|
||||
slave_name = query['slave']
|
||||
bridge_phy_id = query['phy_id']
|
||||
data = { 'clientid': str(owner.pid),
|
||||
'clientemail': str(owner.email),
|
||||
'hostname': 'c' + str(owner.pid) + '-r' + selected_ip,
|
||||
'region': str(region_name),
|
||||
'slave': str(slave_name),
|
||||
'type': 'lxc',
|
||||
'cpu': '1',
|
||||
'mem': '256',
|
||||
'hdd': '1',
|
||||
'net0if': 'vmbr' + str(bridge_phy_id),
|
||||
'net0ip': '192.168.9.1',
|
||||
'net0mask': '24',
|
||||
'net1if': 'vmbr0',
|
||||
'net1ip': selected_ip,
|
||||
'net1mask': '24',
|
||||
'net1gw': '87.120.110.1' #should be queried from the current region
|
||||
}
|
||||
query = contact_proxmaster(data, 'create')
|
||||
if query['status'] == 'lxc_created':
|
||||
router = Router(user_id=int(owner.pid), machine_id=query['unit_id'])
|
||||
db.session.add(router)
|
||||
db.session.commit()
|
||||
else:
|
||||
flash('Router cannot be created.')
|
||||
return redirect(url_for('panel.dashboard'))
|
||||
|
||||
today = datetime.utcnow()
|
||||
expiry = today + relativedelta(today, months=+(form.period.data))
|
||||
daysleft = expiry - today
|
||||
|
|
Loading…
Add table
Reference in a new issue