singlestoredb 1.7.0__cp38-abi3-macosx_10_9_universal2.whl → 1.7.2__cp38-abi3-macosx_10_9_universal2.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 singlestoredb might be problematic. Click here for more details.
- _singlestoredb_accel.abi3.so +0 -0
- singlestoredb/__init__.py +1 -1
- singlestoredb/apps/_cloud_functions.py +26 -6
- singlestoredb/apps/_config.py +46 -13
- singlestoredb/apps/_connection_info.py +10 -0
- singlestoredb/apps/_dashboards.py +25 -29
- singlestoredb/apps/_stdout_supress.py +30 -0
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/METADATA +1 -1
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/RECORD +13 -11
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/LICENSE +0 -0
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/WHEEL +0 -0
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/entry_points.txt +0 -0
- {singlestoredb-1.7.0.dist-info → singlestoredb-1.7.2.dist-info}/top_level.txt +0 -0
_singlestoredb_accel.abi3.so
CHANGED
|
Binary file
|
singlestoredb/__init__.py
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import asyncio
|
|
2
|
+
import textwrap
|
|
2
3
|
import typing
|
|
3
|
-
import urllib.parse
|
|
4
4
|
|
|
5
5
|
from ._config import AppConfig
|
|
6
|
+
from ._connection_info import ConnectionInfo
|
|
6
7
|
from ._process import kill_process_by_port
|
|
7
8
|
|
|
8
9
|
if typing.TYPE_CHECKING:
|
|
@@ -17,8 +18,7 @@ async def run_function_app(
|
|
|
17
18
|
app: 'FastAPI',
|
|
18
19
|
log_level: str = 'error',
|
|
19
20
|
kill_existing_app_server: bool = True,
|
|
20
|
-
) ->
|
|
21
|
-
|
|
21
|
+
) -> ConnectionInfo:
|
|
22
22
|
global _running_server
|
|
23
23
|
from ._uvicorn_util import AwaitableUvicornServer
|
|
24
24
|
|
|
@@ -52,8 +52,7 @@ async def run_function_app(
|
|
|
52
52
|
def ping() -> str:
|
|
53
53
|
return 'Success!'
|
|
54
54
|
|
|
55
|
-
|
|
56
|
-
app.root_path = base_path
|
|
55
|
+
app.root_path = app_config.base_path
|
|
57
56
|
|
|
58
57
|
config = uvicorn.Config(
|
|
59
58
|
app,
|
|
@@ -66,5 +65,26 @@ async def run_function_app(
|
|
|
66
65
|
asyncio.create_task(_running_server.serve())
|
|
67
66
|
await _running_server.wait_for_startup()
|
|
68
67
|
|
|
68
|
+
connection_info = ConnectionInfo(app_config.base_url, app_config.token)
|
|
69
|
+
|
|
69
70
|
if app_config.running_interactively:
|
|
70
|
-
|
|
71
|
+
if app_config.is_gateway_enabled:
|
|
72
|
+
print(
|
|
73
|
+
'Cloud function available at '
|
|
74
|
+
f'{app_config.base_url}docs?authToken={app_config.token}',
|
|
75
|
+
)
|
|
76
|
+
else:
|
|
77
|
+
curl_header = f'-H "Authorization: Bearer {app_config.token}"'
|
|
78
|
+
curl_example = f'curl "{app_config.base_url}" {curl_header}'
|
|
79
|
+
print(
|
|
80
|
+
textwrap.dedent(f"""
|
|
81
|
+
Cloud function available at {app_config.base_url}
|
|
82
|
+
|
|
83
|
+
Auth Token: {app_config.token}
|
|
84
|
+
|
|
85
|
+
Curl example: {curl_example}
|
|
86
|
+
|
|
87
|
+
""").strip(),
|
|
88
|
+
)
|
|
89
|
+
|
|
90
|
+
return connection_info
|
singlestoredb/apps/_config.py
CHANGED
|
@@ -1,33 +1,66 @@
|
|
|
1
1
|
import os
|
|
2
2
|
from dataclasses import dataclass
|
|
3
|
+
from typing import Optional
|
|
3
4
|
|
|
4
5
|
|
|
5
6
|
@dataclass
|
|
6
7
|
class AppConfig:
|
|
7
8
|
listen_port: int
|
|
8
|
-
|
|
9
|
+
base_url: str
|
|
10
|
+
base_path: str
|
|
11
|
+
app_token: Optional[str]
|
|
12
|
+
user_token: Optional[str]
|
|
9
13
|
running_interactively: bool
|
|
14
|
+
is_gateway_enabled: bool
|
|
10
15
|
|
|
11
|
-
@
|
|
12
|
-
def
|
|
13
|
-
|
|
14
|
-
if
|
|
15
|
-
raise RuntimeError(
|
|
16
|
-
'Missing SINGLESTOREDB_APP_LISTEN_PORT environment variable. '
|
|
17
|
-
'Is the code running outside SingleStoreDB notebook environment?',
|
|
18
|
-
)
|
|
19
|
-
url = os.environ.get('SINGLESTOREDB_APP_URL')
|
|
20
|
-
if url is None:
|
|
16
|
+
@staticmethod
|
|
17
|
+
def _read_variable(name: str) -> str:
|
|
18
|
+
value = os.environ.get(name)
|
|
19
|
+
if value is None:
|
|
21
20
|
raise RuntimeError(
|
|
22
|
-
'Missing
|
|
21
|
+
f'Missing {name} environment variable. '
|
|
23
22
|
'Is the code running outside SingleStoreDB notebook environment?',
|
|
24
23
|
)
|
|
24
|
+
return value
|
|
25
|
+
|
|
26
|
+
@classmethod
|
|
27
|
+
def from_env(cls) -> 'AppConfig':
|
|
28
|
+
port = cls._read_variable('SINGLESTOREDB_APP_LISTEN_PORT')
|
|
29
|
+
base_url = cls._read_variable('SINGLESTOREDB_APP_BASE_URL')
|
|
30
|
+
base_path = cls._read_variable('SINGLESTOREDB_APP_BASE_PATH')
|
|
25
31
|
|
|
26
32
|
workload_type = os.environ.get('SINGLESTOREDB_WORKLOAD_TYPE')
|
|
27
33
|
running_interactively = workload_type == 'InteractiveNotebook'
|
|
28
34
|
|
|
35
|
+
is_gateway_enabled = 'SINGLESTOREDB_NOVA_GATEWAY_ENDPOINT' in os.environ
|
|
36
|
+
|
|
37
|
+
app_token = os.environ.get('SINGLESTOREDB_APP_TOKEN')
|
|
38
|
+
user_token = os.environ.get('SINGLESTOREDB_USER_TOKEN')
|
|
39
|
+
|
|
40
|
+
# Make sure the required variables are present
|
|
41
|
+
# and present useful error message if not
|
|
42
|
+
if running_interactively:
|
|
43
|
+
if is_gateway_enabled:
|
|
44
|
+
app_token = cls._read_variable('SINGLESTOREDB_APP_TOKEN')
|
|
45
|
+
else:
|
|
46
|
+
user_token = cls._read_variable('SINGLESTOREDB_USER_TOKEN')
|
|
47
|
+
|
|
29
48
|
return cls(
|
|
30
49
|
listen_port=int(port),
|
|
31
|
-
|
|
50
|
+
base_url=base_url,
|
|
51
|
+
base_path=base_path,
|
|
52
|
+
app_token=app_token,
|
|
53
|
+
user_token=user_token,
|
|
32
54
|
running_interactively=running_interactively,
|
|
55
|
+
is_gateway_enabled=is_gateway_enabled,
|
|
33
56
|
)
|
|
57
|
+
|
|
58
|
+
@property
|
|
59
|
+
def token(self) -> Optional[str]:
|
|
60
|
+
"""
|
|
61
|
+
Returns None if running non-interactively
|
|
62
|
+
"""
|
|
63
|
+
if self.is_gateway_enabled:
|
|
64
|
+
return self.app_token
|
|
65
|
+
else:
|
|
66
|
+
return self.user_token
|
|
@@ -1,51 +1,47 @@
|
|
|
1
1
|
import typing
|
|
2
|
-
import urllib.parse
|
|
3
2
|
|
|
4
3
|
from ._config import AppConfig
|
|
5
4
|
from ._process import kill_process_by_port
|
|
5
|
+
from ._stdout_supress import StdoutSuppressor
|
|
6
|
+
from singlestoredb.apps._connection_info import ConnectionInfo
|
|
6
7
|
|
|
7
8
|
if typing.TYPE_CHECKING:
|
|
8
|
-
from
|
|
9
|
+
from dash import Dash
|
|
9
10
|
|
|
10
11
|
|
|
11
|
-
def run_dashboard_app(
|
|
12
|
-
|
|
12
|
+
async def run_dashboard_app(
|
|
13
|
+
app: 'Dash',
|
|
13
14
|
debug: bool = False,
|
|
14
15
|
kill_existing_app_server: bool = True,
|
|
15
|
-
) ->
|
|
16
|
+
) -> ConnectionInfo:
|
|
16
17
|
try:
|
|
17
|
-
import
|
|
18
|
+
from dash import Dash
|
|
18
19
|
except ImportError:
|
|
19
20
|
raise ImportError('package dash is required to run dashboards')
|
|
20
21
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
except ImportError:
|
|
24
|
-
raise ImportError('package dash is required to run dashboards')
|
|
25
|
-
|
|
26
|
-
if not isinstance(figure, Figure):
|
|
27
|
-
raise TypeError('figure is not an instance of plotly Figure')
|
|
22
|
+
if not isinstance(app, Dash):
|
|
23
|
+
raise TypeError('app is not an instance of Dash App')
|
|
28
24
|
|
|
29
25
|
app_config = AppConfig.from_env()
|
|
30
26
|
|
|
31
27
|
if kill_existing_app_server:
|
|
32
28
|
kill_process_by_port(app_config.listen_port)
|
|
33
29
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
)
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
)
|
|
30
|
+
if app.config.requests_pathname_prefix is None or \
|
|
31
|
+
app.config.requests_pathname_prefix != app_config.base_path:
|
|
32
|
+
raise RuntimeError('''
|
|
33
|
+
requests_pathname_prefix of the Dash App is invalid. Please set
|
|
34
|
+
requests_pathname_prefix=os.environ['SINGLESTOREDB_APP_BASE_PATH']
|
|
35
|
+
while initializing the Dash App and retry''')
|
|
36
|
+
|
|
37
|
+
with StdoutSuppressor():
|
|
38
|
+
app.run(
|
|
39
|
+
host='0.0.0.0',
|
|
40
|
+
debug=debug,
|
|
41
|
+
port=str(app_config.listen_port),
|
|
42
|
+
jupyter_mode='external',
|
|
43
|
+
)
|
|
49
44
|
|
|
50
45
|
if app_config.running_interactively:
|
|
51
|
-
print(f'Dash app available at {app_config.
|
|
46
|
+
print(f'Dash app available at {app_config.base_url}?authToken={app_config.token}')
|
|
47
|
+
return ConnectionInfo(app_config.base_url, app_config.token)
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import io
|
|
2
|
+
import sys
|
|
3
|
+
from typing import Optional
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class StdoutSuppressor:
|
|
7
|
+
"""
|
|
8
|
+
Supresses the stdout for code executed within the context.
|
|
9
|
+
This should not be used for asynchronous or threaded executions.
|
|
10
|
+
|
|
11
|
+
```py
|
|
12
|
+
with Supressor():
|
|
13
|
+
print("This won't be printed")
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
"""
|
|
17
|
+
|
|
18
|
+
def __enter__(self) -> None:
|
|
19
|
+
self.stdout = sys.stdout
|
|
20
|
+
self.buffer = io.StringIO()
|
|
21
|
+
sys.stdout = self.buffer
|
|
22
|
+
|
|
23
|
+
def __exit__(
|
|
24
|
+
self,
|
|
25
|
+
exc_type: Optional[object],
|
|
26
|
+
exc_value: Optional[Exception],
|
|
27
|
+
exc_traceback: Optional[str],
|
|
28
|
+
) -> None:
|
|
29
|
+
del self.buffer
|
|
30
|
+
sys.stdout = self.stdout
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
_singlestoredb_accel.abi3.so,sha256=
|
|
2
|
-
singlestoredb-1.7.
|
|
3
|
-
singlestoredb-1.7.
|
|
4
|
-
singlestoredb-1.7.
|
|
5
|
-
singlestoredb-1.7.
|
|
6
|
-
singlestoredb-1.7.
|
|
7
|
-
singlestoredb-1.7.
|
|
1
|
+
_singlestoredb_accel.abi3.so,sha256=jjAGCvt-P8Qfp6RgPMQT1hsiClTbYyLJgua3Kfq1KsI,206633
|
|
2
|
+
singlestoredb-1.7.2.dist-info/RECORD,,
|
|
3
|
+
singlestoredb-1.7.2.dist-info/LICENSE,sha256=Mlq78idURT-9G026aMYswwwnnrLcgzTLuXeAs5hjDLM,11341
|
|
4
|
+
singlestoredb-1.7.2.dist-info/WHEEL,sha256=_VEguvlLpUd-c8RbFMA4yMIVNMBv2LhpxYLCEQ-Bogk,113
|
|
5
|
+
singlestoredb-1.7.2.dist-info/entry_points.txt,sha256=bSLaTWB5zGjpVYPAaI46MkkDup0su-eb3uAhCNYuRV0,48
|
|
6
|
+
singlestoredb-1.7.2.dist-info/top_level.txt,sha256=SDtemIXf-Kp-_F2f_S6x0db33cHGOILdAEsIQZe2LZc,35
|
|
7
|
+
singlestoredb-1.7.2.dist-info/METADATA,sha256=bqqIW18aA4flY_DhtxVKPVYGbVTUJPNXzpxoxSfrZYE,5570
|
|
8
8
|
singlestoredb/auth.py,sha256=u8D9tpKzrqa4ssaHjyZnGDX1q8XBpGtuoOkTkSv7B28,7599
|
|
9
9
|
singlestoredb/config.py,sha256=NtONv4Etpraoy1nenHqRAS08xHJZmho00J95uDjLxQM,12290
|
|
10
|
-
singlestoredb/__init__.py,sha256=
|
|
10
|
+
singlestoredb/__init__.py,sha256=UjufrohnvC56tM8JigZbe1K0NDetQIji_savOS-HmXc,1634
|
|
11
11
|
singlestoredb/types.py,sha256=FIqO1A7e0Gkk7ITmIysBy-P5S--ItbMSlYvblzqGS30,9969
|
|
12
12
|
singlestoredb/connection.py,sha256=x5lINBa9kB_GoEEeL2uUZi9G8pNwKuFtA1uqJirR6HI,45352
|
|
13
13
|
singlestoredb/pytest.py,sha256=OyF3BO9mgxenifYhOihnzGk8WzCJ_zN5_mxe8XyFPOc,9074
|
|
@@ -122,10 +122,12 @@ singlestoredb/functions/ext/rowdat_1.py,sha256=JgKRsVSQYczFD6cmo2xLilbNPYpyLL2tP
|
|
|
122
122
|
singlestoredb/notebook/__init__.py,sha256=v0j1E3MFAtaC8wTrR-F7XY0nytUvQ4XpYhVXddv2xA0,533
|
|
123
123
|
singlestoredb/notebook/_objects.py,sha256=MkB1eowEq5SQXFHY00xAKAyyeLqHu_uaZiA20BCJPaE,8043
|
|
124
124
|
singlestoredb/notebook/_portal.py,sha256=DLerIEQmAUymtYcx8RBeuYJ4pJSy_xl1K6t1Oc-eTf8,9698
|
|
125
|
-
singlestoredb/apps/_dashboards.py,sha256=
|
|
125
|
+
singlestoredb/apps/_dashboards.py,sha256=_03fI-GJannamA5lxLvIoC6Mim-H1jTRuI8-dw_P--k,1474
|
|
126
126
|
singlestoredb/apps/__init__.py,sha256=uuEH2WZ1ROpmkMBBdz1tSkQSdYR9blXXU2nn7E5P4qQ,118
|
|
127
|
-
singlestoredb/apps/_cloud_functions.py,sha256=
|
|
127
|
+
singlestoredb/apps/_cloud_functions.py,sha256=NJJu0uJsK9TjY3yZjgftpFPR-ga-FrOyaiDD4jWFCtE,2704
|
|
128
128
|
singlestoredb/apps/_uvicorn_util.py,sha256=rEK4nEmq5hbpRgsmK16UVlxe2DyQSq7C5w5WZSp0kX8,962
|
|
129
129
|
singlestoredb/apps/_process.py,sha256=G37fk6bzIxzhfEqp2aJBk3JCij-T2HFtTd078k5Xq9I,944
|
|
130
|
-
singlestoredb/apps/
|
|
130
|
+
singlestoredb/apps/_stdout_supress.py,sha256=8s9zMIIRPpeu44yluJFc_0VueAxZDmr9QVGT6TGiFeY,659
|
|
131
|
+
singlestoredb/apps/_config.py,sha256=w21kH0jMJ0_cP_VgAxHhKiLW5Iyrr7xzUIxRmfe_fqs,2118
|
|
132
|
+
singlestoredb/apps/_connection_info.py,sha256=gQPYzJrBQUEH76zVTkxJ7FAypNoN2T7GYHVOSgJ7Q8Q,175
|
|
131
133
|
singlestoredb/alchemy/__init__.py,sha256=dXRThusYrs_9GjrhPOw0-vw94in_T8yY9jE7SGCqiQk,2523
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|