TypeTransformer
Package: flyte.types
Base transformer type that should be implemented for every python native type that can be handled by flytekit
Parameters
class TypeTransformer(
name: str,
t: Type[T],
enable_type_assertions: bool,
)| Parameter | Type | Description |
|---|---|---|
name |
str |
|
t |
Type[T] |
|
enable_type_assertions |
bool |
Properties
| Property | Type | Description |
|---|---|---|
name |
None |
|
python_type |
None |
This returns the python type |
type_assertions_enabled |
None |
Indicates if the transformer wants type assertions to be enabled at the core type engine layer |
Methods
| Method | Description |
|---|---|
assert_type() |
|
from_binary_idl() |
This function primarily handles deserialization for untyped dicts, dataclasses, Pydantic BaseModels, and. |
get_literal_type() |
Converts the python type to a Flyte LiteralType. |
guess_python_type() |
Converts the Flyte LiteralType to a python object type. |
isinstance_generic() |
|
schema_match() |
Check if a JSON schema fragment matches this transformer’s python_type. |
to_html() |
Converts any python val (dataframe, int, float) to a html string, and it will be wrapped in the HTML div. |
to_literal() |
Converts a given python_val to a Flyte Literal, assuming the given python_val matches the declared python_type. |
to_python_value() |
Converts the given Literal to a Python Type. |
assert_type()
def assert_type(
t: Type[T],
v: T,
)| Parameter | Type | Description |
|---|---|---|
t |
Type[T] |
|
v |
T |
from_binary_idl()
def from_binary_idl(
binary_idl_object: Binary,
expected_python_type: Type[T],
) -> Optional[T]This function primarily handles deserialization for untyped dicts, dataclasses, Pydantic BaseModels, and attribute access.
For untyped dict, dataclass, and pydantic basemodel: Life Cycle (Untyped Dict as example): python val -> msgpack bytes -> binary literal scalar -> msgpack bytes -> python val (to_literal) (from_binary_idl)
For attribute access: Life Cycle: python val -> msgpack bytes -> binary literal scalar -> resolved golang value -> binary literal scalar -> msgpack bytes -> python val (to_literal) (propeller attribute access) (from_binary_idl)
| Parameter | Type | Description |
|---|---|---|
binary_idl_object |
Binary |
|
expected_python_type |
Type[T] |
get_literal_type()
def get_literal_type(
t: Type[T],
) -> LiteralTypeConverts the python type to a Flyte LiteralType
| Parameter | Type | Description |
|---|---|---|
t |
Type[T] |
guess_python_type()
def guess_python_type(
literal_type: LiteralType,
) -> Type[T]Converts the Flyte LiteralType to a python object type.
| Parameter | Type | Description |
|---|---|---|
literal_type |
LiteralType |
isinstance_generic()
def isinstance_generic(
obj,
generic_alias,
)| Parameter | Type | Description |
|---|---|---|
obj |
||
generic_alias |
schema_match()
def schema_match(
schema: dict,
) -> boolCheck if a JSON schema fragment matches this transformer’s python_type.
For BaseModel subclasses, automatically compares the schema’s title, type, and required fields against the type’s own JSON schema. For other types, returns False by default — override if needed.
| Parameter | Type | Description |
|---|---|---|
schema |
dict |
to_html()
def to_html(
python_val: T,
expected_python_type: Type[T],
) -> strConverts any python val (dataframe, int, float) to a html string, and it will be wrapped in the HTML div
| Parameter | Type | Description |
|---|---|---|
python_val |
T |
|
expected_python_type |
Type[T] |
to_literal()
def to_literal(
python_val: T,
python_type: Type[T],
expected: LiteralType,
) -> LiteralConverts a given python_val to a Flyte Literal, assuming the given python_val matches the declared python_type. Implementers should refrain from using type(python_val) instead rely on the passed in python_type. If these do not match (or are not allowed) the Transformer implementer should raise an AssertionError, clearly stating what was the mismatch
| Parameter | Type | Description |
|---|---|---|
python_val |
T |
The actual value to be transformed |
python_type |
Type[T] |
The assumed type of the value (this matches the declared type on the function) |
expected |
LiteralType |
Expected Literal Type |
to_python_value()
def to_python_value(
lv: Literal,
expected_python_type: Type[T],
) -> Optional[T]Converts the given Literal to a Python Type. If the conversion cannot be done an AssertionError should be raised
| Parameter | Type | Description |
|---|---|---|
lv |
Literal |
The received literal Value |
expected_python_type |
Type[T] |
Expected native python type that should be returned |