feat: add schemas subgraph#130
Merged
VictoriaBeilsten-Edmands merged 2 commits intomainfrom Mar 18, 2026
Merged
Conversation
@@ -192,6 +192,7 @@ scalar join__FieldSet
enum join__Graph {
INSTRUMENT_SESSIONS @join__graph(name: "instrument_sessions", url: "https://instrument-sessions.diamond.ac.uk/api/graphql")
SAMPLES @join__graph(name: "samples", url: "https://sample-information.diamond.ac.uk/api/graphql")
+ SCHEMAS @join__graph(name: "schemas", url: "https://schemas.diamond.ac.uk/graphql")
WORKFLOWS @join__graph(name: "workflows", url: "https://workflows.diamond.ac.uk/graphql")
}
@@ -207,6 +208,32 @@ scalar JSON
scalar JSONObject
@join__type(graph: WORKFLOWS)
+"""A JSON schema"""
+type JSONSchema
+ @join__type(graph: SCHEMAS)
+{
+ """The identifier of the schema"""
+ id: String!
+
+ """A URL from which the schema can be accessed"""
+ url: String!
+
+ """The type of object the shema describes (if known)"""
+ type: String
+
+ """The title of the schema"""
+ title: String
+
+ """The version of the schema"""
+ version: String
+
+ """The instrument the schema was created for"""
+ instrument: String
+
+ """The description og the schema"""
+ description: String
+}
+
scalar link__Import
enum link__Purpose {
@@ -294,6 +321,7 @@ enum ProposalState
type Query
@join__type(graph: INSTRUMENT_SESSIONS)
@join__type(graph: SAMPLES)
+ @join__type(graph: SCHEMAS)
@join__type(graph: WORKFLOWS)
{
"""Get a proposal by its number"""
@@ -322,6 +350,8 @@ type Query
"""Get a list of samples associated with a given instrument session"""
samples(proposalNumber: Int!, instrumentSessionNumber: Int!, first: Int!, filter: SampleFilterInput! = {}, before: String = null, after: String = null, last: Int = null, orderBy: SampleOrder! = {}): SampleConnection! @join__field(graph: SAMPLES)
+ jsonSchema(url: String!): JSONSchema @join__field(graph: SCHEMAS)
+ jsonSchemas(type: String = null, instrument: String = null): [JSONSchema!]! @join__field(graph: SCHEMAS)
"""Get a single [`Workflow`] by proposal, visit, and name"""
workflow(visit: VisitInput!, name: String!): Workflow! @join__field(graph: WORKFLOWS) |
diff --git a/tmp/old_sorted.json b/tmp/new_sorted.json
index 2e80215..79c7f62 100644
--- a/tmp/old_sorted.json
+++ b/tmp/new_sorted.json
@@ -598,6 +598,61 @@
"typeName": "Query"
}
]
+ },
+ {
+ "childNodes": [
+ {
+ "fieldNames": [
+ "id",
+ "url",
+ "type",
+ "title",
+ "version",
+ "instrument",
+ "description"
+ ],
+ "typeName": "JSONSchema"
+ }
+ ],
+ "customGraphql": {
+ "federation": {
+ "enabled": true,
+ "serviceSdl": "\"\"\"A JSON schema\"\"\"\ntype JSONSchema {\n \"\"\"The identifier of the schema\"\"\"\n id: String!\n\n \"\"\"A URL from which the schema can be accessed\"\"\"\n url: String!\n\n \"\"\"The type of object the shema describes (if known)\"\"\"\n type: String\n\n \"\"\"The title of the schema\"\"\"\n title: String\n\n \"\"\"The version of the schema\"\"\"\n version: String\n\n \"\"\"The instrument the schema was created for\"\"\"\n instrument: String\n\n \"\"\"The description og the schema\"\"\"\n description: String\n}\n\ntype Query {\n _service: _Service!\n jsonSchema(url: String!): JSONSchema\n jsonSchemas(type: String = null, instrument: String = null): [JSONSchema!]!\n}\n\nscalar _Any\n\ntype _Service {\n sdl: String!\n}\n"
+ },
+ "fetch": {
+ "baseUrl": {},
+ "body": {},
+ "method": "POST",
+ "path": {},
+ "url": {
+ "staticVariableContent": "https://schemas.diamond.ac.uk/graphql"
+ }
+ },
+ "subscription": {
+ "enabled": true,
+ "protocol": "GRAPHQL_SUBSCRIPTION_PROTOCOL_WS",
+ "url": {
+ "staticVariableContent": "https://schemas.diamond.ac.uk/graphql"
+ },
+ "websocketSubprotocol": "GRAPHQL_WEBSOCKET_SUBPROTOCOL_AUTO"
+ },
+ "upstreamSchema": {
+ "key": "ab9040c814f11559b1e7d93f67b38b284f1bf0d3"
+ }
+ },
+ "id": "3",
+ "kind": "GRAPHQL",
+ "overrideFieldPathFromAlias": true,
+ "requestTimeoutSeconds": "10",
+ "rootNodes": [
+ {
+ "fieldNames": [
+ "jsonSchema",
+ "jsonSchemas"
+ ],
+ "typeName": "Query"
+ }
+ ]
}
],
"defaultFlushInterval": "500",
@@ -876,6 +931,30 @@
"fieldName": "sample",
"typeName": "Query"
},
+ {
+ "argumentsConfiguration": [
+ {
+ "name": "url",
+ "sourceType": "FIELD_ARGUMENT"
+ }
+ ],
+ "fieldName": "jsonSchema",
+ "typeName": "Query"
+ },
+ {
+ "argumentsConfiguration": [
+ {
+ "name": "type",
+ "sourceType": "FIELD_ARGUMENT"
+ },
+ {
+ "name": "instrument",
+ "sourceType": "FIELD_ARGUMENT"
+ }
+ ],
+ "fieldName": "jsonSchemas",
+ "typeName": "Query"
+ },
{
"argumentsConfiguration": [
{
@@ -1057,11 +1136,12 @@
"typeName": "SampleMutations"
}
],
- "graphqlSchema": "schema {\n query: Query\n mutation: Mutation\n subscription: Subscription\n}\n\ntype Artifact {\n \"\"\"The file name of the artifact\"\"\"\n name: String!\n \"\"\"The download URL for the artifact\"\"\"\n url: Url!\n \"\"\"The MIME type of the artifact data\"\"\"\n mimeType: String!\n}\n\nscalar Creator\n\n\"\"\"\nImplement the DateTime<Utc> scalar\n\nThe input/output is a string in RFC3339 format.\n\"\"\"\nscalar DateTime\n\n\"\"\"\nThe `JSON` scalar type represents JSON values as specified by [ECMA-404](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf).\n\"\"\"\nscalar JSON\n\n\"\"\"A scalar that can represent any JSON Object value.\"\"\"\nscalar JSONObject\n\n\"\"\"A single log line streamed from a pod\"\"\"\ntype LogEntry {\n \"\"\"The log line content\"\"\"\n content: String!\n \"\"\"The name of the pod producing the log\"\"\"\n podName: String!\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Mutation {\n submitWorkflowTemplate(name: String!, visit: VisitInput!, parameters: JSON!): Workflow!\n instrumentSession(proposalNumber: Int!, instrumentSessionNumber: Int!): InstrumentSessionMutations\n createOrValidateSamples(input: CreateOrValidateSampleInput!): CreateSamplesResponse!\n createSamples(input: CreateSampleInput!): [Sample!]! @deprecated(reason: \"Will be replaced by createOrValidateSamples\")\n sample(sampleId: UUID!): SampleMutations\n}\n\n\"\"\"Represents Relay Node types\"\"\"\nunion NodeValue = Workflow\n\n\"\"\"Information about pagination in a connection\"\"\"\ntype PageInfo {\n \"\"\"When paginating backwards, are there more items?\"\"\"\n hasPreviousPage: Boolean!\n \"\"\"When paginating forwards, are there more items?\"\"\"\n hasNextPage: Boolean!\n \"\"\"When paginating backwards, the cursor to continue.\"\"\"\n startCursor: String\n \"\"\"When paginating forwards, the cursor to continue.\"\"\"\n endCursor: String\n}\n\n\"\"\"The root query of the service\"\"\"\ntype Query {\n node(id: ID!): NodeValue\n \"\"\"Get a single [`Workflow`] by proposal, visit, and name\"\"\"\n workflow(visit: VisitInput!, name: String!): Workflow!\n workflows(visit: VisitInput!, cursor: String, limit: Int, filter: WorkflowFilter): WorkflowConnection!\n workflowTemplate(name: String!): WorkflowTemplate!\n workflowTemplates(cursor: String, limit: Int, filter: WorkflowTemplatesFilter): WorkflowTemplateConnection!\n \"\"\"Get a proposal by its number\"\"\"\n proposal(proposalNumber: Int!): Proposal\n \"\"\"Get a list of proposals\"\"\"\n proposals(proposalCategory: String = null, first: Int = null, last: Int = null, after: String = null, before: String = null): ProposalConnection!\n \"\"\"Get a instrument session\"\"\"\n instrumentSession(proposalNumber: Int!, instrumentSessionNumber: Int!): InstrumentSession\n \"\"\"Get a instrument session\"\"\"\n instrumentSessions(proposalNumber: Int = null, proposalCategory: String = null): [InstrumentSession!]\n \"\"\"Get an instrument\"\"\"\n instrument(instrumentName: String!): Instrument\n \"\"\"Get a list of instruments\"\"\"\n instruments(scienceGroup: String = null): [Instrument!]!\n \"\"\"Get an account\"\"\"\n account(username: String!): Account\n \"\"\"Get a list of samples associated with a given instrument session\"\"\"\n samples(first: Int!, instrumentSessions: [InstrumentSessionInput!] = null, filter: SampleFilterInput! = {schemaUrl: null, createdTime: null, updatedTime: null, name: null, data: null}, before: String = null, after: String = null, last: Int = null, orderBy: SampleOrder! = {name: null, createdTime: null, updatedTime: null}): SampleConnection!\n \"\"\"Get a sample by its id\"\"\"\n sample(sampleId: UUID!): Sample\n}\n\n\"\"\"Supported DLS science groups\"\"\"\nenum ScienceGroup {\n \"\"\"Macromolecular Crystallography\"\"\"\n MX\n \"\"\"Workflows Examples\"\"\"\n EXAMPLES\n \"\"\"Magnetic Materials\"\"\"\n MAGNETIC_MATERIALS\n \"\"\"Soft Condensed Matter\"\"\"\n CONDENSED_MATTER\n \"\"\"Imaging and Microscopy\"\"\"\n IMAGING\n \"\"\"Biological Cryo-Imaging\"\"\"\n BIO_CRYO_IMAGING\n \"\"\"Structures and Surfaces\"\"\"\n SURFACES\n \"\"\"Crystallography\"\"\"\n CRYSTALLOGRAPHY\n \"\"\"Spectroscopy\"\"\"\n SPECTROSCOPY\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Subscription {\n \"\"\"Processing to subscribe to logs for a single pod of a workflow\"\"\"\n logs(visit: VisitInput!, workflowName: String!, taskId: String!): LogEntry!\n \"\"\"Processing to subscribe to data for all workflows in a session\"\"\"\n workflow(visit: VisitInput!, name: String!): Workflow!\n}\n\ntype Task {\n \"\"\"Unique name of the task\"\"\"\n id: String!\n \"\"\"Display name of the task\"\"\"\n name: String!\n \"\"\"Current status of a task\"\"\"\n status: TaskStatus!\n \"\"\"Parent of a task\"\"\"\n depends: [String!]!\n \"\"\"Children of a task\"\"\"\n dependencies: [String!]!\n \"\"\"Artifacts produced by a task\"\"\"\n artifacts: [Artifact!]!\n \"\"\"Node type - Pod, DAG, etc\"\"\"\n stepType: String!\n \"\"\"Start time for a task on a workflow\"\"\"\n startTime: DateTime\n \"\"\"End time for a task on a workflow\"\"\"\n endTime: DateTime\n \"\"\"\n A human readable message indicating details about why this step is in this condition\n \"\"\"\n message: String\n}\n\nenum TaskStatus {\n PENDING\n RUNNING\n SUCCEEDED\n SKIPPED\n FAILED\n ERROR\n OMITTED\n}\n\nscalar Template\n\n\"\"\"Information about where the template is stored\"\"\"\ntype TemplateSource {\n \"\"\"The URL of the GitHub repository\"\"\"\n repositoryUrl: String!\n \"\"\"The path to the template within the repository\"\"\"\n path: String!\n \"\"\"The current tracked branch of the repository\"\"\"\n targetRevision: String!\n}\n\n\"\"\"\nURL is a String implementing the [URL Standard](http://url.spec.whatwg.org/)\n\"\"\"\nscalar Url\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ntype Visit {\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n \"\"\"Session visit Number\"\"\"\n number: Int!\n}\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ninput VisitInput {\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n \"\"\"Session visit Number\"\"\"\n number: Int!\n}\n\ntype Workflow {\n \"\"\"The unique ID derived from the visit and name\"\"\"\n id: ID!\n \"\"\"The name given to the workflow, unique within a given visit\"\"\"\n name: String!\n \"\"\"The visit the Workflow was run against\"\"\"\n visit: Visit!\n \"\"\"The current status of the workflow\"\"\"\n status: WorkflowStatus\n \"\"\"The top-level workflow parameters\"\"\"\n parameters: JSONObject\n \"\"\"The name of the template used to run the workflow\"\"\"\n templateRef: String\n \"\"\"The workflow creator\"\"\"\n creator: WorkflowCreator!\n}\n\ntype WorkflowConnection {\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo!\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowEdge!]!\n \"\"\"A list of nodes.\"\"\"\n nodes: [Workflow!]!\n}\n\n\"\"\"Information about the creator of a workflow.\"\"\"\ntype WorkflowCreator {\n \"\"\"\n An identifier unique to the creator of the workflow.\n Typically this is the creator's Fed-ID.\n \"\"\"\n creatorId: String!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowEdge {\n \"\"\"The item at the end of the edge\"\"\"\n node: Workflow!\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String!\n}\n\n\"\"\"All tasks in the workflow have errored\"\"\"\ntype WorkflowErroredStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All tasks in the workflow have failed\"\"\"\ntype WorkflowFailedStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All the supported Workflows filters\"\"\"\ninput WorkflowFilter {\n \"\"\"The status field for a workflow\"\"\"\n workflowStatusFilter: WorkflowStatusFilter\n \"\"\"The fedid of the user who created the workflow\"\"\"\n creator: Creator\n \"\"\"The name of the workflow template\"\"\"\n template: Template\n}\n\ntype WorkflowPendingStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n}\n\ntype WorkflowRunningStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"The status of a workflow\"\"\"\nunion WorkflowStatus = WorkflowPendingStatus | WorkflowRunningStatus | WorkflowSucceededStatus | WorkflowFailedStatus | WorkflowErroredStatus\n\n\"\"\"Represents workflow status filters\"\"\"\ninput WorkflowStatusFilter {\n pending: Boolean! = false\n running: Boolean! = false\n succeeded: Boolean! = false\n failed: Boolean! = false\n error: Boolean! = false\n}\n\n\"\"\"All tasks in the workflow have succeded\"\"\"\ntype WorkflowSucceededStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\ntype WorkflowTemplate {\n \"\"\"The name given to the workflow template, globally unique\"\"\"\n name: String!\n \"\"\"The group who maintains the workflow template\"\"\"\n maintainer: String!\n \"\"\"A human readable title for the workflow template\"\"\"\n title: String\n \"\"\"A human readable description of the workflow which is created\"\"\"\n description: String\n \"\"\"The repository storing the code associated with this template.\"\"\"\n repository: String\n \"\"\"A JSON Schema describing the arguments of a Workflow Template\"\"\"\n arguments: JSON!\n \"\"\"\n A JSON Forms UI Schema describing how to render the arguments of the Workflow Template\n \"\"\"\n uiSchema: JSON\n \"\"\"Information about where the template is obtained from\"\"\"\n templateSource: TemplateSource\n}\n\ntype WorkflowTemplateConnection {\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo!\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowTemplateEdge!]!\n \"\"\"A list of nodes.\"\"\"\n nodes: [WorkflowTemplate!]!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowTemplateEdge {\n \"\"\"The item at the end of the edge\"\"\"\n node: WorkflowTemplate!\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String!\n}\n\n\"\"\"Supported label filters for ClusterWorkflowTemplates\"\"\"\ninput WorkflowTemplatesFilter {\n \"\"\"The science group owning the template eg imaging\"\"\"\n scienceGroup: [ScienceGroup!]\n}\n\ntype Account {\n accountId: Int!\n username: String!\n emailAddress: String\n title: String\n givenName: String\n familyName: String\n type: AccountType!\n state: AccountState!\n proposalRoles: [ProposalAccount!]!\n instrumentSessionRoles: [InstrumentSessionRole!]!\n}\n\nenum AccountState {\n enabled\n disabled\n}\n\nenum AccountType {\n user\n staff\n functional\n}\n\ntype Instrument {\n name: String!\n scienceGroup: String\n description: String\n proposals: [Proposal!]!\n instrumentSessions: [InstrumentSession!]!\n}\n\ntype InstrumentSession {\n instrumentSessionId: Int!\n instrumentSessionNumber: Int!\n startTime: DateTime\n endTime: DateTime\n type: String\n state: String\n riskRating: String\n proposal: Proposal\n instrument: Instrument!\n roles: [InstrumentSessionRole!]!\n \"\"\"Samples associated with a given instrument session\"\"\"\n samples(first: Int!, filter: SampleFilterInput! = {schemaUrl: null, createdTime: null, updatedTime: null, name: null, data: null}, before: String = null, after: String = null, last: Int = null, orderBy: SampleOrder! = {name: null, createdTime: null, updatedTime: null}): SampleConnection!\n}\n\ntype InstrumentSessionMutations {\n instrumentSessionNumber: Int!\n proposalNumber: Int!\n \"\"\"Create or validate samples associated with this instrument session\"\"\"\n createOrValidateSamples(input: CreateOrValidateSampleInputBase!): CreateSamplesResponse!\n}\n\ntype InstrumentSessionRole {\n instrumentSession: InstrumentSession!\n account: Account!\n role: String!\n onSite: Boolean!\n}\n\ntype Proposal {\n proposalNumber: Int!\n proposalCategory: String\n title: String\n summary: String\n state: ProposalState!\n instrumentSessions: [InstrumentSession!]!\n instruments: [Instrument!]!\n roles: [ProposalAccount!]!\n}\n\ntype ProposalAccount {\n proposal: Proposal!\n account: Account!\n role: String!\n}\n\ntype ProposalConnection {\n edges: [ProposalEdge!]!\n pageInfo: PageInfo!\n}\n\ntype ProposalEdge {\n cursor: String!\n node: Proposal!\n}\n\nenum ProposalState {\n Open\n Closed\n Cancelled\n}\n\ninput AddSampleEventInput {\n description: String!\n}\n\ninput CreateOrValidateSampleInput {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n \"\"\"Number of the proposal the samples should be associated with\"\"\"\n proposalNumber: Int!\n \"\"\"Number of the instrument session the samples should be associated with\"\"\"\n instrumentSessionNumber: Int!\n}\n\ninput CreateOrValidateSampleInputBase {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n}\n\ninput CreateSampleInput {\n proposalNumber: Int!\n instrumentSessionNumber: Int!\n samples: [SampleInLegacy!]!\n validateOnly: Boolean! = false\n}\n\n\"\"\"Return type when creating or validating samples\"\"\"\ntype CreateSamplesResponse {\n \"\"\"Whether the operation has succeeded without validation errors\"\"\"\n success: Boolean!\n \"\"\"Samples that have been created\"\"\"\n samples: [Sample!]!\n \"\"\"Errors that occurred during sample validation\"\"\"\n errors: [SampleValidationError!]!\n}\n\ninput DatetimeOperatorInput {\n \"\"\"\n Will filter to items where the `DateTime` field is greater than (i.e. after) the provided value\n \"\"\"\n gt: DateTime = null\n \"\"\"\n Will filter to items where the `DateTime` field is less than (i.e. before) the provided value\n \"\"\"\n lt: DateTime = null\n}\n\n\"\"\"The details of sample validation error\"\"\"\ntype ErrorDetails {\n \"\"\"The type of error that occurred\"\"\"\n type: String!\n \"\"\"\n Tuple of strings identifying where in the sample schema the error occurred.\n \"\"\"\n location: [String!]!\n \"\"\"A human readable error message.\"\"\"\n message: String!\n}\n\ntype InstrumentSessionConnection {\n edges: [InstrumentSessionEdge!]!\n pageInfo: PageInfo!\n}\n\ntype InstrumentSessionEdge {\n cursor: String!\n node: InstrumentSession!\n}\n\ninput InstrumentSessionInput {\n proposalNumber: Int!\n instrumentSessionNumber: Int!\n}\n\ninput JSONOperator @oneOf {\n stringOperator: StringOperatorInput = null\n datetimeOperator: DatetimeOperatorInput = null\n numericOperator: NumericOperatorInput = null\n}\n\ninput JSONOperatorInput {\n \"\"\"A JSON path specifying the value to filter. Must start with '$.'\"\"\"\n path: String!\n \"\"\"The operator to apply to the JSON field\"\"\"\n operator: JSONOperator!\n}\n\ninput NumericOperatorInput {\n \"\"\"\n Will filter to items where the numeric field is greater than the provided value\n \"\"\"\n gt: Float = null\n \"\"\"\n Will filter to items where the numeric field is less than the provided value\n \"\"\"\n lt: Float = null\n}\n\ntype Sample {\n id: UUID!\n name: String!\n data: JSON!\n createdTime: DateTime!\n updatedTime: DateTime!\n dataSchemaUrl: String!\n \"\"\"Samples from which this sample is derived\"\"\"\n parents(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleConnection!\n \"\"\"Samples derived from this sample\"\"\"\n children(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleConnection!\n \"\"\"Events linked to this sample\"\"\"\n events(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleEventConnection!\n \"\"\"The JSON schema that the sample's `data` conforms to\"\"\"\n dataSchema: JSON!\n \"\"\"The instrument sessions that this sample is associated with\"\"\"\n instrumentSessions: InstrumentSessionConnection!\n images: [SampleImage!]!\n}\n\ntype SampleConnection {\n edges: [SampleEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEdge {\n cursor: String!\n node: Sample!\n}\n\ntype SampleEvent {\n id: UUID!\n timestamp: DateTime!\n description: String!\n}\n\ntype SampleEventConnection {\n edges: [SampleEventEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEventEdge {\n cursor: String!\n node: SampleEvent!\n}\n\ninput SampleFilterInput {\n \"\"\"Filter on the `schemaUrl` field of `Sample`\"\"\"\n schemaUrl: StringOperatorInput = null\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n createdTime: DatetimeOperatorInput = null\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n updatedTime: DatetimeOperatorInput = null\n \"\"\"Filter on the `name` field of `Sample`\"\"\"\n name: StringOperatorInput = null\n \"\"\"Filter on the `data` field of `Sample`\"\"\"\n data: [JSONOperatorInput!] = null\n}\n\ntype SampleImage {\n url: String!\n filename: String!\n}\n\ninput SampleIn {\n \"\"\"Name of the sample\"\"\"\n name: String!\n \"\"\"Data of the sample\"\"\"\n data: JSON!\n}\n\ninput SampleInLegacy {\n name: String!\n data: JSON!\n dataSchemaUrl: String!\n parentIds: [Int!] = null\n children: [SampleInLegacy!] = null\n}\n\ntype SampleMutations {\n sampleId: UUID!\n linkInstrumentSessionToSample(proposalNumber: Int!, instrumentSessionNumber: Int!): Void\n addSampleEvent(sampleEvent: AddSampleEventInput!): SampleEvent!\n createSampleImageUploadUrl(filename: String!, contentType: String!, contentLength: Int!): String!\n}\n\ninput SampleOrder {\n name: SortingOrder = null\n createdTime: SortingOrder = null\n updatedTime: SortingOrder = null\n}\n\n\"\"\"The details of errors occurred when validating a sample\"\"\"\ntype SampleValidationError {\n \"\"\"\n The index of the sample in CreateSampleInput.samples for which the error occurred\n \"\"\"\n index: Int!\n \"\"\"Errors that occurred when validating the sample\"\"\"\n errors: [ErrorDetails!]!\n}\n\nenum SortingOrder {\n ASC\n DESC\n}\n\n\"\"\"Conditions used to filter results based on the value of a String field\"\"\"\ninput StringOperatorInput {\n \"\"\"\n Will filter to items where the `String` field is equal to the provided value\n \"\"\"\n eq: String = null\n \"\"\"\n Will filter to items where the `String` field is not equal to the provided value\n \"\"\"\n ne: String = null\n \"\"\"\n Will filter to items where the `String` field is a member of the provided value\n \"\"\"\n in: [String!] = null\n \"\"\"\n Will filter to items where the `String` field is not a member of the provided value\n \"\"\"\n nin: [String!] = null\n \"\"\"\n Will filter to items where the `String` field is contains the provided value\n \"\"\"\n contains: String = null\n}\n\nscalar UUID\n\n\"\"\"Represents NULL values\"\"\"\nscalar Void",
+ "graphqlSchema": "schema {\n query: Query\n mutation: Mutation\n subscription: Subscription\n}\n\ntype Artifact {\n \"\"\"The file name of the artifact\"\"\"\n name: String!\n \"\"\"The download URL for the artifact\"\"\"\n url: Url!\n \"\"\"The MIME type of the artifact data\"\"\"\n mimeType: String!\n}\n\nscalar Creator\n\n\"\"\"\nImplement the DateTime<Utc> scalar\n\nThe input/output is a string in RFC3339 format.\n\"\"\"\nscalar DateTime\n\n\"\"\"\nThe `JSON` scalar type represents JSON values as specified by [ECMA-404](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf).\n\"\"\"\nscalar JSON\n\n\"\"\"A scalar that can represent any JSON Object value.\"\"\"\nscalar JSONObject\n\n\"\"\"A single log line streamed from a pod\"\"\"\ntype LogEntry {\n \"\"\"The log line content\"\"\"\n content: String!\n \"\"\"The name of the pod producing the log\"\"\"\n podName: String!\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Mutation {\n submitWorkflowTemplate(name: String!, visit: VisitInput!, parameters: JSON!): Workflow!\n instrumentSession(proposalNumber: Int!, instrumentSessionNumber: Int!): InstrumentSessionMutations\n createOrValidateSamples(input: CreateOrValidateSampleInput!): CreateSamplesResponse!\n createSamples(input: CreateSampleInput!): [Sample!]! @deprecated(reason: \"Will be replaced by createOrValidateSamples\")\n sample(sampleId: UUID!): SampleMutations\n}\n\n\"\"\"Represents Relay Node types\"\"\"\nunion NodeValue = Workflow\n\n\"\"\"Information about pagination in a connection\"\"\"\ntype PageInfo {\n \"\"\"When paginating backwards, are there more items?\"\"\"\n hasPreviousPage: Boolean!\n \"\"\"When paginating forwards, are there more items?\"\"\"\n hasNextPage: Boolean!\n \"\"\"When paginating backwards, the cursor to continue.\"\"\"\n startCursor: String\n \"\"\"When paginating forwards, the cursor to continue.\"\"\"\n endCursor: String\n}\n\n\"\"\"The root query of the service\"\"\"\ntype Query {\n node(id: ID!): NodeValue\n \"\"\"Get a single [`Workflow`] by proposal, visit, and name\"\"\"\n workflow(visit: VisitInput!, name: String!): Workflow!\n workflows(visit: VisitInput!, cursor: String, limit: Int, filter: WorkflowFilter): WorkflowConnection!\n workflowTemplate(name: String!): WorkflowTemplate!\n workflowTemplates(cursor: String, limit: Int, filter: WorkflowTemplatesFilter): WorkflowTemplateConnection!\n \"\"\"Get a proposal by its number\"\"\"\n proposal(proposalNumber: Int!): Proposal\n \"\"\"Get a list of proposals\"\"\"\n proposals(proposalCategory: String = null, first: Int = null, last: Int = null, after: String = null, before: String = null): ProposalConnection!\n \"\"\"Get a instrument session\"\"\"\n instrumentSession(proposalNumber: Int!, instrumentSessionNumber: Int!): InstrumentSession\n \"\"\"Get a instrument session\"\"\"\n instrumentSessions(proposalNumber: Int = null, proposalCategory: String = null): [InstrumentSession!]\n \"\"\"Get an instrument\"\"\"\n instrument(instrumentName: String!): Instrument\n \"\"\"Get a list of instruments\"\"\"\n instruments(scienceGroup: String = null): [Instrument!]!\n \"\"\"Get an account\"\"\"\n account(username: String!): Account\n \"\"\"Get a list of samples associated with a given instrument session\"\"\"\n samples(first: Int!, instrumentSessions: [InstrumentSessionInput!] = null, filter: SampleFilterInput! = {schemaUrl: null, createdTime: null, updatedTime: null, name: null, data: null}, before: String = null, after: String = null, last: Int = null, orderBy: SampleOrder! = {name: null, createdTime: null, updatedTime: null}): SampleConnection!\n \"\"\"Get a sample by its id\"\"\"\n sample(sampleId: UUID!): Sample\n jsonSchema(url: String!): JSONSchema\n jsonSchemas(type: String = null, instrument: String = null): [JSONSchema!]!\n}\n\n\"\"\"Supported DLS science groups\"\"\"\nenum ScienceGroup {\n \"\"\"Macromolecular Crystallography\"\"\"\n MX\n \"\"\"Workflows Examples\"\"\"\n EXAMPLES\n \"\"\"Magnetic Materials\"\"\"\n MAGNETIC_MATERIALS\n \"\"\"Soft Condensed Matter\"\"\"\n CONDENSED_MATTER\n \"\"\"Imaging and Microscopy\"\"\"\n IMAGING\n \"\"\"Biological Cryo-Imaging\"\"\"\n BIO_CRYO_IMAGING\n \"\"\"Structures and Surfaces\"\"\"\n SURFACES\n \"\"\"Crystallography\"\"\"\n CRYSTALLOGRAPHY\n \"\"\"Spectroscopy\"\"\"\n SPECTROSCOPY\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Subscription {\n \"\"\"Processing to subscribe to logs for a single pod of a workflow\"\"\"\n logs(visit: VisitInput!, workflowName: String!, taskId: String!): LogEntry!\n \"\"\"Processing to subscribe to data for all workflows in a session\"\"\"\n workflow(visit: VisitInput!, name: String!): Workflow!\n}\n\ntype Task {\n \"\"\"Unique name of the task\"\"\"\n id: String!\n \"\"\"Display name of the task\"\"\"\n name: String!\n \"\"\"Current status of a task\"\"\"\n status: TaskStatus!\n \"\"\"Parent of a task\"\"\"\n depends: [String!]!\n \"\"\"Children of a task\"\"\"\n dependencies: [String!]!\n \"\"\"Artifacts produced by a task\"\"\"\n artifacts: [Artifact!]!\n \"\"\"Node type - Pod, DAG, etc\"\"\"\n stepType: String!\n \"\"\"Start time for a task on a workflow\"\"\"\n startTime: DateTime\n \"\"\"End time for a task on a workflow\"\"\"\n endTime: DateTime\n \"\"\"\n A human readable message indicating details about why this step is in this condition\n \"\"\"\n message: String\n}\n\nenum TaskStatus {\n PENDING\n RUNNING\n SUCCEEDED\n SKIPPED\n FAILED\n ERROR\n OMITTED\n}\n\nscalar Template\n\n\"\"\"Information about where the template is stored\"\"\"\ntype TemplateSource {\n \"\"\"The URL of the GitHub repository\"\"\"\n repositoryUrl: String!\n \"\"\"The path to the template within the repository\"\"\"\n path: String!\n \"\"\"The current tracked branch of the repository\"\"\"\n targetRevision: String!\n}\n\n\"\"\"\nURL is a String implementing the [URL Standard](http://url.spec.whatwg.org/)\n\"\"\"\nscalar Url\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ntype Visit {\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n \"\"\"Session visit Number\"\"\"\n number: Int!\n}\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ninput VisitInput {\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n \"\"\"Session visit Number\"\"\"\n number: Int!\n}\n\ntype Workflow {\n \"\"\"The unique ID derived from the visit and name\"\"\"\n id: ID!\n \"\"\"The name given to the workflow, unique within a given visit\"\"\"\n name: String!\n \"\"\"The visit the Workflow was run against\"\"\"\n visit: Visit!\n \"\"\"The current status of the workflow\"\"\"\n status: WorkflowStatus\n \"\"\"The top-level workflow parameters\"\"\"\n parameters: JSONObject\n \"\"\"The name of the template used to run the workflow\"\"\"\n templateRef: String\n \"\"\"The workflow creator\"\"\"\n creator: WorkflowCreator!\n}\n\ntype WorkflowConnection {\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo!\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowEdge!]!\n \"\"\"A list of nodes.\"\"\"\n nodes: [Workflow!]!\n}\n\n\"\"\"Information about the creator of a workflow.\"\"\"\ntype WorkflowCreator {\n \"\"\"\n An identifier unique to the creator of the workflow.\n Typically this is the creator's Fed-ID.\n \"\"\"\n creatorId: String!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowEdge {\n \"\"\"The item at the end of the edge\"\"\"\n node: Workflow!\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String!\n}\n\n\"\"\"All tasks in the workflow have errored\"\"\"\ntype WorkflowErroredStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All tasks in the workflow have failed\"\"\"\ntype WorkflowFailedStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All the supported Workflows filters\"\"\"\ninput WorkflowFilter {\n \"\"\"The status field for a workflow\"\"\"\n workflowStatusFilter: WorkflowStatusFilter\n \"\"\"The fedid of the user who created the workflow\"\"\"\n creator: Creator\n \"\"\"The name of the workflow template\"\"\"\n template: Template\n}\n\ntype WorkflowPendingStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n}\n\ntype WorkflowRunningStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"The status of a workflow\"\"\"\nunion WorkflowStatus = WorkflowPendingStatus | WorkflowRunningStatus | WorkflowSucceededStatus | WorkflowFailedStatus | WorkflowErroredStatus\n\n\"\"\"Represents workflow status filters\"\"\"\ninput WorkflowStatusFilter {\n pending: Boolean! = false\n running: Boolean! = false\n succeeded: Boolean! = false\n failed: Boolean! = false\n error: Boolean! = false\n}\n\n\"\"\"All tasks in the workflow have succeded\"\"\"\ntype WorkflowSucceededStatus {\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\ntype WorkflowTemplate {\n \"\"\"The name given to the workflow template, globally unique\"\"\"\n name: String!\n \"\"\"The group who maintains the workflow template\"\"\"\n maintainer: String!\n \"\"\"A human readable title for the workflow template\"\"\"\n title: String\n \"\"\"A human readable description of the workflow which is created\"\"\"\n description: String\n \"\"\"The repository storing the code associated with this template.\"\"\"\n repository: String\n \"\"\"A JSON Schema describing the arguments of a Workflow Template\"\"\"\n arguments: JSON!\n \"\"\"\n A JSON Forms UI Schema describing how to render the arguments of the Workflow Template\n \"\"\"\n uiSchema: JSON\n \"\"\"Information about where the template is obtained from\"\"\"\n templateSource: TemplateSource\n}\n\ntype WorkflowTemplateConnection {\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo!\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowTemplateEdge!]!\n \"\"\"A list of nodes.\"\"\"\n nodes: [WorkflowTemplate!]!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowTemplateEdge {\n \"\"\"The item at the end of the edge\"\"\"\n node: WorkflowTemplate!\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String!\n}\n\n\"\"\"Supported label filters for ClusterWorkflowTemplates\"\"\"\ninput WorkflowTemplatesFilter {\n \"\"\"The science group owning the template eg imaging\"\"\"\n scienceGroup: [ScienceGroup!]\n}\n\ntype Account {\n accountId: Int!\n username: String!\n emailAddress: String\n title: String\n givenName: String\n familyName: String\n type: AccountType!\n state: AccountState!\n proposalRoles: [ProposalAccount!]!\n instrumentSessionRoles: [InstrumentSessionRole!]!\n}\n\nenum AccountState {\n enabled\n disabled\n}\n\nenum AccountType {\n user\n staff\n functional\n}\n\ntype Instrument {\n name: String!\n scienceGroup: String\n description: String\n proposals: [Proposal!]!\n instrumentSessions: [InstrumentSession!]!\n}\n\ntype InstrumentSession {\n instrumentSessionId: Int!\n instrumentSessionNumber: Int!\n startTime: DateTime\n endTime: DateTime\n type: String\n state: String\n riskRating: String\n proposal: Proposal\n instrument: Instrument!\n roles: [InstrumentSessionRole!]!\n \"\"\"Samples associated with a given instrument session\"\"\"\n samples(first: Int!, filter: SampleFilterInput! = {schemaUrl: null, createdTime: null, updatedTime: null, name: null, data: null}, before: String = null, after: String = null, last: Int = null, orderBy: SampleOrder! = {name: null, createdTime: null, updatedTime: null}): SampleConnection!\n}\n\ntype InstrumentSessionMutations {\n instrumentSessionNumber: Int!\n proposalNumber: Int!\n \"\"\"Create or validate samples associated with this instrument session\"\"\"\n createOrValidateSamples(input: CreateOrValidateSampleInputBase!): CreateSamplesResponse!\n}\n\ntype InstrumentSessionRole {\n instrumentSession: InstrumentSession!\n account: Account!\n role: String!\n onSite: Boolean!\n}\n\ntype Proposal {\n proposalNumber: Int!\n proposalCategory: String\n title: String\n summary: String\n state: ProposalState!\n instrumentSessions: [InstrumentSession!]!\n instruments: [Instrument!]!\n roles: [ProposalAccount!]!\n}\n\ntype ProposalAccount {\n proposal: Proposal!\n account: Account!\n role: String!\n}\n\ntype ProposalConnection {\n edges: [ProposalEdge!]!\n pageInfo: PageInfo!\n}\n\ntype ProposalEdge {\n cursor: String!\n node: Proposal!\n}\n\nenum ProposalState {\n Open\n Closed\n Cancelled\n}\n\ninput AddSampleEventInput {\n description: String!\n}\n\ninput CreateOrValidateSampleInput {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n \"\"\"Number of the proposal the samples should be associated with\"\"\"\n proposalNumber: Int!\n \"\"\"Number of the instrument session the samples should be associated with\"\"\"\n instrumentSessionNumber: Int!\n}\n\ninput CreateOrValidateSampleInputBase {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n}\n\ninput CreateSampleInput {\n proposalNumber: Int!\n instrumentSessionNumber: Int!\n samples: [SampleInLegacy!]!\n validateOnly: Boolean! = false\n}\n\n\"\"\"Return type when creating or validating samples\"\"\"\ntype CreateSamplesResponse {\n \"\"\"Whether the operation has succeeded without validation errors\"\"\"\n success: Boolean!\n \"\"\"Samples that have been created\"\"\"\n samples: [Sample!]!\n \"\"\"Errors that occurred during sample validation\"\"\"\n errors: [SampleValidationError!]!\n}\n\ninput DatetimeOperatorInput {\n \"\"\"\n Will filter to items where the `DateTime` field is greater than (i.e. after) the provided value\n \"\"\"\n gt: DateTime = null\n \"\"\"\n Will filter to items where the `DateTime` field is less than (i.e. before) the provided value\n \"\"\"\n lt: DateTime = null\n}\n\n\"\"\"The details of sample validation error\"\"\"\ntype ErrorDetails {\n \"\"\"The type of error that occurred\"\"\"\n type: String!\n \"\"\"\n Tuple of strings identifying where in the sample schema the error occurred.\n \"\"\"\n location: [String!]!\n \"\"\"A human readable error message.\"\"\"\n message: String!\n}\n\ntype InstrumentSessionConnection {\n edges: [InstrumentSessionEdge!]!\n pageInfo: PageInfo!\n}\n\ntype InstrumentSessionEdge {\n cursor: String!\n node: InstrumentSession!\n}\n\ninput InstrumentSessionInput {\n proposalNumber: Int!\n instrumentSessionNumber: Int!\n}\n\ninput JSONOperator @oneOf {\n stringOperator: StringOperatorInput = null\n datetimeOperator: DatetimeOperatorInput = null\n numericOperator: NumericOperatorInput = null\n}\n\ninput JSONOperatorInput {\n \"\"\"A JSON path specifying the value to filter. Must start with '$.'\"\"\"\n path: String!\n \"\"\"The operator to apply to the JSON field\"\"\"\n operator: JSONOperator!\n}\n\ninput NumericOperatorInput {\n \"\"\"\n Will filter to items where the numeric field is greater than the provided value\n \"\"\"\n gt: Float = null\n \"\"\"\n Will filter to items where the numeric field is less than the provided value\n \"\"\"\n lt: Float = null\n}\n\ntype Sample {\n id: UUID!\n name: String!\n data: JSON!\n createdTime: DateTime!\n updatedTime: DateTime!\n dataSchemaUrl: String!\n \"\"\"Samples from which this sample is derived\"\"\"\n parents(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleConnection!\n \"\"\"Samples derived from this sample\"\"\"\n children(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleConnection!\n \"\"\"Events linked to this sample\"\"\"\n events(first: Int = null, before: String = null, after: String = null, last: Int = null): SampleEventConnection!\n \"\"\"The JSON schema that the sample's `data` conforms to\"\"\"\n dataSchema: JSON!\n \"\"\"The instrument sessions that this sample is associated with\"\"\"\n instrumentSessions: InstrumentSessionConnection!\n images: [SampleImage!]!\n}\n\ntype SampleConnection {\n edges: [SampleEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEdge {\n cursor: String!\n node: Sample!\n}\n\ntype SampleEvent {\n id: UUID!\n timestamp: DateTime!\n description: String!\n}\n\ntype SampleEventConnection {\n edges: [SampleEventEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEventEdge {\n cursor: String!\n node: SampleEvent!\n}\n\ninput SampleFilterInput {\n \"\"\"Filter on the `schemaUrl` field of `Sample`\"\"\"\n schemaUrl: StringOperatorInput = null\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n createdTime: DatetimeOperatorInput = null\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n updatedTime: DatetimeOperatorInput = null\n \"\"\"Filter on the `name` field of `Sample`\"\"\"\n name: StringOperatorInput = null\n \"\"\"Filter on the `data` field of `Sample`\"\"\"\n data: [JSONOperatorInput!] = null\n}\n\ntype SampleImage {\n url: String!\n filename: String!\n}\n\ninput SampleIn {\n \"\"\"Name of the sample\"\"\"\n name: String!\n \"\"\"Data of the sample\"\"\"\n data: JSON!\n}\n\ninput SampleInLegacy {\n name: String!\n data: JSON!\n dataSchemaUrl: String!\n parentIds: [Int!] = null\n children: [SampleInLegacy!] = null\n}\n\ntype SampleMutations {\n sampleId: UUID!\n linkInstrumentSessionToSample(proposalNumber: Int!, instrumentSessionNumber: Int!): Void\n addSampleEvent(sampleEvent: AddSampleEventInput!): SampleEvent!\n createSampleImageUploadUrl(filename: String!, contentType: String!, contentLength: Int!): String!\n}\n\ninput SampleOrder {\n name: SortingOrder = null\n createdTime: SortingOrder = null\n updatedTime: SortingOrder = null\n}\n\n\"\"\"The details of errors occurred when validating a sample\"\"\"\ntype SampleValidationError {\n \"\"\"\n The index of the sample in CreateSampleInput.samples for which the error occurred\n \"\"\"\n index: Int!\n \"\"\"Errors that occurred when validating the sample\"\"\"\n errors: [ErrorDetails!]!\n}\n\nenum SortingOrder {\n ASC\n DESC\n}\n\n\"\"\"Conditions used to filter results based on the value of a String field\"\"\"\ninput StringOperatorInput {\n \"\"\"\n Will filter to items where the `String` field is equal to the provided value\n \"\"\"\n eq: String = null\n \"\"\"\n Will filter to items where the `String` field is not equal to the provided value\n \"\"\"\n ne: String = null\n \"\"\"\n Will filter to items where the `String` field is a member of the provided value\n \"\"\"\n in: [String!] = null\n \"\"\"\n Will filter to items where the `String` field is not a member of the provided value\n \"\"\"\n nin: [String!] = null\n \"\"\"\n Will filter to items where the `String` field is contains the provided value\n \"\"\"\n contains: String = null\n}\n\nscalar UUID\n\n\"\"\"Represents NULL values\"\"\"\nscalar Void\n\n\"\"\"A JSON schema\"\"\"\ntype JSONSchema {\n \"\"\"The identifier of the schema\"\"\"\n id: String!\n \"\"\"A URL from which the schema can be accessed\"\"\"\n url: String!\n \"\"\"The type of object the shema describes (if known)\"\"\"\n type: String\n \"\"\"The title of the schema\"\"\"\n title: String\n \"\"\"The version of the schema\"\"\"\n version: String\n \"\"\"The instrument the schema was created for\"\"\"\n instrument: String\n \"\"\"The description og the schema\"\"\"\n description: String\n}",
"stringStorage": {
"636412ec8e6e8e278df46ce7da59047a6182733c": "schema @link(url: \"https://specs.apollo.dev/federation/v2.7\", import: [\"@key\", \"@shareable\"]) {\n query: Query\n mutation: Mutation\n}\n\ndirective @key(fields: openfed__FieldSet!, resolvable: Boolean = true) repeatable on INTERFACE | OBJECT\n\ndirective @link(as: String, for: link__Purpose, import: [link__Import], url: String!) repeatable on SCHEMA\n\ndirective @shareable repeatable on FIELD_DEFINITION | OBJECT\n\ntype Account {\n accountId: Int!\n emailAddress: String\n familyName: String\n givenName: String\n instrumentSessionRoles: [InstrumentSessionRole!]!\n proposalRoles: [ProposalAccount!]!\n state: AccountState!\n title: String\n type: AccountType!\n username: String!\n}\n\nenum AccountState {\n disabled\n enabled\n}\n\nenum AccountType {\n functional\n staff\n user\n}\n\n\"\"\"Date with time (isoformat)\"\"\"\nscalar DateTime\n\ntype Instrument {\n description: String\n instrumentSessions: [InstrumentSession!]!\n name: String!\n proposals: [Proposal!]!\n scienceGroup: String\n}\n\ntype InstrumentSession @key(fields: \"instrumentSessionNumber proposal {proposalNumber}\") {\n endTime: DateTime\n instrument: Instrument!\n instrumentSessionId: Int!\n instrumentSessionNumber: Int!\n proposal: Proposal\n riskRating: String\n roles: [InstrumentSessionRole!]!\n startTime: DateTime\n state: String\n type: String\n}\n\ntype InstrumentSessionMutations @key(fields: \"instrumentSessionNumber proposalNumber\") {\n instrumentSessionNumber: Int!\n proposalNumber: Int!\n}\n\ntype InstrumentSessionRole {\n account: Account!\n instrumentSession: InstrumentSession!\n onSite: Boolean!\n role: String!\n}\n\ntype Mutation {\n instrumentSession(instrumentSessionNumber: Int!, proposalNumber: Int!): InstrumentSessionMutations\n}\n\ntype PageInfo {\n endCursor: String @shareable\n hasNextPage: Boolean! @shareable\n hasPreviousPage: Boolean! @shareable\n startCursor: String @shareable\n}\n\ntype Proposal @key(fields: \"proposalNumber\") {\n instrumentSessions: [InstrumentSession!]!\n instruments: [Instrument!]!\n proposalCategory: String\n proposalNumber: Int!\n roles: [ProposalAccount!]!\n state: ProposalState!\n summary: String\n title: String\n}\n\ntype ProposalAccount {\n account: Account!\n proposal: Proposal!\n role: String!\n}\n\ntype ProposalConnection {\n edges: [ProposalEdge!]! @shareable\n pageInfo: PageInfo! @shareable\n}\n\ntype ProposalEdge {\n cursor: String! @shareable\n node: Proposal! @shareable\n}\n\nenum ProposalState {\n Cancelled\n Closed\n Open\n}\n\ntype Query {\n \"\"\"Get an account\"\"\"\n account(username: String!): Account\n \"\"\"Get an instrument\"\"\"\n instrument(instrumentName: String!): Instrument\n \"\"\"Get a instrument session\"\"\"\n instrumentSession(instrumentSessionNumber: Int!, proposalNumber: Int!): InstrumentSession\n \"\"\"Get a instrument session\"\"\"\n instrumentSessions(proposalCategory: String = null, proposalNumber: Int = null): [InstrumentSession!]\n \"\"\"Get a list of instruments\"\"\"\n instruments(scienceGroup: String = null): [Instrument!]!\n \"\"\"Get a proposal by its number\"\"\"\n proposal(proposalNumber: Int!): Proposal\n \"\"\"Get a list of proposals\"\"\"\n proposals(after: String = null, before: String = null, first: Int = null, last: Int = null, proposalCategory: String = null): ProposalConnection!\n}\n\nscalar link__Import\n\nenum link__Purpose {\n EXECUTION\n SECURITY\n}\n\nscalar openfed__FieldSet",
"6f02287e3cbb3840d5136c3ef6f75c1e24560b94": "schema @link(url: \"https://specs.apollo.dev/federation/v2.7\", import: [\"@external\", \"@key\", \"@provides\", \"@shareable\"]) {\n query: Query\n mutation: Mutation\n}\n\ndirective @external on FIELD_DEFINITION | OBJECT\n\ndirective @key(fields: openfed__FieldSet!, resolvable: Boolean = true) repeatable on INTERFACE | OBJECT\n\ndirective @link(as: String, for: link__Purpose, import: [link__Import], url: String!) repeatable on SCHEMA\n\ndirective @provides(fields: openfed__FieldSet!) on FIELD_DEFINITION\n\ndirective @shareable repeatable on FIELD_DEFINITION | OBJECT\n\ninput AddSampleEventInput {\n description: String!\n}\n\ninput CreateOrValidateSampleInput {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Number of the instrument session the samples should be associated with\"\"\"\n instrumentSessionNumber: Int!\n \"\"\"Number of the proposal the samples should be associated with\"\"\"\n proposalNumber: Int!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n}\n\ninput CreateOrValidateSampleInputBase {\n \"\"\"URL of the JSON schema the samples' `data` should be validated against\"\"\"\n dataSchemaUrl: String!\n \"\"\"Samples to be created\"\"\"\n samples: [SampleIn!]!\n \"\"\"\n Whether or not the provided samples should only be validated and not created\n \"\"\"\n validateOnly: Boolean! = false\n}\n\ninput CreateSampleInput {\n instrumentSessionNumber: Int!\n proposalNumber: Int!\n samples: [SampleInLegacy!]!\n validateOnly: Boolean! = false\n}\n\n\"\"\"Return type when creating or validating samples\"\"\"\ntype CreateSamplesResponse {\n \"\"\"Errors that occurred during sample validation\"\"\"\n errors: [SampleValidationError!]!\n \"\"\"Samples that have been created\"\"\"\n samples: [Sample!]!\n \"\"\"Whether the operation has succeeded without validation errors\"\"\"\n success: Boolean!\n}\n\n\"\"\"Date with time (isoformat)\"\"\"\nscalar DateTime\n\ninput DatetimeOperatorInput {\n \"\"\"\n Will filter to items where the `DateTime` field is greater than (i.e. after) the provided value\n \"\"\"\n gt: DateTime = null\n \"\"\"\n Will filter to items where the `DateTime` field is less than (i.e. before) the provided value\n \"\"\"\n lt: DateTime = null\n}\n\n\"\"\"The details of sample validation error\"\"\"\ntype ErrorDetails {\n \"\"\"\n Tuple of strings identifying where in the sample schema the error occurred.\n \"\"\"\n location: [String!]!\n \"\"\"A human readable error message.\"\"\"\n message: String!\n \"\"\"The type of error that occurred\"\"\"\n type: String!\n}\n\ntype InstrumentSession @key(fields: \"instrumentSessionNumber proposal { proposalNumber }\") {\n instrumentSessionNumber: Int! @external\n proposal: Proposal @external\n \"\"\"Samples associated with a given instrument session\"\"\"\n samples(after: String = null, before: String = null, filter: SampleFilterInput! = {createdTime: null, data: null, name: null, schemaUrl: null, updatedTime: null}, first: Int!, last: Int = null, orderBy: SampleOrder! = {createdTime: null, name: null, updatedTime: null}): SampleConnection!\n}\n\ntype InstrumentSessionConnection {\n edges: [InstrumentSessionEdge!]!\n pageInfo: PageInfo!\n}\n\ntype InstrumentSessionEdge {\n cursor: String!\n node: InstrumentSession!\n}\n\ninput InstrumentSessionInput {\n instrumentSessionNumber: Int!\n proposalNumber: Int!\n}\n\ntype InstrumentSessionMutations @key(fields: \"instrumentSessionNumber proposalNumber\") {\n \"\"\"Create or validate samples associated with this instrument session\"\"\"\n createOrValidateSamples(input: CreateOrValidateSampleInputBase!): CreateSamplesResponse!\n instrumentSessionNumber: Int! @external\n proposalNumber: Int! @external\n}\n\n\"\"\"\nThe `JSON` scalar type represents JSON values as specified by [ECMA-404](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf).\n\"\"\"\nscalar JSON @specifiedBy(url: \"https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf\")\n\ninput JSONOperator @oneOf {\n datetimeOperator: DatetimeOperatorInput = null\n numericOperator: NumericOperatorInput = null\n stringOperator: StringOperatorInput = null\n}\n\ninput JSONOperatorInput {\n \"\"\"The operator to apply to the JSON field\"\"\"\n operator: JSONOperator!\n \"\"\"A JSON path specifying the value to filter. Must start with '$.'\"\"\"\n path: String!\n}\n\ntype Mutation {\n createOrValidateSamples(input: CreateOrValidateSampleInput!): CreateSamplesResponse!\n createSamples(input: CreateSampleInput!): [Sample!]! @deprecated(reason: \"Will be replaced by createOrValidateSamples\")\n sample(sampleId: UUID!): SampleMutations\n}\n\ninput NumericOperatorInput {\n \"\"\"\n Will filter to items where the numeric field is greater than the provided value\n \"\"\"\n gt: Float = null\n \"\"\"\n Will filter to items where the numeric field is less than the provided value\n \"\"\"\n lt: Float = null\n}\n\ntype PageInfo {\n endCursor: String @shareable\n hasNextPage: Boolean! @shareable\n hasPreviousPage: Boolean! @shareable\n startCursor: String @shareable\n}\n\ntype Proposal @key(fields: \"proposalNumber\") {\n proposalNumber: Int! @external\n}\n\ntype Query {\n \"\"\"Get a sample by its id\"\"\"\n sample(sampleId: UUID!): Sample\n \"\"\"Get a list of samples associated with a given instrument session\"\"\"\n samples(after: String = null, before: String = null, filter: SampleFilterInput! = {createdTime: null, data: null, name: null, schemaUrl: null, updatedTime: null}, first: Int!, instrumentSessions: [InstrumentSessionInput!] = null, last: Int = null, orderBy: SampleOrder! = {createdTime: null, name: null, updatedTime: null}): SampleConnection!\n}\n\ntype Sample {\n \"\"\"Samples derived from this sample\"\"\"\n children(after: String = null, before: String = null, first: Int = null, last: Int = null): SampleConnection!\n createdTime: DateTime!\n data: JSON!\n \"\"\"The JSON schema that the sample's `data` conforms to\"\"\"\n dataSchema: JSON!\n dataSchemaUrl: String!\n \"\"\"Events linked to this sample\"\"\"\n events(after: String = null, before: String = null, first: Int = null, last: Int = null): SampleEventConnection!\n id: UUID!\n images: [SampleImage!]!\n \"\"\"The instrument sessions that this sample is associated with\"\"\"\n instrumentSessions: InstrumentSessionConnection! @provides(fields: \"edges{ node{ instrumentSessionNumber proposal{ proposalNumber }}}\")\n name: String!\n \"\"\"Samples from which this sample is derived\"\"\"\n parents(after: String = null, before: String = null, first: Int = null, last: Int = null): SampleConnection!\n updatedTime: DateTime!\n}\n\ntype SampleConnection {\n edges: [SampleEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEdge {\n cursor: String!\n node: Sample!\n}\n\ntype SampleEvent {\n description: String!\n id: UUID!\n timestamp: DateTime!\n}\n\ntype SampleEventConnection {\n edges: [SampleEventEdge!]!\n pageInfo: PageInfo!\n}\n\ntype SampleEventEdge {\n cursor: String!\n node: SampleEvent!\n}\n\ninput SampleFilterInput {\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n createdTime: DatetimeOperatorInput = null\n \"\"\"Filter on the `data` field of `Sample`\"\"\"\n data: [JSONOperatorInput!] = null\n \"\"\"Filter on the `name` field of `Sample`\"\"\"\n name: StringOperatorInput = null\n \"\"\"Filter on the `schemaUrl` field of `Sample`\"\"\"\n schemaUrl: StringOperatorInput = null\n \"\"\"Filter on the `createdTime` field of `Sample`\"\"\"\n updatedTime: DatetimeOperatorInput = null\n}\n\ntype SampleImage {\n filename: String!\n url: String!\n}\n\ninput SampleIn {\n \"\"\"Data of the sample\"\"\"\n data: JSON!\n \"\"\"Name of the sample\"\"\"\n name: String!\n}\n\ninput SampleInLegacy {\n children: [SampleInLegacy!] = null\n data: JSON!\n dataSchemaUrl: String!\n name: String!\n parentIds: [Int!] = null\n}\n\ntype SampleMutations {\n addSampleEvent(sampleEvent: AddSampleEventInput!): SampleEvent!\n createSampleImageUploadUrl(contentLength: Int!, contentType: String!, filename: String!): String!\n linkInstrumentSessionToSample(instrumentSessionNumber: Int!, proposalNumber: Int!): Void\n sampleId: UUID!\n}\n\ninput SampleOrder {\n createdTime: SortingOrder = null\n name: SortingOrder = null\n updatedTime: SortingOrder = null\n}\n\n\"\"\"The details of errors occurred when validating a sample\"\"\"\ntype SampleValidationError {\n \"\"\"Errors that occurred when validating the sample\"\"\"\n errors: [ErrorDetails!]!\n \"\"\"\n The index of the sample in CreateSampleInput.samples for which the error occurred\n \"\"\"\n index: Int!\n}\n\nenum SortingOrder {\n ASC\n DESC\n}\n\n\"\"\"Conditions used to filter results based on the value of a String field\"\"\"\ninput StringOperatorInput {\n \"\"\"\n Will filter to items where the `String` field is contains the provided value\n \"\"\"\n contains: String = null\n \"\"\"\n Will filter to items where the `String` field is equal to the provided value\n \"\"\"\n eq: String = null\n \"\"\"\n Will filter to items where the `String` field is a member of the provided value\n \"\"\"\n in: [String!] = null\n \"\"\"\n Will filter to items where the `String` field is not equal to the provided value\n \"\"\"\n ne: String = null\n \"\"\"\n Will filter to items where the `String` field is not a member of the provided value\n \"\"\"\n nin: [String!] = null\n}\n\nscalar UUID\n\n\"\"\"Represents NULL values\"\"\"\nscalar Void\n\nscalar link__Import\n\nenum link__Purpose {\n EXECUTION\n SECURITY\n}\n\nscalar openfed__FieldSet",
- "9a94e595184badd514b2996e26945dd3a01edbf4": "schema {\n query: Query\n mutation: Mutation\n subscription: Subscription\n}\n\ndirective @link(as: String, for: link__Purpose, import: [link__Import], url: String!) repeatable on SCHEMA\n\ndirective @shareable repeatable on FIELD_DEFINITION | OBJECT\n\ntype Artifact {\n \"\"\"The MIME type of the artifact data\"\"\"\n mimeType: String!\n \"\"\"The file name of the artifact\"\"\"\n name: String!\n \"\"\"The download URL for the artifact\"\"\"\n url: Url!\n}\n\nscalar Creator\n\n\"\"\"\nImplement the DateTime<Utc> scalar\n\nThe input/output is a string in RFC3339 format.\n\"\"\"\nscalar DateTime\n\n\"\"\"A scalar that can represent any JSON value.\"\"\"\nscalar JSON\n\n\"\"\"A scalar that can represent any JSON Object value.\"\"\"\nscalar JSONObject\n\n\"\"\"A single log line streamed from a pod\"\"\"\ntype LogEntry {\n \"\"\"The log line content\"\"\"\n content: String!\n \"\"\"The name of the pod producing the log\"\"\"\n podName: String!\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Mutation {\n submitWorkflowTemplate(name: String!, parameters: JSON!, visit: VisitInput!): Workflow!\n}\n\n\"\"\"Represents Relay Node types\"\"\"\nunion NodeValue = Workflow\n\n\"\"\"Information about pagination in a connection\"\"\"\ntype PageInfo {\n \"\"\"When paginating forwards, the cursor to continue.\"\"\"\n endCursor: String @shareable\n \"\"\"When paginating forwards, are there more items?\"\"\"\n hasNextPage: Boolean! @shareable\n \"\"\"When paginating backwards, are there more items?\"\"\"\n hasPreviousPage: Boolean! @shareable\n \"\"\"When paginating backwards, the cursor to continue.\"\"\"\n startCursor: String @shareable\n}\n\n\"\"\"The root query of the service\"\"\"\ntype Query {\n node(id: ID!): NodeValue\n \"\"\"Get a single [`Workflow`] by proposal, visit, and name\"\"\"\n workflow(name: String!, visit: VisitInput!): Workflow!\n workflowTemplate(name: String!): WorkflowTemplate!\n workflowTemplates(cursor: String, filter: WorkflowTemplatesFilter, limit: Int): WorkflowTemplateConnection!\n workflows(cursor: String, filter: WorkflowFilter, limit: Int, visit: VisitInput!): WorkflowConnection!\n}\n\n\"\"\"Supported DLS science groups\"\"\"\nenum ScienceGroup {\n \"\"\"Biological Cryo-Imaging\"\"\"\n BIO_CRYO_IMAGING\n \"\"\"Soft Condensed Matter\"\"\"\n CONDENSED_MATTER\n \"\"\"Crystallography\"\"\"\n CRYSTALLOGRAPHY\n \"\"\"Workflows Examples\"\"\"\n EXAMPLES\n \"\"\"Imaging and Microscopy\"\"\"\n IMAGING\n \"\"\"Magnetic Materials\"\"\"\n MAGNETIC_MATERIALS\n \"\"\"Macromolecular Crystallography\"\"\"\n MX\n \"\"\"Spectroscopy\"\"\"\n SPECTROSCOPY\n \"\"\"Structures and Surfaces\"\"\"\n SURFACES\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Subscription {\n \"\"\"Processing to subscribe to logs for a single pod of a workflow\"\"\"\n logs(taskId: String!, visit: VisitInput!, workflowName: String!): LogEntry!\n \"\"\"Processing to subscribe to data for all workflows in a session\"\"\"\n workflow(name: String!, visit: VisitInput!): Workflow!\n}\n\ntype Task {\n \"\"\"Artifacts produced by a task\"\"\"\n artifacts: [Artifact!]!\n \"\"\"Children of a task\"\"\"\n dependencies: [String!]!\n \"\"\"Parent of a task\"\"\"\n depends: [String!]!\n \"\"\"End time for a task on a workflow\"\"\"\n endTime: DateTime\n \"\"\"Unique name of the task\"\"\"\n id: String!\n \"\"\"\n A human readable message indicating details about why this step is in this condition\n \"\"\"\n message: String\n \"\"\"Display name of the task\"\"\"\n name: String!\n \"\"\"Start time for a task on a workflow\"\"\"\n startTime: DateTime\n \"\"\"Current status of a task\"\"\"\n status: TaskStatus!\n \"\"\"Node type - Pod, DAG, etc\"\"\"\n stepType: String!\n}\n\nenum TaskStatus {\n ERROR\n FAILED\n OMITTED\n PENDING\n RUNNING\n SKIPPED\n SUCCEEDED\n}\n\nscalar Template\n\n\"\"\"Information about where the template is stored\"\"\"\ntype TemplateSource {\n \"\"\"The path to the template within the repository\"\"\"\n path: String!\n \"\"\"The URL of the GitHub repository\"\"\"\n repositoryUrl: String!\n \"\"\"The current tracked branch of the repository\"\"\"\n targetRevision: String!\n}\n\n\"\"\"\nURL is a String implementing the [URL Standard](http://url.spec.whatwg.org/)\n\"\"\"\nscalar Url\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ntype Visit {\n \"\"\"Session visit Number\"\"\"\n number: Int!\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n}\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ninput VisitInput {\n \"\"\"Session visit Number\"\"\"\n number: Int!\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n}\n\ntype Workflow {\n \"\"\"The workflow creator\"\"\"\n creator: WorkflowCreator!\n \"\"\"The unique ID derived from the visit and name\"\"\"\n id: ID!\n \"\"\"The name given to the workflow, unique within a given visit\"\"\"\n name: String!\n \"\"\"The top-level workflow parameters\"\"\"\n parameters: JSONObject\n \"\"\"The current status of the workflow\"\"\"\n status: WorkflowStatus\n \"\"\"The name of the template used to run the workflow\"\"\"\n templateRef: String\n \"\"\"The visit the Workflow was run against\"\"\"\n visit: Visit!\n}\n\ntype WorkflowConnection {\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowEdge!]! @shareable\n \"\"\"A list of nodes.\"\"\"\n nodes: [Workflow!]! @shareable\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo! @shareable\n}\n\n\"\"\"Information about the creator of a workflow.\"\"\"\ntype WorkflowCreator {\n \"\"\"\n An identifier unique to the creator of the workflow.\n Typically this is the creator's Fed-ID.\n \"\"\"\n creatorId: String!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowEdge {\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String! @shareable\n \"\"\"The item at the end of the edge\"\"\"\n node: Workflow! @shareable\n}\n\n\"\"\"All tasks in the workflow have errored\"\"\"\ntype WorkflowErroredStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All tasks in the workflow have failed\"\"\"\ntype WorkflowFailedStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All the supported Workflows filters\"\"\"\ninput WorkflowFilter {\n \"\"\"The fedid of the user who created the workflow\"\"\"\n creator: Creator\n \"\"\"The name of the workflow template\"\"\"\n template: Template\n \"\"\"The status field for a workflow\"\"\"\n workflowStatusFilter: WorkflowStatusFilter\n}\n\ntype WorkflowPendingStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n}\n\ntype WorkflowRunningStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"The status of a workflow\"\"\"\nunion WorkflowStatus = WorkflowErroredStatus | WorkflowFailedStatus | WorkflowPendingStatus | WorkflowRunningStatus | WorkflowSucceededStatus\n\n\"\"\"Represents workflow status filters\"\"\"\ninput WorkflowStatusFilter {\n error: Boolean! = false\n failed: Boolean! = false\n pending: Boolean! = false\n running: Boolean! = false\n succeeded: Boolean! = false\n}\n\n\"\"\"All tasks in the workflow have succeded\"\"\"\ntype WorkflowSucceededStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\ntype WorkflowTemplate {\n \"\"\"A JSON Schema describing the arguments of a Workflow Template\"\"\"\n arguments: JSON!\n \"\"\"A human readable description of the workflow which is created\"\"\"\n description: String\n \"\"\"The group who maintains the workflow template\"\"\"\n maintainer: String!\n \"\"\"The name given to the workflow template, globally unique\"\"\"\n name: String!\n \"\"\"The repository storing the code associated with this template.\"\"\"\n repository: String\n \"\"\"Information about where the template is obtained from\"\"\"\n templateSource: TemplateSource\n \"\"\"A human readable title for the workflow template\"\"\"\n title: String\n \"\"\"\n A JSON Forms UI Schema describing how to render the arguments of the Workflow Template\n \"\"\"\n uiSchema: JSON\n}\n\ntype WorkflowTemplateConnection {\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowTemplateEdge!]! @shareable\n \"\"\"A list of nodes.\"\"\"\n nodes: [WorkflowTemplate!]! @shareable\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo! @shareable\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowTemplateEdge {\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String! @shareable\n \"\"\"The item at the end of the edge\"\"\"\n node: WorkflowTemplate! @shareable\n}\n\n\"\"\"Supported label filters for ClusterWorkflowTemplates\"\"\"\ninput WorkflowTemplatesFilter {\n \"\"\"The science group owning the template eg imaging\"\"\"\n scienceGroup: [ScienceGroup!]\n}\n\nscalar link__Import\n\nenum link__Purpose {\n EXECUTION\n SECURITY\n}"
+ "9a94e595184badd514b2996e26945dd3a01edbf4": "schema {\n query: Query\n mutation: Mutation\n subscription: Subscription\n}\n\ndirective @link(as: String, for: link__Purpose, import: [link__Import], url: String!) repeatable on SCHEMA\n\ndirective @shareable repeatable on FIELD_DEFINITION | OBJECT\n\ntype Artifact {\n \"\"\"The MIME type of the artifact data\"\"\"\n mimeType: String!\n \"\"\"The file name of the artifact\"\"\"\n name: String!\n \"\"\"The download URL for the artifact\"\"\"\n url: Url!\n}\n\nscalar Creator\n\n\"\"\"\nImplement the DateTime<Utc> scalar\n\nThe input/output is a string in RFC3339 format.\n\"\"\"\nscalar DateTime\n\n\"\"\"A scalar that can represent any JSON value.\"\"\"\nscalar JSON\n\n\"\"\"A scalar that can represent any JSON Object value.\"\"\"\nscalar JSONObject\n\n\"\"\"A single log line streamed from a pod\"\"\"\ntype LogEntry {\n \"\"\"The log line content\"\"\"\n content: String!\n \"\"\"The name of the pod producing the log\"\"\"\n podName: String!\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Mutation {\n submitWorkflowTemplate(name: String!, parameters: JSON!, visit: VisitInput!): Workflow!\n}\n\n\"\"\"Represents Relay Node types\"\"\"\nunion NodeValue = Workflow\n\n\"\"\"Information about pagination in a connection\"\"\"\ntype PageInfo {\n \"\"\"When paginating forwards, the cursor to continue.\"\"\"\n endCursor: String @shareable\n \"\"\"When paginating forwards, are there more items?\"\"\"\n hasNextPage: Boolean! @shareable\n \"\"\"When paginating backwards, are there more items?\"\"\"\n hasPreviousPage: Boolean! @shareable\n \"\"\"When paginating backwards, the cursor to continue.\"\"\"\n startCursor: String @shareable\n}\n\n\"\"\"The root query of the service\"\"\"\ntype Query {\n node(id: ID!): NodeValue\n \"\"\"Get a single [`Workflow`] by proposal, visit, and name\"\"\"\n workflow(name: String!, visit: VisitInput!): Workflow!\n workflowTemplate(name: String!): WorkflowTemplate!\n workflowTemplates(cursor: String, filter: WorkflowTemplatesFilter, limit: Int): WorkflowTemplateConnection!\n workflows(cursor: String, filter: WorkflowFilter, limit: Int, visit: VisitInput!): WorkflowConnection!\n}\n\n\"\"\"Supported DLS science groups\"\"\"\nenum ScienceGroup {\n \"\"\"Biological Cryo-Imaging\"\"\"\n BIO_CRYO_IMAGING\n \"\"\"Soft Condensed Matter\"\"\"\n CONDENSED_MATTER\n \"\"\"Crystallography\"\"\"\n CRYSTALLOGRAPHY\n \"\"\"Workflows Examples\"\"\"\n EXAMPLES\n \"\"\"Imaging and Microscopy\"\"\"\n IMAGING\n \"\"\"Magnetic Materials\"\"\"\n MAGNETIC_MATERIALS\n \"\"\"Macromolecular Crystallography\"\"\"\n MX\n \"\"\"Spectroscopy\"\"\"\n SPECTROSCOPY\n \"\"\"Structures and Surfaces\"\"\"\n SURFACES\n}\n\n\"\"\"The root mutation of the service\"\"\"\ntype Subscription {\n \"\"\"Processing to subscribe to logs for a single pod of a workflow\"\"\"\n logs(taskId: String!, visit: VisitInput!, workflowName: String!): LogEntry!\n \"\"\"Processing to subscribe to data for all workflows in a session\"\"\"\n workflow(name: String!, visit: VisitInput!): Workflow!\n}\n\ntype Task {\n \"\"\"Artifacts produced by a task\"\"\"\n artifacts: [Artifact!]!\n \"\"\"Children of a task\"\"\"\n dependencies: [String!]!\n \"\"\"Parent of a task\"\"\"\n depends: [String!]!\n \"\"\"End time for a task on a workflow\"\"\"\n endTime: DateTime\n \"\"\"Unique name of the task\"\"\"\n id: String!\n \"\"\"\n A human readable message indicating details about why this step is in this condition\n \"\"\"\n message: String\n \"\"\"Display name of the task\"\"\"\n name: String!\n \"\"\"Start time for a task on a workflow\"\"\"\n startTime: DateTime\n \"\"\"Current status of a task\"\"\"\n status: TaskStatus!\n \"\"\"Node type - Pod, DAG, etc\"\"\"\n stepType: String!\n}\n\nenum TaskStatus {\n ERROR\n FAILED\n OMITTED\n PENDING\n RUNNING\n SKIPPED\n SUCCEEDED\n}\n\nscalar Template\n\n\"\"\"Information about where the template is stored\"\"\"\ntype TemplateSource {\n \"\"\"The path to the template within the repository\"\"\"\n path: String!\n \"\"\"The URL of the GitHub repository\"\"\"\n repositoryUrl: String!\n \"\"\"The current tracked branch of the repository\"\"\"\n targetRevision: String!\n}\n\n\"\"\"\nURL is a String implementing the [URL Standard](http://url.spec.whatwg.org/)\n\"\"\"\nscalar Url\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ntype Visit {\n \"\"\"Session visit Number\"\"\"\n number: Int!\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n}\n\n\"\"\"A visit to an instrument as part of a session\"\"\"\ninput VisitInput {\n \"\"\"Session visit Number\"\"\"\n number: Int!\n \"\"\"Project Proposal Code\"\"\"\n proposalCode: String!\n \"\"\"Project Proposal Number\"\"\"\n proposalNumber: Int!\n}\n\ntype Workflow {\n \"\"\"The workflow creator\"\"\"\n creator: WorkflowCreator!\n \"\"\"The unique ID derived from the visit and name\"\"\"\n id: ID!\n \"\"\"The name given to the workflow, unique within a given visit\"\"\"\n name: String!\n \"\"\"The top-level workflow parameters\"\"\"\n parameters: JSONObject\n \"\"\"The current status of the workflow\"\"\"\n status: WorkflowStatus\n \"\"\"The name of the template used to run the workflow\"\"\"\n templateRef: String\n \"\"\"The visit the Workflow was run against\"\"\"\n visit: Visit!\n}\n\ntype WorkflowConnection {\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowEdge!]! @shareable\n \"\"\"A list of nodes.\"\"\"\n nodes: [Workflow!]! @shareable\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo! @shareable\n}\n\n\"\"\"Information about the creator of a workflow.\"\"\"\ntype WorkflowCreator {\n \"\"\"\n An identifier unique to the creator of the workflow.\n Typically this is the creator's Fed-ID.\n \"\"\"\n creatorId: String!\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowEdge {\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String! @shareable\n \"\"\"The item at the end of the edge\"\"\"\n node: Workflow! @shareable\n}\n\n\"\"\"All tasks in the workflow have errored\"\"\"\ntype WorkflowErroredStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All tasks in the workflow have failed\"\"\"\ntype WorkflowFailedStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"All the supported Workflows filters\"\"\"\ninput WorkflowFilter {\n \"\"\"The fedid of the user who created the workflow\"\"\"\n creator: Creator\n \"\"\"The name of the workflow template\"\"\"\n template: Template\n \"\"\"The status field for a workflow\"\"\"\n workflowStatusFilter: WorkflowStatusFilter\n}\n\ntype WorkflowPendingStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n}\n\ntype WorkflowRunningStatus {\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\n\"\"\"The status of a workflow\"\"\"\nunion WorkflowStatus = WorkflowErroredStatus | WorkflowFailedStatus | WorkflowPendingStatus | WorkflowRunningStatus | WorkflowSucceededStatus\n\n\"\"\"Represents workflow status filters\"\"\"\ninput WorkflowStatusFilter {\n error: Boolean! = false\n failed: Boolean! = false\n pending: Boolean! = false\n running: Boolean! = false\n succeeded: Boolean! = false\n}\n\n\"\"\"All tasks in the workflow have succeded\"\"\"\ntype WorkflowSucceededStatus {\n \"\"\"Time at which this workflow completed\"\"\"\n endTime: DateTime!\n \"\"\"\n A human readable message indicating details about why the workflow is in this condition\n \"\"\"\n message: String\n \"\"\"Time at which this workflow started\"\"\"\n startTime: DateTime!\n \"\"\"Tasks created by the workflow\"\"\"\n tasks: [Task!]!\n}\n\ntype WorkflowTemplate {\n \"\"\"A JSON Schema describing the arguments of a Workflow Template\"\"\"\n arguments: JSON!\n \"\"\"A human readable description of the workflow which is created\"\"\"\n description: String\n \"\"\"The group who maintains the workflow template\"\"\"\n maintainer: String!\n \"\"\"The name given to the workflow template, globally unique\"\"\"\n name: String!\n \"\"\"The repository storing the code associated with this template.\"\"\"\n repository: String\n \"\"\"Information about where the template is obtained from\"\"\"\n templateSource: TemplateSource\n \"\"\"A human readable title for the workflow template\"\"\"\n title: String\n \"\"\"\n A JSON Forms UI Schema describing how to render the arguments of the Workflow Template\n \"\"\"\n uiSchema: JSON\n}\n\ntype WorkflowTemplateConnection {\n \"\"\"A list of edges.\"\"\"\n edges: [WorkflowTemplateEdge!]! @shareable\n \"\"\"A list of nodes.\"\"\"\n nodes: [WorkflowTemplate!]! @shareable\n \"\"\"Information to aid in pagination.\"\"\"\n pageInfo: PageInfo! @shareable\n}\n\n\"\"\"An edge in a connection.\"\"\"\ntype WorkflowTemplateEdge {\n \"\"\"A cursor for use in pagination\"\"\"\n cursor: String! @shareable\n \"\"\"The item at the end of the edge\"\"\"\n node: WorkflowTemplate! @shareable\n}\n\n\"\"\"Supported label filters for ClusterWorkflowTemplates\"\"\"\ninput WorkflowTemplatesFilter {\n \"\"\"The science group owning the template eg imaging\"\"\"\n scienceGroup: [ScienceGroup!]\n}\n\nscalar link__Import\n\nenum link__Purpose {\n EXECUTION\n SECURITY\n}",
+ "ab9040c814f11559b1e7d93f67b38b284f1bf0d3": "schema {\n query: Query\n}\n\n\"\"\"A JSON schema\"\"\"\ntype JSONSchema {\n \"\"\"The description og the schema\"\"\"\n description: String\n \"\"\"The identifier of the schema\"\"\"\n id: String!\n \"\"\"The instrument the schema was created for\"\"\"\n instrument: String\n \"\"\"The title of the schema\"\"\"\n title: String\n \"\"\"The type of object the shema describes (if known)\"\"\"\n type: String\n \"\"\"A URL from which the schema can be accessed\"\"\"\n url: String!\n \"\"\"The version of the schema\"\"\"\n version: String\n}\n\ntype Query {\n jsonSchema(url: String!): JSONSchema\n jsonSchemas(instrument: String = null, type: String = null): [JSONSchema!]!\n}"
}
},
"subgraphs": [
@@ -1079,6 +1159,11 @@
"id": "2",
"name": "samples",
"routingUrl": "https://sample-information.diamond.ac.uk/api/graphql"
+ },
+ {
+ "id": "3",
+ "name": "schemas",
+ "routingUrl": "https://schemas.diamond.ac.uk/graphql"
}
],
"version": "00000000-0000-0000-0000-000000000000" |
diff --git a/tmp/old_supergraph.graphql b/tmp/new_supergraph.graphql
index 67abf03..36ce517 100644
--- a/tmp/old_supergraph.graphql
+++ b/tmp/new_supergraph.graphql
@@ -98,6 +98,8 @@ type Query {
"""Get a sample by its id"""
sample(sampleId: UUID!): Sample
+ jsonSchema(url: String!): JSONSchema
+ jsonSchemas(type: String = null, instrument: String = null): [JSONSchema!]!
}
"""Supported DLS science groups"""
@@ -794,4 +796,28 @@ input StringOperatorInput {
scalar UUID
"""Represents NULL values"""
-scalar Void
\ No newline at end of file
+scalar Void
+
+"""A JSON schema"""
+type JSONSchema {
+ """The identifier of the schema"""
+ id: String!
+
+ """A URL from which the schema can be accessed"""
+ url: String!
+
+ """The type of object the shema describes (if known)"""
+ type: String
+
+ """The title of the schema"""
+ title: String
+
+ """The version of the schema"""
+ version: String
+
+ """The instrument the schema was created for"""
+ instrument: String
+
+ """The description og the schema"""
+ description: String
+}
\ No newline at end of file |
VictoriaBeilsten-Edmands
approved these changes
Mar 18, 2026
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Repository
Subgraph maintainers
@DiamondLightSource/ulims