-
Notifications
You must be signed in to change notification settings - Fork 1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #16778 from heisner-tillman/jobs
Migrate a part of the jobs API to Fast API
- Loading branch information
Showing
9 changed files
with
1,654 additions
and
997 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,233 @@ | ||
import json | ||
from typing import ( | ||
Any, | ||
Dict, | ||
List, | ||
Optional, | ||
) | ||
|
||
from pydantic import ( | ||
Extra, | ||
Field, | ||
Required, | ||
UUID4, | ||
validator, | ||
) | ||
from typing_extensions import Literal | ||
|
||
from galaxy.schema.fields import ( | ||
DecodedDatabaseIdField, | ||
EncodedDatabaseIdField, | ||
) | ||
from galaxy.schema.schema import ( | ||
DataItemSourceType, | ||
EncodedDataItemSourceId, | ||
EntityIdField, | ||
JobState, | ||
JobSummary, | ||
Model, | ||
) | ||
|
||
|
||
class JobInputSummary(Model): | ||
has_empty_inputs: bool = Field( | ||
default=Required, | ||
title="Empty inputs", | ||
description="Job has empty inputs.", | ||
) | ||
has_duplicate_inputs: bool = Field( | ||
default=Required, | ||
title="Duplicate inputs", | ||
description="Job has duplicate inputs.", | ||
) | ||
|
||
|
||
# TODO: Use Tuple again when `make update-client-api-schema` supports them | ||
class JobErrorSummary(Model): | ||
# messages: List[Union[Tuple[str, str], List[str]]] | ||
messages: List[List[str]] = Field( | ||
default=Required, | ||
title="Error messages", | ||
description="The error messages for the specified job.", | ||
) | ||
|
||
|
||
class JobAssociation(Model): | ||
name: str = Field( | ||
default=Required, | ||
title="name", | ||
description="Name of the job parameter.", | ||
) | ||
dataset: EncodedDataItemSourceId = Field( | ||
default=Required, | ||
title="dataset", | ||
description="Reference to the associated item.", | ||
) | ||
|
||
|
||
class JobInputAssociation(JobAssociation): | ||
name: str = Field( | ||
default=Required, | ||
title="name", | ||
description="Name of the job input parameter.", | ||
) | ||
|
||
|
||
class JobOutputAssociation(JobAssociation): | ||
name: str = Field( | ||
default=Required, | ||
title="name", | ||
description="Name of the job output parameter.", | ||
) | ||
|
||
|
||
class ReportJobErrorPayload(Model): | ||
dataset_id: DecodedDatabaseIdField = Field( | ||
default=Required, | ||
title="History Dataset Association ID", | ||
description="The History Dataset Association ID related to the error.", | ||
) | ||
email: Optional[str] = Field( | ||
default=None, | ||
title="Email", | ||
description="Email address for communication with the user. Only required for anonymous users.", | ||
) | ||
message: Optional[str] = Field( | ||
default=None, | ||
title="Message", | ||
description="The optional message sent with the error report.", | ||
) | ||
|
||
|
||
class SearchJobsPayload(Model): | ||
tool_id: str = Field( | ||
default=Required, | ||
title="Tool ID", | ||
description="The tool ID related to the job.", | ||
) | ||
inputs: Dict[str, Any] = Field( | ||
default=Required, | ||
title="Inputs", | ||
description="The inputs of the job.", | ||
) | ||
state: JobState = Field( | ||
default=Required, | ||
title="State", | ||
description="Current state of the job.", | ||
) | ||
|
||
@validator("inputs", pre=True) | ||
def decode_json(cls, v): | ||
if isinstance(v, str): | ||
return json.loads(v) | ||
return v | ||
|
||
class Config: | ||
extra = Extra.allow # This is used for items named file_ and __file_ | ||
|
||
|
||
class DeleteJobPayload(Model): | ||
message: Optional[str] = Field( | ||
default=None, | ||
title="Job message", | ||
description="Stop message", | ||
) | ||
|
||
|
||
class SrcItem(Model): | ||
src: DataItemSourceType | ||
|
||
|
||
class EncodedHdcaSourceId(SrcItem): | ||
id: EncodedDatabaseIdField = EntityIdField | ||
src: Literal[DataItemSourceType.hdca] = Field( | ||
default=Required, | ||
title="Source", | ||
description="The source of this dataset, which in the case of the model can only be `hdca`.", | ||
) | ||
|
||
|
||
class EncodedDatasetJobInfo(EncodedDataItemSourceId): | ||
uuid: Optional[UUID4] = Field( | ||
default=None, | ||
deprecated=True, | ||
title="UUID", | ||
description="Universal unique identifier for this dataset.", | ||
) | ||
|
||
|
||
class EncodedJobDetails(JobSummary): | ||
command_version: str = Field( | ||
..., | ||
title="Command Version", | ||
description="Tool version indicated during job execution.", | ||
) | ||
params: Any = Field( | ||
..., | ||
title="Parameters", | ||
description=( | ||
"Object containing all the parameters of the tool associated with this job. " | ||
"The specific parameters depend on the tool itself." | ||
), | ||
) | ||
inputs: Dict[str, EncodedDatasetJobInfo] = Field( | ||
{}, | ||
title="Inputs", | ||
description="Dictionary mapping all the tool inputs (by name) to the corresponding data references.", | ||
) | ||
outputs: Dict[str, EncodedDatasetJobInfo] = Field( | ||
{}, | ||
title="Outputs", | ||
description="Dictionary mapping all the tool outputs (by name) to the corresponding data references.", | ||
) | ||
copied_from_job_id: Optional[EncodedDatabaseIdField] = Field( | ||
default=None, title="Copied from Job-ID", description="Reference to cached job if job execution was cached." | ||
) | ||
output_collections: Dict[str, EncodedHdcaSourceId] = Field(default={}, title="Output collections", description="") | ||
|
||
|
||
class JobDestinationParams(Model): | ||
runner: Optional[str] = Field(None, title="Runner", description="Job runner class", alias="Runner") | ||
runner_job_id: Optional[str] = Field( | ||
None, | ||
title="Runner Job ID", | ||
description="ID assigned to submitted job by external job running system", | ||
alias="Runner Job ID", | ||
) | ||
handler: Optional[str] = Field( | ||
None, title="Handler", description="Name of the process that handled the job.", alias="Handler" | ||
) | ||
|
||
|
||
class JobOutput(Model): | ||
label: Any = Field(default=Required, title="Output label", description="The output label") # check if this is true | ||
value: EncodedDataItemSourceId = Field(default=Required, title="Dataset", description="The associated dataset.") | ||
|
||
|
||
class JobParameter(Model): | ||
text: str = Field( | ||
default=Required, | ||
title="Text", | ||
description="Text associated with the job parameter.", | ||
) | ||
depth: int = Field( | ||
default=Required, | ||
title="Depth", | ||
description="The depth of the job parameter.", | ||
) | ||
value: Any = Field(default=Required, title="Value", description="The values of the job parameter") | ||
notes: Optional[str] = Field(default=None, title="Notes", description="Notes associated with the job parameter.") | ||
|
||
|
||
class JobDisplayParametersSummary(Model): | ||
parameters: List[JobParameter] = Field( | ||
default=Required, title="Parameters", description="The parameters of the job in a nested format." | ||
) | ||
has_parameter_errors: bool = Field( | ||
default=Required, title="Has parameter errors", description="The job has parameter errors" | ||
) | ||
outputs: Dict[str, List[JobOutput]] = Field( | ||
default=Required, | ||
title="Outputs", | ||
description="Dictionary mapping all the tool outputs (by name) with the corresponding dataset information in a nested format.", | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.