tigrbl_engine_snowflake 0.4.2.dev3__tar.gz → 0.4.2.dev4__tar.gz

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 (17) hide show
  1. tigrbl_engine_snowflake-0.4.2.dev4/NOTICE +7 -0
  2. {tigrbl_engine_snowflake-0.4.2.dev3/src/tigrbl_engine_snowflake.egg-info → tigrbl_engine_snowflake-0.4.2.dev4}/PKG-INFO +116 -27
  3. tigrbl_engine_snowflake-0.4.2.dev4/README.md +157 -0
  4. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/pyproject.toml +1 -1
  5. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4/src/tigrbl_engine_snowflake.egg-info}/PKG-INFO +116 -27
  6. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake.egg-info/SOURCES.txt +1 -0
  7. tigrbl_engine_snowflake-0.4.2.dev3/README.md +0 -69
  8. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/LICENSE +0 -0
  9. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/setup.cfg +0 -0
  10. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake/__init__.py +0 -0
  11. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake/engine.py +0 -0
  12. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake/session.py +0 -0
  13. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake.egg-info/dependency_links.txt +0 -0
  14. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake.egg-info/entry_points.txt +0 -0
  15. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake.egg-info/requires.txt +0 -0
  16. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/src/tigrbl_engine_snowflake.egg-info/top_level.txt +0 -0
  17. {tigrbl_engine_snowflake-0.4.2.dev3 → tigrbl_engine_snowflake-0.4.2.dev4}/tests/test_smoke.py +0 -0
@@ -0,0 +1,7 @@
1
+ Tigrbl
2
+ Copyright 2026 Swarmauri
3
+
4
+ This product includes software developed by Swarmauri.
5
+
6
+ Tigrbl is licensed under the Apache License, Version 2.0.
7
+ See the LICENSE file distributed with this work for the full license text.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: tigrbl_engine_snowflake
3
- Version: 0.4.2.dev3
3
+ Version: 0.4.2.dev4
4
4
  Summary: Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.
5
5
  Author-email: Jacob Stewart <jacob@swarmauri.com>
6
6
  License: Apache License
@@ -231,6 +231,7 @@ Classifier: Topic :: Database
231
231
  Requires-Python: <3.15,>=3.10
232
232
  Description-Content-Type: text/markdown
233
233
  License-File: LICENSE
234
+ License-File: NOTICE
234
235
  Requires-Dist: SQLAlchemy<3.0,>=2.0
235
236
  Requires-Dist: snowflake-sqlalchemy<2.0,>=1.5
236
237
  Requires-Dist: snowflake-connector-python<4.0,>=3.0
@@ -242,12 +243,45 @@ Dynamic: license-file
242
243
  <p><strong>Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.</strong></p>
243
244
  <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://img.shields.io/pypi/v/tigrbl_engine_snowflake?label=PyPI" alt="PyPI version for tigrbl_engine_snowflake"/></a>
244
245
  <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://static.pepy.tech/badge/tigrbl_engine_snowflake" alt="Downloads for tigrbl_engine_snowflake"/></a>
246
+ <a href="https://discord.gg/K4YTAPapjR"><img src="https://img.shields.io/badge/Discord-Join%20chat-5865F2?logo=discord&logoColor=white" alt="Discord community for tigrbl_engine_snowflake"/></a>
245
247
  <a href="https://github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md"><img src="https://hits.sh/github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md.svg?label=hits" alt="Repository hits for tigrbl_engine_snowflake README"/></a>
246
248
  <a href="LICENSE"><img src="https://img.shields.io/badge/license-Apache%202.0-525252" alt="Apache 2.0 license"/></a>
247
- <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20to%203.15-3776ab" alt="Python requirement for tigrbl_engine_snowflake"/></a>
249
+ <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12%20%7C%203.13%20%7C%203.14-3776ab" alt="Python versions 3.10 | 3.11 | 3.12 | 3.13 | 3.14 for tigrbl_engine_snowflake"/></a>
248
250
  <a href="https://github.com/tigrbl/tigrbl/blob/master/docs/README.md"><img src="https://img.shields.io/badge/workspace-engines-1f6feb" alt="Workspace group for tigrbl_engine_snowflake"/></a>
249
251
  </div>
250
252
 
253
+ ## What is tigrbl_engine_snowflake?
254
+
255
+ Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.
256
+
257
+ ## Why use tigrbl_engine_snowflake?
258
+
259
+ Use it when a Tigrbl application needs this backend without installing every engine package.
260
+
261
+ ## When should I install tigrbl_engine_snowflake?
262
+
263
+ Install it when the storage, analytics, cache, or integration workload named by this package is the intended runtime backend.
264
+
265
+ ## Who is tigrbl_engine_snowflake for?
266
+
267
+ Application developers, data platform engineers, and operators choosing concrete persistence or data-plane behavior.
268
+
269
+ ## Where does tigrbl_engine_snowflake fit?
270
+
271
+ `tigrbl_engine_snowflake` lives at `pkgs/engines/tigrbl_engine_snowflake` and serves Snowflake warehouse-backed analytics.
272
+
273
+ ## How does tigrbl_engine_snowflake work?
274
+
275
+ It exposes a `tigrbl.engine` entry point and a package `register()` hook so Tigrbl can discover or load the backend at runtime.
276
+
277
+ ## Certification Status
278
+
279
+ - Package status: governed package in the `tigrbl/tigrbl` workspace.
280
+ - Governance source: [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json).
281
+ - Release evidence: [publish workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml) validates package builds, tests, GitHub release assets, and PyPI publication for managed packages.
282
+ - Local certification guard: `pkgs/core/tigrbl_tests/tests/unit/test_package_badges_and_notices.py` verifies every package README keeps the Discord badge, Apache 2.0 badge, explicit Python-version badge, `LICENSE`, and `NOTICE`.
283
+ - Scope note: this README documents the package boundary. Runtime feature support remains governed by `.ssot/` entities and the conformance docs linked below.
284
+
251
285
  ## Install
252
286
 
253
287
  ```bash
@@ -258,50 +292,105 @@ uv add tigrbl_engine_snowflake
258
292
  pip install tigrbl_engine_snowflake
259
293
  ```
260
294
 
295
+ ## Surface Coverage
296
+
297
+ | Surface | Value |
298
+ |---|---|
299
+ | PyPI package | [`tigrbl_engine_snowflake`](https://pypi.org/project/tigrbl_engine_snowflake/) |
300
+ | Repository path | [`pkgs/engines/tigrbl_engine_snowflake`](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake) |
301
+ | Python import root | `tigrbl_engine_snowflake` |
302
+ | Console scripts | none declared |
303
+ | Entry points | `tigrbl.engine` |
304
+ | Optional extras | none declared |
305
+ | Legal files | `LICENSE`, `NOTICE` |
306
+ | Supported Python | `3.10 | 3.11 | 3.12 | 3.13 | 3.14` |
307
+
261
308
  ## What It Owns
262
309
 
263
- `tigrbl_engine_snowflake` owns the engine snowflake backend boundary for Tigrbl, including engine registration, session adapters, and backend-specific helpers. Key implementation roots include `tigrbl_engine_snowflake` with `engine, session`.
310
+ `tigrbl_engine_snowflake` owns the `engine plugin` boundary. It should be installed when you need this package's focused responsibility without assuming every other Tigrbl workspace package is present.
311
+
312
+ Implementation orientation:
313
+ - `tigrbl_engine_snowflake`: engine, session
264
314
 
265
- ## Use It When
315
+ ## Public API and Import Surface
266
316
 
267
- Use `tigrbl_engine_snowflake` when you want the engine snowflake backend installed as an isolated dependency instead of pulling every engine into your environment.
317
+ - Import roots: `tigrbl_engine_snowflake`.
318
+ - Public symbols: `SnowflakeSession`, `register`, `snowflake_capabilities`, `snowflake_engine`.
319
+ - Workspace dependencies: none declared.
320
+ - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
268
321
 
269
- ## Public Surface
322
+ ## Usage Examples
270
323
 
271
- - `tigrbl_engine_snowflake` exposes `snowflake_engine, snowflake_capabilities, SnowflakeSession, register`.
324
+ ### Verify the installed package
272
325
 
273
- ## Internal Layout
326
+ ```bash
327
+ python -m pip show tigrbl_engine_snowflake
328
+ python - <<'PY'
329
+ from importlib.metadata import version
330
+ print(version("tigrbl_engine_snowflake"))
331
+ PY
332
+ ```
274
333
 
275
- - Workspace path: `pkgs/engines/tigrbl_engine_snowflake`.
276
- - Package class: `engine plugin`.
277
- - Python requirement: `>=3.10,<3.15`.
278
- - `tigrbl_engine_snowflake` modules: `engine, session`.
334
+ ### Register the engine plugin explicitly
279
335
 
280
- ## Dependency Surface
336
+ ```python
337
+ from tigrbl_engine_snowflake import register
281
338
 
282
- - Workspace package dependencies: none declared.
283
- - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
284
- - Optional extras: none declared.
339
+ register()
340
+ ```
341
+
342
+ ### Discover the engine through package metadata
343
+
344
+ ```python
345
+ from importlib.metadata import entry_points
346
+
347
+ for entry_point in entry_points(group="tigrbl.engine"):
348
+ if entry_point.module.startswith("tigrbl_engine_snowflake"):
349
+ plugin_register = entry_point.load()
350
+ plugin_register()
351
+ ```
352
+
353
+ ### Install alongside the facade
354
+
355
+ ```bash
356
+ uv add tigrbl tigrbl_engine_snowflake
357
+ pip install tigrbl tigrbl_engine_snowflake
358
+ ```
359
+
360
+ ## How To Choose This Package
361
+
362
+ Choose `tigrbl_engine_snowflake` when the quick-answer table matches your use case. Choose [`tigrbl`](https://pypi.org/project/tigrbl/) instead when you want the full public facade. Choose a lower-level package such as [`tigrbl-core`](https://pypi.org/project/tigrbl-core/), [`tigrbl-base`](https://pypi.org/project/tigrbl-base/), or [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/) when you are building framework extensions or testing a specific internal boundary.
285
363
 
286
364
  ## Related Packages
287
365
 
288
366
  - [`tigrbl`](https://pypi.org/project/tigrbl/)
367
+ - [`tigrbl-core`](https://pypi.org/project/tigrbl-core/)
368
+ - [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/)
369
+ - [`tigrbl_engine_sqlite`](https://pypi.org/project/tigrbl_engine_sqlite/)
370
+ - [`tigrbl_engine_postgres`](https://pypi.org/project/tigrbl_engine_postgres/)
371
+ - [`tigrbl_engine_duckdb`](https://pypi.org/project/tigrbl_engine_duckdb/)
372
+ - [`tigrbl_engine_pandas`](https://pypi.org/project/tigrbl_engine_pandas/)
373
+
374
+ ## Documentation Links
375
+
376
+ - [Workspace docs](https://github.com/tigrbl/tigrbl/blob/master/docs/README.md)
377
+ - [Package catalog](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_CATALOG.md)
378
+ - [Package layout](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_LAYOUT.md)
379
+ - [Current target](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_TARGET.md)
380
+ - [Current state](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_STATE.md)
381
+ - [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json)
382
+ - [Release workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml)
289
383
 
290
- ## Canonical Repository Docs
384
+ ## Support
291
385
 
292
- - `docs/README.md`
293
- - `docs/conformance/CURRENT_TARGET.md`
294
- - `docs/conformance/CURRENT_STATE.md`
295
- - `docs/conformance/NEXT_STEPS.md`
296
- - `docs/governance/DOC_POINTERS.md`
297
- - `docs/developer/PACKAGE_CATALOG.md`
298
- - `docs/developer/PACKAGE_LAYOUT.md`
386
+ - Community: [Discord](https://discord.gg/K4YTAPapjR).
387
+ - Issues: [GitHub Issues](https://github.com/tigrbl/tigrbl/issues).
388
+ - Repository: [pkgs/engines/tigrbl_engine_snowflake](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake).
299
389
 
300
390
  ## Package-local Boundary
301
391
 
302
- This file is a package-local distribution entry point.
303
- Use this page for package installation and boundary orientation. Repository governance, conformance state, target status, and release evidence remain governed from `docs/` and `.ssot/`.
392
+ This README is the package-local distribution entry point for `tigrbl_engine_snowflake`. It answers install, usage, API, ownership, and certification-orientation questions for this package. Broader architectural decisions, release status, and cross-package proof chains remain in the repository-level docs and SSOT registry.
304
393
 
305
394
  ## License
306
395
 
307
- Licensed under the Apache License, Version 2.0. See `LICENSE` and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).
396
+ Licensed under the Apache License, Version 2.0. See `LICENSE`, `NOTICE`, and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).
@@ -0,0 +1,157 @@
1
+ <div align="center">
2
+ <h1>tigrbl_engine_snowflake</h1>
3
+ <img src="https://raw.githubusercontent.com/swarmauri/swarmauri-sdk/master/assets/tigrbl_full_logo.png" alt="Tigrbl logo" width="140"/>
4
+ <p><strong>Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.</strong></p>
5
+ <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://img.shields.io/pypi/v/tigrbl_engine_snowflake?label=PyPI" alt="PyPI version for tigrbl_engine_snowflake"/></a>
6
+ <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://static.pepy.tech/badge/tigrbl_engine_snowflake" alt="Downloads for tigrbl_engine_snowflake"/></a>
7
+ <a href="https://discord.gg/K4YTAPapjR"><img src="https://img.shields.io/badge/Discord-Join%20chat-5865F2?logo=discord&logoColor=white" alt="Discord community for tigrbl_engine_snowflake"/></a>
8
+ <a href="https://github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md"><img src="https://hits.sh/github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md.svg?label=hits" alt="Repository hits for tigrbl_engine_snowflake README"/></a>
9
+ <a href="LICENSE"><img src="https://img.shields.io/badge/license-Apache%202.0-525252" alt="Apache 2.0 license"/></a>
10
+ <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12%20%7C%203.13%20%7C%203.14-3776ab" alt="Python versions 3.10 | 3.11 | 3.12 | 3.13 | 3.14 for tigrbl_engine_snowflake"/></a>
11
+ <a href="https://github.com/tigrbl/tigrbl/blob/master/docs/README.md"><img src="https://img.shields.io/badge/workspace-engines-1f6feb" alt="Workspace group for tigrbl_engine_snowflake"/></a>
12
+ </div>
13
+
14
+ ## What is tigrbl_engine_snowflake?
15
+
16
+ Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.
17
+
18
+ ## Why use tigrbl_engine_snowflake?
19
+
20
+ Use it when a Tigrbl application needs this backend without installing every engine package.
21
+
22
+ ## When should I install tigrbl_engine_snowflake?
23
+
24
+ Install it when the storage, analytics, cache, or integration workload named by this package is the intended runtime backend.
25
+
26
+ ## Who is tigrbl_engine_snowflake for?
27
+
28
+ Application developers, data platform engineers, and operators choosing concrete persistence or data-plane behavior.
29
+
30
+ ## Where does tigrbl_engine_snowflake fit?
31
+
32
+ `tigrbl_engine_snowflake` lives at `pkgs/engines/tigrbl_engine_snowflake` and serves Snowflake warehouse-backed analytics.
33
+
34
+ ## How does tigrbl_engine_snowflake work?
35
+
36
+ It exposes a `tigrbl.engine` entry point and a package `register()` hook so Tigrbl can discover or load the backend at runtime.
37
+
38
+ ## Certification Status
39
+
40
+ - Package status: governed package in the `tigrbl/tigrbl` workspace.
41
+ - Governance source: [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json).
42
+ - Release evidence: [publish workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml) validates package builds, tests, GitHub release assets, and PyPI publication for managed packages.
43
+ - Local certification guard: `pkgs/core/tigrbl_tests/tests/unit/test_package_badges_and_notices.py` verifies every package README keeps the Discord badge, Apache 2.0 badge, explicit Python-version badge, `LICENSE`, and `NOTICE`.
44
+ - Scope note: this README documents the package boundary. Runtime feature support remains governed by `.ssot/` entities and the conformance docs linked below.
45
+
46
+ ## Install
47
+
48
+ ```bash
49
+ uv add tigrbl_engine_snowflake
50
+ ```
51
+
52
+ ```bash
53
+ pip install tigrbl_engine_snowflake
54
+ ```
55
+
56
+ ## Surface Coverage
57
+
58
+ | Surface | Value |
59
+ |---|---|
60
+ | PyPI package | [`tigrbl_engine_snowflake`](https://pypi.org/project/tigrbl_engine_snowflake/) |
61
+ | Repository path | [`pkgs/engines/tigrbl_engine_snowflake`](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake) |
62
+ | Python import root | `tigrbl_engine_snowflake` |
63
+ | Console scripts | none declared |
64
+ | Entry points | `tigrbl.engine` |
65
+ | Optional extras | none declared |
66
+ | Legal files | `LICENSE`, `NOTICE` |
67
+ | Supported Python | `3.10 | 3.11 | 3.12 | 3.13 | 3.14` |
68
+
69
+ ## What It Owns
70
+
71
+ `tigrbl_engine_snowflake` owns the `engine plugin` boundary. It should be installed when you need this package's focused responsibility without assuming every other Tigrbl workspace package is present.
72
+
73
+ Implementation orientation:
74
+ - `tigrbl_engine_snowflake`: engine, session
75
+
76
+ ## Public API and Import Surface
77
+
78
+ - Import roots: `tigrbl_engine_snowflake`.
79
+ - Public symbols: `SnowflakeSession`, `register`, `snowflake_capabilities`, `snowflake_engine`.
80
+ - Workspace dependencies: none declared.
81
+ - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
82
+
83
+ ## Usage Examples
84
+
85
+ ### Verify the installed package
86
+
87
+ ```bash
88
+ python -m pip show tigrbl_engine_snowflake
89
+ python - <<'PY'
90
+ from importlib.metadata import version
91
+ print(version("tigrbl_engine_snowflake"))
92
+ PY
93
+ ```
94
+
95
+ ### Register the engine plugin explicitly
96
+
97
+ ```python
98
+ from tigrbl_engine_snowflake import register
99
+
100
+ register()
101
+ ```
102
+
103
+ ### Discover the engine through package metadata
104
+
105
+ ```python
106
+ from importlib.metadata import entry_points
107
+
108
+ for entry_point in entry_points(group="tigrbl.engine"):
109
+ if entry_point.module.startswith("tigrbl_engine_snowflake"):
110
+ plugin_register = entry_point.load()
111
+ plugin_register()
112
+ ```
113
+
114
+ ### Install alongside the facade
115
+
116
+ ```bash
117
+ uv add tigrbl tigrbl_engine_snowflake
118
+ pip install tigrbl tigrbl_engine_snowflake
119
+ ```
120
+
121
+ ## How To Choose This Package
122
+
123
+ Choose `tigrbl_engine_snowflake` when the quick-answer table matches your use case. Choose [`tigrbl`](https://pypi.org/project/tigrbl/) instead when you want the full public facade. Choose a lower-level package such as [`tigrbl-core`](https://pypi.org/project/tigrbl-core/), [`tigrbl-base`](https://pypi.org/project/tigrbl-base/), or [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/) when you are building framework extensions or testing a specific internal boundary.
124
+
125
+ ## Related Packages
126
+
127
+ - [`tigrbl`](https://pypi.org/project/tigrbl/)
128
+ - [`tigrbl-core`](https://pypi.org/project/tigrbl-core/)
129
+ - [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/)
130
+ - [`tigrbl_engine_sqlite`](https://pypi.org/project/tigrbl_engine_sqlite/)
131
+ - [`tigrbl_engine_postgres`](https://pypi.org/project/tigrbl_engine_postgres/)
132
+ - [`tigrbl_engine_duckdb`](https://pypi.org/project/tigrbl_engine_duckdb/)
133
+ - [`tigrbl_engine_pandas`](https://pypi.org/project/tigrbl_engine_pandas/)
134
+
135
+ ## Documentation Links
136
+
137
+ - [Workspace docs](https://github.com/tigrbl/tigrbl/blob/master/docs/README.md)
138
+ - [Package catalog](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_CATALOG.md)
139
+ - [Package layout](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_LAYOUT.md)
140
+ - [Current target](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_TARGET.md)
141
+ - [Current state](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_STATE.md)
142
+ - [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json)
143
+ - [Release workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml)
144
+
145
+ ## Support
146
+
147
+ - Community: [Discord](https://discord.gg/K4YTAPapjR).
148
+ - Issues: [GitHub Issues](https://github.com/tigrbl/tigrbl/issues).
149
+ - Repository: [pkgs/engines/tigrbl_engine_snowflake](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake).
150
+
151
+ ## Package-local Boundary
152
+
153
+ This README is the package-local distribution entry point for `tigrbl_engine_snowflake`. It answers install, usage, API, ownership, and certification-orientation questions for this package. Broader architectural decisions, release status, and cross-package proof chains remain in the repository-level docs and SSOT registry.
154
+
155
+ ## License
156
+
157
+ Licensed under the Apache License, Version 2.0. See `LICENSE`, `NOTICE`, and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "tigrbl_engine_snowflake"
7
- version = "0.4.2.dev3"
7
+ version = "0.4.2.dev4"
8
8
  description = "Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration."
9
9
  readme = "README.md"
10
10
  license = { file = "LICENSE" }
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: tigrbl_engine_snowflake
3
- Version: 0.4.2.dev3
3
+ Version: 0.4.2.dev4
4
4
  Summary: Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.
5
5
  Author-email: Jacob Stewart <jacob@swarmauri.com>
6
6
  License: Apache License
@@ -231,6 +231,7 @@ Classifier: Topic :: Database
231
231
  Requires-Python: <3.15,>=3.10
232
232
  Description-Content-Type: text/markdown
233
233
  License-File: LICENSE
234
+ License-File: NOTICE
234
235
  Requires-Dist: SQLAlchemy<3.0,>=2.0
235
236
  Requires-Dist: snowflake-sqlalchemy<2.0,>=1.5
236
237
  Requires-Dist: snowflake-connector-python<4.0,>=3.0
@@ -242,12 +243,45 @@ Dynamic: license-file
242
243
  <p><strong>Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.</strong></p>
243
244
  <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://img.shields.io/pypi/v/tigrbl_engine_snowflake?label=PyPI" alt="PyPI version for tigrbl_engine_snowflake"/></a>
244
245
  <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://static.pepy.tech/badge/tigrbl_engine_snowflake" alt="Downloads for tigrbl_engine_snowflake"/></a>
246
+ <a href="https://discord.gg/K4YTAPapjR"><img src="https://img.shields.io/badge/Discord-Join%20chat-5865F2?logo=discord&logoColor=white" alt="Discord community for tigrbl_engine_snowflake"/></a>
245
247
  <a href="https://github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md"><img src="https://hits.sh/github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md.svg?label=hits" alt="Repository hits for tigrbl_engine_snowflake README"/></a>
246
248
  <a href="LICENSE"><img src="https://img.shields.io/badge/license-Apache%202.0-525252" alt="Apache 2.0 license"/></a>
247
- <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20to%203.15-3776ab" alt="Python requirement for tigrbl_engine_snowflake"/></a>
249
+ <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12%20%7C%203.13%20%7C%203.14-3776ab" alt="Python versions 3.10 | 3.11 | 3.12 | 3.13 | 3.14 for tigrbl_engine_snowflake"/></a>
248
250
  <a href="https://github.com/tigrbl/tigrbl/blob/master/docs/README.md"><img src="https://img.shields.io/badge/workspace-engines-1f6feb" alt="Workspace group for tigrbl_engine_snowflake"/></a>
249
251
  </div>
250
252
 
253
+ ## What is tigrbl_engine_snowflake?
254
+
255
+ Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.
256
+
257
+ ## Why use tigrbl_engine_snowflake?
258
+
259
+ Use it when a Tigrbl application needs this backend without installing every engine package.
260
+
261
+ ## When should I install tigrbl_engine_snowflake?
262
+
263
+ Install it when the storage, analytics, cache, or integration workload named by this package is the intended runtime backend.
264
+
265
+ ## Who is tigrbl_engine_snowflake for?
266
+
267
+ Application developers, data platform engineers, and operators choosing concrete persistence or data-plane behavior.
268
+
269
+ ## Where does tigrbl_engine_snowflake fit?
270
+
271
+ `tigrbl_engine_snowflake` lives at `pkgs/engines/tigrbl_engine_snowflake` and serves Snowflake warehouse-backed analytics.
272
+
273
+ ## How does tigrbl_engine_snowflake work?
274
+
275
+ It exposes a `tigrbl.engine` entry point and a package `register()` hook so Tigrbl can discover or load the backend at runtime.
276
+
277
+ ## Certification Status
278
+
279
+ - Package status: governed package in the `tigrbl/tigrbl` workspace.
280
+ - Governance source: [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json).
281
+ - Release evidence: [publish workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml) validates package builds, tests, GitHub release assets, and PyPI publication for managed packages.
282
+ - Local certification guard: `pkgs/core/tigrbl_tests/tests/unit/test_package_badges_and_notices.py` verifies every package README keeps the Discord badge, Apache 2.0 badge, explicit Python-version badge, `LICENSE`, and `NOTICE`.
283
+ - Scope note: this README documents the package boundary. Runtime feature support remains governed by `.ssot/` entities and the conformance docs linked below.
284
+
251
285
  ## Install
252
286
 
253
287
  ```bash
@@ -258,50 +292,105 @@ uv add tigrbl_engine_snowflake
258
292
  pip install tigrbl_engine_snowflake
259
293
  ```
260
294
 
295
+ ## Surface Coverage
296
+
297
+ | Surface | Value |
298
+ |---|---|
299
+ | PyPI package | [`tigrbl_engine_snowflake`](https://pypi.org/project/tigrbl_engine_snowflake/) |
300
+ | Repository path | [`pkgs/engines/tigrbl_engine_snowflake`](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake) |
301
+ | Python import root | `tigrbl_engine_snowflake` |
302
+ | Console scripts | none declared |
303
+ | Entry points | `tigrbl.engine` |
304
+ | Optional extras | none declared |
305
+ | Legal files | `LICENSE`, `NOTICE` |
306
+ | Supported Python | `3.10 | 3.11 | 3.12 | 3.13 | 3.14` |
307
+
261
308
  ## What It Owns
262
309
 
263
- `tigrbl_engine_snowflake` owns the engine snowflake backend boundary for Tigrbl, including engine registration, session adapters, and backend-specific helpers. Key implementation roots include `tigrbl_engine_snowflake` with `engine, session`.
310
+ `tigrbl_engine_snowflake` owns the `engine plugin` boundary. It should be installed when you need this package's focused responsibility without assuming every other Tigrbl workspace package is present.
311
+
312
+ Implementation orientation:
313
+ - `tigrbl_engine_snowflake`: engine, session
264
314
 
265
- ## Use It When
315
+ ## Public API and Import Surface
266
316
 
267
- Use `tigrbl_engine_snowflake` when you want the engine snowflake backend installed as an isolated dependency instead of pulling every engine into your environment.
317
+ - Import roots: `tigrbl_engine_snowflake`.
318
+ - Public symbols: `SnowflakeSession`, `register`, `snowflake_capabilities`, `snowflake_engine`.
319
+ - Workspace dependencies: none declared.
320
+ - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
268
321
 
269
- ## Public Surface
322
+ ## Usage Examples
270
323
 
271
- - `tigrbl_engine_snowflake` exposes `snowflake_engine, snowflake_capabilities, SnowflakeSession, register`.
324
+ ### Verify the installed package
272
325
 
273
- ## Internal Layout
326
+ ```bash
327
+ python -m pip show tigrbl_engine_snowflake
328
+ python - <<'PY'
329
+ from importlib.metadata import version
330
+ print(version("tigrbl_engine_snowflake"))
331
+ PY
332
+ ```
274
333
 
275
- - Workspace path: `pkgs/engines/tigrbl_engine_snowflake`.
276
- - Package class: `engine plugin`.
277
- - Python requirement: `>=3.10,<3.15`.
278
- - `tigrbl_engine_snowflake` modules: `engine, session`.
334
+ ### Register the engine plugin explicitly
279
335
 
280
- ## Dependency Surface
336
+ ```python
337
+ from tigrbl_engine_snowflake import register
281
338
 
282
- - Workspace package dependencies: none declared.
283
- - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
284
- - Optional extras: none declared.
339
+ register()
340
+ ```
341
+
342
+ ### Discover the engine through package metadata
343
+
344
+ ```python
345
+ from importlib.metadata import entry_points
346
+
347
+ for entry_point in entry_points(group="tigrbl.engine"):
348
+ if entry_point.module.startswith("tigrbl_engine_snowflake"):
349
+ plugin_register = entry_point.load()
350
+ plugin_register()
351
+ ```
352
+
353
+ ### Install alongside the facade
354
+
355
+ ```bash
356
+ uv add tigrbl tigrbl_engine_snowflake
357
+ pip install tigrbl tigrbl_engine_snowflake
358
+ ```
359
+
360
+ ## How To Choose This Package
361
+
362
+ Choose `tigrbl_engine_snowflake` when the quick-answer table matches your use case. Choose [`tigrbl`](https://pypi.org/project/tigrbl/) instead when you want the full public facade. Choose a lower-level package such as [`tigrbl-core`](https://pypi.org/project/tigrbl-core/), [`tigrbl-base`](https://pypi.org/project/tigrbl-base/), or [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/) when you are building framework extensions or testing a specific internal boundary.
285
363
 
286
364
  ## Related Packages
287
365
 
288
366
  - [`tigrbl`](https://pypi.org/project/tigrbl/)
367
+ - [`tigrbl-core`](https://pypi.org/project/tigrbl-core/)
368
+ - [`tigrbl-runtime`](https://pypi.org/project/tigrbl-runtime/)
369
+ - [`tigrbl_engine_sqlite`](https://pypi.org/project/tigrbl_engine_sqlite/)
370
+ - [`tigrbl_engine_postgres`](https://pypi.org/project/tigrbl_engine_postgres/)
371
+ - [`tigrbl_engine_duckdb`](https://pypi.org/project/tigrbl_engine_duckdb/)
372
+ - [`tigrbl_engine_pandas`](https://pypi.org/project/tigrbl_engine_pandas/)
373
+
374
+ ## Documentation Links
375
+
376
+ - [Workspace docs](https://github.com/tigrbl/tigrbl/blob/master/docs/README.md)
377
+ - [Package catalog](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_CATALOG.md)
378
+ - [Package layout](https://github.com/tigrbl/tigrbl/blob/master/docs/developer/PACKAGE_LAYOUT.md)
379
+ - [Current target](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_TARGET.md)
380
+ - [Current state](https://github.com/tigrbl/tigrbl/blob/master/docs/conformance/CURRENT_STATE.md)
381
+ - [SSOT registry](https://github.com/tigrbl/tigrbl/blob/master/.ssot/registry.json)
382
+ - [Release workflow](https://github.com/tigrbl/tigrbl/actions/workflows/publish.yml)
289
383
 
290
- ## Canonical Repository Docs
384
+ ## Support
291
385
 
292
- - `docs/README.md`
293
- - `docs/conformance/CURRENT_TARGET.md`
294
- - `docs/conformance/CURRENT_STATE.md`
295
- - `docs/conformance/NEXT_STEPS.md`
296
- - `docs/governance/DOC_POINTERS.md`
297
- - `docs/developer/PACKAGE_CATALOG.md`
298
- - `docs/developer/PACKAGE_LAYOUT.md`
386
+ - Community: [Discord](https://discord.gg/K4YTAPapjR).
387
+ - Issues: [GitHub Issues](https://github.com/tigrbl/tigrbl/issues).
388
+ - Repository: [pkgs/engines/tigrbl_engine_snowflake](https://github.com/tigrbl/tigrbl/tree/master/pkgs/engines/tigrbl_engine_snowflake).
299
389
 
300
390
  ## Package-local Boundary
301
391
 
302
- This file is a package-local distribution entry point.
303
- Use this page for package installation and boundary orientation. Repository governance, conformance state, target status, and release evidence remain governed from `docs/` and `.ssot/`.
392
+ This README is the package-local distribution entry point for `tigrbl_engine_snowflake`. It answers install, usage, API, ownership, and certification-orientation questions for this package. Broader architectural decisions, release status, and cross-package proof chains remain in the repository-level docs and SSOT registry.
304
393
 
305
394
  ## License
306
395
 
307
- Licensed under the Apache License, Version 2.0. See `LICENSE` and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).
396
+ Licensed under the Apache License, Version 2.0. See `LICENSE`, `NOTICE`, and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).
@@ -1,4 +1,5 @@
1
1
  LICENSE
2
+ NOTICE
2
3
  README.md
3
4
  pyproject.toml
4
5
  src/tigrbl_engine_snowflake/__init__.py
@@ -1,69 +0,0 @@
1
- <div align="center">
2
- <h1>tigrbl_engine_snowflake</h1>
3
- <img src="https://raw.githubusercontent.com/swarmauri/swarmauri-sdk/master/assets/tigrbl_full_logo.png" alt="Tigrbl logo" width="140"/>
4
- <p><strong>Snowflake engine plugin for warehouse sessions, analytical workloads, and Tigrbl engine registration.</strong></p>
5
- <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://img.shields.io/pypi/v/tigrbl_engine_snowflake?label=PyPI" alt="PyPI version for tigrbl_engine_snowflake"/></a>
6
- <a href="https://pypi.org/project/tigrbl_engine_snowflake/"><img src="https://static.pepy.tech/badge/tigrbl_engine_snowflake" alt="Downloads for tigrbl_engine_snowflake"/></a>
7
- <a href="https://github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md"><img src="https://hits.sh/github.com/tigrbl/tigrbl/blob/master/pkgs/engines/tigrbl_engine_snowflake/README.md.svg?label=hits" alt="Repository hits for tigrbl_engine_snowflake README"/></a>
8
- <a href="LICENSE"><img src="https://img.shields.io/badge/license-Apache%202.0-525252" alt="Apache 2.0 license"/></a>
9
- <a href="pyproject.toml"><img src="https://img.shields.io/badge/python-3.10%20to%203.15-3776ab" alt="Python requirement for tigrbl_engine_snowflake"/></a>
10
- <a href="https://github.com/tigrbl/tigrbl/blob/master/docs/README.md"><img src="https://img.shields.io/badge/workspace-engines-1f6feb" alt="Workspace group for tigrbl_engine_snowflake"/></a>
11
- </div>
12
-
13
- ## Install
14
-
15
- ```bash
16
- uv add tigrbl_engine_snowflake
17
- ```
18
-
19
- ```bash
20
- pip install tigrbl_engine_snowflake
21
- ```
22
-
23
- ## What It Owns
24
-
25
- `tigrbl_engine_snowflake` owns the engine snowflake backend boundary for Tigrbl, including engine registration, session adapters, and backend-specific helpers. Key implementation roots include `tigrbl_engine_snowflake` with `engine, session`.
26
-
27
- ## Use It When
28
-
29
- Use `tigrbl_engine_snowflake` when you want the engine snowflake backend installed as an isolated dependency instead of pulling every engine into your environment.
30
-
31
- ## Public Surface
32
-
33
- - `tigrbl_engine_snowflake` exposes `snowflake_engine, snowflake_capabilities, SnowflakeSession, register`.
34
-
35
- ## Internal Layout
36
-
37
- - Workspace path: `pkgs/engines/tigrbl_engine_snowflake`.
38
- - Package class: `engine plugin`.
39
- - Python requirement: `>=3.10,<3.15`.
40
- - `tigrbl_engine_snowflake` modules: `engine, session`.
41
-
42
- ## Dependency Surface
43
-
44
- - Workspace package dependencies: none declared.
45
- - External runtime dependencies: `SQLAlchemy>=2.0,<3.0`, `snowflake-sqlalchemy>=1.5,<2.0`, `snowflake-connector-python>=3.0,<4.0`.
46
- - Optional extras: none declared.
47
-
48
- ## Related Packages
49
-
50
- - [`tigrbl`](https://pypi.org/project/tigrbl/)
51
-
52
- ## Canonical Repository Docs
53
-
54
- - `docs/README.md`
55
- - `docs/conformance/CURRENT_TARGET.md`
56
- - `docs/conformance/CURRENT_STATE.md`
57
- - `docs/conformance/NEXT_STEPS.md`
58
- - `docs/governance/DOC_POINTERS.md`
59
- - `docs/developer/PACKAGE_CATALOG.md`
60
- - `docs/developer/PACKAGE_LAYOUT.md`
61
-
62
- ## Package-local Boundary
63
-
64
- This file is a package-local distribution entry point.
65
- Use this page for package installation and boundary orientation. Repository governance, conformance state, target status, and release evidence remain governed from `docs/` and `.ssot/`.
66
-
67
- ## License
68
-
69
- Licensed under the Apache License, Version 2.0. See `LICENSE` and the official [Apache 2.0 license text](https://www.apache.org/licenses/LICENSE-2.0).