Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtp (Exim 4.84_2) (envelope-from ) id 1aihWw-0000d9-8Q for pgadmin-hackers@arkaria.postgresql.org; Wed, 23 Mar 2016 12:04:54 +0000 Received: from localhost ([127.0.0.1] helo=postgresql.org) by malur.postgresql.org with smtp (Exim 4.84_2) (envelope-from ) id 1aihWv-0004Bg-Ny for pgadmin-hackers@arkaria.postgresql.org; Wed, 23 Mar 2016 12:04:53 +0000 Received: from magus.postgresql.org ([2a02:c0:301:0:ffff::29]) by malur.postgresql.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA384:256) (Exim 4.84_2) (envelope-from ) id 1aihWv-0004Ba-7A for pgadmin-hackers@postgresql.org; Wed, 23 Mar 2016 12:04:53 +0000 Received: from mail-io0-x235.google.com ([2607:f8b0:4001:c06::235]) by magus.postgresql.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.84_2) (envelope-from ) id 1aihWo-0007Kw-20 for pgadmin-hackers@postgresql.org; Wed, 23 Mar 2016 12:04:52 +0000 Received: by mail-io0-x235.google.com with SMTP id v187so6982762ioe.2 for ; Wed, 23 Mar 2016 05:04:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=pgadmin-org.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc; bh=SOMHhr24W7m/+AAbQh0r5s2s/+G2yuQTKUg7x2IaY2E=; b=l+ggib0M+tinu6uygV9jq64i+IQfd4qfssZsQuaZHAIaiQbuRLkTLXTsAt5lDHiYnV d5FWQ9RRLj0U8fU9xyLF8A9Klo+QteJ5roKA348xGgpFURwFuZhiYUxN8ZTiqsCDV2E/ IOBXThqyr7+N62IHefGF2aHyXDpDzwyKZ6CJFGC/KT4KJgBRQAWQNaS+Ize9JWyVr++9 NJgFvtex9v3HVBti6QtgvmN75z1LnOK5ru/ivwmkyNQlh+79uRSSX1Gi9BA11UdbJnbD Tbm2fRSxYLdzR8hllhpOw6PfntihgDX+uo9Yac/OjI9jLAbBpyxVywLCzrd0fOD7BNA6 3WlQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc; bh=SOMHhr24W7m/+AAbQh0r5s2s/+G2yuQTKUg7x2IaY2E=; b=TPtkkVlzjK8isPMB9soVC9LL2Kj+u6XnHH+KwBDR/i8Il0tFWFz6rAlWmneUIcV0JD FVMhchEy4SpKh+Yhjy64wPYzsHiNKWIrvQcDno+G/BZLHigavpGMEkanxEcNALRs0KO1 wxu3MU6xGu7QQ9A0cb5DDBthP9YrEfjCNHfLcxuWp5Z5810MMOb2+G6YcBLucSROl75e vii6HwkFKLscny17LYLLJpY6Ljb01BMFC7Ti1IJpjoeXbZnu38jGYAn3AZ+jHMdWZLjp ZEZLZI1UfcNR10TZmZZHGeg+7Gi6x+QzuLFSe4MDIyh2/xAAWWYiN+a++OzoML+Ii5zE 048w== X-Gm-Message-State: AD7BkJIHH7E+nU7PvMiolO1Ey7vfjhx/OLjcS7utkVHTO1yHIw7AofxDKEfC6MDfTQ0kqP5SiexbRwRZz4ccEg== MIME-Version: 1.0 X-Received: by 10.107.158.148 with SMTP id h142mr3180417ioe.63.1458734595066; Wed, 23 Mar 2016 05:03:15 -0700 (PDT) Received: by 10.64.24.175 with HTTP; Wed, 23 Mar 2016 05:03:14 -0700 (PDT) In-Reply-To: References: Date: Wed, 23 Mar 2016 12:03:14 +0000 Message-ID: Subject: Re: [pgAdmin4][Patch]: Functions/Procedures Module From: Dave Page To: Khushboo Vashi Cc: pgadmin-hackers Content-Type: text/plain; charset=UTF-8 X-Pg-Spam-Score: -2.6 (--) List-Archive: List-Help: List-ID: List-Owner: List-Post: List-Subscribe: List-Unsubscribe: X-Mailing-List: pgadmin-hackers Precedence: bulk Sender: pgadmin-hackers-owner@postgresql.org On Tue, Mar 22, 2016 at 10:51 AM, Khushboo Vashi wrote: > Hi, > > Please find updated Patch for the Functions/Procedures Module. Hi Unfortunately I found more issues as I tested in-depth. I've attached an updated patch in which I've done some cleanup - additional comments below: - Some argument lists are shown with an extra space, e.g. character varying , integer (pem.create_agent(character varying , integer)) - A 404 error is seen when functions are selected under a Catalog node. - Procedures have a property of "System function?" - should be "System procedure?" - The Return Type, Returns a Set and Window fields should be hidden for Procedures. - When creating a procedure (below), I get the following error: ----- -- PROCEDURE: foo -- DROP PROCEDURE foo; CREATE OR REPLACE PROCEDURE public.foo(IN a integer DEFAULT 10, INOUT b integer DEFAULT -) VOLATILE NOT LEAKPROOF SECURITY DEFINER COST 100.0 AS BEGIN b:=a+b+1; END; COMMENT ON PROCEDURE public.foo IS 'Foo procedure'; ----- ----- 2016-03-23 11:22:02,186: INFO werkzeug: 127.0.0.1 - - [23/Mar/2016 11:22:02] "GET /browser/procedure/obj/1/2/14844/13627/16387 HTTP/1.1" 500 - Traceback (most recent call last): File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1836, in __call__ return self.wsgi_app(environ, start_response) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1820, in wsgi_app response = self.make_response(self.handle_exception(e)) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1403, in handle_exception reraise(exc_type, exc_value, tb) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1817, in wsgi_app response = self.full_dispatch_request() File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1477, in full_dispatch_request rv = self.handle_user_exception(e) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1381, in handle_user_exception reraise(exc_type, exc_value, tb) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1475, in full_dispatch_request rv = self.dispatch_request() File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1461, in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/views.py", line 84, in view return self.dispatch_request(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/utils.py", line 233, in dispatch_request return method(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/server_groups/servers/databases/schemas/functions/__init__.py", line 349, in wrap return f(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/server_groups/servers/databases/schemas/functions/__init__.py", line 425, in properties resp_data = self._fetch_properties(gid, sid, did, scid, fnid) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/server_groups/servers/databases/schemas/functions/__init__.py", line 1097, in _fetch_properties resp_data = res['rows'][0] IndexError: list index out of range ----- - After a Python server reset, I get the following error when trying to view SQL of a Procedure (seems like it thinks it's connected to PG?): TemplateNotFound: procedure/pg/sql/9.5_plus/node.sql 2016-03-23 11:28:52,852: INFO werkzeug: 127.0.0.1 - - [23/Mar/2016 11:28:52] "GET /browser/procedure/nodes/1/2/14844/2200/ HTTP/1.1" 500 - Traceback (most recent call last): File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1836, in __call__ return self.wsgi_app(environ, start_response) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1820, in wsgi_app response = self.make_response(self.handle_exception(e)) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1403, in handle_exception reraise(exc_type, exc_value, tb) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1817, in wsgi_app response = self.full_dispatch_request() File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1477, in full_dispatch_request rv = self.handle_user_exception(e) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1381, in handle_user_exception reraise(exc_type, exc_value, tb) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1475, in full_dispatch_request rv = self.dispatch_request() File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/app.py", line 1461, in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/views.py", line 84, in view return self.dispatch_request(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/utils.py", line 233, in dispatch_request return method(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/server_groups/servers/databases/schemas/functions/__init__.py", line 349, in wrap return f(*args, **kwargs) File "/Users/dpage/git/pgadmin4/web/pgadmin/browser/server_groups/servers/databases/schemas/functions/__init__.py", line 390, in nodes 'node.sql']), scid=scid) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/templating.py", line 127, in render_template return _render(ctx.app.jinja_env.get_or_select_template(template_name_or_list), File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/jinja2/environment.py", line 830, in get_or_select_template return self.get_template(template_name_or_list, parent, globals) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/jinja2/environment.py", line 791, in get_template return self._load_template(name, self.make_globals(globals)) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/jinja2/environment.py", line 765, in _load_template template = self.loader.load(self, name, globals) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/jinja2/loaders.py", line 113, in load source, filename, uptodate = self.get_source(environment, name) File "/Users/dpage/.virtualenvs/pgadmin4/lib/python2.7/site-packages/flask/templating.py", line 64, in get_source raise TemplateNotFound(template) TemplateNotFound: procedure/pg/sql/9.5_plus/node.sql 2016-03-23 11:28:57,953: INFO werkzeug: 127.0.0.1 - - [23/Mar/2016 11:28:57] "POST /ping HTTP/1.1" 200 - - Procedures do not include the schema name in the headers of reverse engineered SQL, e.g. - What's the trailing - in the parameter list in this reverse engineered SQL? -- PROCEDURE: foo -- DROP PROCEDURE foo; CREATE OR REPLACE PROCEDURE public.foo(IN a integer DEFAULT 10, INOUT b integer DEFAULT -) VOLATILE NOT LEAKPROOF SECURITY DEFINER COST 100.0 AS BEGIN b:=a+b+1; END; COMMENT ON PROCEDURE public.foo IS 'Foo procedure'; Thanks! -- Dave Page Blog: http://pgsnake.blogspot.com Twitter: @pgsnake EnterpriseDB UK: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgadmin-hackers mailing list (pgadmin-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgadmin-hackers