scalar Time scalar Any scalar NullableFloat scalar MetricScope scalar JobState type Job { id: ID! jobId: Int! user: String! project: String! cluster: String! subCluster: String! startTime: Time! duration: Int! walltime: Int! numNodes: Int! numHWThreads: Int! numAcc: Int! energy: Float! SMT: Int! exclusive: Int! partition: String! arrayJobId: Int! monitoringStatus: Int! state: JobState! tags: [Tag!]! resources: [Resource!]! concurrentJobs: JobLinkResultList footprint: [FootprintValue] energyFootprint: [EnergyFootprintValue] metaData: Any userData: User } type JobLink { id: ID! jobId: Int! } type Cluster { name: String! partitions: [String!]! # Slurm partitions subClusters: [SubCluster!]! # Hardware partitions/subclusters } type SubCluster { name: String! nodes: String! numberOfNodes: Int! processorType: String! socketsPerNode: Int! coresPerSocket: Int! threadsPerCore: Int! flopRateScalar: MetricValue! flopRateSimd: MetricValue! memoryBandwidth: MetricValue! topology: Topology! metricConfig: [MetricConfig!]! footprint: [String!]! } type FootprintValue { name: String! stat: String! value: Float! } type EnergyFootprintValue { hardware: String! metric: String! value: Float! } type MetricValue { name: String unit: Unit! value: Float! } type Topology { node: [Int!] socket: [[Int!]!] memoryDomain: [[Int!]!] die: [[Int!]!] core: [[Int!]!] accelerators: [Accelerator!] } type Accelerator { id: String! type: String! model: String! } type SubClusterConfig { name: String! peak: Float normal: Float caution: Float alert: Float remove: Boolean } type MetricConfig { name: String! unit: Unit! scope: MetricScope! aggregation: String! timestep: Int! peak: Float! normal: Float caution: Float! alert: Float! lowerIsBetter: Boolean subClusters: [SubClusterConfig!]! } type Tag { id: ID! type: String! name: String! scope: String! } type Resource { hostname: String! hwthreads: [Int!] accelerators: [String!] configuration: String } type JobMetricWithName { name: String! scope: MetricScope! metric: JobMetric! } type JobMetric { unit: Unit timestep: Int! series: [Series!] statisticsSeries: StatsSeries } type Series { hostname: String! id: String statistics: MetricStatistics data: [NullableFloat!]! } type Unit { base: String! prefix: String } type MetricStatistics { avg: Float! min: Float! max: Float! } type StatsSeries { mean: [NullableFloat!]! median: [NullableFloat!]! min: [NullableFloat!]! max: [NullableFloat!]! } type MetricFootprints { metric: String! data: [NullableFloat!]! } type Footprints { timeWeights: TimeWeights! metrics: [MetricFootprints!]! } type TimeWeights { nodeHours: [NullableFloat!]! accHours: [NullableFloat!]! coreHours: [NullableFloat!]! } enum Aggregate { USER, PROJECT, CLUSTER } enum SortByAggregate { TOTALWALLTIME, TOTALJOBS, TOTALNODES, TOTALNODEHOURS, TOTALCORES, TOTALCOREHOURS, TOTALACCS, TOTALACCHOURS } type NodeMetrics { host: String! subCluster: String! metrics: [JobMetricWithName!]! } type NodesResultList { items: [NodeMetrics!]! offset: Int limit: Int count: Int totalNodes: Int hasNextPage: Boolean } type ClusterSupport { cluster: String! subClusters: [String!]! } type GlobalMetricListItem { name: String! unit: Unit! scope: MetricScope! footprint: String availability: [ClusterSupport!]! } type Count { name: String! count: Int! } type User { username: String! name: String! email: String! } input MetricStatItem { metricName: String! range: FloatRange! } type Query { clusters: [Cluster!]! # List of all clusters tags: [Tag!]! # List of all tags globalMetrics: [GlobalMetricListItem!]! user(username: String!): User allocatedNodes(cluster: String!): [Count!]! job(id: ID!): Job jobMetrics(id: ID!, metrics: [String!], scopes: [MetricScope!], resolution: Int): [JobMetricWithName!]! jobsFootprints(filter: [JobFilter!], metrics: [String!]!): Footprints jobs(filter: [JobFilter!], page: PageRequest, order: OrderByInput): JobResultList! jobsStatistics(filter: [JobFilter!], metrics: [String!], page: PageRequest, sortBy: SortByAggregate, groupBy: Aggregate): [JobsStatistics!]! rooflineHeatmap(filter: [JobFilter!]!, rows: Int!, cols: Int!, minX: Float!, minY: Float!, maxX: Float!, maxY: Float!): [[Float!]!]! nodeMetrics(cluster: String!, nodes: [String!], scopes: [MetricScope!], metrics: [String!], from: Time!, to: Time!): [NodeMetrics!]! nodeMetricsList(cluster: String!, subCluster: String!, nodeFilter: String!, scopes: [MetricScope!], metrics: [String!], from: Time!, to: Time!, page: PageRequest, resolution: Int): NodesResultList! } type Mutation { createTag(type: String!, name: String!, scope: String!): Tag! deleteTag(id: ID!): ID! addTagsToJob(job: ID!, tagIds: [ID!]!): [Tag!]! removeTagsFromJob(job: ID!, tagIds: [ID!]!): [Tag!]! updateConfiguration(name: String!, value: String!): String } type IntRangeOutput { from: Int!, to: Int! } type TimeRangeOutput { range: String, from: Time!, to: Time! } input JobFilter { tags: [ID!] jobId: StringInput arrayJobId: Int user: StringInput project: StringInput jobName: StringInput cluster: StringInput partition: StringInput duration: IntRange energy: FloatRange minRunningFor: Int numNodes: IntRange numAccelerators: IntRange numHWThreads: IntRange startTime: TimeRange state: [JobState!] metricStats: [MetricStatItem!] exclusive: Int node: StringInput } input OrderByInput { field: String! type: String!, order: SortDirectionEnum! = ASC } enum SortDirectionEnum { DESC ASC } input StringInput { eq: String neq: String contains: String startsWith: String endsWith: String in: [String!] } input IntRange { from: Int!, to: Int! } input TimeRange { range: String, from: Time, to: Time } input FloatRange { from: Float! to: Float! } type JobResultList { items: [Job!]! offset: Int limit: Int count: Int hasNextPage: Boolean } type JobLinkResultList { listQuery: String items: [JobLink!]! count: Int } type HistoPoint { count: Int! value: Int! } type MetricHistoPoints { metric: String! unit: String! stat: String data: [MetricHistoPoint!] } type MetricHistoPoint { bin: Int count: Int! min: Int max: Int } type JobsStatistics { id: ID! # If `groupBy` was used, ID of the user/project/cluster name: String! # if User-Statistics: Given Name of Account (ID) Owner totalJobs: Int! # Number of jobs runningJobs: Int! # Number of running jobs shortJobs: Int! # Number of jobs with a duration of less than duration totalWalltime: Int! # Sum of the duration of all matched jobs in hours totalNodes: Int! # Sum of the nodes of all matched jobs totalNodeHours: Int! # Sum of the node hours of all matched jobs totalCores: Int! # Sum of the cores of all matched jobs totalCoreHours: Int! # Sum of the core hours of all matched jobs totalAccs: Int! # Sum of the accs of all matched jobs totalAccHours: Int! # Sum of the gpu hours of all matched jobs histDuration: [HistoPoint!]! # value: hour, count: number of jobs with a rounded duration of value histNumNodes: [HistoPoint!]! # value: number of nodes, count: number of jobs with that number of nodes histNumCores: [HistoPoint!]! # value: number of cores, count: number of jobs with that number of cores histNumAccs: [HistoPoint!]! # value: number of accs, count: number of jobs with that number of accs histMetrics: [MetricHistoPoints!]! # metric: metricname, data array of histopoints: value: metric average bin, count: number of jobs with that metric average } input PageRequest { itemsPerPage: Int! page: Int! }