Skip to main content

upload_task_templates

This script takes a config of task templates and uploads them to bitfount hub.

The config also contains paths to any custom models and weights that are used in the task templates. If the models or weights have changed since the last upload, the models and weights are uploaded to bitfount hub and the task templates are updated to use the new versions of the models and weights. Finally, there is also the option to archive task templates that are no longer used.


Example dev usage:

```bash
BITFOUNT_ENVIRONMENT=dev python -m bitfount.runners.upload_task_templates \\
task_templates/config-staging.yaml -u <username> -p <password>

Example production usage:

python -m bitfount.runners.upload_task_templates \\
task_templates/config-production.yaml -u <username> -p <password>

Module

Functions

main

def main(    config_file: os.PathLike, username: str = 'bitfount', password: Optional[str] = None,)> None:

Uploads models, weights and task templates to bitfount.

Iterates over the models in the config file and uploads them to bitfount if the code hash or weights are different from the latest version on bitfount. Once the models are updated, the task templates are updated to use the latest versions of the models and the task templates are themselves uploaded to bitfount.

Arguments

  • config_file: The path to the YAML config.
  • username: The username for the model owner. Defaults to 'bitfount'.
  • password: The password for the model owner if using ExternallyManagedJWTHandler for authentication. Defaults to None.

Classes

BasicTaskTemplateConfig

class BasicTaskTemplateConfig(**data: Any):

Base task template config model for static and runtime type checking.

Create a new model by parsing and validating input data from keyword arguments.

Raises [ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.

self is explicitly positional-only to allow self as a field name.

Ancestors

  • pydantic.main.BaseModel

Variables

  • static model_computed_fields
  • static model_config
  • static model_fields
  • static slug : str

ModelConfig

class ModelConfig(**data: Any):

Model config model for static and runtime type checking.

Create a new model by parsing and validating input data from keyword arguments.

Raises [ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.

self is explicitly positional-only to allow self as a field name.

Ancestors

  • pydantic.main.BaseModel

Variables

  • static model_computed_fields
  • static model_config
  • static model_fields
  • static model_file : str
  • static private : bool
  • static weights_file : Optional[str]

TaskTemplateConfig

class TaskTemplateConfig(**data: Any):

Model config model for static and runtime type checking.

Create a new model by parsing and validating input data from keyword arguments.

Raises [ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.

self is explicitly positional-only to allow self as a field name.

Ancestors

Variables

  • static description : str
  • static model_computed_fields
  • static model_config
  • static model_fields
  • static tags : Optional[list[str]]
  • static template : str
  • static title : str
  • static type : Union[Literal['image-segmentation'], Literal['image-classification'], Literal['object-detection'], Literal['text-classification'], Literal['text-generation'], Literal['tabular-classification'], Literal['tabular-regression']]