UWSAppSettings#
- pydantic settings safir.uws.UWSAppSettings#
- Settings common to all applications using the UWS library. - The - Configclass for an application should inherit from this class to get the standard UWS application settings.- Parameters:
- _nested_model_default_partial_update ( - bool|- None, default:- None)
- _env_file ( - Union[- Path,- str,- Sequence[- Union[- Path,- str]],- None], default:- PosixPath('.'))
- _cli_parse_args ( - bool|- list[- str] |- tuple[- str,- ...] |- None, default:- None)
- _cli_settings_source ( - Optional[- CliSettingsSource[- Any]], default:- None)
- _cli_shortcuts ( - Mapping[- str,- str|- list[- str]] |- None, default:- None)
- _secrets_dir ( - Union[- Path,- str,- Sequence[- Union[- Path,- str]],- None], default:- None)
- values ( - Any)
 
 - Show JSON schema- { "title": "UWSAppSettings", "description": "Settings common to all applications using the UWS library.\n\nThe ``Config`` class for an application should inherit from this class to\nget the standard UWS application settings.", "type": "object", "properties": { "arq_mode": { "$ref": "#/$defs/ArqMode", "default": "production", "description": "This will always be production outside the test suite", "title": "arq operation mode" }, "arq_queue_url": { "$ref": "#/$defs/EnvRedisDsn", "description": "DSN of Redis server to use for the arq queue", "title": "arq Redis DSN" }, "arq_queue_password": { "anyOf": [ { "format": "password", "type": "string", "writeOnly": true }, { "type": "null" } ], "default": null, "description": "Password of Redis server to use for the arq queue", "title": "Password for arq Redis server" }, "grace_period": { "$ref": "#/$defs/SecondsTimedelta", "default": "PT30S", "description": "How long to wait for a job to finish on shutdown before canceling it", "title": "Grace period for jobs" }, "lifetime": { "$ref": "#/$defs/HumanTimedelta", "default": "P7D", "title": "Lifetime of job results" }, "service_account": { "description": "Email of the service account to use for signed URLs of results. The default credentials that the application frontend runs with must have the ``roles/iam.serviceAccountTokenCreator`` role on the service account with this email.", "title": "Service account for URL signing", "type": "string" }, "storage_url": { "description": "Must be a ``gs`` or ``s3`` URL pointing to a Google Cloud Storage bucket that is writable by the backend and readable by the frontend.", "title": "Root URL for cutout results", "type": "string" }, "sync_timeout": { "$ref": "#/$defs/HumanTimedelta", "default": "PT1M", "title": "Timeout for sync requests" }, "timeout": { "$ref": "#/$defs/SecondsTimedelta", "default": "PT10M", "description": "Must be given as a number of seconds as a string or integer", "title": "Job timeout in seconds" }, "wobbly_url": { "description": "URL to Wobbly UWS job tracking API", "format": "uri", "maxLength": 2083, "minLength": 1, "title": "Wobbly URL", "type": "string" } }, "$defs": { "ArqMode": { "description": "Mode configuration for the Arq queue.", "enum": [ "production", "test" ], "title": "ArqMode", "type": "string" }, "EnvRedisDsn": { "format": "uri", "minLength": 1, "type": "string" }, "HumanTimedelta": { "format": "duration", "type": "string" }, "SecondsTimedelta": { "format": "duration", "type": "string" } }, "additionalProperties": false, "required": [ "arq_queue_url", "service_account", "storage_url", "wobbly_url" ] } - Fields:
 - field arq_mode: ArqMode = ArqMode.production#
- This will always be production outside the test suite 
 - field arq_queue_password: SecretStr | None = None#
- Password of Redis server to use for the arq queue 
 - field arq_queue_url: EnvRedisDsn [Required]#
- DSN of Redis server to use for the arq queue 
 - field grace_period: SecondsTimedelta = datetime.timedelta(seconds=30)#
- How long to wait for a job to finish on shutdown before canceling it 
 - field lifetime: HumanTimedelta = datetime.timedelta(days=7)#
 - field service_account: str [Required]#
- Email of the service account to use for signed URLs of results. The default credentials that the application frontend runs with must have the - roles/iam.serviceAccountTokenCreatorrole on the service account with this email.
 - field storage_url: str [Required]#
- Must be a - gsor- s3URL pointing to a Google Cloud Storage bucket that is writable by the backend and readable by the frontend.
 - field sync_timeout: HumanTimedelta = datetime.timedelta(seconds=60)#
 - field timeout: SecondsTimedelta = datetime.timedelta(seconds=600)#
- Must be given as a number of seconds as a string or integer 
 - field wobbly_url: HttpUrl [Required]#
- URL to Wobbly UWS job tracking API 
 - build_uws_config(*, async_post_route, job_summary_type, parameters_type, slack_webhook=None, sync_get_route=None, sync_post_route=None, url_lifetime=datetime.timedelta(seconds=900), validate_destruction=None, validate_execution_duration=None, wait_timeout=datetime.timedelta(seconds=60), worker)#
- Construct a - UWSConfigobject from the application configuration.- This helper method can be used by application - Configclasses to help build the- UWSConfigobject corresponding to the application configuration. Its parameters are the additional settings accepted by the UWS library that are not part of the- UWSAppSettingsmodel.- Parameters:
- async_post_route ( - UWSRoute) – Route configuration for job parameters for an async job via POST. The FastAPI dependency included in this object should expect POST parameters and return a Pydantic model representing the job parameters.
- job_summary_type ( - type[- JobSummary]) – Type representing the XML job summary type, qualified with an appropriate subclass of- Parameters. That subclass should be the same as that returned by the- to_xml_modelmethod of- parameters_type.
- parameters_type ( - type[- ParametersModel]) – Type representing the job parameters. This will be used to validate parameters and to parse them before passing them to the worker.
- slack_webhook ( - SecretStr|- None, default:- None) – Slack incoming webhook for reporting errors.
- sync_get_route ( - UWSRoute|- None, default:- None) – Route configuration for creating a sync job via GET. The FastAPI dependency included in this object should expect GET parameters and return a Pydantic model representing the job parameters. If- None, no route to create a job via sync GET will be created.
- sync_post_route ( - UWSRoute|- None, default:- None) – Route configuration for creating a sync job via POST. The FastAPI dependency included in this object should expect POST parameters and return a Pydantic model representing the job parameters. If- None, no route to create a job via sync POST will be created.
- url_lifetime ( - timedelta, default:- datetime.timedelta(seconds=900)) – How long result URLs should be valid for.
- validate_destruction ( - TypeAliasType|- None, default:- None) – Validate a new destruction time for a job. If provided, called with the requested destruction time and the current job record and should return the new destruction time. Otherwise, any destruction time before the configured maximum lifetime will be allowed.
- validate_execution_duration ( - TypeAliasType|- None, default:- None) – Validate a new execution duration for a job. If provided, called with the requested execution duration and the current job record and should return the new execution duration time. Otherwise, the execution duration may not be changed.
- wait_timeout ( - timedelta, default:- datetime.timedelta(seconds=60)) – Maximum time a client can wait for a job change.
- worker ( - str) – Name of the backend worker to call to execute a job.
 
- Returns:
- UWS configuration. 
- Return type:
 - Examples - Normally, this method is used from a property method that returns the UWS configuration, such as the following example for a cutout service: - @property def uws_config(self) -> UWSConfig: return self.build_uws_config( async_post_route=UWSRoute( dependency=post_params_dependency, summary="Create async cutout job", ), parameters_type=CutoutParameters, slack_webhook=self.slack_webhook, sync_get_route=UWSRoute( dependency=get_params_dependency, summary="Synchronous cutout", ), sync_post_route=UWSRoute( dependency=post_params_dependency, summary="Synchronous cutout", ), worker="cutout", ) 
 - property arq_redis_settings: RedisSettings#
- Redis settings for arq.