mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2025-01-12 04:29:06 +01:00
d93610f700
- Relates to issue #97 - required GQL schema extension and regeneration - Works for archived jobs aswell
265 lines
6.0 KiB
Go
265 lines
6.0 KiB
Go
// Code generated by github.com/99designs/gqlgen, DO NOT EDIT.
|
|
|
|
package model
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/ClusterCockpit/cc-backend/pkg/schema"
|
|
)
|
|
|
|
type Count struct {
|
|
Name string `json:"name"`
|
|
Count int `json:"count"`
|
|
}
|
|
|
|
type FloatRange struct {
|
|
From float64 `json:"from"`
|
|
To float64 `json:"to"`
|
|
}
|
|
|
|
type Footprints struct {
|
|
Nodehours []schema.Float `json:"nodehours"`
|
|
Metrics []*MetricFootprints `json:"metrics"`
|
|
}
|
|
|
|
type HistoPoint struct {
|
|
Count int `json:"count"`
|
|
Value int `json:"value"`
|
|
}
|
|
|
|
type IntRangeOutput struct {
|
|
From int `json:"from"`
|
|
To int `json:"to"`
|
|
}
|
|
|
|
type JobFilter struct {
|
|
Tags []string `json:"tags"`
|
|
JobID *StringInput `json:"jobId"`
|
|
ArrayJobID *int `json:"arrayJobId"`
|
|
User *StringInput `json:"user"`
|
|
Project *StringInput `json:"project"`
|
|
JobName *StringInput `json:"jobName"`
|
|
Cluster *StringInput `json:"cluster"`
|
|
Partition *StringInput `json:"partition"`
|
|
Duration *schema.IntRange `json:"duration"`
|
|
MinRunningFor *int `json:"minRunningFor"`
|
|
NumNodes *schema.IntRange `json:"numNodes"`
|
|
NumAccelerators *schema.IntRange `json:"numAccelerators"`
|
|
NumHWThreads *schema.IntRange `json:"numHWThreads"`
|
|
StartTime *schema.TimeRange `json:"startTime"`
|
|
State []schema.JobState `json:"state"`
|
|
FlopsAnyAvg *FloatRange `json:"flopsAnyAvg"`
|
|
MemBwAvg *FloatRange `json:"memBwAvg"`
|
|
LoadAvg *FloatRange `json:"loadAvg"`
|
|
MemUsedMax *FloatRange `json:"memUsedMax"`
|
|
Exclusive *int `json:"exclusive"`
|
|
SharedNode *StringInput `json:"sharedNode"`
|
|
SelfJobID *StringInput `json:"selfJobId"`
|
|
SelfStartTime *time.Time `json:"selfStartTime"`
|
|
SelfDuration *int `json:"selfDuration"`
|
|
}
|
|
|
|
type JobLink struct {
|
|
ID string `json:"id"`
|
|
JobID int `json:"jobId"`
|
|
}
|
|
|
|
type JobLinkResultList struct {
|
|
Items []*JobLink `json:"items"`
|
|
Count *int `json:"count"`
|
|
}
|
|
|
|
type JobMetricWithName struct {
|
|
Name string `json:"name"`
|
|
Scope schema.MetricScope `json:"scope"`
|
|
Metric *schema.JobMetric `json:"metric"`
|
|
}
|
|
|
|
type JobResultList struct {
|
|
Items []*schema.Job `json:"items"`
|
|
Offset *int `json:"offset"`
|
|
Limit *int `json:"limit"`
|
|
Count *int `json:"count"`
|
|
}
|
|
|
|
type JobsStatistics struct {
|
|
ID string `json:"id"`
|
|
Name *string `json:"name"`
|
|
TotalJobs int `json:"totalJobs"`
|
|
ShortJobs int `json:"shortJobs"`
|
|
TotalWalltime int `json:"totalWalltime"`
|
|
TotalCoreHours int `json:"totalCoreHours"`
|
|
HistDuration []*HistoPoint `json:"histDuration"`
|
|
HistNumNodes []*HistoPoint `json:"histNumNodes"`
|
|
}
|
|
|
|
type MetricFootprints struct {
|
|
Metric string `json:"metric"`
|
|
Data []schema.Float `json:"data"`
|
|
}
|
|
|
|
type NodeMetrics struct {
|
|
Host string `json:"host"`
|
|
SubCluster string `json:"subCluster"`
|
|
Metrics []*JobMetricWithName `json:"metrics"`
|
|
}
|
|
|
|
type OrderByInput struct {
|
|
Field string `json:"field"`
|
|
Order SortDirectionEnum `json:"order"`
|
|
}
|
|
|
|
type PageRequest struct {
|
|
ItemsPerPage int `json:"itemsPerPage"`
|
|
Page int `json:"page"`
|
|
}
|
|
|
|
type StringInput struct {
|
|
Eq *string `json:"eq"`
|
|
Neq *string `json:"neq"`
|
|
Contains *string `json:"contains"`
|
|
StartsWith *string `json:"startsWith"`
|
|
EndsWith *string `json:"endsWith"`
|
|
In []string `json:"in"`
|
|
}
|
|
|
|
type TimeRangeOutput struct {
|
|
From time.Time `json:"from"`
|
|
To time.Time `json:"to"`
|
|
}
|
|
|
|
type User struct {
|
|
Username string `json:"username"`
|
|
Name string `json:"name"`
|
|
Email string `json:"email"`
|
|
}
|
|
|
|
type Aggregate string
|
|
|
|
const (
|
|
AggregateUser Aggregate = "USER"
|
|
AggregateProject Aggregate = "PROJECT"
|
|
AggregateCluster Aggregate = "CLUSTER"
|
|
)
|
|
|
|
var AllAggregate = []Aggregate{
|
|
AggregateUser,
|
|
AggregateProject,
|
|
AggregateCluster,
|
|
}
|
|
|
|
func (e Aggregate) IsValid() bool {
|
|
switch e {
|
|
case AggregateUser, AggregateProject, AggregateCluster:
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (e Aggregate) String() string {
|
|
return string(e)
|
|
}
|
|
|
|
func (e *Aggregate) UnmarshalGQL(v interface{}) error {
|
|
str, ok := v.(string)
|
|
if !ok {
|
|
return fmt.Errorf("enums must be strings")
|
|
}
|
|
|
|
*e = Aggregate(str)
|
|
if !e.IsValid() {
|
|
return fmt.Errorf("%s is not a valid Aggregate", str)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (e Aggregate) MarshalGQL(w io.Writer) {
|
|
fmt.Fprint(w, strconv.Quote(e.String()))
|
|
}
|
|
|
|
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()))
|
|
}
|
|
|
|
type Weights string
|
|
|
|
const (
|
|
WeightsNodeCount Weights = "NODE_COUNT"
|
|
WeightsNodeHours Weights = "NODE_HOURS"
|
|
)
|
|
|
|
var AllWeights = []Weights{
|
|
WeightsNodeCount,
|
|
WeightsNodeHours,
|
|
}
|
|
|
|
func (e Weights) IsValid() bool {
|
|
switch e {
|
|
case WeightsNodeCount, WeightsNodeHours:
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (e Weights) String() string {
|
|
return string(e)
|
|
}
|
|
|
|
func (e *Weights) UnmarshalGQL(v interface{}) error {
|
|
str, ok := v.(string)
|
|
if !ok {
|
|
return fmt.Errorf("enums must be strings")
|
|
}
|
|
|
|
*e = Weights(str)
|
|
if !e.IsValid() {
|
|
return fmt.Errorf("%s is not a valid Weights", str)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (e Weights) MarshalGQL(w io.Writer) {
|
|
fmt.Fprint(w, strconv.Quote(e.String()))
|
|
}
|