type Job { id: ID! jobId: String! userId: String! projectId: String! clusterId: String! startTime: Time! duration: Int! numNodes: Int! hasProfile: Boolean! memUsed_max: Float flopsAny_avg: Float memBw_avg: Float netBw_avg: Float fileBw_avg: Float tags: [JobTag!] } type Cluster { clusterID: String! processorType: String! socketsPerNode: Int! coresPerSocket: Int! threadsPerCore: Int! flopRateScalar: Int! flopRateSimd: Int! memoryBandwidth: Int! metricConfig: [MetricConfig!]! } type MetricConfig { name: String! unit: String! sampletime: Int! peak: Int! normal: Int! caution: Int! alert: Int! } type JobMetric { unit: String! scope: JobMetricScope! timestep: Int! series: [JobMetricSeries]! } enum JobMetricScope { node cpu socket } type JobMetricSeries { node_id: String! statistics: JobMetricStatistics data: [Float]! } type JobMetricStatistics { avg: Float! min: Float! max: Float! } type JobTag { id: ID! tagType: String! tagName: String! } type Query { clusters: [Cluster!]! jobById(jobId: String!): Job jobs(filter: JobFilterList, page: PageRequest, order: OrderByInput): JobResultList! jobsStatistics(filter: JobFilterList): JobsStatistics! jobMetrics(jobId: String!, metrics: [String]): [JobMetricWithName]! # Return all known tags or, if jobId is specified, only tags from this job tags(jobId: String): [JobTag!]! } input StartJobInput { jobId: String! userId: String! projectId: String! clusterId: String! startTime: Time! numNodes: Int! } input StopJobInput { stopTime: Time! } input AddJobInput { jobId: String! userId: String! projectId: String! clusterId: String! startTime: Time! duration: Int! numNodes: Int! } input JobFilterList { list: [JobFilter] } input JobFilter { tagName: String tagType: String jobId: StringInput userId: StringInput projectId: StringInput clusterId: StringInput duration: IntRange numNodes: IntRange startTime: TimeRange hasProfile: Boolean } input OrderByInput { field: String! order: SortDirectionEnum = ASC } enum SortDirectionEnum { DESC ASC } input StringInput { eq: String contains: String startsWith: String endsWith: String } input IntRange { from: Int! to: Int! } input FloatRange { from: Float! to: Float! } input TimeRange { from: Time! to: Time! } type JobResultList { items: [Job]! offset: Int limit: Int count: Int } type JobMetricWithName { name: String! metric: JobMetric! } type HistoPoint { count: Int! value: Int! } type JobsStatistics { totalJobs: Int! shortJobs: Int! totalWalltime: Int! totalCoreHours: Int! histWalltime: [HistoPoint]! histNumNodes: [HistoPoint]! } input PageRequest { itemsPerPage: Int page: Int } scalar Time