lumera 0.9.5__tar.gz → 0.9.6__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.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: lumera
3
- Version: 0.9.5
3
+ Version: 0.9.6
4
4
  Summary: SDK for building on Lumera platform
5
5
  Requires-Python: >=3.11
6
6
  Requires-Dist: requests
@@ -31,6 +31,9 @@ from .exceptions import (
31
31
  ValidationError,
32
32
  )
33
33
 
34
+ # Import file types for Pydantic automation inputs
35
+ from .files import LumeraFile, LumeraFiles
36
+
34
37
  # Import key SDK helpers to expose them at the package root.
35
38
  from .sdk import (
36
39
  CollectionField,
@@ -87,6 +90,8 @@ __all__ = [
87
90
  # Type definitions
88
91
  "CollectionField",
89
92
  "HookReplayResult",
93
+ "LumeraFile",
94
+ "LumeraFiles",
90
95
  # Exceptions
91
96
  "LumeraAPIError",
92
97
  "RecordNotUniqueError",
@@ -0,0 +1,97 @@
1
+ """
2
+ File input types for Lumera automations.
3
+
4
+ These types are used with Pydantic models to define file inputs for automations.
5
+ They generate the correct JSON schema format that the frontend recognizes for
6
+ file picker UI.
7
+
8
+ Example:
9
+ from pydantic import BaseModel, Field
10
+ from lumera import LumeraFile, LumeraFiles
11
+
12
+ class ProcessInputs(BaseModel):
13
+ report: LumeraFile = Field(..., description="Excel report to process")
14
+ attachments: LumeraFiles = Field(default=[], description="Additional files")
15
+
16
+ def main(inputs: ProcessInputs):
17
+ # inputs.report is a string path like "/tmp/lumera-files/report.xlsx"
18
+ with open(inputs.report) as f:
19
+ ...
20
+ """
21
+
22
+ from typing import Annotated, Any
23
+
24
+ # Check if Pydantic is available
25
+ try:
26
+ from pydantic import GetJsonSchemaHandler
27
+ from pydantic.json_schema import JsonSchemaValue
28
+ from pydantic_core import CoreSchema
29
+
30
+ _HAS_PYDANTIC = True
31
+ except ImportError:
32
+ _HAS_PYDANTIC = False
33
+
34
+
35
+ if _HAS_PYDANTIC:
36
+
37
+ class _LumeraFileSchema:
38
+ """
39
+ Pydantic JSON schema handler for single file inputs.
40
+
41
+ Generates: {"type": "string", "format": "file"}
42
+
43
+ The frontend recognizes this schema and renders a file picker.
44
+ At runtime, the value is a string path to the downloaded file.
45
+ """
46
+
47
+ @classmethod
48
+ def __get_pydantic_json_schema__(
49
+ cls, core_schema: CoreSchema, handler: GetJsonSchemaHandler
50
+ ) -> JsonSchemaValue:
51
+ return {"type": "string", "format": "file"}
52
+
53
+ class _LumeraFilesSchema:
54
+ """
55
+ Pydantic JSON schema handler for multiple file inputs.
56
+
57
+ Generates: {"type": "array", "items": {"type": "string", "format": "file"}}
58
+
59
+ The frontend recognizes this schema and renders a multi-file picker.
60
+ At runtime, the value is a list of string paths to downloaded files.
61
+ """
62
+
63
+ @classmethod
64
+ def __get_pydantic_json_schema__(
65
+ cls, core_schema: CoreSchema, handler: GetJsonSchemaHandler
66
+ ) -> JsonSchemaValue:
67
+ return {"type": "array", "items": {"type": "string", "format": "file"}}
68
+
69
+ # Public types using Annotated to attach schema handlers
70
+ LumeraFile: Any = Annotated[str, _LumeraFileSchema()]
71
+ """
72
+ Type for single file input in Pydantic models.
73
+
74
+ At runtime, this is a string containing the local file path.
75
+ In JSON schema, generates {"type": "string", "format": "file"}.
76
+
77
+ Example:
78
+ class Inputs(BaseModel):
79
+ document: LumeraFile = Field(..., description="PDF to process")
80
+ """
81
+
82
+ LumeraFiles: Any = Annotated[list[str], _LumeraFilesSchema()]
83
+ """
84
+ Type for multiple file inputs in Pydantic models.
85
+
86
+ At runtime, this is a list of strings containing local file paths.
87
+ In JSON schema, generates {"type": "array", "items": {"type": "string", "format": "file"}}.
88
+
89
+ Example:
90
+ class Inputs(BaseModel):
91
+ documents: LumeraFiles = Field(default=[], description="PDFs to merge")
92
+ """
93
+
94
+ else:
95
+ # Fallback when Pydantic is not installed - types are just aliases
96
+ LumeraFile: Any = str
97
+ LumeraFiles: Any = list
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: lumera
3
- Version: 0.9.5
3
+ Version: 0.9.6
4
4
  Summary: SDK for building on Lumera platform
5
5
  Requires-Python: >=3.11
6
6
  Requires-Dist: requests
@@ -3,6 +3,7 @@ lumera/__init__.py
3
3
  lumera/_utils.py
4
4
  lumera/automations.py
5
5
  lumera/exceptions.py
6
+ lumera/files.py
6
7
  lumera/google.py
7
8
  lumera/llm.py
8
9
  lumera/locks.py
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "lumera"
3
- version = "0.9.5"
3
+ version = "0.9.6"
4
4
  description = "SDK for building on Lumera platform"
5
5
  requires-python = ">=3.11"
6
6
  dependencies = [
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes