2021-03-31 08:50:53 +02:00
|
|
|
// Code generated by github.com/99designs/gqlgen, DO NOT EDIT.
|
|
|
|
|
|
|
|
package model
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"strconv"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2021-05-06 08:36:24 +02:00
|
|
|
type FilterRanges struct {
|
|
|
|
Duration *IntRangeOutput `json:"duration"`
|
|
|
|
NumNodes *IntRangeOutput `json:"numNodes"`
|
|
|
|
StartTime *TimeRangeOutput `json:"startTime"`
|
2021-03-31 08:50:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type FloatRange struct {
|
|
|
|
From float64 `json:"from"`
|
|
|
|
To float64 `json:"to"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type HistoPoint struct {
|
|
|
|
Count int `json:"count"`
|
|
|
|
Value int `json:"value"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type IntRange struct {
|
|
|
|
From int `json:"from"`
|
|
|
|
To int `json:"to"`
|
|
|
|
}
|
|
|
|
|
2021-05-06 08:36:24 +02:00
|
|
|
type IntRangeOutput struct {
|
|
|
|
From int `json:"from"`
|
|
|
|
To int `json:"to"`
|
|
|
|
}
|
|
|
|
|
2021-03-31 08:50:53 +02:00
|
|
|
type JobFilter struct {
|
2021-05-06 13:50:38 +02:00
|
|
|
Tags []string `json:"tags"`
|
|
|
|
JobID *StringInput `json:"jobId"`
|
|
|
|
UserID *StringInput `json:"userId"`
|
|
|
|
ProjectID *StringInput `json:"projectId"`
|
|
|
|
ClusterID *StringInput `json:"clusterId"`
|
|
|
|
Duration *IntRange `json:"duration"`
|
|
|
|
NumNodes *IntRange `json:"numNodes"`
|
|
|
|
StartTime *TimeRange `json:"startTime"`
|
2021-09-23 11:45:20 +02:00
|
|
|
IsRunning *bool `json:"isRunning"`
|
2021-05-06 13:50:38 +02:00
|
|
|
FlopsAnyAvg *FloatRange `json:"flopsAnyAvg"`
|
|
|
|
MemBwAvg *FloatRange `json:"memBwAvg"`
|
|
|
|
LoadAvg *FloatRange `json:"loadAvg"`
|
|
|
|
MemUsedMax *FloatRange `json:"memUsedMax"`
|
2021-03-31 08:50:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type JobFilterList struct {
|
|
|
|
List []*JobFilter `json:"list"`
|
|
|
|
}
|
|
|
|
|
2021-04-07 09:19:21 +02:00
|
|
|
type JobMetric struct {
|
|
|
|
Unit string `json:"unit"`
|
|
|
|
Scope JobMetricScope `json:"scope"`
|
|
|
|
Timestep int `json:"timestep"`
|
|
|
|
Series []*JobMetricSeries `json:"series"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetricSeries struct {
|
|
|
|
NodeID string `json:"node_id"`
|
|
|
|
Statistics *JobMetricStatistics `json:"statistics"`
|
|
|
|
Data []*float64 `json:"data"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetricStatistics struct {
|
|
|
|
Avg float64 `json:"avg"`
|
|
|
|
Min float64 `json:"min"`
|
|
|
|
Max float64 `json:"max"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetricWithName struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Metric *JobMetric `json:"metric"`
|
|
|
|
}
|
|
|
|
|
2021-03-31 08:50:53 +02:00
|
|
|
type JobResultList struct {
|
|
|
|
Items []*Job `json:"items"`
|
|
|
|
Offset *int `json:"offset"`
|
|
|
|
Limit *int `json:"limit"`
|
|
|
|
Count *int `json:"count"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobsStatistics struct {
|
|
|
|
TotalJobs int `json:"totalJobs"`
|
|
|
|
ShortJobs int `json:"shortJobs"`
|
|
|
|
TotalWalltime int `json:"totalWalltime"`
|
|
|
|
TotalCoreHours int `json:"totalCoreHours"`
|
|
|
|
HistWalltime []*HistoPoint `json:"histWalltime"`
|
|
|
|
HistNumNodes []*HistoPoint `json:"histNumNodes"`
|
|
|
|
}
|
|
|
|
|
2021-04-22 15:00:54 +02:00
|
|
|
type MetricConfig struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Unit string `json:"unit"`
|
|
|
|
Sampletime int `json:"sampletime"`
|
|
|
|
Peak int `json:"peak"`
|
|
|
|
Normal int `json:"normal"`
|
|
|
|
Caution int `json:"caution"`
|
|
|
|
Alert int `json:"alert"`
|
|
|
|
}
|
|
|
|
|
2021-03-31 08:50:53 +02:00
|
|
|
type OrderByInput struct {
|
|
|
|
Field string `json:"field"`
|
|
|
|
Order *SortDirectionEnum `json:"order"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type PageRequest struct {
|
2021-09-23 11:45:20 +02:00
|
|
|
ItemsPerPage int `json:"itemsPerPage"`
|
|
|
|
Page int `json:"page"`
|
2021-03-31 08:50:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type StringInput struct {
|
|
|
|
Eq *string `json:"eq"`
|
|
|
|
Contains *string `json:"contains"`
|
|
|
|
StartsWith *string `json:"startsWith"`
|
|
|
|
EndsWith *string `json:"endsWith"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type TimeRange struct {
|
|
|
|
From time.Time `json:"from"`
|
|
|
|
To time.Time `json:"to"`
|
|
|
|
}
|
|
|
|
|
2021-05-06 08:36:24 +02:00
|
|
|
type TimeRangeOutput struct {
|
|
|
|
From time.Time `json:"from"`
|
|
|
|
To time.Time `json:"to"`
|
|
|
|
}
|
|
|
|
|
2021-09-23 11:45:20 +02:00
|
|
|
type UserStats struct {
|
|
|
|
UserID string `json:"userId"`
|
|
|
|
TotalJobs int `json:"totalJobs"`
|
|
|
|
TotalWalltime float64 `json:"totalWalltime"`
|
|
|
|
TotalCoreHours float64 `json:"totalCoreHours"`
|
|
|
|
}
|
|
|
|
|
2021-04-07 09:19:21 +02:00
|
|
|
type JobMetricScope string
|
|
|
|
|
|
|
|
const (
|
|
|
|
JobMetricScopeNode JobMetricScope = "node"
|
|
|
|
JobMetricScopeCPU JobMetricScope = "cpu"
|
|
|
|
JobMetricScopeSocket JobMetricScope = "socket"
|
|
|
|
)
|
|
|
|
|
|
|
|
var AllJobMetricScope = []JobMetricScope{
|
|
|
|
JobMetricScopeNode,
|
|
|
|
JobMetricScopeCPU,
|
|
|
|
JobMetricScopeSocket,
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e JobMetricScope) IsValid() bool {
|
|
|
|
switch e {
|
|
|
|
case JobMetricScopeNode, JobMetricScopeCPU, JobMetricScopeSocket:
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e JobMetricScope) String() string {
|
|
|
|
return string(e)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *JobMetricScope) UnmarshalGQL(v interface{}) error {
|
|
|
|
str, ok := v.(string)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("enums must be strings")
|
|
|
|
}
|
|
|
|
|
|
|
|
*e = JobMetricScope(str)
|
|
|
|
if !e.IsValid() {
|
|
|
|
return fmt.Errorf("%s is not a valid JobMetricScope", str)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e JobMetricScope) MarshalGQL(w io.Writer) {
|
|
|
|
fmt.Fprint(w, strconv.Quote(e.String()))
|
|
|
|
}
|
|
|
|
|
2021-03-31 08:50:53 +02:00
|
|
|
type SortDirectionEnum string
|
|
|
|
|
|
|
|
const (
|
|
|
|
SortDirectionEnumDesc SortDirectionEnum = "DESC"
|
|
|
|
SortDirectionEnumAsc SortDirectionEnum = "ASC"
|
|
|
|
)
|
|
|
|
|
|
|
|
var AllSortDirectionEnum = []SortDirectionEnum{
|
|
|
|
SortDirectionEnumDesc,
|
|
|
|
SortDirectionEnumAsc,
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e SortDirectionEnum) IsValid() bool {
|
|
|
|
switch e {
|
|
|
|
case SortDirectionEnumDesc, SortDirectionEnumAsc:
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e SortDirectionEnum) String() string {
|
|
|
|
return string(e)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *SortDirectionEnum) UnmarshalGQL(v interface{}) error {
|
|
|
|
str, ok := v.(string)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("enums must be strings")
|
|
|
|
}
|
|
|
|
|
|
|
|
*e = SortDirectionEnum(str)
|
|
|
|
if !e.IsValid() {
|
|
|
|
return fmt.Errorf("%s is not a valid SortDirectionEnum", str)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e SortDirectionEnum) MarshalGQL(w io.Writer) {
|
|
|
|
fmt.Fprint(w, strconv.Quote(e.String()))
|
|
|
|
}
|