tinybird 0.0.1.dev89__py3-none-any.whl → 0.0.1.dev91__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.

Potentially problematic release.


This version of tinybird might be problematic. Click here for more details.

tinybird/client.py CHANGED
@@ -288,6 +288,25 @@ class TinyB:
288
288
  ds = [x for x in ds if x["name"].startswith(branch)]
289
289
  return ds
290
290
 
291
+ async def secrets(self) -> List[Dict[str, Any]]:
292
+ response = await self._req("/v0/variables")
293
+ return response["variables"]
294
+
295
+ async def get_secret(self, name: str) -> Optional[Dict[str, Any]]:
296
+ return await self._req(f"/v0/variables/{name}")
297
+
298
+ async def create_secret(self, name: str, value: str):
299
+ response = await self._req("/v0/variables", method="POST", data={"name": name, "value": value})
300
+ return response
301
+
302
+ async def update_secret(self, name: str, value: str):
303
+ response = await self._req(f"/v0/variables/{name}", method="PUT", data={"value": value})
304
+ return response
305
+
306
+ async def delete_secret(self, name: str):
307
+ response = await self._req(f"/v0/variables/{name}", method="DELETE")
308
+ return response
309
+
291
310
  async def get_connections(self, service: Optional[str] = None):
292
311
  params = {}
293
312
 
tinybird/tb/__cli__.py CHANGED
@@ -4,5 +4,5 @@ __description__ = 'Tinybird Command Line Tool'
4
4
  __url__ = 'https://www.tinybird.co/docs/cli/introduction.html'
5
5
  __author__ = 'Tinybird'
6
6
  __author_email__ = 'support@tinybird.co'
7
- __version__ = '0.0.1.dev89'
8
- __revision__ = '6153af6'
7
+ __version__ = '0.0.1.dev91'
8
+ __revision__ = 'b965ddf'
tinybird/tb/cli.py CHANGED
@@ -8,6 +8,7 @@ import tinybird.tb.modules.auth
8
8
  import tinybird.tb.modules.build
9
9
  import tinybird.tb.modules.cli
10
10
  import tinybird.tb.modules.common
11
+ import tinybird.tb.modules.connection
11
12
  import tinybird.tb.modules.copy
12
13
  import tinybird.tb.modules.create
13
14
  import tinybird.tb.modules.datasource
@@ -22,6 +23,7 @@ import tinybird.tb.modules.materialization
22
23
  import tinybird.tb.modules.mock
23
24
  import tinybird.tb.modules.pipe
24
25
  import tinybird.tb.modules.playground
26
+ import tinybird.tb.modules.secret
25
27
  import tinybird.tb.modules.tag
26
28
  import tinybird.tb.modules.test
27
29
  import tinybird.tb.modules.token
@@ -412,7 +412,7 @@ async def create_ctx_client(ctx: Context, config: Dict[str, Any], cloud: bool, b
412
412
  return _get_tb_client(config.get("token", None), config["host"], staging=staging)
413
413
  build = command in commands_always_build or build
414
414
  if not build and command not in commands_always_local and command not in commands_always_build:
415
- click.echo(FeedbackManager.gray(message="Running against Tinybird Local\n"))
415
+ click.echo(FeedbackManager.gray(message="Running against Tinybird Local"))
416
416
  return await get_tinybird_local_client(config, build=build, staging=staging)
417
417
 
418
418
 
@@ -0,0 +1,125 @@
1
+ # This is a command file for our CLI. Please keep it clean.
2
+ #
3
+ # - If it makes sense and only when strictly necessary, you can create utility functions in this file.
4
+ # - But please, **do not** interleave utility functions and command definitions.
5
+
6
+ from typing import Any, Dict, List, Optional
7
+
8
+ import click
9
+ from click import Context
10
+
11
+ from tinybird.client import TinyB
12
+ from tinybird.tb.modules.cli import cli
13
+ from tinybird.tb.modules.common import (
14
+ DataConnectorType,
15
+ _get_setting_value,
16
+ coro,
17
+ echo_safe_humanfriendly_tables_format_smart_table,
18
+ )
19
+ from tinybird.tb.modules.feedback_manager import FeedbackManager
20
+
21
+ DATA_CONNECTOR_SETTINGS: Dict[DataConnectorType, List[str]] = {
22
+ DataConnectorType.KAFKA: [
23
+ "kafka_bootstrap_servers",
24
+ "kafka_sasl_plain_username",
25
+ "kafka_sasl_plain_password",
26
+ "cli_version",
27
+ "endpoint",
28
+ "kafka_security_protocol",
29
+ "kafka_sasl_mechanism",
30
+ "kafka_schema_registry_url",
31
+ "kafka_ssl_ca_pem",
32
+ ],
33
+ DataConnectorType.GCLOUD_SCHEDULER: ["gcscheduler_region"],
34
+ DataConnectorType.SNOWFLAKE: [
35
+ "account",
36
+ "username",
37
+ "password",
38
+ "role",
39
+ "warehouse",
40
+ "warehouse_size",
41
+ "stage",
42
+ "integration",
43
+ ],
44
+ DataConnectorType.BIGQUERY: ["account"],
45
+ DataConnectorType.GCLOUD_STORAGE: [
46
+ "gcs_private_key_id",
47
+ "gcs_client_x509_cert_url",
48
+ "gcs_project_id",
49
+ "gcs_client_id",
50
+ "gcs_client_email",
51
+ "gcs_private_key",
52
+ ],
53
+ DataConnectorType.GCLOUD_STORAGE_HMAC: [
54
+ "gcs_hmac_access_id",
55
+ "gcs_hmac_secret",
56
+ ],
57
+ DataConnectorType.GCLOUD_STORAGE_SA: ["account_email"],
58
+ DataConnectorType.AMAZON_S3: [
59
+ "s3_access_key_id",
60
+ "s3_secret_access_key",
61
+ "s3_region",
62
+ ],
63
+ DataConnectorType.AMAZON_S3_IAMROLE: [
64
+ "s3_iamrole_arn",
65
+ "s3_iamrole_region",
66
+ "s3_iamrole_external_id",
67
+ ],
68
+ DataConnectorType.AMAZON_DYNAMODB: [
69
+ "dynamodb_iamrole_arn",
70
+ "dynamodb_iamrole_region",
71
+ "dynamodb_iamrole_external_id",
72
+ ],
73
+ }
74
+
75
+ SENSITIVE_CONNECTOR_SETTINGS = {
76
+ DataConnectorType.KAFKA: ["kafka_sasl_plain_password"],
77
+ DataConnectorType.GCLOUD_SCHEDULER: [
78
+ "gcscheduler_target_url",
79
+ "gcscheduler_job_name",
80
+ "gcscheduler_region",
81
+ ],
82
+ DataConnectorType.GCLOUD_STORAGE_HMAC: ["gcs_hmac_secret"],
83
+ DataConnectorType.AMAZON_S3: ["s3_secret_access_key"],
84
+ DataConnectorType.AMAZON_S3_IAMROLE: ["s3_iamrole_arn"],
85
+ DataConnectorType.AMAZON_DYNAMODB: ["dynamodb_iamrole_arn"],
86
+ }
87
+
88
+
89
+ @cli.group()
90
+ @click.pass_context
91
+ def connection(ctx: Context) -> None:
92
+ """Connection commands."""
93
+
94
+
95
+ @connection.command(name="ls")
96
+ @click.option("--service", help="Filter by service")
97
+ @click.pass_context
98
+ @coro
99
+ async def connection_ls(ctx: Context, service: Optional[DataConnectorType] = None) -> None:
100
+ """List connections."""
101
+ obj: Dict[str, Any] = ctx.ensure_object(dict)
102
+ client: TinyB = obj["client"]
103
+
104
+ connections = await client.connections(connector=service, skip_bigquery=True)
105
+ columns = []
106
+ table = []
107
+
108
+ click.echo(FeedbackManager.info_connections())
109
+
110
+ if not service:
111
+ sensitive_settings = []
112
+ columns = ["service", "name", "id", "connected_datasources"]
113
+ else:
114
+ sensitive_settings = SENSITIVE_CONNECTOR_SETTINGS.get(service, [])
115
+ columns = ["service", "name", "id", "connected_datasources"]
116
+ if connector_settings := DATA_CONNECTOR_SETTINGS.get(service):
117
+ columns += connector_settings
118
+
119
+ for connection in connections:
120
+ row = [_get_setting_value(connection, setting, sensitive_settings) for setting in columns]
121
+ table.append(row)
122
+
123
+ column_names = [c.replace("kafka_", "") for c in columns]
124
+ echo_safe_humanfriendly_tables_format_smart_table(table, column_names=column_names)
125
+ click.echo("\n")
@@ -0,0 +1,85 @@
1
+ import re
2
+ from typing import Optional
3
+
4
+ import click
5
+
6
+ from tinybird.client import TinyB
7
+ from tinybird.tb.modules.cli import cli
8
+ from tinybird.tb.modules.common import coro, echo_safe_humanfriendly_tables_format_smart_table
9
+ from tinybird.tb.modules.feedback_manager import FeedbackManager
10
+
11
+
12
+ @cli.group()
13
+ @click.pass_context
14
+ def secret(ctx):
15
+ """Secret commands."""
16
+
17
+
18
+ @secret.command(name="ls")
19
+ @click.option("--match", default=None, help="Retrieve any secrets matching the pattern. For example, --match _test")
20
+ @click.pass_context
21
+ @coro
22
+ async def secret_ls(ctx: click.Context, match: Optional[str]):
23
+ """List secrets"""
24
+
25
+ client: TinyB = ctx.ensure_object(dict)["client"]
26
+ secrets = await client.secrets()
27
+ columns = ["name", "created_at", "updated_at"]
28
+ table_human_readable = []
29
+ table_machine_readable = []
30
+ pattern = re.compile(match) if match else None
31
+
32
+ for secret in secrets:
33
+ name = secret["name"]
34
+
35
+ if pattern and not pattern.search(name):
36
+ continue
37
+
38
+ created_at = secret["created_at"]
39
+ updated_at = secret["updated_at"]
40
+
41
+ table_human_readable.append((name, created_at, updated_at))
42
+ table_machine_readable.append({"name": name, "created at": created_at, "updated at": updated_at})
43
+
44
+ click.echo(FeedbackManager.info(message="** Secrets:"))
45
+ echo_safe_humanfriendly_tables_format_smart_table(table_human_readable, column_names=columns)
46
+ click.echo("\n")
47
+
48
+
49
+ @secret.command(name="set")
50
+ @click.argument("name")
51
+ @click.argument("value")
52
+ @click.pass_context
53
+ @coro
54
+ async def secret_set(ctx: click.Context, name: str, value: str):
55
+ """Create or update secrets"""
56
+ try:
57
+ click.echo(FeedbackManager.highlight(message=f"\n» Setting secret '{name}'..."))
58
+ client: TinyB = ctx.ensure_object(dict)["client"]
59
+ existing_secret = None
60
+ try:
61
+ existing_secret = await client.get_secret(name)
62
+ except Exception:
63
+ pass
64
+ if existing_secret:
65
+ await client.update_secret(name, value)
66
+ else:
67
+ await client.create_secret(name, value)
68
+ click.echo(FeedbackManager.success(message=f"\n✓ Secret '{name}' set"))
69
+ except Exception as e:
70
+ click.echo(FeedbackManager.error(message=f"✗ Error: {e}"))
71
+
72
+
73
+ @secret.command(name="rm")
74
+ @click.argument("name")
75
+ @click.pass_context
76
+ @coro
77
+ async def secret_rm(ctx: click.Context, name: str):
78
+ """Delete a secret"""
79
+ try:
80
+ click.echo(FeedbackManager.highlight(message=f"\n» Deleting secret '{name}'..."))
81
+ client: TinyB = ctx.ensure_object(dict)["client"]
82
+ await client.delete_secret(name)
83
+ click.echo(FeedbackManager.success(message=f"\n✓ Secret '{name}' deleted"))
84
+ except Exception as e:
85
+ click.echo(FeedbackManager.error(message=f"✗ Error: {e}"))
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: tinybird
3
- Version: 0.0.1.dev89
3
+ Version: 0.0.1.dev91
4
4
  Summary: Tinybird Command Line Tool
5
5
  Home-page: https://www.tinybird.co/docs/cli/introduction.html
6
6
  Author: Tinybird
@@ -1,5 +1,5 @@
1
1
  tinybird/__cli__.py,sha256=esPl5QDTzuQgHe5FuxWLm-fURFigGGwjnYLh9GuWUw4,232
2
- tinybird/client.py,sha256=Ng4HQHum6ezf7nRZ61PbEOhYvEEPadmXKDYu2SGaL0c,53393
2
+ tinybird/client.py,sha256=B6FaylxfcalxJTjiMgaS1Iyn9aBRsDaphwhC5VKeK6M,54179
3
3
  tinybird/config.py,sha256=5UP_UZ2Qtlm5aOH5W7SbtN8r7X-8u3-r853joKqU5zs,6072
4
4
  tinybird/connectors.py,sha256=7Gjms7b5MAaBFGi3xytsJurCylprONpFcYrzp4Fw2Rc,15241
5
5
  tinybird/context.py,sha256=FfqYfrGX_I7PKGTQo93utaKPDNVYWelg4Hsp3evX5wM,1291
@@ -15,14 +15,15 @@ tinybird/syncasync.py,sha256=IPnOx6lMbf9SNddN1eBtssg8vCLHMt76SuZ6YNYm-Yk,27761
15
15
  tinybird/tornado_template.py,sha256=jjNVDMnkYFWXflmT8KU_Ssbo5vR8KQq3EJMk5vYgXRw,41959
16
16
  tinybird/ch_utils/constants.py,sha256=aYvg2C_WxYWsnqPdZB1ZFoIr8ZY-XjUXYyHKE9Ansj0,3890
17
17
  tinybird/ch_utils/engine.py,sha256=BZuPM7MFS7vaEKK5tOMR2bwSAgJudPrJt27uVEwZmTY,40512
18
- tinybird/tb/__cli__.py,sha256=xWmtpX_BrBWY-ALVqm-M8PCmUyEnwSYABEqNIkELu8M,251
19
- tinybird/tb/cli.py,sha256=qon0Lim-v5hHWWRW7TXaOoGo3p2kc5Xwgg3feI4mbMQ,998
18
+ tinybird/tb/__cli__.py,sha256=T_ssIbV6pifxlCyF-t9ua_F2d_5mle0hocUCAZm8PNY,251
19
+ tinybird/tb/cli.py,sha256=SSXALqjtPShcQbgvT1u7up2YL0ls36wXABX0hZwebdQ,1070
20
20
  tinybird/tb/modules/auth.py,sha256=L1IatO2arRSzys3t8px8xVt8uPWUL5EVD0sFzAV_uVU,9022
21
21
  tinybird/tb/modules/build.py,sha256=-lRGBxKtuipmyl3pmiGcfp67fH1Ed-COfHAZKdgLIWo,10483
22
22
  tinybird/tb/modules/cicd.py,sha256=T0lb9u_bDdTUVe8TwNNb1qQ5KnSPHMVjqPfKF4BBNBw,5347
23
- tinybird/tb/modules/cli.py,sha256=rE-0PtttuXvigKP1BkdgolP833pEhe-daK6l86bnaEw,16468
23
+ tinybird/tb/modules/cli.py,sha256=atBf86g3mgXi9L7wy3YtovvdFk8QXfjneUP08NvY_jk,16466
24
24
  tinybird/tb/modules/common.py,sha256=xWdxukkqTdK0YFHSUYxHx8_cJO165h2hdrE75aLHa7g,80383
25
25
  tinybird/tb/modules/config.py,sha256=BVZg-4f_R3vJTwCChXY2AXaH67SRk62xoP_IymquosI,11404
26
+ tinybird/tb/modules/connection.py,sha256=WKeDxbTpSsQ1PUmsT730g3S5RT2PtR5mPpVEanD1nbM,3933
26
27
  tinybird/tb/modules/copy.py,sha256=MAVqKip8_QhOYq99U_XuqSO6hCLJEh5sFtbhcXtI3SI,5802
27
28
  tinybird/tb/modules/create.py,sha256=KjotVfIQLfcPyQBykTHnPLn4ikrm6qqeMcbRE1d-6Jo,13280
28
29
  tinybird/tb/modules/datasource.py,sha256=dNCK9iCR2xPLfwqqwg2ixyE6NuoVEiJU2mBZBmOYrVY,16906
@@ -44,6 +45,7 @@ tinybird/tb/modules/pipe.py,sha256=gcLz0qHgwKDLsWFY3yFLO9a0ETAV1dFbI8YeLHi9460,2
44
45
  tinybird/tb/modules/playground.py,sha256=CQaz2JqFDdReK2fJY1yZsSwiSY24_jeTb9PKw1WUigA,4848
45
46
  tinybird/tb/modules/project.py,sha256=ei0TIAuRksdV2g2FJqByuV4DPyivQGrZ42z_eQDNBgI,2963
46
47
  tinybird/tb/modules/regions.py,sha256=QjsL5H6Kg-qr0aYVLrvb1STeJ5Sx_sjvbOYO0LrEGMk,166
48
+ tinybird/tb/modules/secret.py,sha256=xxzfKxfFN7GORib1WslCaFDHt_dgnjmfOewyptPU_VM,2820
47
49
  tinybird/tb/modules/shell.py,sha256=a98W4L4gfrmxEyybtu6S4ENXrBYtgNASB5e_evuXQvI,13936
48
50
  tinybird/tb/modules/table.py,sha256=4XrtjM-N0zfNtxVkbvLDQQazno1EPXnxTyo7llivfXk,11035
49
51
  tinybird/tb/modules/tag.py,sha256=anPmMUBc-TbFovlpFi8GPkKA18y7Y0GczMsMms5TZsU,3502
@@ -77,8 +79,8 @@ tinybird/tb_cli_modules/config.py,sha256=IsgdtFRnUrkY8-Zo32lmk6O7u3bHie1QCxLwgp4
77
79
  tinybird/tb_cli_modules/exceptions.py,sha256=pmucP4kTF4irIt7dXiG-FcnI-o3mvDusPmch1L8RCWk,3367
78
80
  tinybird/tb_cli_modules/regions.py,sha256=QjsL5H6Kg-qr0aYVLrvb1STeJ5Sx_sjvbOYO0LrEGMk,166
79
81
  tinybird/tb_cli_modules/telemetry.py,sha256=Hh2Io8ZPROSunbOLuMvuIFU4TqwWPmQTqal4WS09K1A,10449
80
- tinybird-0.0.1.dev89.dist-info/METADATA,sha256=pKJ86pTylK2iqAqdOcWyaaApey6C8eiBM_NpLv-ZzWA,2585
81
- tinybird-0.0.1.dev89.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
82
- tinybird-0.0.1.dev89.dist-info/entry_points.txt,sha256=LwdHU6TfKx4Qs7BqqtaczEZbImgU7Abe9Lp920zb_fo,43
83
- tinybird-0.0.1.dev89.dist-info/top_level.txt,sha256=VqqqEmkAy7UNaD8-V51FCoMMWXjLUlR0IstvK7tJYVY,54
84
- tinybird-0.0.1.dev89.dist-info/RECORD,,
82
+ tinybird-0.0.1.dev91.dist-info/METADATA,sha256=iN68_RO9ZH5bntib_gq07U3hcPtPv206bagyLYciECw,2585
83
+ tinybird-0.0.1.dev91.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
84
+ tinybird-0.0.1.dev91.dist-info/entry_points.txt,sha256=LwdHU6TfKx4Qs7BqqtaczEZbImgU7Abe9Lp920zb_fo,43
85
+ tinybird-0.0.1.dev91.dist-info/top_level.txt,sha256=VqqqEmkAy7UNaD8-V51FCoMMWXjLUlR0IstvK7tJYVY,54
86
+ tinybird-0.0.1.dev91.dist-info/RECORD,,