scalebox-sdk 0.1.24__py3-none-any.whl → 1.0.1__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.
Files changed (87) hide show
  1. scalebox/__init__.py +2 -2
  2. scalebox/api/__init__.py +130 -128
  3. scalebox/api/client/__init__.py +8 -8
  4. scalebox/api/client/api/sandboxes/get_sandboxes_sandbox_id_metrics.py +2 -2
  5. scalebox/api/client/api/sandboxes/post_sandboxes.py +2 -2
  6. scalebox/api/client/api/sandboxes/post_sandboxes_sandbox_id_connect.py +193 -0
  7. scalebox/api/client/client.py +288 -288
  8. scalebox/api/client/models/connect_sandbox.py +59 -0
  9. scalebox/api/client/models/error.py +2 -2
  10. scalebox/api/client/models/listed_sandbox.py +19 -1
  11. scalebox/api/client/models/new_sandbox.py +10 -0
  12. scalebox/api/client/models/sandbox.py +138 -125
  13. scalebox/api/client/models/sandbox_detail.py +24 -0
  14. scalebox/api/client/types.py +46 -46
  15. scalebox/cli.py +125 -125
  16. scalebox/client/aclient.py +57 -57
  17. scalebox/client/client.py +102 -102
  18. scalebox/code_interpreter/__init__.py +12 -12
  19. scalebox/code_interpreter/charts.py +230 -230
  20. scalebox/code_interpreter/constants.py +3 -3
  21. scalebox/code_interpreter/exceptions.py +13 -13
  22. scalebox/code_interpreter/models.py +485 -485
  23. scalebox/connection_config.py +34 -1
  24. scalebox/csx_connect/__init__.py +1 -1
  25. scalebox/csx_connect/client.py +485 -485
  26. scalebox/csx_desktop/main.py +651 -651
  27. scalebox/exceptions.py +83 -83
  28. scalebox/generated/api.py +61 -61
  29. scalebox/generated/api_pb2.py +203 -203
  30. scalebox/generated/api_pb2.pyi +956 -956
  31. scalebox/generated/api_pb2_connect.py +1407 -1407
  32. scalebox/generated/rpc.py +50 -50
  33. scalebox/sandbox/main.py +146 -139
  34. scalebox/sandbox/sandbox_api.py +105 -91
  35. scalebox/sandbox/signature.py +40 -40
  36. scalebox/sandbox/utils.py +34 -34
  37. scalebox/sandbox_async/commands/command.py +307 -307
  38. scalebox/sandbox_async/commands/command_handle.py +187 -187
  39. scalebox/sandbox_async/commands/pty.py +187 -187
  40. scalebox/sandbox_async/filesystem/filesystem.py +557 -557
  41. scalebox/sandbox_async/filesystem/watch_handle.py +61 -61
  42. scalebox/sandbox_async/main.py +228 -46
  43. scalebox/sandbox_async/sandbox_api.py +124 -3
  44. scalebox/sandbox_async/utils.py +7 -7
  45. scalebox/sandbox_sync/__init__.py +2 -2
  46. scalebox/sandbox_sync/commands/command.py +300 -300
  47. scalebox/sandbox_sync/commands/command_handle.py +150 -150
  48. scalebox/sandbox_sync/commands/pty.py +181 -181
  49. scalebox/sandbox_sync/filesystem/filesystem.py +3 -3
  50. scalebox/sandbox_sync/filesystem/watch_handle.py +66 -66
  51. scalebox/sandbox_sync/main.py +208 -133
  52. scalebox/sandbox_sync/sandbox_api.py +119 -3
  53. scalebox/test/CODE_INTERPRETER_TESTS_READY.md +323 -323
  54. scalebox/test/README.md +329 -329
  55. scalebox/test/bedrock_openai_adapter.py +67 -0
  56. scalebox/test/code_interpreter_test.py +34 -34
  57. scalebox/test/code_interpreter_test_sync.py +34 -34
  58. scalebox/test/run_stress_code_interpreter_sync.py +166 -0
  59. scalebox/test/simple_upload_example.py +123 -0
  60. scalebox/test/stabitiy_test.py +310 -0
  61. scalebox/test/test_browser_use.py +25 -0
  62. scalebox/test/test_browser_use_scalebox.py +61 -0
  63. scalebox/test/test_code_interpreter_sync_comprehensive.py +115 -65
  64. scalebox/test/test_connect_pause_async.py +277 -0
  65. scalebox/test/test_connect_pause_sync.py +267 -0
  66. scalebox/test/test_desktop_sandbox_sf.py +117 -0
  67. scalebox/test/test_download_url.py +49 -0
  68. scalebox/test/test_sandbox_async_comprehensive.py +1 -1
  69. scalebox/test/test_sandbox_object_storage_example.py +146 -0
  70. scalebox/test/test_sandbox_object_storage_example_async.py +156 -0
  71. scalebox/test/test_sf.py +137 -0
  72. scalebox/test/test_watch_dir_async.py +56 -0
  73. scalebox/test/testacreate.py +1 -1
  74. scalebox/test/testagetinfo.py +1 -1
  75. scalebox/test/testcomputeuse.py +243 -243
  76. scalebox/test/testsandbox_api.py +13 -0
  77. scalebox/test/testsandbox_sync.py +1 -1
  78. scalebox/test/upload_100mb_example.py +355 -0
  79. scalebox/utils/httpcoreclient.py +297 -297
  80. scalebox/utils/httpxclient.py +403 -403
  81. scalebox/version.py +2 -2
  82. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/METADATA +1 -1
  83. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/RECORD +87 -69
  84. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/WHEEL +1 -1
  85. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/entry_points.txt +0 -0
  86. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/licenses/LICENSE +0 -0
  87. {scalebox_sdk-0.1.24.dist-info → scalebox_sdk-1.0.1.dist-info}/top_level.txt +0 -0
@@ -1,230 +1,230 @@
1
- import enum
2
- from typing import Any, List, Optional, Tuple, Union
3
-
4
-
5
- class ChartType(str, enum.Enum):
6
- """
7
- Chart types
8
- """
9
-
10
- LINE = "line"
11
- SCATTER = "scatter"
12
- BAR = "bar"
13
- PIE = "pie"
14
- BOX_AND_WHISKER = "box_and_whisker"
15
- SUPERCHART = "superchart"
16
- UNKNOWN = "unknown"
17
-
18
-
19
- class ScaleType(str, enum.Enum):
20
- """
21
- Ax scale types
22
- """
23
-
24
- LINEAR = "linear"
25
- DATETIME = "datetime"
26
- CATEGORICAL = "categorical"
27
- LOG = "log"
28
- SYMLOG = "symlog"
29
- LOGIT = "logit"
30
- FUNCTION = "function"
31
- FUNCTIONLOG = "functionlog"
32
- ASINH = "asinh"
33
- UNKNOWN = "unknown"
34
-
35
-
36
- class Chart:
37
- """
38
- Extracted data from a chart. It's useful for building an interactive charts or custom visualizations.
39
- """
40
-
41
- type: ChartType
42
- title: str
43
-
44
- elements: List[Any]
45
-
46
- def __init__(self, **kwargs) -> None:
47
- self._raw_data = kwargs
48
- self.type = ChartType(kwargs["type"] or ChartType.UNKNOWN)
49
- self.title = kwargs["title"]
50
- self.elements = kwargs["elements"]
51
-
52
- def to_dict(self) -> dict:
53
- return self._raw_data
54
-
55
-
56
- class Chart2D(Chart):
57
- x_label: Optional[str]
58
- y_label: Optional[str]
59
- x_unit: Optional[str]
60
- y_unit: Optional[str]
61
-
62
- def __init__(self, **kwargs) -> None:
63
- super().__init__(**kwargs)
64
- self.x_label = kwargs["x_label"]
65
- self.y_label = kwargs["y_label"]
66
- self.x_unit = kwargs["x_unit"]
67
- self.y_unit = kwargs["y_unit"]
68
-
69
-
70
- class PointData:
71
- label: str
72
- points: List[Tuple[Union[str, float], Union[str, float]]]
73
-
74
- def __init__(self, **kwargs) -> None:
75
- self.label = kwargs["label"]
76
- self.points = [(x, y) for x, y in kwargs["points"]]
77
-
78
-
79
- class PointChart(Chart2D):
80
- x_ticks: List[Union[str, float]]
81
- x_tick_labels: List[str]
82
- x_scale: ScaleType
83
-
84
- y_ticks: List[Union[str, float]]
85
- y_tick_labels: List[str]
86
- y_scale: ScaleType
87
-
88
- elements: List[PointData]
89
-
90
- def __init__(self, **kwargs) -> None:
91
- super().__init__(**kwargs)
92
- self.x_label = kwargs["x_label"]
93
-
94
- try:
95
- self.x_scale = ScaleType(kwargs.get("x_scale"))
96
- except ValueError:
97
- self.x_scale = ScaleType.UNKNOWN
98
-
99
- self.x_ticks = kwargs["x_ticks"]
100
- self.x_tick_labels = kwargs["x_tick_labels"]
101
-
102
- self.y_label = kwargs["y_label"]
103
-
104
- try:
105
- self.y_scale = ScaleType(kwargs.get("y_scale"))
106
- except ValueError:
107
- self.y_scale = ScaleType.UNKNOWN
108
-
109
- self.y_ticks = kwargs["y_ticks"]
110
- self.y_tick_labels = kwargs["y_tick_labels"]
111
-
112
- self.elements = [PointData(**d) for d in kwargs["elements"]]
113
-
114
-
115
- class LineChart(PointChart):
116
- type = ChartType.LINE
117
-
118
-
119
- class ScatterChart(PointChart):
120
- type = ChartType.SCATTER
121
-
122
-
123
- class BarData:
124
- label: str
125
- group: str
126
- value: str
127
-
128
- def __init__(self, **kwargs) -> None:
129
- self.label = kwargs["label"]
130
- self.value = kwargs["value"]
131
- self.group = kwargs["group"]
132
-
133
-
134
- class BarChart(Chart2D):
135
- type = ChartType.BAR
136
-
137
- elements: List[BarData]
138
-
139
- def __init__(self, **kwargs) -> None:
140
- super().__init__(**kwargs)
141
- self.elements = [BarData(**d) for d in kwargs["elements"]]
142
-
143
-
144
- class PieData:
145
- label: str
146
- angle: float
147
- radius: float
148
-
149
- def __init__(self, **kwargs) -> None:
150
- self.label = kwargs["label"]
151
- self.angle = kwargs["angle"]
152
- self.radius = kwargs["radius"]
153
-
154
-
155
- class PieChart(Chart):
156
- type = ChartType.PIE
157
-
158
- elements: List[PieData]
159
-
160
- def __init__(self, **kwargs) -> None:
161
- super().__init__(**kwargs)
162
- self.elements = [PieData(**d) for d in kwargs["elements"]]
163
-
164
-
165
- class BoxAndWhiskerData:
166
- label: str
167
- min: float
168
- first_quartile: float
169
- median: float
170
- third_quartile: float
171
- max: float
172
- outliers: List[float]
173
-
174
- def __init__(self, **kwargs) -> None:
175
- self.label = kwargs["label"]
176
- self.min = kwargs["min"]
177
- self.first_quartile = kwargs["first_quartile"]
178
- self.median = kwargs["median"]
179
- self.third_quartile = kwargs["third_quartile"]
180
- self.max = kwargs["max"]
181
- self.outliers = kwargs.get("outliers") or []
182
-
183
-
184
- class BoxAndWhiskerChart(Chart2D):
185
- type = ChartType.BOX_AND_WHISKER
186
-
187
- elements: List[BoxAndWhiskerData]
188
-
189
- def __init__(self, **kwargs) -> None:
190
- super().__init__(**kwargs)
191
- self.elements = [BoxAndWhiskerData(**d) for d in kwargs["elements"]]
192
-
193
-
194
- class SuperChart(Chart):
195
- type = ChartType.SUPERCHART
196
-
197
- elements: List[
198
- Union[LineChart, ScatterChart, BarChart, PieChart, BoxAndWhiskerChart]
199
- ]
200
-
201
- def __init__(self, **kwargs) -> None:
202
- super().__init__(**kwargs)
203
- self.elements = [_deserialize_chart(g) for g in kwargs["elements"]]
204
-
205
-
206
- ChartTypes = Union[
207
- LineChart, ScatterChart, BarChart, PieChart, BoxAndWhiskerChart, SuperChart
208
- ]
209
-
210
-
211
- def _deserialize_chart(data: Optional[dict]) -> Optional[ChartTypes]:
212
- if not data:
213
- return None
214
-
215
- if data["type"] == ChartType.LINE:
216
- chart = LineChart(**data)
217
- elif data["type"] == ChartType.SCATTER:
218
- chart = ScatterChart(**data)
219
- elif data["type"] == ChartType.BAR:
220
- chart = BarChart(**data)
221
- elif data["type"] == ChartType.PIE:
222
- chart = PieChart(**data)
223
- elif data["type"] == ChartType.BOX_AND_WHISKER:
224
- chart = BoxAndWhiskerChart(**data)
225
- elif data["type"] == ChartType.SUPERCHART:
226
- chart = SuperChart(**data)
227
- else:
228
- chart = Chart(**data)
229
-
230
- return chart
1
+ import enum
2
+ from typing import Any, List, Optional, Tuple, Union
3
+
4
+
5
+ class ChartType(str, enum.Enum):
6
+ """
7
+ Chart types
8
+ """
9
+
10
+ LINE = "line"
11
+ SCATTER = "scatter"
12
+ BAR = "bar"
13
+ PIE = "pie"
14
+ BOX_AND_WHISKER = "box_and_whisker"
15
+ SUPERCHART = "superchart"
16
+ UNKNOWN = "unknown"
17
+
18
+
19
+ class ScaleType(str, enum.Enum):
20
+ """
21
+ Ax scale types
22
+ """
23
+
24
+ LINEAR = "linear"
25
+ DATETIME = "datetime"
26
+ CATEGORICAL = "categorical"
27
+ LOG = "log"
28
+ SYMLOG = "symlog"
29
+ LOGIT = "logit"
30
+ FUNCTION = "function"
31
+ FUNCTIONLOG = "functionlog"
32
+ ASINH = "asinh"
33
+ UNKNOWN = "unknown"
34
+
35
+
36
+ class Chart:
37
+ """
38
+ Extracted data from a chart. It's useful for building an interactive charts or custom visualizations.
39
+ """
40
+
41
+ type: ChartType
42
+ title: str
43
+
44
+ elements: List[Any]
45
+
46
+ def __init__(self, **kwargs) -> None:
47
+ self._raw_data = kwargs
48
+ self.type = ChartType(kwargs["type"] or ChartType.UNKNOWN)
49
+ self.title = kwargs["title"]
50
+ self.elements = kwargs["elements"]
51
+
52
+ def to_dict(self) -> dict:
53
+ return self._raw_data
54
+
55
+
56
+ class Chart2D(Chart):
57
+ x_label: Optional[str]
58
+ y_label: Optional[str]
59
+ x_unit: Optional[str]
60
+ y_unit: Optional[str]
61
+
62
+ def __init__(self, **kwargs) -> None:
63
+ super().__init__(**kwargs)
64
+ self.x_label = kwargs["x_label"]
65
+ self.y_label = kwargs["y_label"]
66
+ self.x_unit = kwargs["x_unit"]
67
+ self.y_unit = kwargs["y_unit"]
68
+
69
+
70
+ class PointData:
71
+ label: str
72
+ points: List[Tuple[Union[str, float], Union[str, float]]]
73
+
74
+ def __init__(self, **kwargs) -> None:
75
+ self.label = kwargs["label"]
76
+ self.points = [(x, y) for x, y in kwargs["points"]]
77
+
78
+
79
+ class PointChart(Chart2D):
80
+ x_ticks: List[Union[str, float]]
81
+ x_tick_labels: List[str]
82
+ x_scale: ScaleType
83
+
84
+ y_ticks: List[Union[str, float]]
85
+ y_tick_labels: List[str]
86
+ y_scale: ScaleType
87
+
88
+ elements: List[PointData]
89
+
90
+ def __init__(self, **kwargs) -> None:
91
+ super().__init__(**kwargs)
92
+ self.x_label = kwargs["x_label"]
93
+
94
+ try:
95
+ self.x_scale = ScaleType(kwargs.get("x_scale"))
96
+ except ValueError:
97
+ self.x_scale = ScaleType.UNKNOWN
98
+
99
+ self.x_ticks = kwargs["x_ticks"]
100
+ self.x_tick_labels = kwargs["x_tick_labels"]
101
+
102
+ self.y_label = kwargs["y_label"]
103
+
104
+ try:
105
+ self.y_scale = ScaleType(kwargs.get("y_scale"))
106
+ except ValueError:
107
+ self.y_scale = ScaleType.UNKNOWN
108
+
109
+ self.y_ticks = kwargs["y_ticks"]
110
+ self.y_tick_labels = kwargs["y_tick_labels"]
111
+
112
+ self.elements = [PointData(**d) for d in kwargs["elements"]]
113
+
114
+
115
+ class LineChart(PointChart):
116
+ type = ChartType.LINE
117
+
118
+
119
+ class ScatterChart(PointChart):
120
+ type = ChartType.SCATTER
121
+
122
+
123
+ class BarData:
124
+ label: str
125
+ group: str
126
+ value: str
127
+
128
+ def __init__(self, **kwargs) -> None:
129
+ self.label = kwargs["label"]
130
+ self.value = kwargs["value"]
131
+ self.group = kwargs["group"]
132
+
133
+
134
+ class BarChart(Chart2D):
135
+ type = ChartType.BAR
136
+
137
+ elements: List[BarData]
138
+
139
+ def __init__(self, **kwargs) -> None:
140
+ super().__init__(**kwargs)
141
+ self.elements = [BarData(**d) for d in kwargs["elements"]]
142
+
143
+
144
+ class PieData:
145
+ label: str
146
+ angle: float
147
+ radius: float
148
+
149
+ def __init__(self, **kwargs) -> None:
150
+ self.label = kwargs["label"]
151
+ self.angle = kwargs["angle"]
152
+ self.radius = kwargs["radius"]
153
+
154
+
155
+ class PieChart(Chart):
156
+ type = ChartType.PIE
157
+
158
+ elements: List[PieData]
159
+
160
+ def __init__(self, **kwargs) -> None:
161
+ super().__init__(**kwargs)
162
+ self.elements = [PieData(**d) for d in kwargs["elements"]]
163
+
164
+
165
+ class BoxAndWhiskerData:
166
+ label: str
167
+ min: float
168
+ first_quartile: float
169
+ median: float
170
+ third_quartile: float
171
+ max: float
172
+ outliers: List[float]
173
+
174
+ def __init__(self, **kwargs) -> None:
175
+ self.label = kwargs["label"]
176
+ self.min = kwargs["min"]
177
+ self.first_quartile = kwargs["first_quartile"]
178
+ self.median = kwargs["median"]
179
+ self.third_quartile = kwargs["third_quartile"]
180
+ self.max = kwargs["max"]
181
+ self.outliers = kwargs.get("outliers") or []
182
+
183
+
184
+ class BoxAndWhiskerChart(Chart2D):
185
+ type = ChartType.BOX_AND_WHISKER
186
+
187
+ elements: List[BoxAndWhiskerData]
188
+
189
+ def __init__(self, **kwargs) -> None:
190
+ super().__init__(**kwargs)
191
+ self.elements = [BoxAndWhiskerData(**d) for d in kwargs["elements"]]
192
+
193
+
194
+ class SuperChart(Chart):
195
+ type = ChartType.SUPERCHART
196
+
197
+ elements: List[
198
+ Union[LineChart, ScatterChart, BarChart, PieChart, BoxAndWhiskerChart]
199
+ ]
200
+
201
+ def __init__(self, **kwargs) -> None:
202
+ super().__init__(**kwargs)
203
+ self.elements = [_deserialize_chart(g) for g in kwargs["elements"]]
204
+
205
+
206
+ ChartTypes = Union[
207
+ LineChart, ScatterChart, BarChart, PieChart, BoxAndWhiskerChart, SuperChart
208
+ ]
209
+
210
+
211
+ def _deserialize_chart(data: Optional[dict]) -> Optional[ChartTypes]:
212
+ if not data:
213
+ return None
214
+
215
+ if data["type"] == ChartType.LINE:
216
+ chart = LineChart(**data)
217
+ elif data["type"] == ChartType.SCATTER:
218
+ chart = ScatterChart(**data)
219
+ elif data["type"] == ChartType.BAR:
220
+ chart = BarChart(**data)
221
+ elif data["type"] == ChartType.PIE:
222
+ chart = PieChart(**data)
223
+ elif data["type"] == ChartType.BOX_AND_WHISKER:
224
+ chart = BoxAndWhiskerChart(**data)
225
+ elif data["type"] == ChartType.SUPERCHART:
226
+ chart = SuperChart(**data)
227
+ else:
228
+ chart = Chart(**data)
229
+
230
+ return chart
@@ -1,3 +1,3 @@
1
- DEFAULT_TEMPLATE = "code-interpreter"
2
- JUPYTER_PORT = 32000
3
- DEFAULT_TIMEOUT = 300
1
+ DEFAULT_TEMPLATE = "code-interpreter"
2
+ JUPYTER_PORT = 32000
3
+ DEFAULT_TIMEOUT = 300
@@ -1,13 +1,13 @@
1
- from ..exceptions import TimeoutException
2
-
3
-
4
- def format_request_timeout_error() -> Exception:
5
- return TimeoutException(
6
- f"Request timed out — the 'request_timeout' option can be used to increase this timeout",
7
- )
8
-
9
-
10
- def format_execution_timeout_error() -> Exception:
11
- return TimeoutException(
12
- f"Execution timed out — the 'timeout' option can be used to increase this timeout",
13
- )
1
+ from ..exceptions import TimeoutException
2
+
3
+
4
+ def format_request_timeout_error() -> Exception:
5
+ return TimeoutException(
6
+ f"Request timed out — the 'request_timeout' option can be used to increase this timeout",
7
+ )
8
+
9
+
10
+ def format_execution_timeout_error() -> Exception:
11
+ return TimeoutException(
12
+ f"Execution timed out — the 'timeout' option can be used to increase this timeout",
13
+ )