2019-02-19 23:56:41 +00:00
|
|
|
// Copyright 2019 Drone IO, Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
2019-07-30 02:55:25 +00:00
|
|
|
"errors"
|
2019-02-19 23:56:41 +00:00
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/dchest/uniuri"
|
|
|
|
"github.com/dustin/go-humanize"
|
|
|
|
"github.com/kelseyhightower/envconfig"
|
|
|
|
"gopkg.in/yaml.v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
// IMPORTANT please do not add new configuration parameters unless it has
|
|
|
|
// been discussed on the mailing list. We are attempting to reduce the
|
|
|
|
// number of configuration parameters, and may reject pull requests that
|
|
|
|
// introduce new parameters. (mailing list https://discourse.drone.io)
|
|
|
|
|
|
|
|
// default runner hostname.
|
|
|
|
var hostname string
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
hostname, _ = os.Hostname()
|
|
|
|
if hostname == "" {
|
|
|
|
hostname = "localhost"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type (
|
|
|
|
// Config provides the system configuration.
|
|
|
|
Config struct {
|
|
|
|
License string `envconfig:"DRONE_LICENSE"`
|
|
|
|
|
2019-04-24 21:53:01 +00:00
|
|
|
Authn Authentication
|
|
|
|
Agent Agent
|
2019-08-14 04:12:39 +00:00
|
|
|
AzureBlob AzureBlob
|
2019-09-03 06:05:30 +00:00
|
|
|
Convert Convert
|
2020-06-05 02:15:30 +00:00
|
|
|
Cleanup Cleanup
|
2019-04-24 21:53:01 +00:00
|
|
|
Cron Cron
|
|
|
|
Cloning Cloning
|
|
|
|
Database Database
|
|
|
|
Datadog Datadog
|
|
|
|
Docker Docker
|
|
|
|
HTTP HTTP
|
|
|
|
Jsonnet Jsonnet
|
2020-11-20 13:56:47 +00:00
|
|
|
Starlark Starlark
|
2019-04-24 21:53:01 +00:00
|
|
|
Logging Logging
|
|
|
|
Prometheus Prometheus
|
2019-02-19 23:56:41 +00:00
|
|
|
Proxy Proxy
|
2021-07-22 13:03:57 +00:00
|
|
|
Redis Redis
|
2019-02-19 23:56:41 +00:00
|
|
|
Registration Registration
|
|
|
|
Registries Registries
|
|
|
|
Repository Repository
|
|
|
|
Runner Runner
|
|
|
|
RPC RPC
|
|
|
|
S3 S3
|
|
|
|
Secrets Secrets
|
|
|
|
Server Server
|
|
|
|
Session Session
|
|
|
|
Status Status
|
|
|
|
Users Users
|
2019-09-03 06:05:30 +00:00
|
|
|
Validate Validate
|
2019-02-19 23:56:41 +00:00
|
|
|
Webhook Webhook
|
|
|
|
Yaml Yaml
|
|
|
|
|
|
|
|
// Remote configurations
|
|
|
|
Bitbucket Bitbucket
|
|
|
|
Gitea Gitea
|
|
|
|
Github Github
|
|
|
|
GitLab GitLab
|
|
|
|
Gogs Gogs
|
|
|
|
Stash Stash
|
2021-11-25 15:35:02 +00:00
|
|
|
Gitee Gitee
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Cloning provides the cloning configuration.
|
|
|
|
Cloning struct {
|
|
|
|
AlwaysAuth bool `envconfig:"DRONE_GIT_ALWAYS_AUTH"`
|
|
|
|
Username string `envconfig:"DRONE_GIT_USERNAME"`
|
|
|
|
Password string `envconfig:"DRONE_GIT_PASSWORD"`
|
|
|
|
Image string `envconfig:"DRONE_GIT_IMAGE"`
|
|
|
|
Pull string `envconfig:"DRONE_GIT_IMAGE_PULL" default:"IfNotExists"`
|
|
|
|
}
|
|
|
|
|
2020-06-05 02:15:30 +00:00
|
|
|
Cleanup struct {
|
2020-09-15 21:28:45 +00:00
|
|
|
Disabled bool `envconfig:"DRONE_CLEANUP_DISABLED"`
|
2020-06-05 02:15:30 +00:00
|
|
|
Interval time.Duration `envconfig:"DRONE_CLEANUP_INTERVAL" default:"24h"`
|
|
|
|
Running time.Duration `envconfig:"DRONE_CLEANUP_DEADLINE_RUNNING" default:"24h"`
|
|
|
|
Pending time.Duration `envconfig:"DRONE_CLEANUP_DEADLINE_PENDING" default:"24h"`
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// Cron provides the cron configuration.
|
|
|
|
Cron struct {
|
|
|
|
Disabled bool `envconfig:"DRONE_CRON_DISABLED"`
|
|
|
|
Interval time.Duration `envconfig:"DRONE_CRON_INTERVAL" default:"30m"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Database provides the database configuration.
|
|
|
|
Database struct {
|
2021-06-08 10:00:20 +00:00
|
|
|
Driver string `envconfig:"DRONE_DATABASE_DRIVER" default:"sqlite3"`
|
|
|
|
Datasource string `envconfig:"DRONE_DATABASE_DATASOURCE" default:"core.sqlite"`
|
|
|
|
Secret string `envconfig:"DRONE_DATABASE_SECRET"`
|
|
|
|
MaxConnections int `envconfig:"DRONE_DATABASE_MAX_CONNECTIONS" default:"0"`
|
2019-09-23 23:54:04 +00:00
|
|
|
|
|
|
|
// Feature flag
|
2019-10-03 21:34:36 +00:00
|
|
|
LegacyBatch bool `envconfig:"DRONE_DATABASE_LEGACY_BATCH"`
|
2021-05-04 22:59:03 +00:00
|
|
|
|
|
|
|
// Feature flag
|
|
|
|
EncryptUserTable bool `envconfig:"DRONE_DATABASE_ENCRYPT_USER_TABLE"`
|
|
|
|
EncryptMixedContent bool `envconfig:"DRONE_DATABASE_ENCRYPT_MIXED_MODE"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Docker provides docker configuration
|
|
|
|
Docker struct {
|
|
|
|
Config string `envconfig:"DRONE_DOCKER_CONFIG"`
|
|
|
|
}
|
|
|
|
|
2019-03-05 07:16:53 +00:00
|
|
|
// Datadog provides datadog configuration
|
|
|
|
Datadog struct {
|
|
|
|
Enabled bool `envconfig:"DRONE_DATADOG_ENABLED"`
|
|
|
|
Endpoint string `envconfig:"DRONE_DATADOG_ENDPOINT"`
|
|
|
|
Token string `envconfig:"DRONE_DATADOG_TOKEN"`
|
|
|
|
}
|
|
|
|
|
2019-03-13 23:12:54 +00:00
|
|
|
// Jsonnet configures the jsonnet plugin
|
|
|
|
Jsonnet struct {
|
2021-09-21 08:37:12 +00:00
|
|
|
Enabled bool `envconfig:"DRONE_JSONNET_ENABLED"`
|
|
|
|
ImportLimit int `envconfig:"DRONE_JSONNET_IMPORT_LIMIT" default:"0"`
|
2019-03-13 23:12:54 +00:00
|
|
|
}
|
|
|
|
|
2020-11-20 13:56:47 +00:00
|
|
|
// Starlark configures the starlark plugin
|
|
|
|
Starlark struct {
|
2021-09-07 12:25:29 +00:00
|
|
|
Enabled bool `envconfig:"DRONE_STARLARK_ENABLED"`
|
2021-09-03 10:35:44 +00:00
|
|
|
StepLimit uint64 `envconfig:"DRONE_STARLARK_STEP_LIMIT"`
|
2020-11-20 13:56:47 +00:00
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// License provides license configuration
|
|
|
|
License struct {
|
|
|
|
Key string `envconfig:"DRONE_LICENSE"`
|
|
|
|
Endpoint string `envconfig:"DRONE_LICENSE_ENDPOINT"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Logging provides the logging configuration.
|
|
|
|
Logging struct {
|
|
|
|
Debug bool `envconfig:"DRONE_LOGS_DEBUG"`
|
|
|
|
Trace bool `envconfig:"DRONE_LOGS_TRACE"`
|
|
|
|
Color bool `envconfig:"DRONE_LOGS_COLOR"`
|
|
|
|
Pretty bool `envconfig:"DRONE_LOGS_PRETTY"`
|
|
|
|
Text bool `envconfig:"DRONE_LOGS_TEXT"`
|
|
|
|
}
|
|
|
|
|
2019-04-24 21:53:01 +00:00
|
|
|
// Prometheus provides the prometheus configuration.
|
|
|
|
Prometheus struct {
|
|
|
|
EnableAnonymousAccess bool `envconfig:"DRONE_PROMETHEUS_ANONYMOUS_ACCESS" default:"false"`
|
|
|
|
}
|
|
|
|
|
2021-07-22 13:03:57 +00:00
|
|
|
// Redis provides the redis configuration.
|
|
|
|
Redis struct {
|
|
|
|
ConnectionString string `envconfig:"DRONE_REDIS_CONNECTION"`
|
2021-08-11 14:25:50 +00:00
|
|
|
Addr string `envconfig:"DRONE_REDIS_ADDR"`
|
|
|
|
Password string `envconfig:"DRONE_REDIS_PASSWORD"`
|
|
|
|
DB int `envconfig:"DRONE_REDIS_DB"`
|
2021-07-22 13:03:57 +00:00
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// Repository provides the repository configuration.
|
|
|
|
Repository struct {
|
2019-09-11 03:16:19 +00:00
|
|
|
Filter []string `envconfig:"DRONE_REPOSITORY_FILTER"`
|
|
|
|
Visibility string `envconfig:"DRONE_REPOSITORY_VISIBILITY"`
|
2019-09-12 06:46:07 +00:00
|
|
|
Trusted bool `envconfig:"DRONE_REPOSITORY_TRUSTED"`
|
2020-09-15 21:28:45 +00:00
|
|
|
|
|
|
|
// THIS SETTING IS INTERNAL USE ONLY AND SHOULD
|
|
|
|
// NOT BE USED OR RELIED UPON IN PRODUCTION.
|
|
|
|
Ignore []string `envconfig:"DRONE_REPOSITORY_IGNORE"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Registries provides the registry configuration.
|
|
|
|
Registries struct {
|
|
|
|
Endpoint string `envconfig:"DRONE_REGISTRY_ENDPOINT"`
|
|
|
|
Password string `envconfig:"DRONE_REGISTRY_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_REGISTRY_SKIP_VERIFY"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Secrets provides the secret configuration.
|
|
|
|
Secrets struct {
|
|
|
|
Endpoint string `envconfig:"DRONE_SECRET_ENDPOINT"`
|
|
|
|
Password string `envconfig:"DRONE_SECRET_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_SECRET_SKIP_VERIFY"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// RPC provides the rpc configuration.
|
|
|
|
RPC struct {
|
|
|
|
Server string `envconfig:"DRONE_RPC_SERVER"`
|
|
|
|
Secret string `envconfig:"DRONE_RPC_SECRET"`
|
|
|
|
Debug bool `envconfig:"DRONE_RPC_DEBUG"`
|
|
|
|
Host string `envconfig:"DRONE_RPC_HOST"`
|
|
|
|
Proto string `envconfig:"DRONE_RPC_PROTO"`
|
|
|
|
// Hosts map[string]string `envconfig:"DRONE_RPC_EXTRA_HOSTS"`
|
|
|
|
}
|
|
|
|
|
|
|
|
Agent struct {
|
2019-09-23 23:46:20 +00:00
|
|
|
Disabled bool `envconfig:"DRONE_AGENTS_DISABLED"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Runner provides the runner configuration.
|
|
|
|
Runner struct {
|
|
|
|
Local bool `envconfig:"DRONE_RUNNER_LOCAL"`
|
2019-12-13 16:14:10 +00:00
|
|
|
Image string `envconfig:"DRONE_RUNNER_IMAGE" default:"drone/controller:1"`
|
2019-02-19 23:56:41 +00:00
|
|
|
Platform string `envconfig:"DRONE_RUNNER_PLATFORM" default:"linux/amd64"`
|
|
|
|
OS string `envconfig:"DRONE_RUNNER_OS"`
|
|
|
|
Arch string `envconfig:"DRONE_RUNNER_ARCH"`
|
|
|
|
Kernel string `envconfig:"DRONE_RUNNER_KERNEL"`
|
|
|
|
Variant string `envconfig:"DRONE_RUNNER_VARIANT"`
|
|
|
|
Machine string `envconfig:"DRONE_RUNNER_NAME"`
|
|
|
|
Capacity int `envconfig:"DRONE_RUNNER_CAPACITY" default:"2"`
|
|
|
|
Labels map[string]string `envconfig:"DRONE_RUNNER_LABELS"`
|
|
|
|
Volumes []string `envconfig:"DRONE_RUNNER_VOLUMES"`
|
|
|
|
Networks []string `envconfig:"DRONE_RUNNER_NETWORKS"`
|
|
|
|
Devices []string `envconfig:"DRONE_RUNNER_DEVICES"`
|
|
|
|
Privileged []string `envconfig:"DRONE_RUNNER_PRIVILEGED_IMAGES"`
|
|
|
|
Environ map[string]string `envconfig:"DRONE_RUNNER_ENVIRON"`
|
|
|
|
Limits struct {
|
|
|
|
MemSwapLimit Bytes `envconfig:"DRONE_LIMIT_MEM_SWAP"`
|
|
|
|
MemLimit Bytes `envconfig:"DRONE_LIMIT_MEM"`
|
|
|
|
ShmSize Bytes `envconfig:"DRONE_LIMIT_SHM_SIZE"`
|
|
|
|
CPUQuota int64 `envconfig:"DRONE_LIMIT_CPU_QUOTA"`
|
|
|
|
CPUShares int64 `envconfig:"DRONE_LIMIT_CPU_SHARES"`
|
|
|
|
CPUSet string `envconfig:"DRONE_LIMIT_CPU_SET"`
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Server provides the server configuration.
|
|
|
|
Server struct {
|
|
|
|
Addr string `envconfig:"-"`
|
|
|
|
Host string `envconfig:"DRONE_SERVER_HOST" default:"localhost:8080"`
|
|
|
|
Port string `envconfig:"DRONE_SERVER_PORT" default:":8080"`
|
|
|
|
Proto string `envconfig:"DRONE_SERVER_PROTO" default:"http"`
|
2019-12-30 01:59:42 +00:00
|
|
|
Pprof bool `envconfig:"DRONE_PPROF_ENABLED"`
|
2019-02-19 23:56:41 +00:00
|
|
|
Acme bool `envconfig:"DRONE_TLS_AUTOCERT"`
|
2019-09-04 04:11:49 +00:00
|
|
|
Email string `envconfig:"DRONE_TLS_EMAIL"`
|
2019-02-19 23:56:41 +00:00
|
|
|
Cert string `envconfig:"DRONE_TLS_CERT"`
|
|
|
|
Key string `envconfig:"DRONE_TLS_KEY"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Proxy provides proxy server configuration.
|
|
|
|
Proxy struct {
|
|
|
|
Addr string `envconfig:"-"`
|
|
|
|
Host string `envconfig:"DRONE_SERVER_PROXY_HOST"`
|
|
|
|
Proto string `envconfig:"DRONE_SERVER_PROXY_PROTO"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Registration configuration.
|
|
|
|
Registration struct {
|
|
|
|
Closed bool `envconfig:"DRONE_REGISTRATION_CLOSED"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Authentication Controller configuration
|
|
|
|
Authentication struct {
|
2019-09-19 05:52:13 +00:00
|
|
|
Endpoint string `envconfig:"DRONE_ADMISSION_PLUGIN_ENDPOINT"`
|
|
|
|
Secret string `envconfig:"DRONE_ADMISSION_PLUGIN_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_ADMISSION_PLUGIN_SKIP_VERIFY"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Session provides the session configuration.
|
|
|
|
Session struct {
|
2021-08-31 13:26:10 +00:00
|
|
|
Timeout time.Duration `envconfig:"DRONE_COOKIE_TIMEOUT" default:"720h"`
|
|
|
|
Secret string `envconfig:"DRONE_COOKIE_SECRET"`
|
|
|
|
Secure bool `envconfig:"DRONE_COOKIE_SECURE"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Status provides status configurations.
|
|
|
|
Status struct {
|
|
|
|
Disabled bool `envconfig:"DRONE_STATUS_DISABLED"`
|
|
|
|
Name string `envconfig:"DRONE_STATUS_NAME"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Users provides the user configuration.
|
|
|
|
Users struct {
|
|
|
|
Create UserCreate `envconfig:"DRONE_USER_CREATE"`
|
|
|
|
Filter []string `envconfig:"DRONE_USER_FILTER"`
|
|
|
|
MinAge time.Duration `envconfig:"DRONE_MIN_AGE"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Webhook provides the webhook configuration.
|
|
|
|
Webhook struct {
|
2019-07-28 19:22:16 +00:00
|
|
|
Events []string `envconfig:"DRONE_WEBHOOK_EVENTS"`
|
2019-02-19 23:56:41 +00:00
|
|
|
Endpoint []string `envconfig:"DRONE_WEBHOOK_ENDPOINT"`
|
|
|
|
Secret string `envconfig:"DRONE_WEBHOOK_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_WEBHOOK_SKIP_VERIFY"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Yaml provides the yaml webhook configuration.
|
|
|
|
Yaml struct {
|
2020-07-20 23:37:21 +00:00
|
|
|
Endpoint string `envconfig:"DRONE_YAML_ENDPOINT"`
|
|
|
|
Secret string `envconfig:"DRONE_YAML_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_YAML_SKIP_VERIFY"`
|
|
|
|
Timeout time.Duration `envconfig:"DRONE_YAML_TIMEOUT" default:"1m"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
2019-09-03 06:05:30 +00:00
|
|
|
// Convert provides the converter webhook configuration.
|
|
|
|
Convert struct {
|
2020-07-20 23:37:21 +00:00
|
|
|
Extension string `envconfig:"DRONE_CONVERT_PLUGIN_EXTENSION"`
|
|
|
|
Endpoint string `envconfig:"DRONE_CONVERT_PLUGIN_ENDPOINT"`
|
|
|
|
Secret string `envconfig:"DRONE_CONVERT_PLUGIN_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_CONVERT_PLUGIN_SKIP_VERIFY"`
|
2021-05-14 18:06:47 +00:00
|
|
|
CacheSize int `envconfig:"DRONE_CONVERT_PLUGIN_CACHE_SIZE" default:"10"`
|
2020-07-20 23:37:21 +00:00
|
|
|
Timeout time.Duration `envconfig:"DRONE_CONVERT_TIMEOUT" default:"1m"`
|
2022-03-17 21:51:48 +00:00
|
|
|
|
|
|
|
// this flag can be removed once we solve for
|
|
|
|
// https://github.com/harness/drone/pull/2994#issuecomment-795955312
|
2022-03-17 23:12:53 +00:00
|
|
|
Multi bool `envconfig:"DRONE_CONVERT_MULTI"`
|
2019-09-03 06:05:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Validate provides the validation webhook configuration.
|
|
|
|
Validate struct {
|
2020-07-20 23:37:21 +00:00
|
|
|
Endpoint string `envconfig:"DRONE_VALIDATE_PLUGIN_ENDPOINT"`
|
|
|
|
Secret string `envconfig:"DRONE_VALIDATE_PLUGIN_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_VALIDATE_PLUGIN_SKIP_VERIFY"`
|
|
|
|
Timeout time.Duration `envconfig:"DRONE_VALIDATE_TIMEOUT" default:"1m"`
|
2019-09-03 06:05:30 +00:00
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
//
|
|
|
|
// Source code management.
|
|
|
|
//
|
|
|
|
|
|
|
|
// Bitbucket provides the bitbucket client configuration.
|
|
|
|
Bitbucket struct {
|
|
|
|
ClientID string `envconfig:"DRONE_BITBUCKET_CLIENT_ID"`
|
|
|
|
ClientSecret string `envconfig:"DRONE_BITBUCKET_CLIENT_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_BITBUCKET_SKIP_VERIFY"`
|
|
|
|
Debug bool `envconfig:"DRONE_BITBUCKET_DEBUG"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Gitea provides the gitea client configuration.
|
|
|
|
Gitea struct {
|
2019-03-13 22:27:21 +00:00
|
|
|
Server string `envconfig:"DRONE_GITEA_SERVER"`
|
2019-03-09 02:55:43 +00:00
|
|
|
ClientID string `envconfig:"DRONE_GITEA_CLIENT_ID"`
|
|
|
|
ClientSecret string `envconfig:"DRONE_GITEA_CLIENT_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_GITEA_SKIP_VERIFY"`
|
|
|
|
Scope []string `envconfig:"DRONE_GITEA_SCOPE" default:"repo,repo:status,user:email,read:org"`
|
|
|
|
Debug bool `envconfig:"DRONE_GITEA_DEBUG"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Github provides the github client configuration.
|
|
|
|
Github struct {
|
|
|
|
Server string `envconfig:"DRONE_GITHUB_SERVER" default:"https://github.com"`
|
|
|
|
APIServer string `envconfig:"DRONE_GITHUB_API_SERVER"`
|
|
|
|
ClientID string `envconfig:"DRONE_GITHUB_CLIENT_ID"`
|
|
|
|
ClientSecret string `envconfig:"DRONE_GITHUB_CLIENT_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_GITHUB_SKIP_VERIFY"`
|
|
|
|
Scope []string `envconfig:"DRONE_GITHUB_SCOPE" default:"repo,repo:status,user:email,read:org"`
|
|
|
|
RateLimit int `envconfig:"DRONE_GITHUB_USER_RATELIMIT"`
|
|
|
|
Debug bool `envconfig:"DRONE_GITHUB_DEBUG"`
|
|
|
|
}
|
|
|
|
|
2021-11-25 15:35:02 +00:00
|
|
|
// Gitee providers the gitee client configuration.
|
|
|
|
Gitee struct {
|
|
|
|
Server string `envconfig:"DRONE_GITEE_SERVER" default:"https://gitee.com"`
|
|
|
|
APIServer string `envconfig:"DRONE_GITEE_API_SERVER" default:"https://gitee.com/api/v5"`
|
|
|
|
ClientID string `envconfig:"DRONE_GITEE_CLIENT_ID"`
|
|
|
|
ClientSecret string `envconfig:"DRONE_GITEE_CLIENT_SECRET"`
|
|
|
|
RedirectURL string `envconfig:"DRONE_GITEE_REDIRECT_URL"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_GITEE_SKIP_VERIFY"`
|
|
|
|
Scope []string `envconfig:"DRONE_GITEE_SCOPE" default:"user_info,projects,pull_requests,hook"`
|
|
|
|
Debug bool `envconfig:"DRONE_GITEE_DEBUG"`
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// GitLab provides the gitlab client configuration.
|
|
|
|
GitLab struct {
|
|
|
|
Server string `envconfig:"DRONE_GITLAB_SERVER" default:"https://gitlab.com"`
|
|
|
|
ClientID string `envconfig:"DRONE_GITLAB_CLIENT_ID"`
|
|
|
|
ClientSecret string `envconfig:"DRONE_GITLAB_CLIENT_SECRET"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_GITLAB_SKIP_VERIFY"`
|
|
|
|
Debug bool `envconfig:"DRONE_GITLAB_DEBUG"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Gogs provides the gogs client configuration.
|
|
|
|
Gogs struct {
|
|
|
|
Server string `envconfig:"DRONE_GOGS_SERVER"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_GOGS_SKIP_VERIFY"`
|
|
|
|
Debug bool `envconfig:"DRONE_GOGS_DEBUG"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Stash provides the stash client configuration.
|
|
|
|
Stash struct {
|
|
|
|
Server string `envconfig:"DRONE_STASH_SERVER"`
|
|
|
|
ConsumerKey string `envconfig:"DRONE_STASH_CONSUMER_KEY"`
|
|
|
|
ConsumerSecret string `envconfig:"DRONE_STASH_CONSUMER_SECRET"`
|
|
|
|
PrivateKey string `envconfig:"DRONE_STASH_PRIVATE_KEY"`
|
|
|
|
SkipVerify bool `envconfig:"DRONE_STASH_SKIP_VERIFY"`
|
|
|
|
Debug bool `envconfig:"DRONE_STASH_DEBUG"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// S3 provides the storage configuration.
|
|
|
|
S3 struct {
|
2019-02-26 21:09:56 +00:00
|
|
|
Bucket string `envconfig:"DRONE_S3_BUCKET"`
|
|
|
|
Prefix string `envconfig:"DRONE_S3_PREFIX"`
|
|
|
|
Endpoint string `envconfig:"DRONE_S3_ENDPOINT"`
|
|
|
|
PathStyle bool `envconfig:"DRONE_S3_PATH_STYLE"`
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
|
2019-08-14 04:12:39 +00:00
|
|
|
//AzureBlob providers the storage configuration.
|
|
|
|
AzureBlob struct {
|
|
|
|
ContainerName string `envconfig:"DRONE_AZURE_BLOB_CONTAINER_NAME"`
|
|
|
|
StorageAccountName string `envconfig:"DRONE_AZURE_STORAGE_ACCOUNT_NAME"`
|
|
|
|
StorageAccessKey string `envconfig:"DRONE_AZURE_STORAGE_ACCESS_KEY"`
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// HTTP provides http configuration.
|
|
|
|
HTTP struct {
|
|
|
|
AllowedHosts []string `envconfig:"DRONE_HTTP_ALLOWED_HOSTS"`
|
|
|
|
HostsProxyHeaders []string `envconfig:"DRONE_HTTP_PROXY_HEADERS"`
|
|
|
|
SSLRedirect bool `envconfig:"DRONE_HTTP_SSL_REDIRECT"`
|
|
|
|
SSLTemporaryRedirect bool `envconfig:"DRONE_HTTP_SSL_TEMPORARY_REDIRECT"`
|
|
|
|
SSLHost string `envconfig:"DRONE_HTTP_SSL_HOST"`
|
|
|
|
SSLProxyHeaders map[string]string `envconfig:"DRONE_HTTP_SSL_PROXY_HEADERS"`
|
|
|
|
STSSeconds int64 `envconfig:"DRONE_HTTP_STS_SECONDS"`
|
|
|
|
STSIncludeSubdomains bool `envconfig:"DRONE_HTTP_STS_INCLUDE_SUBDOMAINS"`
|
|
|
|
STSPreload bool `envconfig:"DRONE_HTTP_STS_PRELOAD"`
|
|
|
|
ForceSTSHeader bool `envconfig:"DRONE_HTTP_STS_FORCE_HEADER"`
|
|
|
|
BrowserXSSFilter bool `envconfig:"DRONE_HTTP_BROWSER_XSS_FILTER" default:"true"`
|
|
|
|
FrameDeny bool `envconfig:"DRONE_HTTP_FRAME_DENY" default:"true"`
|
|
|
|
ContentTypeNosniff bool `envconfig:"DRONE_HTTP_CONTENT_TYPE_NO_SNIFF"`
|
|
|
|
ContentSecurityPolicy string `envconfig:"DRONE_HTTP_CONTENT_SECURITY_POLICY"`
|
|
|
|
ReferrerPolicy string `envconfig:"DRONE_HTTP_REFERRER_POLICY"`
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// Environ returns the settings from the environment.
|
|
|
|
func Environ() (Config, error) {
|
|
|
|
cfg := Config{}
|
|
|
|
err := envconfig.Process("", &cfg)
|
|
|
|
defaultAddress(&cfg)
|
|
|
|
defaultProxy(&cfg)
|
|
|
|
defaultRunner(&cfg)
|
|
|
|
defaultSession(&cfg)
|
|
|
|
defaultCallback(&cfg)
|
|
|
|
configureGithub(&cfg)
|
2019-07-30 02:55:25 +00:00
|
|
|
if err := kubernetesServiceConflict(&cfg); err != nil {
|
|
|
|
return cfg, err
|
|
|
|
}
|
2019-02-19 23:56:41 +00:00
|
|
|
return cfg, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns the configuration in string format.
|
|
|
|
func (c *Config) String() string {
|
|
|
|
out, _ := yaml.Marshal(c)
|
|
|
|
return string(out)
|
|
|
|
}
|
|
|
|
|
2019-03-13 21:47:47 +00:00
|
|
|
// IsGitHub returns true if the GitHub integration
|
|
|
|
// is activated.
|
|
|
|
func (c *Config) IsGitHub() bool {
|
|
|
|
return c.Github.ClientID != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsGitHubEnterprise returns true if the GitHub
|
|
|
|
// integration is activated.
|
|
|
|
func (c *Config) IsGitHubEnterprise() bool {
|
|
|
|
return c.IsGitHub() && !strings.HasPrefix(c.Github.Server, "https://github.com")
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsGitLab returns true if the GitLab integration
|
|
|
|
// is activated.
|
|
|
|
func (c *Config) IsGitLab() bool {
|
|
|
|
return c.GitLab.ClientID != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsGogs returns true if the Gogs integration
|
|
|
|
// is activated.
|
|
|
|
func (c *Config) IsGogs() bool {
|
|
|
|
return c.Gogs.Server != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsGitea returns true if the Gitea integration
|
|
|
|
// is activated.
|
|
|
|
func (c *Config) IsGitea() bool {
|
|
|
|
return c.Gitea.Server != ""
|
|
|
|
}
|
|
|
|
|
2021-12-27 00:44:19 +00:00
|
|
|
// IsGitee returns true if the Gitee integration
|
|
|
|
// is activated.
|
|
|
|
func (c *Config) IsGitee() bool {
|
|
|
|
return c.Gitee.ClientID != ""
|
|
|
|
}
|
|
|
|
|
2019-03-13 21:47:47 +00:00
|
|
|
// IsBitbucket returns true if the Bitbucket Cloud
|
|
|
|
// integration is activated.
|
|
|
|
func (c *Config) IsBitbucket() bool {
|
|
|
|
return c.Bitbucket.ClientID != ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsStash returns true if the Atlassian Stash
|
|
|
|
// integration is activated.
|
|
|
|
func (c *Config) IsStash() bool {
|
|
|
|
return c.Stash.Server != ""
|
|
|
|
}
|
|
|
|
|
2021-09-07 12:25:29 +00:00
|
|
|
func cleanHostname(hostname string) string {
|
|
|
|
hostname = strings.ToLower(hostname)
|
|
|
|
hostname = strings.TrimPrefix(hostname, "http://")
|
|
|
|
hostname = strings.TrimPrefix(hostname, "https://")
|
|
|
|
|
|
|
|
return hostname
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
func defaultAddress(c *Config) {
|
|
|
|
if c.Server.Key != "" || c.Server.Cert != "" || c.Server.Acme {
|
|
|
|
c.Server.Port = ":443"
|
|
|
|
c.Server.Proto = "https"
|
|
|
|
}
|
2021-09-07 12:25:29 +00:00
|
|
|
c.Server.Host = cleanHostname(c.Server.Host)
|
2019-02-19 23:56:41 +00:00
|
|
|
c.Server.Addr = c.Server.Proto + "://" + c.Server.Host
|
|
|
|
}
|
|
|
|
|
|
|
|
func defaultProxy(c *Config) {
|
|
|
|
if c.Proxy.Host == "" {
|
|
|
|
c.Proxy.Host = c.Server.Host
|
2021-09-07 12:25:29 +00:00
|
|
|
} else {
|
|
|
|
c.Proxy.Host = cleanHostname(c.Proxy.Host)
|
2019-02-19 23:56:41 +00:00
|
|
|
}
|
|
|
|
if c.Proxy.Proto == "" {
|
|
|
|
c.Proxy.Proto = c.Server.Proto
|
|
|
|
}
|
|
|
|
c.Proxy.Addr = c.Proxy.Proto + "://" + c.Proxy.Host
|
|
|
|
}
|
|
|
|
|
|
|
|
func defaultCallback(c *Config) {
|
|
|
|
if c.RPC.Host == "" {
|
|
|
|
c.RPC.Host = c.Server.Host
|
|
|
|
}
|
|
|
|
if c.RPC.Proto == "" {
|
|
|
|
c.RPC.Proto = c.Server.Proto
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func defaultRunner(c *Config) {
|
|
|
|
if c.Runner.Machine == "" {
|
|
|
|
c.Runner.Machine = hostname
|
|
|
|
}
|
|
|
|
parts := strings.Split(c.Runner.Platform, "/")
|
|
|
|
if len(parts) == 2 && c.Runner.OS == "" {
|
|
|
|
c.Runner.OS = parts[0]
|
|
|
|
}
|
|
|
|
if len(parts) == 2 && c.Runner.Arch == "" {
|
|
|
|
c.Runner.Arch = parts[1]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func defaultSession(c *Config) {
|
|
|
|
if c.Session.Secret == "" {
|
|
|
|
c.Session.Secret = uniuri.NewLen(32)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func configureGithub(c *Config) {
|
|
|
|
if c.Github.APIServer != "" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if c.Github.Server == "https://github.com" {
|
|
|
|
c.Github.APIServer = "https://api.github.com"
|
|
|
|
} else {
|
|
|
|
c.Github.APIServer = strings.TrimSuffix(c.Github.Server, "/") + "/api/v3"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-30 02:55:25 +00:00
|
|
|
func kubernetesServiceConflict(c *Config) error {
|
|
|
|
if strings.HasPrefix(c.Server.Port, "tcp://") {
|
|
|
|
return errors.New("Invalid port configuration. See https://discourse.drone.io/t/drone-server-changing-ports-protocol/4144")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:56:41 +00:00
|
|
|
// Bytes stores number bytes (e.g. megabytes)
|
|
|
|
type Bytes int64
|
|
|
|
|
|
|
|
// Decode implements a decoder that parses a string representation
|
|
|
|
// of bytes into the number of bytes it represents.
|
|
|
|
func (b *Bytes) Decode(value string) error {
|
|
|
|
v, err := humanize.ParseBytes(value)
|
|
|
|
*b = Bytes(v)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Int64 returns the int64 value of the Byte.
|
|
|
|
func (b *Bytes) Int64() int64 {
|
|
|
|
return int64(*b)
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns the string value of the Byte.
|
|
|
|
func (b *Bytes) String() string {
|
|
|
|
return fmt.Sprint(*b)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserCreate stores account information used to bootstrap
|
|
|
|
// the admin user account when the system initializes.
|
|
|
|
type UserCreate struct {
|
|
|
|
Username string
|
|
|
|
Machine bool
|
|
|
|
Admin bool
|
|
|
|
Token string
|
|
|
|
}
|
|
|
|
|
|
|
|
// Decode implements a decoder that extracts user information
|
|
|
|
// from the environment variable string.
|
|
|
|
func (u *UserCreate) Decode(value string) error {
|
|
|
|
for _, param := range strings.Split(value, ",") {
|
|
|
|
parts := strings.Split(param, ":")
|
|
|
|
if len(parts) != 2 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
key := parts[0]
|
|
|
|
val := parts[1]
|
|
|
|
switch key {
|
|
|
|
case "username":
|
|
|
|
u.Username = val
|
|
|
|
case "token":
|
|
|
|
u.Token = val
|
|
|
|
case "machine":
|
|
|
|
u.Machine = val == "true"
|
|
|
|
case "admin":
|
|
|
|
u.Admin = val == "true"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|