2020-04-06 07:03:07 -05:00
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
2024-01-01 02:43:48 -06:00
|
|
|
# Copyright (C) 2013 - 2024, The pgAdmin Development Team
|
2020-04-06 07:03:07 -05:00
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
|
|
|
##########################################################################
|
|
|
|
|
|
|
|
"""Implements Search Object feature"""
|
|
|
|
|
|
|
|
from flask import request
|
2021-11-24 05:52:57 -06:00
|
|
|
from flask_babel import gettext
|
2024-04-29 03:11:02 -05:00
|
|
|
from pgadmin.user_login_check import pga_login_required
|
2020-04-06 07:03:07 -05:00
|
|
|
|
|
|
|
from pgadmin.utils import PgAdminModule
|
|
|
|
from pgadmin.utils.ajax import make_json_response, bad_request,\
|
|
|
|
internal_server_error
|
|
|
|
from pgadmin.utils.preferences import Preferences
|
|
|
|
from pgadmin.tools.search_objects.utils import SearchObjectsHelper
|
|
|
|
|
|
|
|
MODULE_NAME = 'search_objects'
|
|
|
|
|
|
|
|
|
|
|
|
class SearchObjectsModule(PgAdminModule):
|
|
|
|
LABEL = gettext('Search objects')
|
|
|
|
|
|
|
|
def get_exposed_url_endpoints(self):
|
|
|
|
"""
|
|
|
|
Returns:
|
|
|
|
list: URL endpoints for search_object module
|
|
|
|
"""
|
|
|
|
return ['search_objects.search', 'search_objects.types']
|
|
|
|
|
|
|
|
def show_system_objects(self):
|
|
|
|
"""
|
|
|
|
return system preference objects
|
|
|
|
"""
|
|
|
|
return self.pref_show_system_objects.get()
|
|
|
|
|
|
|
|
def register_preferences(self):
|
|
|
|
"""
|
|
|
|
Get show_system_objects preference
|
|
|
|
"""
|
|
|
|
browser_preference = Preferences.module('browser')
|
|
|
|
self.pref_show_system_objects =\
|
|
|
|
browser_preference.preference('show_system_objects')
|
|
|
|
|
|
|
|
|
|
|
|
# Create blueprint for BackupModule class
|
|
|
|
blueprint = SearchObjectsModule(
|
|
|
|
MODULE_NAME, __name__, static_url_path=''
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route("/", endpoint='index')
|
2024-04-29 03:11:02 -05:00
|
|
|
@pga_login_required
|
2020-04-06 07:03:07 -05:00
|
|
|
def index():
|
2020-04-08 03:44:25 -05:00
|
|
|
return bad_request(errormsg=gettext("This URL cannot be called directly."))
|
2020-04-06 07:03:07 -05:00
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route("types/<int:sid>/<int:did>", endpoint='types')
|
2024-04-29 03:11:02 -05:00
|
|
|
@pga_login_required
|
2020-04-06 07:03:07 -05:00
|
|
|
def types(sid, did):
|
|
|
|
so_obj = SearchObjectsHelper(sid, did, blueprint.show_system_objects())
|
|
|
|
return make_json_response(data=so_obj.get_supported_types())
|
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route("search/<int:sid>/<int:did>", endpoint='search')
|
2024-04-29 03:11:02 -05:00
|
|
|
@pga_login_required
|
2020-04-06 07:03:07 -05:00
|
|
|
def search(sid, did):
|
|
|
|
"""
|
|
|
|
URL args:
|
|
|
|
text <required>: search text
|
|
|
|
type <optional>: type of object to be searched.
|
|
|
|
"""
|
|
|
|
text = request.args.get('text', None)
|
|
|
|
obj_type = request.args.get('type', None)
|
|
|
|
|
|
|
|
so_obj = SearchObjectsHelper(sid, did, blueprint.show_system_objects())
|
|
|
|
|
|
|
|
status, res = so_obj.search(text, obj_type)
|
|
|
|
|
|
|
|
if not status:
|
|
|
|
return internal_server_error(errormsg=res)
|
|
|
|
|
|
|
|
return make_json_response(data=res)
|