2022-02-14 00:43:48 -06:00
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
2024-01-01 02:43:48 -06:00
|
|
|
# Copyright (C) 2013 - 2024, The pgAdmin Development Team
|
2022-02-14 00:43:48 -06:00
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
|
|
|
##########################################################################
|
|
|
|
|
|
|
|
"""Implements Cloud Deployment"""
|
|
|
|
|
2023-02-14 23:40:12 -06:00
|
|
|
import json
|
2022-04-26 06:11:10 -05:00
|
|
|
from flask import Response, url_for
|
|
|
|
from flask import render_template, request
|
2022-02-14 00:43:48 -06:00
|
|
|
from flask_babel import gettext
|
|
|
|
from flask_security import login_required, current_user
|
|
|
|
|
|
|
|
from pgadmin.utils import PgAdminModule, html
|
|
|
|
from pgadmin.utils.ajax import make_json_response,\
|
|
|
|
internal_server_error, bad_request, success_return
|
|
|
|
|
|
|
|
from pgadmin.utils.constants import MIMETYPE_APP_JS
|
|
|
|
from pgadmin.model import db, Server, Process
|
2022-02-28 06:49:18 -06:00
|
|
|
from pgadmin.misc.cloud.utils import get_my_ip
|
2022-02-14 00:43:48 -06:00
|
|
|
|
2022-04-26 06:11:10 -05:00
|
|
|
from pgadmin.misc.cloud.biganimal import deploy_on_biganimal,\
|
|
|
|
clear_biganimal_session
|
|
|
|
from pgadmin.misc.cloud.rds import deploy_on_rds, clear_aws_session
|
2022-06-15 00:52:42 -05:00
|
|
|
from pgadmin.misc.cloud.azure import deploy_on_azure, clear_azure_session
|
2023-03-13 04:26:16 -05:00
|
|
|
from pgadmin.misc.cloud.google import clear_google_session, deploy_on_google
|
2022-06-28 08:18:41 -05:00
|
|
|
import config
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
# set template path for sql scripts
|
|
|
|
MODULE_NAME = 'cloud'
|
|
|
|
|
|
|
|
|
|
|
|
class CloudModule(PgAdminModule):
|
|
|
|
"""
|
2022-11-18 22:43:41 -06:00
|
|
|
class CloudModule():
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
It is a wizard which inherits PgAdminModule
|
|
|
|
class and define methods to load its own
|
|
|
|
javascript file.
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
def get_exposed_url_endpoints(self):
|
|
|
|
"""
|
|
|
|
Returns:
|
|
|
|
list: URL endpoints for cloud module
|
|
|
|
"""
|
|
|
|
return ['cloud.deploy_on_cloud',
|
|
|
|
'cloud.update_cloud_server',
|
|
|
|
'cloud.update_cloud_process',
|
2022-06-15 00:52:42 -05:00
|
|
|
'cloud.get_host_ip',
|
|
|
|
'cloud.clear_cloud_session']
|
2022-02-14 00:43:48 -06:00
|
|
|
|
2022-06-30 00:36:50 -05:00
|
|
|
def register(self, app, options):
|
|
|
|
"""
|
|
|
|
Override the default register function to automagically register
|
|
|
|
sub-modules at once.
|
|
|
|
"""
|
2022-11-18 22:43:41 -06:00
|
|
|
super().register(app, options)
|
2022-06-30 00:36:50 -05:00
|
|
|
|
|
|
|
from .azure import blueprint as module
|
|
|
|
app.register_blueprint(module)
|
|
|
|
|
|
|
|
from .biganimal import blueprint as module
|
|
|
|
app.register_blueprint(module)
|
|
|
|
|
|
|
|
from .rds import blueprint as module
|
|
|
|
app.register_blueprint(module)
|
|
|
|
|
2023-03-13 04:26:16 -05:00
|
|
|
from .google import blueprint as module
|
|
|
|
app.register_blueprint(module)
|
|
|
|
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
# Create blueprint for CloudModule class
|
|
|
|
blueprint = CloudModule(
|
|
|
|
MODULE_NAME, __name__, static_url_path='/misc/cloud')
|
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route("/")
|
|
|
|
@login_required
|
|
|
|
def index():
|
|
|
|
return bad_request(
|
|
|
|
errormsg=gettext("This URL cannot be called directly.")
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route("/cloud.js")
|
|
|
|
@login_required
|
|
|
|
def script():
|
|
|
|
"""render own javascript"""
|
|
|
|
res = Response(response=render_template(
|
|
|
|
"cloud/js/cloud.js", _=gettext),
|
|
|
|
status=200,
|
|
|
|
mimetype=MIMETYPE_APP_JS)
|
|
|
|
return res
|
|
|
|
|
|
|
|
|
2022-06-15 00:52:42 -05:00
|
|
|
@blueprint.route('/clear_cloud_session/',
|
|
|
|
methods=['POST'], endpoint='clear_cloud_session')
|
|
|
|
@login_required
|
|
|
|
def clear_session():
|
|
|
|
"""Get host IP Address"""
|
|
|
|
clear_cloud_session()
|
|
|
|
return make_json_response(success=1)
|
|
|
|
|
|
|
|
|
2022-02-28 06:49:18 -06:00
|
|
|
@blueprint.route('/get_host_ip/',
|
|
|
|
methods=['GET'], endpoint='get_host_ip')
|
|
|
|
@login_required
|
|
|
|
def get_host_ip():
|
2022-04-26 06:11:10 -05:00
|
|
|
"""Get host IP Address"""
|
2022-03-02 07:32:35 -06:00
|
|
|
ip = get_my_ip()
|
|
|
|
return make_json_response(data=ip)
|
2022-02-28 06:49:18 -06:00
|
|
|
|
|
|
|
|
2022-02-14 00:43:48 -06:00
|
|
|
@blueprint.route(
|
|
|
|
'/deploy', methods=['POST'], endpoint='deploy_on_cloud'
|
|
|
|
)
|
|
|
|
@login_required
|
|
|
|
def deploy_on_cloud():
|
2022-04-26 06:11:10 -05:00
|
|
|
"""Deploy on Cloud."""
|
2022-02-14 00:43:48 -06:00
|
|
|
|
2023-02-14 23:40:12 -06:00
|
|
|
data = json.loads(request.data)
|
2023-04-28 04:46:22 -05:00
|
|
|
if data['cloud'] == 'aws':
|
2022-08-11 00:19:45 -05:00
|
|
|
status, p, resp = deploy_on_rds(data)
|
2022-04-26 06:11:10 -05:00
|
|
|
elif data['cloud'] == 'biganimal':
|
2022-08-11 00:19:45 -05:00
|
|
|
status, p, resp = deploy_on_biganimal(data)
|
2022-06-15 00:52:42 -05:00
|
|
|
elif data['cloud'] == 'azure':
|
2022-08-11 00:19:45 -05:00
|
|
|
status, p, resp = deploy_on_azure(data)
|
2023-03-13 04:26:16 -05:00
|
|
|
elif data['cloud'] == 'google':
|
|
|
|
status, p, resp = deploy_on_google(data)
|
2022-04-26 06:11:10 -05:00
|
|
|
else:
|
|
|
|
status = False
|
|
|
|
resp = gettext('No cloud implementation.')
|
2022-02-14 00:43:48 -06:00
|
|
|
|
2022-04-26 06:11:10 -05:00
|
|
|
if not status:
|
2022-02-14 00:43:48 -06:00
|
|
|
return make_json_response(
|
|
|
|
status=410,
|
|
|
|
success=0,
|
2022-04-26 06:11:10 -05:00
|
|
|
errormsg=resp
|
2022-02-14 00:43:48 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
# Return response
|
|
|
|
return make_json_response(
|
|
|
|
success=1,
|
2022-08-11 00:19:45 -05:00
|
|
|
data={
|
|
|
|
'job_id': p.id,
|
|
|
|
'desc': p.desc.message,
|
|
|
|
'node': {
|
|
|
|
'_id': resp['sid'],
|
|
|
|
'_pid': data['db_details']['gid'],
|
|
|
|
'connected': False,
|
|
|
|
'_type': 'server',
|
|
|
|
'icon': 'icon-server-cloud-deploy',
|
|
|
|
'id': 'server_{}'.format(resp['sid']),
|
|
|
|
'inode': True,
|
|
|
|
'label': resp['label'],
|
|
|
|
'server_type': 'pg',
|
|
|
|
'module': 'pgadmin.node.server',
|
|
|
|
'cloud_status': -1
|
|
|
|
}}
|
2022-02-14 00:43:48 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def update_server(data):
|
|
|
|
"""Update Server."""
|
|
|
|
server_data = data
|
2022-07-06 01:13:49 -05:00
|
|
|
pid = data['instance']['pid']
|
2022-02-14 00:43:48 -06:00
|
|
|
server = Server.query.filter_by(
|
|
|
|
user_id=current_user.id,
|
|
|
|
id=server_data['instance']['sid']
|
|
|
|
).first()
|
|
|
|
|
|
|
|
if server is None:
|
2022-04-26 06:11:10 -05:00
|
|
|
return False, gettext("Could not find the server.")
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
if server_data['instance'] == '' or\
|
|
|
|
not server_data['instance']['status']:
|
|
|
|
db.session.delete(server)
|
|
|
|
else:
|
|
|
|
server.host = server_data['instance']['Hostname']
|
|
|
|
server.port = server_data['instance']['Port']
|
|
|
|
server.cloud_status = 1
|
|
|
|
|
|
|
|
try:
|
|
|
|
db.session.commit()
|
|
|
|
except Exception as e:
|
|
|
|
db.session.rollback()
|
|
|
|
return False, e.message
|
|
|
|
|
|
|
|
_server = {
|
|
|
|
'id': server.id,
|
|
|
|
'servergroup_id': server.servergroup_id,
|
|
|
|
'name': server.name,
|
|
|
|
'cloud_status': server.cloud_status
|
|
|
|
}
|
|
|
|
if not server_data['instance']['status']:
|
|
|
|
_server['status'] = False
|
|
|
|
else:
|
|
|
|
_server['status'] = True
|
2022-07-06 01:13:49 -05:00
|
|
|
clear_cloud_session(pid)
|
2022-02-14 00:43:48 -06:00
|
|
|
|
|
|
|
return True, _server
|
|
|
|
|
|
|
|
|
2022-07-06 01:13:49 -05:00
|
|
|
def clear_cloud_session(pid=None):
|
2022-04-26 06:11:10 -05:00
|
|
|
"""Clear cloud sessions."""
|
|
|
|
clear_aws_session()
|
|
|
|
clear_biganimal_session()
|
2022-07-06 01:13:49 -05:00
|
|
|
clear_azure_session(pid)
|
2023-03-13 04:26:16 -05:00
|
|
|
clear_google_session()
|
2022-04-26 06:11:10 -05:00
|
|
|
|
|
|
|
|
2022-02-14 00:43:48 -06:00
|
|
|
@blueprint.route(
|
|
|
|
'/update_cloud_process/<sid>', methods=['GET'],
|
|
|
|
endpoint='update_cloud_process'
|
|
|
|
)
|
|
|
|
@login_required
|
|
|
|
def update_cloud_process(sid):
|
|
|
|
"""Update Cloud Server Process"""
|
|
|
|
_process = Process.query.filter_by(user_id=current_user.id,
|
|
|
|
server_id=sid).first()
|
|
|
|
_process.acknowledge = None
|
|
|
|
db.session.commit()
|
|
|
|
return success_return()
|
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route(
|
|
|
|
'/update_cloud_server', methods=['POST'],
|
|
|
|
endpoint='update_cloud_server'
|
|
|
|
)
|
|
|
|
@login_required
|
|
|
|
def update_cloud_server():
|
|
|
|
"""Update Cloud Server."""
|
2023-02-14 23:40:12 -06:00
|
|
|
server_data = json.loads(request.data)
|
2022-02-14 00:43:48 -06:00
|
|
|
status, server = update_server(server_data)
|
|
|
|
|
|
|
|
if not status:
|
|
|
|
return make_json_response(
|
|
|
|
status=410, success=0, errormsg=server
|
|
|
|
)
|
|
|
|
|
|
|
|
return make_json_response(
|
|
|
|
success=1,
|
|
|
|
data={'node': {
|
|
|
|
'sid': server.id,
|
|
|
|
'gid': server.servergroup_id,
|
|
|
|
'_type': 'server',
|
|
|
|
'icon': 'icon-server-not-connected',
|
|
|
|
'id': 'server_{}'.format(server.id),
|
|
|
|
'label': server.name
|
|
|
|
}}
|
|
|
|
)
|