kaqing 2.0.49__py3-none-any.whl → 2.0.50__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.
@@ -1,12 +1,13 @@
1
- from adam.commands.cql.cql_table_completer import CqlTableCompleter
1
+ from adam.commands.cql.cql_table_completer import CqlTableNameCompleter
2
2
  from adam.commands.cql.cql_utils import table_names
3
3
  from adam.repl_state import ReplState
4
+ from adam.sql.sql_completer import SqlCompleter
4
5
 
5
6
  def cql_completions(state: ReplState) -> dict[str, any]:
6
- completer = CqlTableCompleter(table_names(state))
7
+ table_name_completer = CqlTableNameCompleter(table_names(state))
7
8
  return {
8
9
  'describe': {
9
10
  'keyspaces': None,
10
- 'table': completer.completions(),
11
+ 'table': table_name_completer,
11
12
  'tables': None},
12
- } | completer.completions()
13
+ } | SqlCompleter.completions(table_name_completer)
@@ -1,6 +1,6 @@
1
- from adam.table_completer import NestedDict, TableCompleter
1
+ from adam.sql.table_name_completer import NestedDict, TableNameCompleter
2
2
 
3
- class CqlTableCompleter(TableCompleter):
3
+ class CqlTableNameCompleter(TableNameCompleter):
4
4
  def __init__(self, tables: list[str], nested_dict: NestedDict = {}, ignore_case: bool = True):
5
5
  self._tables = tables
6
6
  self.ignore_case = ignore_case
@@ -9,8 +9,8 @@ class CqlTableCompleter(TableCompleter):
9
9
  def __repr__(self) -> str:
10
10
  return "CqlTableCompleter(%r)" % (len(self._tables))
11
11
 
12
- def nested(self, data: NestedDict) -> 'TableCompleter':
13
- return CqlTableCompleter(self._tables).append_nested_dict(data)
12
+ def nested(self, data: NestedDict) -> 'TableNameCompleter':
13
+ return CqlTableNameCompleter(self._tables).append_nested_dict(data)
14
14
 
15
15
  def tables(self) -> list[str]:
16
16
  return self._tables
@@ -55,6 +55,7 @@ class Cqlsh(Command):
55
55
 
56
56
  def completion(self, state: ReplState) -> dict[str, any]:
57
57
  if state.device != state.C:
58
+ # conflicts with psql completions
58
59
  return {}
59
60
 
60
61
  if state.sts or state.pod:
@@ -59,8 +59,7 @@ class MedusaRestore(Command):
59
59
  now_dtformat = datetime.now().strftime("%Y-%m-%d.%H.%M.%S")
60
60
  rtname = 'medusa-' + now_dtformat + '-restore-from-' + bkname
61
61
  try:
62
- print('SEAN doing')
63
- # CustomResources.create_medusa_restorejob(rtname, bkname, dc, ns)
62
+ CustomResources.create_medusa_restorejob(rtname, bkname, dc, ns)
64
63
  except Exception as e:
65
64
  log2("Exception: MedusaRestore failed: %s\n" % e)
66
65
 
@@ -1,7 +1,7 @@
1
1
  import click
2
2
 
3
3
  from adam.commands.command import Command
4
- from adam.commands.postgres.pg_completions import pg_completions
4
+ from adam.commands.postgres.psql_completions import psql_completions
5
5
  from adam.commands.postgres.postgres_utils import pg_table_names
6
6
  from .postgres_ls import PostgresLs
7
7
  from .postgres_preview import PostgresPreview
@@ -66,13 +66,14 @@ class Postgres(Command):
66
66
 
67
67
  def completion(self, state: ReplState):
68
68
  if state.device != state.P:
69
+ # conflicts with cql completions
69
70
  return {}
70
71
 
71
72
  leaf = {}
72
73
  session = PostgresSession(state.namespace, state.pg_path)
73
74
  if session.db:
74
75
  if pg_table_names(state.namespace, state.pg_path):
75
- leaf = pg_completions(state.namespace, state.pg_path)
76
+ leaf = psql_completions(state.namespace, state.pg_path)
76
77
  elif state.pg_path:
77
78
  leaf = {
78
79
  '\h': None,
@@ -0,0 +1,11 @@
1
+ from adam.commands.postgres.psql_table_completer import PsqlTableNameCompleter
2
+ from adam.sql.sql_completer import SqlCompleter
3
+
4
+ def psql_completions(ns: str, pg_path: str):
5
+ return {
6
+ '\h': None,
7
+ '\d': None,
8
+ '\dt': None,
9
+ '\du': None
10
+ } | SqlCompleter.completions(PsqlTableNameCompleter(ns, pg_path))
11
+ # } | PsqlTableCompleter(ns, pg_path).completions()
@@ -0,0 +1,18 @@
1
+ from adam.commands.postgres.postgres_utils import pg_table_names
2
+ from adam.sql.table_name_completer import NestedDict, TableNameCompleter
3
+
4
+ class PsqlTableNameCompleter(TableNameCompleter):
5
+ def __init__(self, namespace: str, pg_path: str, nested_dict: NestedDict = {}, ignore_case: bool = True):
6
+ self.namespace = namespace
7
+ self.pg_path = pg_path
8
+ self.ignore_case = ignore_case
9
+ self.append_nested_dict(nested_dict)
10
+
11
+ def __repr__(self) -> str:
12
+ return "PsqlTableCompleter(%r, pg_path=%r)" % (self.namespace, self.pg_path)
13
+
14
+ def nested(self, data: NestedDict) -> 'TableNameCompleter':
15
+ return PsqlTableNameCompleter(self.namespace, self.pg_path).append_nested_dict(data)
16
+
17
+ def tables(self) -> list[str]:
18
+ return pg_table_names(self.namespace, self.pg_path)
@@ -1,9 +1,9 @@
1
1
  import functools
2
2
 
3
3
  from adam.commands.command import Command
4
- from adam.commands.cql.cql_table_completer import CqlTableCompleter
4
+ from adam.commands.cql.cql_table_completer import CqlTableNameCompleter
5
5
  from adam.commands.cql.cql_utils import run_cql, table_names, tables
6
- from adam.commands.postgres.pg_table_completer import PgTableCompleter
6
+ from adam.commands.postgres.psql_table_completer import PsqlTableNameCompleter
7
7
  from adam.commands.postgres.postgres_session import PostgresSession
8
8
  from adam.config import Config
9
9
  from adam.repl_state import ReplState, RequiredState
@@ -73,9 +73,9 @@ class PreviewTable(Command):
73
73
 
74
74
  def completion(self, state: ReplState):
75
75
  if state.device == ReplState.P:
76
- return {PreviewTable.COMMAND: PgTableCompleter(state.namespace, state.pg_path)}
76
+ return {PreviewTable.COMMAND: PsqlTableNameCompleter(state.namespace, state.pg_path)}
77
77
  elif state.sts:
78
- return {PreviewTable.COMMAND: CqlTableCompleter(table_names(state))}
78
+ return {PreviewTable.COMMAND: CqlTableNameCompleter(table_names(state))}
79
79
 
80
80
  return {}
81
81
 
adam/repl.py CHANGED
@@ -18,6 +18,7 @@ from adam.log import Log
18
18
  from adam.repl_commands import ReplCommands
19
19
  from adam.repl_session import ReplSession
20
20
  from adam.repl_state import ReplState
21
+ from adam.sql.sql_completer import SqlCompleter
21
22
  from adam.utils import deep_merge_dicts, deep_sort_dict, lines_to_tabular, log2
22
23
  from adam.apps import Apps
23
24
  from . import __version__
@@ -108,7 +109,7 @@ def enter_repl(state: ReplState):
108
109
  log2(f'Timing auto-completion-calc {cmd.command()}: {time.time() - s1:.2f}')
109
110
 
110
111
  # print(json.dumps(completions, indent=4))
111
- completer = NestedCompleter.from_nested_dict(completions)
112
+ completer = SqlCompleter.from_nested_dict(completions)
112
113
 
113
114
  cmd = session.prompt(prompt_msg(), completer=completer, key_bindings=kb)
114
115
  s0 = time.time()
adam/sql/__init__.py ADDED
File without changes
@@ -1,16 +1,18 @@
1
- from abc import abstractmethod
2
1
  from typing import Any, Dict, Iterable, Mapping, Optional, Set, Union
3
2
  from prompt_toolkit.completion import CompleteEvent, Completer, Completion, NestedCompleter, WordCompleter
4
3
  from prompt_toolkit.document import Document
5
4
 
5
+ from adam.sql.sql_utils import safe_terms
6
+
6
7
  NestedDict = Mapping[str, Union[Any, Set[str], None, Completer]]
7
8
 
8
- class TableCompleter(Completer):
9
- def __init__(self, nested_dict: NestedDict = {}, ignore_case: bool = True):
9
+ class AnyCompleter(Completer):
10
+ def __init__(self, default: str = None, nested_dict: NestedDict = {}, ignore_case: bool = True):
11
+ self.default = default
10
12
  self.ignore_case = ignore_case
11
13
  self.append_nested_dict(nested_dict)
12
14
 
13
- def append_nested_dict(self, data: NestedDict) -> "TableCompleter":
15
+ def append_nested_dict(self, data: NestedDict) -> "AnyCompleter":
14
16
  options: Dict[str, Optional[Completer]] = {}
15
17
  for key, value in data.items():
16
18
  if isinstance(value, Completer):
@@ -33,18 +35,18 @@ class TableCompleter(Completer):
33
35
  text = document.text_before_cursor.lstrip()
34
36
  stripped_len = len(document.text_before_cursor) - len(text)
35
37
 
36
- if " " in text:
38
+ terms, has_space = safe_terms(text)
39
+ if has_space:
37
40
  second_term = None
38
- tokens = text.split()
39
- if len(tokens) > 1:
40
- second_term = tokens[1]
41
+ if len(terms) > 1:
42
+ second_term = terms[1]
41
43
 
42
44
  yielded = False
43
45
  if second_term:
44
46
  completer = self.options.get(second_term)
45
47
 
46
48
  if completer is not None:
47
- first_term = tokens[0]
49
+ first_term = terms[0]
48
50
  remaining_text = text[len(first_term) :].lstrip()
49
51
  move_cursor = len(text) - len(remaining_text) + stripped_len
50
52
 
@@ -66,28 +68,17 @@ class TableCompleter(Completer):
66
68
  )
67
69
  for c in completer.get_completions(document, complete_event):
68
70
  yield c
69
- else:
70
- completer = WordCompleter(
71
- self.tables(), ignore_case=self.ignore_case
72
- )
73
- for c in completer.get_completions(document, complete_event):
71
+ elif words := self.words():
72
+ for c in words.get_completions(document, complete_event):
74
73
  yield c
75
74
 
76
- @abstractmethod
77
- def nested(self, data: NestedDict) -> 'TableCompleter':
78
- pass
79
-
80
- @abstractmethod
81
- def tables(self) -> list[str]:
82
- pass
83
-
84
- def completions(self):
85
- return {
86
- 'delete': {'from': self.nested({'where': {'id': {'=': {"'id'": None}}}})},
87
- 'insert': {'into': self.nested({'values(': None})},
88
- 'select': {'*': {'from': self.nested({
89
- 'limit': {'1': {'where': {'id': {'=': {"'id'": None}}}}},
90
- 'where': {'id': {'=': {"'id'": {'limit': {'1': None}}}}}
91
- })}},
92
- 'update': self.nested({'set': {'column': {'=': None}}}),
93
- }
75
+ def words(self):
76
+ if not self.default:
77
+ return None
78
+
79
+ return WordCompleter(
80
+ [self.default], ignore_case=self.ignore_case
81
+ )
82
+
83
+ def nested(self, data: NestedDict) -> 'AnyCompleter':
84
+ return AnyCompleter(self.default).append_nested_dict(data)
@@ -0,0 +1,53 @@
1
+ from typing import Dict, Iterable, Optional
2
+ from prompt_toolkit.completion import CompleteEvent, Completer, Completion, NestedCompleter, WordCompleter
3
+ from prompt_toolkit.document import Document
4
+
5
+ from adam.sql.any_completer import AnyCompleter as any
6
+ from adam.sql.sql_utils import safe_terms
7
+ from adam.sql.table_name_completer import TableNameCompleter
8
+
9
+ class SqlCompleter(NestedCompleter):
10
+ def __init__(
11
+ self, options: Dict[str, Optional[Completer]], ignore_case: bool = True
12
+ ) -> None:
13
+ super().__init__(options, ignore_case)
14
+
15
+ def get_completions(
16
+ self, document: Document, complete_event: CompleteEvent
17
+ ) -> Iterable[Completion]:
18
+ text = document.text_before_cursor.lstrip()
19
+ stripped_len = len(document.text_before_cursor) - len(text)
20
+
21
+ terms, has_space = safe_terms(text)
22
+ if has_space:
23
+ first_term = terms[0]
24
+ completer = self.options.get(first_term)
25
+
26
+ if completer is not None:
27
+ remaining_text = text[len(first_term) :].lstrip()
28
+ move_cursor = len(text) - len(remaining_text) + stripped_len
29
+
30
+ new_document = Document(
31
+ remaining_text,
32
+ cursor_position=document.cursor_position - move_cursor,
33
+ )
34
+
35
+ for c in completer.get_completions(new_document, complete_event):
36
+ yield c
37
+ else:
38
+ completer = WordCompleter(
39
+ list(self.options.keys()), ignore_case=self.ignore_case
40
+ )
41
+ for c in completer.get_completions(document, complete_event):
42
+ yield c
43
+
44
+ def completions(table: TableNameCompleter):
45
+ return {
46
+ 'delete': {'from': table.nested({'where': any('id').nested({'=': any("'id'")})})},
47
+ 'insert': {'into': table.nested({'values(': None})},
48
+ 'select': any('*').nested({'from': table.nested({
49
+ 'limit': any('1'),
50
+ 'where': any('id').nested({'=': any("'id'").nested({'limit': any('1')})})
51
+ })}),
52
+ 'update': table.nested({'set': {'column': {'=': None}}}),
53
+ }
adam/sql/sql_utils.py ADDED
@@ -0,0 +1,5 @@
1
+ import re
2
+
3
+ def safe_terms(text: str):
4
+ tokens = re.findall(r'"[^"]+"|\b\w+\b|\S', text)
5
+ return tokens, len(tokens) > 1 or text.startswith(' ') or text.endswith(' ')
@@ -0,0 +1,17 @@
1
+ from abc import abstractmethod
2
+ from prompt_toolkit.completion import WordCompleter
3
+
4
+ from .any_completer import AnyCompleter, NestedDict
5
+
6
+ class TableNameCompleter(AnyCompleter):
7
+ def __init__(self, nested_dict: NestedDict = {}, ignore_case: bool = True):
8
+ super().__init__(nested_dict=nested_dict, ignore_case=ignore_case)
9
+
10
+ def words(self):
11
+ return WordCompleter(
12
+ self.tables(), ignore_case=self.ignore_case
13
+ )
14
+
15
+ @abstractmethod
16
+ def tables(self) -> list[str]:
17
+ pass
adam/version.py CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env python
2
2
  # -*- coding: utf-8 -*-
3
3
 
4
- __version__ = "2.0.49" #: the working version
4
+ __version__ = "2.0.50" #: the working version
5
5
  __release__ = "1.0.0" #: the release version
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: kaqing
3
- Version: 2.0.49
3
+ Version: 2.0.50
4
4
  Summary: UNKNOWN
5
5
  Home-page: UNKNOWN
6
6
  License: UNKNOWN
@@ -9,13 +9,12 @@ adam/embedded_apps.py,sha256=lKPx63mKzJbNmwz0rgL4gF76M9fDGxraYTtNAIGnZ_s,419
9
9
  adam/embedded_params.py,sha256=_9tBKpkSzBfzm-s3tUgZs8DcSVBnPA1iumG0ZRCbZIs,4586
10
10
  adam/log.py,sha256=gg5DK52wLPc9cjykeh0WFHyAk1qI3HEpGaAK8W2dzXY,1146
11
11
  adam/pod_exec_result.py,sha256=nq0xnCNOpUGBSijGF0H-YNrwBc9vUQs4DkvLMIFS5LQ,951
12
- adam/repl.py,sha256=X9ga1iZFIXADQxBXvztFyVNBrfBRxiFLxTUYkm11img,7328
12
+ adam/repl.py,sha256=ACIBgqitFt5z6lKFSeF4JOXbnCa3seZHWxFiMJ5Q9zw,7373
13
13
  adam/repl_commands.py,sha256=WA90Rl27Juctzr3U3kfCDk5N-oYMKlfWbZeafUgk7k0,4723
14
14
  adam/repl_session.py,sha256=uIogcvWBh7wd8QQ-p_JgLsyJ8YJgINw5vOd6JIsd7Vo,472
15
15
  adam/repl_state.py,sha256=591d7gV6uQSFtm7IWdlIYAHjfAzs9bdvIkwlIAeKddE,7540
16
- adam/table_completer.py,sha256=6lOSusLCbmILJfERRNxOIgVp-8GrmJf4rQ_pchZbceg,3569
17
16
  adam/utils.py,sha256=2DoWsrcaioFFH0-RjT30qelVRPUJqCGTfz_ucfE7F8g,7406
18
- adam/version.py,sha256=yZ-JQgru1WpJO6wYfsHtZ05JFJ6_oRFLc_ltDuD5KEI,139
17
+ adam/version.py,sha256=LFuTm_lavjxHMfAJnqFwLX9zL3RVjQ6n-Au9M0IztXo,139
19
18
  adam/checks/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
20
19
  adam/checks/check.py,sha256=Qopr3huYcMu2bzQgb99dEUYjFzkjKHRI76S6KA9b9Rk,702
21
20
  adam/checks/check_context.py,sha256=FEHkQ32jY1EDopQ2uYWqy9v7aEEX1orLpJWhopwAlh4,402
@@ -70,7 +69,7 @@ adam/commands/nodetool.py,sha256=HV9yDzMhRjS4lw6UfV7Hc1pcmeSx5a1jU6cAEKSZ1Bg,233
70
69
  adam/commands/nodetool_commands.py,sha256=5IgWC3rmeDD1cgwqQjiiWzi-wJpJ3n_8pAzz_9phXuk,2635
71
70
  adam/commands/param_get.py,sha256=kPAAppK2T0tEFRnSIVFLDPIIGHhgLA7drJhn8TRyvvE,1305
72
71
  adam/commands/param_set.py,sha256=QDIuqfU80aWCB16OK49yf7XRaRTWwiLkwMsJuVikq9I,1271
73
- adam/commands/preview_table.py,sha256=T70GQULpoxBQWppGlMKpqjJiBTmCVlArTSuPf1hHh9c,3046
72
+ adam/commands/preview_table.py,sha256=EJZms-8sXqwDDNjix92z2tpU9823-WKv6y-Z3A7ucao,3068
74
73
  adam/commands/pwd.py,sha256=VlgFjxFl66I7Df1YI6cuiEeY6Q13lEavMKfrzHLESKo,2340
75
74
  adam/commands/report.py,sha256=Ky45LIzSlB_X4V12JZWjU3SA2u4_FKRencRTq7psOWU,1944
76
75
  adam/commands/restart.py,sha256=Hik1t5rjH2ATZv4tzwrGB3e44b3dNuATgY327_Nb8Bs,2044
@@ -78,10 +77,10 @@ adam/commands/rollout.py,sha256=52_4ijna3v-8Oug12et43DRHFDNhiN34p6xLTQmhdbQ,2959
78
77
  adam/commands/shell.py,sha256=wY_PIx7Lt6vuxhFArlfxdEnBbrouCJ3yNHhFn17DEqw,848
79
78
  adam/commands/watch.py,sha256=mmBFpB8T1V7zrNs5b2YNyDDztMym_ILPDdkrbdAXTas,2438
80
79
  adam/commands/cql/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
81
- adam/commands/cql/cql_completions.py,sha256=stgjuB7iAXKY2F6vM5bkOrNuJF9zmTziNEd9dyA5fpE,442
82
- adam/commands/cql/cql_table_completer.py,sha256=6kvKatvKDW4qL2auZDjH050CKlV3lSmTSV4lvcEnpMo,604
80
+ adam/commands/cql/cql_completions.py,sha256=BfaBlLMBdSSbuYmuyVMhOcJ7IgELvYKJroq4qOjoZWc,529
81
+ adam/commands/cql/cql_table_completer.py,sha256=ktTXC_Ii8NhxRbvUebc_Rg__Z7v2faQJBt3mR-5LPoI,633
83
82
  adam/commands/cql/cql_utils.py,sha256=q5hzAUVh7h8iVVH2s0M4E76zWqaMUDXULMn412mfHII,3893
84
- adam/commands/cql/cqlsh.py,sha256=mIoF8S33DAOFhkJrITRR4rkxFGVznD5hDb_Y-LsZA2w,2615
83
+ adam/commands/cql/cqlsh.py,sha256=qEQufaDVi9FXkvruum6OHQDfLX01DVWVDnWsAjyCZYQ,2661
85
84
  adam/commands/deploy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
86
85
  adam/commands/deploy/code_start.py,sha256=-iH8HThTNM83IfBxT_LqTByuHVatV9d-Il4OYOfrwLI,1370
87
86
  adam/commands/deploy/code_stop.py,sha256=ch7ZMgosvTHsGaIcDwQY5XYh_5HYrUjBkZFOI-d2gOU,1696
@@ -104,17 +103,17 @@ adam/commands/describe/describe_tables.py,sha256=vIs4lKz4nHBJumOlR4wBhR1QxXTFqzX
104
103
  adam/commands/medusa/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
105
104
  adam/commands/medusa/medusa.py,sha256=KNFjStvilIuOJt3wTtcWmKvdm8FdCnrDY2ltEWbratk,1402
106
105
  adam/commands/medusa/medusa_backup.py,sha256=j4DTVWFT-4rzs4gG_pBvjE-JuPsVCJIsnyQjIzJ4EbA,1801
107
- adam/commands/medusa/medusa_restore.py,sha256=MU47bmozrjfGJ6GVkj_OVgLH6Uz_fGh03MdLR4ZDKHE,3308
106
+ adam/commands/medusa/medusa_restore.py,sha256=GSjwsZYCqRA-XmJ1f6VELzX9cKXh5NDwxyBoGEiqUXY,3274
108
107
  adam/commands/medusa/medusa_show_backupjobs.py,sha256=QekHpKezVJdgfa9hOxfgyx-y4D08tmHzyu_AAa8QPR0,1756
109
108
  adam/commands/medusa/medusa_show_restorejobs.py,sha256=wgPonSmC6buDIp3k3WUY-Yu2MyP1xyE3Q_XhvAwpnx4,1651
110
109
  adam/commands/postgres/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
111
- adam/commands/postgres/pg_completions.py,sha256=GteenLhrBlRXMKQLSqM-6SmNZEFXY8wZ4CQWkz091OI,260
112
- adam/commands/postgres/pg_table_completer.py,sha256=f5YLFcmC2e1_sb_Kl5T5OZ6b8I-kjE5Lf4_BWH392qM,784
113
- adam/commands/postgres/postgres.py,sha256=A2mGzvyuCLFFTSKL74_RUcnJ0fI8wkkUukwmx2sF0as,3091
110
+ adam/commands/postgres/postgres.py,sha256=TiJwXGa4faPZ7DI8698SwgjnUXsIaVgG-R_-eXVPhwk,3142
114
111
  adam/commands/postgres/postgres_ls.py,sha256=HwZTgwGKXUqHX33S8aQPF6FqCrLqtoz4cLyJV2SpoE0,1186
115
112
  adam/commands/postgres/postgres_preview.py,sha256=MLzdEc4mvNj6V1Q8jO5OPznXyYELJHgd35_eQgLlNIU,1274
116
113
  adam/commands/postgres/postgres_session.py,sha256=RcqkCgtA78M-9LKTwG6pp8n9JwjmURXgf1FknIIPl9g,9305
117
114
  adam/commands/postgres/postgres_utils.py,sha256=mC5PZXrfxzqZt6n_HYASwe6Y-OyAK3QwEtDeVb_TKrA,877
115
+ adam/commands/postgres/psql_completions.py,sha256=huEvqYTjBk_3CY_Tu1dDeUlaNwPIMLagnv9QuSWCB5U,392
116
+ adam/commands/postgres/psql_table_completer.py,sha256=8-4flf-PEtQGOSjTdA_93ht1EoZGZ4-dAbrXtyVblS4,819
118
117
  adam/commands/reaper/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
119
118
  adam/commands/reaper/reaper.py,sha256=83R0ZRitEwaYKKssfKxn3zAzLnWIP9QKd1mA6awceS8,1908
120
119
  adam/commands/reaper/reaper_forward.py,sha256=mUp409MzT91cVXGxoPfBGceaR3qZ0rVdWKGdyzPNzSA,3177
@@ -164,6 +163,11 @@ adam/k8s_utils/service_accounts.py,sha256=v2oQSqCrNvt2uRnKlNwR3fjtpUG7oF5nqgzEB7
164
163
  adam/k8s_utils/services.py,sha256=EOJJGACVbbRvu5T3rMKqIJqgYic1_MSJ17EA0TJ6UOk,3156
165
164
  adam/k8s_utils/statefulsets.py,sha256=hiBOmJZ3KTI6_naAFzNoW1NoYnnBG35BZ7RMdPhNC6o,4664
166
165
  adam/k8s_utils/volumes.py,sha256=RIBmlOSWM3V3QVXLCFT0owVOyh4rGG1ETp521a-6ndo,1137
166
+ adam/sql/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
167
+ adam/sql/any_completer.py,sha256=hPnhqAyWIk1-gyZsna1X7AJ8po23cYR-MvYY-7iBn3w,3184
168
+ adam/sql/sql_completer.py,sha256=9JSZj-Rv5aag720xuQLgq9WlseLtPEAcQXx6OH-pFP8,2160
169
+ adam/sql/sql_utils.py,sha256=MLoxB9h22WZiANu0SZzmBJcY2gtb6f_D4jnoJEjLgPc,171
170
+ adam/sql/table_name_completer.py,sha256=n_vJbsfM4XYN0tCjov1l-4skFYO3xaLcyOVcZ77mteo,519
167
171
  adam/sso/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
168
172
  adam/sso/authenticator.py,sha256=BCm16L9zf5aLU47-sTCnudn2zLPwd8M2wwRminJfsqw,615
169
173
  adam/sso/authn_ad.py,sha256=fDW8UR3WWykny5Awa5dQjjBUSFzIDz4aMn-lwXoABl8,5857
@@ -174,8 +178,8 @@ adam/sso/idp.py,sha256=fvcwUw_URTgsO6ySaqTIw0zQT2qRO1IPSGhf6rPtybo,5804
174
178
  adam/sso/idp_login.py,sha256=QAtCUeDTVWliJy40RK_oac8Vgybr13xH8wzeBoxPaa8,1754
175
179
  adam/sso/idp_session.py,sha256=9BUHNRf70u4rVKrVY1HKPOEmOviXvkjam8WJxmXSKIM,1735
176
180
  adam/sso/sso_config.py,sha256=5N8WZgIJQBtHUy585XLRWKjpU87_v6QluyNK9E27D5s,2459
177
- kaqing-2.0.49.dist-info/METADATA,sha256=wtMivpLn3FjaPqvRL1TCEzPNjhNlB9SwDJNUH3Wb0CI,132
178
- kaqing-2.0.49.dist-info/WHEEL,sha256=tZoeGjtWxWRfdplE7E3d45VPlLNQnvbKiYnx7gwAy8A,92
179
- kaqing-2.0.49.dist-info/entry_points.txt,sha256=SkzhuQJUWsXOzHeZ5TgQ2c3_g53UGK23zzJU_JTZOZI,39
180
- kaqing-2.0.49.dist-info/top_level.txt,sha256=8_2PZkwBb-xDcnc8a2rAbQeJhXKXskc7zTP7pSPa1fw,5
181
- kaqing-2.0.49.dist-info/RECORD,,
181
+ kaqing-2.0.50.dist-info/METADATA,sha256=6cRmIvrJppOAGCWN23OkycCXqvwVuUh8CMOcImdjjxs,132
182
+ kaqing-2.0.50.dist-info/WHEEL,sha256=tZoeGjtWxWRfdplE7E3d45VPlLNQnvbKiYnx7gwAy8A,92
183
+ kaqing-2.0.50.dist-info/entry_points.txt,sha256=SkzhuQJUWsXOzHeZ5TgQ2c3_g53UGK23zzJU_JTZOZI,39
184
+ kaqing-2.0.50.dist-info/top_level.txt,sha256=8_2PZkwBb-xDcnc8a2rAbQeJhXKXskc7zTP7pSPa1fw,5
185
+ kaqing-2.0.50.dist-info/RECORD,,
@@ -1,9 +0,0 @@
1
- from adam.commands.postgres.pg_table_completer import PgTableCompleter
2
-
3
- def pg_completions(ns: str, pg_path: str):
4
- return {
5
- '\h': None,
6
- '\d': None,
7
- '\dt': None,
8
- '\du': None
9
- } | PgTableCompleter(ns, pg_path).completions()
@@ -1,18 +0,0 @@
1
- from adam.commands.postgres.postgres_utils import pg_table_names
2
- from adam.table_completer import NestedDict, TableCompleter
3
-
4
- class PgTableCompleter(TableCompleter):
5
- def __init__(self, namespace: str, pg_path: str, nested_dict: NestedDict = {}, ignore_case: bool = True):
6
- self.namespace = namespace
7
- self.pg_path = pg_path
8
- self.ignore_case = ignore_case
9
- self.append_nested_dict(nested_dict)
10
-
11
- def __repr__(self) -> str:
12
- return "PgTableCompleter(%r, pg_path=%r)" % (self.namespace, self.pg_path)
13
-
14
- def nested(self, data: NestedDict) -> 'TableCompleter':
15
- return PgTableCompleter(self.namespace, self.pg_path).append_nested_dict(data)
16
-
17
- def tables(self) -> list[str]:
18
- return pg_table_names(self.namespace, self.pg_path)