mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2025-01-27 19:49:05 +01:00
177 lines
6.2 KiB
Go
177 lines
6.2 KiB
Go
// Copyright (C) NHR@FAU, University Erlangen-Nuremberg.
|
|
// All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
package schema
|
|
|
|
import (
|
|
"encoding/json"
|
|
"time"
|
|
)
|
|
|
|
type LdapConfig struct {
|
|
Url string `json:"url"`
|
|
UserBase string `json:"user_base"`
|
|
SearchDN string `json:"search_dn"`
|
|
UserBind string `json:"user_bind"`
|
|
UserFilter string `json:"user_filter"`
|
|
UserAttr string `json:"username_attr"`
|
|
SyncInterval string `json:"sync_interval"` // Parsed using time.ParseDuration.
|
|
SyncDelOldUsers bool `json:"sync_del_old_users"`
|
|
|
|
// Should an non-existent user be added to the DB if user exists in ldap directory
|
|
SyncUserOnLogin bool `json:"syncUserOnLogin"`
|
|
}
|
|
|
|
type OpenIDConfig struct {
|
|
Provider string `json:"provider"`
|
|
SyncUserOnLogin bool `json:"syncUserOnLogin"`
|
|
UpdateUserOnLogin bool `json:"updateUserOnLogin"`
|
|
}
|
|
|
|
type JWTAuthConfig struct {
|
|
// Specifies for how long a JWT token shall be valid
|
|
// as a string parsable by time.ParseDuration().
|
|
MaxAge string `json:"max-age"`
|
|
|
|
// Specifies which cookie should be checked for a JWT token (if no authorization header is present)
|
|
CookieName string `json:"cookieName"`
|
|
|
|
// Deny login for users not in database (but defined in JWT).
|
|
// Ignore user roles defined in JWTs ('roles' claim), get them from db.
|
|
ValidateUser bool `json:"validateUser"`
|
|
|
|
// Specifies which issuer should be accepted when validating external JWTs ('iss' claim)
|
|
TrustedIssuer string `json:"trustedIssuer"`
|
|
|
|
// Should an non-existent user be added to the DB based on the information in the token
|
|
SyncUserOnLogin bool `json:"syncUserOnLogin"`
|
|
|
|
// Should an existent user be updated in the DB based on the information in the token
|
|
UpdateUserOnLogin bool `json:"updateUserOnLogin"`
|
|
}
|
|
|
|
type IntRange struct {
|
|
From int `json:"from"`
|
|
To int `json:"to"`
|
|
}
|
|
|
|
type TimeRange struct {
|
|
Range string `json:"range,omitempty"` // Optional, e.g. 'last6h'
|
|
From *time.Time `json:"from"`
|
|
To *time.Time `json:"to"`
|
|
}
|
|
|
|
type FilterRanges struct {
|
|
Duration *IntRange `json:"duration"`
|
|
NumNodes *IntRange `json:"numNodes"`
|
|
StartTime *TimeRange `json:"startTime"`
|
|
}
|
|
|
|
type ClusterConfig struct {
|
|
Name string `json:"name"`
|
|
FilterRanges *FilterRanges `json:"filterRanges"`
|
|
MetricDataRepository json.RawMessage `json:"metricDataRepository"`
|
|
}
|
|
|
|
type Retention struct {
|
|
Policy string `json:"policy"`
|
|
Location string `json:"location"`
|
|
Age int `json:"age"`
|
|
IncludeDB bool `json:"includeDB"`
|
|
}
|
|
|
|
type ResampleConfig struct {
|
|
// Trigger next zoom level at less than this many visible datapoints
|
|
Trigger int `json:"trigger"`
|
|
// Array of resampling target resolutions, in seconds; Example: [600,300,60]
|
|
Resolutions []int `json:"resolutions"`
|
|
}
|
|
|
|
type CronFrequency struct {
|
|
// Duration Update Worker [Defaults to '5m']
|
|
DurationWorker string `json:"duration-worker"`
|
|
// Metric- and Energy Footprint Update Worker [Defaults to '10m']
|
|
FootprintWorker string `json:"footprint-worker"`
|
|
}
|
|
|
|
// Format of the configuration (file). See below for the defaults.
|
|
type ProgramConfig struct {
|
|
// Address where the http (or https) server will listen on (for example: 'localhost:80').
|
|
Addr string `json:"addr"`
|
|
|
|
// Addresses from which secured API endpoints can be reached
|
|
ApiAllowedIPs []string `json:"apiAllowedIPs"`
|
|
|
|
// Drop root permissions once .env was read and the port was taken.
|
|
User string `json:"user"`
|
|
Group string `json:"group"`
|
|
|
|
// Disable authentication (for everything: API, Web-UI, ...)
|
|
DisableAuthentication bool `json:"disable-authentication"`
|
|
|
|
// If `embed-static-files` is true (default), the frontend files are directly
|
|
// embeded into the go binary and expected to be in web/frontend. Only if
|
|
// it is false the files in `static-files` are served instead.
|
|
EmbedStaticFiles bool `json:"embed-static-files"`
|
|
StaticFiles string `json:"static-files"`
|
|
|
|
// 'sqlite3' or 'mysql' (mysql will work for mariadb as well)
|
|
DBDriver string `json:"db-driver"`
|
|
|
|
// For sqlite3 a filename, for mysql a DSN in this format: https://github.com/go-sql-driver/mysql#dsn-data-source-name (Without query parameters!).
|
|
DB string `json:"db"`
|
|
|
|
// Config for job archive
|
|
Archive json.RawMessage `json:"archive"`
|
|
|
|
// Keep all metric data in the metric data repositories,
|
|
// do not write to the job-archive.
|
|
DisableArchive bool `json:"disable-archive"`
|
|
|
|
// Validate json input against schema
|
|
Validate bool `json:"validate"`
|
|
|
|
// For LDAP Authentication and user synchronisation.
|
|
LdapConfig *LdapConfig `json:"ldap"`
|
|
JwtConfig *JWTAuthConfig `json:"jwts"`
|
|
OpenIDConfig *OpenIDConfig `json:"oidc"`
|
|
|
|
// If 0 or empty, the session does not expire!
|
|
SessionMaxAge string `json:"session-max-age"`
|
|
|
|
// If both those options are not empty, use HTTPS using those certificates.
|
|
HttpsCertFile string `json:"https-cert-file"`
|
|
HttpsKeyFile string `json:"https-key-file"`
|
|
|
|
// If not the empty string and `addr` does not end in ":80",
|
|
// redirect every request incoming at port 80 to that url.
|
|
RedirectHttpTo string `json:"redirect-http-to"`
|
|
|
|
// If overwritten, at least all the options in the defaults below must
|
|
// be provided! Most options here can be overwritten by the user.
|
|
UiDefaults map[string]interface{} `json:"ui-defaults"`
|
|
|
|
// If exists, will enable dynamic zoom in frontend metric plots using the configured values
|
|
EnableResampling *ResampleConfig `json:"enable-resampling"`
|
|
|
|
// Where to store MachineState files
|
|
MachineStateDir string `json:"machine-state-dir"`
|
|
|
|
// If not zero, automatically mark jobs as stopped running X seconds longer than their walltime.
|
|
StopJobsExceedingWalltime int `json:"stop-jobs-exceeding-walltime"`
|
|
|
|
// Defines time X in seconds in which jobs are considered to be "short" and will be filtered in specific views.
|
|
ShortRunningJobsDuration int `json:"short-running-jobs-duration"`
|
|
|
|
// Array of Clusters
|
|
Clusters []*ClusterConfig `json:"clusters"`
|
|
|
|
// Energy Mix CO2 Emission Constant [g/kWh]
|
|
// If entered, displays estimated CO2 emission for job based on jobs totalEnergy
|
|
EmissionConstant int `json:"emission-constant"`
|
|
|
|
// Frequency of cron job workers
|
|
CronFrequency *CronFrequency `json:"cron-frequency"`
|
|
}
|