polyapi-python 0.2.6.dev2__py3-none-any.whl → 0.2.7__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
polyapi/api.py CHANGED
@@ -1,7 +1,7 @@
1
1
  from typing import Any, Dict, List, Tuple
2
2
 
3
3
  from polyapi.typedefs import PropertySpecification
4
- from polyapi.utils import add_type_import_path, camelCase, parse_arguments, get_type_and_def
4
+ from polyapi.utils import add_type_import_path, parse_arguments, get_type_and_def, rewrite_arg_name
5
5
 
6
6
 
7
7
  API_DEFS_TEMPLATE = """
@@ -41,7 +41,7 @@ def render_api_function(
41
41
  arg_names = [a["name"] for a in arguments]
42
42
  args, args_def = parse_arguments(function_name, arguments)
43
43
  return_type_name, return_type_def = get_type_and_def(return_type) # type: ignore
44
- data = "{" + ", ".join([f"'{arg}': {camelCase(arg)}" for arg in arg_names]) + "}"
44
+ data = "{" + ", ".join([f"'{arg}': {rewrite_arg_name(arg)}" for arg in arg_names]) + "}"
45
45
 
46
46
  api_response_type = f"{function_name}Response"
47
47
  func_type_defs = API_DEFS_TEMPLATE.format(
polyapi/cli.py CHANGED
@@ -4,7 +4,7 @@ from polyapi.utils import print_green
4
4
 
5
5
  from .config import clear_config, set_api_key_and_url
6
6
  from .generate import generate, clear
7
- from .function_cli import function_add_or_update
7
+ from .function_cli import function_add_or_update, function_execute
8
8
  from .rendered_spec import get_and_update_rendered_spec
9
9
 
10
10
 
@@ -56,4 +56,7 @@ def execute_from_cli() -> None:
56
56
  print("Clearing the generated library...")
57
57
  clear()
58
58
  elif command == "function":
59
- function_add_or_update(args.context, args.description, args.client, args.server, args.logs, args.subcommands, not args.skip_generate)
59
+ if args.subcommands[0] == "execute":
60
+ print(function_execute(args.context, args.subcommands))
61
+ else:
62
+ function_add_or_update(args.context, args.description, args.client, args.server, args.logs, args.subcommands, not args.skip_generate)
polyapi/client.py CHANGED
@@ -1,7 +1,7 @@
1
1
  from typing import Any, Dict, List, Tuple
2
2
 
3
3
  from polyapi.typedefs import PropertySpecification
4
- from polyapi.utils import camelCase, add_type_import_path, parse_arguments, get_type_and_def
4
+ from polyapi.utils import parse_arguments, get_type_and_def
5
5
 
6
6
  DEFS_TEMPLATE = """
7
7
  from typing import List, Dict, Any, TypedDict
polyapi/function_cli.py CHANGED
@@ -3,7 +3,7 @@ import argparse
3
3
  import json
4
4
  import types
5
5
  import sys
6
- from typing import Dict, List, Mapping, Optional, Tuple
6
+ from typing import Any, Dict, List, Mapping, Optional, Tuple
7
7
  from typing import _TypedDictMeta as BaseTypedDict # type: ignore
8
8
  from typing_extensions import _TypedDictMeta # type: ignore
9
9
  import requests
@@ -279,3 +279,31 @@ def function_add_or_update(
279
279
  print(resp.status_code)
280
280
  print(resp.content)
281
281
  sys.exit(1)
282
+
283
+
284
+ def function_execute(context: str, subcommands: List) -> Any:
285
+ assert subcommands[0] == "execute"
286
+ context_code = importlib.import_module(f"polyapi.poly.{context}")
287
+ print(f"Executing poly.{context}.{subcommands[1]}... ")
288
+ fn = getattr(context_code, subcommands[1])
289
+ return fn(*subcommands[2:])
290
+
291
+
292
+ def spec_delete(function_type: str, function_id: str):
293
+ api_key, api_url = get_api_key_and_url()
294
+ assert api_key
295
+ if function_type == "api":
296
+ url = f"{api_url}/functions/api/{function_id}"
297
+ elif function_type == "serverFunction":
298
+ url = f"{api_url}/functions/server/{function_id}"
299
+ elif function_type == "customFunction":
300
+ url = f"{api_url}/functions/client/{function_id}"
301
+ elif function_type == "webhookHandle":
302
+ url = f"{api_url}/webhooks/{function_id}"
303
+ else:
304
+ print_red("ERROR")
305
+ print(f"Unknown function type: {function_type}")
306
+ sys.exit(1)
307
+ headers = get_auth_headers(api_key)
308
+ resp = requests.delete(url, headers=headers)
309
+ return resp
polyapi/schema.py CHANGED
@@ -77,20 +77,6 @@ def generate_schema_types(input_data: Dict, root=None):
77
77
  with open(tmp_output) as f:
78
78
  output = f.read()
79
79
 
80
- output = _fix_title(input_data, output)
81
- return output
82
-
83
-
84
- def _fix_title(input_data, output) -> str:
85
- """ the jsonschema_gentypes library changes all titles to Pascalcase
86
- this function changes them back
87
- TODO fix bug in gentypes so this step is not necessary
88
- """
89
- for k, v in input_data.items():
90
- if isinstance(v, dict):
91
- output = _fix_title(v, output)
92
- elif k == "title":
93
- output = output.replace(f"class {v.title()}", f"class {v}")
94
80
  return output
95
81
 
96
82
 
polyapi/server.py CHANGED
@@ -1,7 +1,7 @@
1
1
  from typing import Any, Dict, List, Tuple
2
2
 
3
3
  from polyapi.typedefs import PropertySpecification
4
- from polyapi.utils import camelCase, add_type_import_path, parse_arguments, get_type_and_def
4
+ from polyapi.utils import add_type_import_path, parse_arguments, get_type_and_def, rewrite_arg_name
5
5
 
6
6
  SERVER_DEFS_TEMPLATE = """
7
7
  from typing import List, Dict, Any, TypedDict, Callable
@@ -38,7 +38,7 @@ def render_server_function(
38
38
  arg_names = [a["name"] for a in arguments]
39
39
  args, args_def = parse_arguments(function_name, arguments)
40
40
  return_type_name, return_type_def = get_type_and_def(return_type) # type: ignore
41
- data = "{" + ", ".join([f"'{arg}': {camelCase(arg)}" for arg in arg_names]) + "}"
41
+ data = "{" + ", ".join([f"'{arg}': {rewrite_arg_name(arg)}" for arg in arg_names]) + "}"
42
42
  func_type_defs = SERVER_DEFS_TEMPLATE.format(
43
43
  args_def=args_def,
44
44
  return_type_def=return_type_def,
polyapi/utils.py CHANGED
@@ -1,3 +1,4 @@
1
+ import keyword
1
2
  import re
2
3
  import os
3
4
  from typing import Tuple, List
@@ -164,9 +165,10 @@ def parse_arguments(function_name: str, arguments: List[PropertySpecification])
164
165
  arg_type, arg_def = get_type_and_def(a["type"])
165
166
  if arg_def:
166
167
  args_def.append(arg_def)
167
- a["name"] = camelCase(a["name"])
168
+ a["name"] = rewrite_arg_name(a["name"])
168
169
  arg_string += f" {a['name']}: {add_type_import_path(function_name, arg_type)}"
169
170
  description = a.get("description", "")
171
+ description = description.replace("\n", " ")
170
172
  if description:
171
173
  if idx == len(arguments) - 1:
172
174
  arg_string += f" # {description}\n"
@@ -186,7 +188,7 @@ def poly_full_path(context, name) -> str:
186
188
  return f"poly.{path}"
187
189
 
188
190
 
189
- RESERVED_TYPES = {"List", "Dict", "Any", "Optional", "Callable"}
191
+ RESERVED_WORDS = {"List", "Dict", "Any", "Optional", "Callable"} | set(keyword.kwlist)
190
192
 
191
193
 
192
194
  def to_func_namespace(s: str) -> str:
@@ -194,7 +196,16 @@ def to_func_namespace(s: str) -> str:
194
196
  by default it is
195
197
  """
196
198
  rv = s[0].upper() + s[1:]
197
- if rv in RESERVED_TYPES:
198
- return "_" + rv
199
+ rv = rewrite_reserved(rv)
200
+ return rv
201
+
202
+
203
+ def rewrite_reserved(s: str) -> str:
204
+ if s in RESERVED_WORDS:
205
+ return "_" + s
199
206
  else:
200
- return rv
207
+ return s
208
+
209
+
210
+ def rewrite_arg_name(s: str):
211
+ return rewrite_reserved(camelCase(s))
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: polyapi-python
3
- Version: 0.2.6.dev2
3
+ Version: 0.2.7
4
4
  Summary: The Python Client for PolyAPI, the IPaaS by Developers for Developers
5
5
  Author-email: Dan Fellin <dan@polyapi.io>
6
6
  License: MIT License
@@ -1,26 +1,26 @@
1
1
  polyapi/__init__.py,sha256=5iujRodfgRyLxT-zY0L3xax3rKRvfSt4NZlZYKOz03w,608
2
2
  polyapi/__main__.py,sha256=V4zhAh_YGxno5f_KSrlkELxcuDh9bR3WSd0n-2r-qQQ,93
3
- polyapi/api.py,sha256=bE651P47RuhqNYkVyvTH_pA44JypRZED_2M5UG_qzDI,1863
3
+ polyapi/api.py,sha256=e-8nOzq6SXD7_YPVBlW82_9wVxDCc8XD9ioMv_QvnH0,1877
4
4
  polyapi/auth.py,sha256=zrIGatjba5GwUTNjKj1GHQWTEDP9B-HrSzCKbLFoqvc,5336
5
- polyapi/cli.py,sha256=XvsE5QEJZpobISVN2U0Mi-fC1nN8dmXF7AQOIpjUe-A,2636
6
- polyapi/client.py,sha256=w15XOABkwdL4V4r2iWY_nypzLjvoKVuux8jUKbA16pQ,1329
5
+ polyapi/cli.py,sha256=1ZeaK1A0wZM91YLJrYmvSR2wwHRkT7w1p7q9Y0KZu9c,2785
6
+ polyapi/client.py,sha256=CoFDYvyKsqL4wPQbUDIr0Qb8Q5eD92xN4OEEcJEVuGQ,1296
7
7
  polyapi/config.py,sha256=S8TU10upy5OW1_vX-CqQTJD-ZOB6329aMjiUCmukfUI,2292
8
8
  polyapi/constants.py,sha256=sc-FnS0SngBLvSu1ZWMs0UCf9EYD1u1Yhfr-sZXGLns,607
9
9
  polyapi/error_handler.py,sha256=I_e0iz6VM23FLVQWJljxs2NGcl_OODbi43OcbnqBlp8,2398
10
10
  polyapi/exceptions.py,sha256=Zh7i7eCUhDuXEdUYjatkLFTeZkrx1BJ1P5ePgbJ9eIY,89
11
11
  polyapi/execute.py,sha256=kXnvlNQ7nz9cRlV2_5gXH09UCmyiDP5zi3wiAw0uDuk,1943
12
- polyapi/function_cli.py,sha256=NE8CT1E22PC5DorVWJefXsBBGUnpSIsUyhHla02SV4k,9193
12
+ polyapi/function_cli.py,sha256=E92Pq3sDh7qrKL322DTQiTCqigp-IKayHJOmdlR5vT4,10232
13
13
  polyapi/generate.py,sha256=LN2Z6fE-HfpMsXlkJfOl8bqZdR3fUythE_ZsAe15tmk,8012
14
14
  polyapi/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
15
15
  polyapi/rendered_spec.py,sha256=uaNzBhP4cX7iGfKwzZv0dxMagWzsGeDr0cQYx_AyIhQ,2153
16
- polyapi/schema.py,sha256=qxzuWhpDLyO4eGutiaWHGVL9sT46-kVE3r4xByIwGVI,3662
17
- polyapi/server.py,sha256=n-nMGjXoq9T9ZwE2EBDkAaxJ7UytConGaHthkjbkCXA,1894
16
+ polyapi/schema.py,sha256=VVMHAT5yU47cRC7xF44BrmUSemlk5oIKSxH2HTVPaQ8,3169
17
+ polyapi/server.py,sha256=NzQCZFSAJK7XiRw1kiU_i9uMvgYK7i8qh7UX2xjytJU,1908
18
18
  polyapi/typedefs.py,sha256=mRqwd2LKofxNn_VSKxBzixni2j-tai8mfTQ0Wi2aLNM,1487
19
- polyapi/utils.py,sha256=JtL_v0PVkJBlTeRu0gIV5IDScqoiggS8m-VcS4HN22c,6890
19
+ polyapi/utils.py,sha256=PD70FbVLZX0x1Jf2IYZLG2U5XHP6DfYZAwjwlVcl1z8,7141
20
20
  polyapi/variables.py,sha256=d36-trnfTL_8m2NkorMiImb4O3UrJbiFV38CHxV5i0A,4200
21
21
  polyapi/webhook.py,sha256=LWv28c2MLz_OKBI_Nn7WR4C-gs1SWgbdXsoxIIf-9UI,4886
22
- polyapi_python-0.2.6.dev2.dist-info/LICENSE,sha256=Hi0kDr56Dsy0uYIwNt4r9G7tI8x8miXRTlyvbeplCP8,1068
23
- polyapi_python-0.2.6.dev2.dist-info/METADATA,sha256=uTLAKOtYHntaVrHussXHXROuhLTQEWRFaAcjd87loGY,4867
24
- polyapi_python-0.2.6.dev2.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
25
- polyapi_python-0.2.6.dev2.dist-info/top_level.txt,sha256=CEFllOnzowci_50RYJac-M54KD2IdAptFsayVVF_f04,8
26
- polyapi_python-0.2.6.dev2.dist-info/RECORD,,
22
+ polyapi_python-0.2.7.dist-info/LICENSE,sha256=Hi0kDr56Dsy0uYIwNt4r9G7tI8x8miXRTlyvbeplCP8,1068
23
+ polyapi_python-0.2.7.dist-info/METADATA,sha256=97IpFMAOromWL3zv2DKfN4fK6qfH2dmHvFcIpN3aYX8,4862
24
+ polyapi_python-0.2.7.dist-info/WHEEL,sha256=Z4pYXqR_rTB7OWNDYFOm1qRk0RX6GFP2o8LgvP453Hk,91
25
+ polyapi_python-0.2.7.dist-info/top_level.txt,sha256=CEFllOnzowci_50RYJac-M54KD2IdAptFsayVVF_f04,8
26
+ polyapi_python-0.2.7.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: bdist_wheel (0.43.0)
2
+ Generator: setuptools (70.3.0)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5