blob: 2b5017e4c5578a105ed9a7721fd7ed44a1972f5f [file] [log] [blame]
khenaidoobf6e7bb2018-08-14 22:27:29 -04001/*
2 * Copyright 2018-present Open Networking Foundation
3
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7
8 * http://www.apache.org/licenses/LICENSE-2.0
9
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
npujar1d86a522019-11-14 17:11:16 +053016
khenaidoocfee5f42018-07-19 22:47:38 -040017package config
18
19import (
khenaidoocfee5f42018-07-19 22:47:38 -040020 "flag"
21 "fmt"
Girish Kumar4d3887d2019-11-22 14:22:05 +000022 "time"
khenaidoocfee5f42018-07-19 22:47:38 -040023)
24
khenaidoo5c11af72018-07-20 17:21:05 -040025// RW Core service default constants
khenaidoocfee5f42018-07-19 22:47:38 -040026const (
npujar1d86a522019-11-14 17:11:16 +053027 EtcdStoreName = "etcd"
Neha Sharmad1387da2020-05-07 20:07:28 +000028 defaultGrpcAddress = ":50057"
29 defaultKafkaAdapterAddress = "127.0.0.1:9092"
30 defaultKafkaClusterAddress = "127.0.0.1:9094"
npujar1d86a522019-11-14 17:11:16 +053031 defaultKVStoreType = EtcdStoreName
Neha Sharma7d6f3a92020-04-14 15:26:22 +000032 defaultKVStoreTimeout = 5 * time.Second
serkant.uluderyac431f2c2021-02-24 17:32:43 +030033 defaultKVStoreAddress = "127.0.0.1:2379" // Etcd = 2379
npujar1d86a522019-11-14 17:11:16 +053034 defaultKVTxnKeyDelTime = 60
David Bainbridge48d46e12020-03-17 15:05:55 -070035 defaultLogLevel = "WARN"
npujar1d86a522019-11-14 17:11:16 +053036 defaultBanner = false
37 defaultDisplayVersionOnly = false
38 defaultCoreTopic = "rwcore"
Himani Chawlab4c25912020-11-12 17:16:38 +053039 defaultEventTopic = "voltha.events"
npujar1d86a522019-11-14 17:11:16 +053040 defaultRWCoreEndpoint = "rwcore"
41 defaultRWCoreKey = "pki/voltha.key"
42 defaultRWCoreCert = "pki/voltha.crt"
43 defaultRWCoreCA = "pki/voltha-CA.pem"
khenaidoo442e7c72020-03-10 16:13:48 -040044 defaultLongRunningRequestTimeout = 2000 * time.Millisecond
45 defaultDefaultRequestTimeout = 1000 * time.Millisecond
46 defaultCoreTimeout = 1000 * time.Millisecond
npujar1d86a522019-11-14 17:11:16 +053047 defaultCoreBindingKey = "voltha_backend_name"
npujar1d86a522019-11-14 17:11:16 +053048 defaultMaxConnectionRetries = -1 // retries forever
49 defaultConnectionRetryInterval = 2 * time.Second
50 defaultLiveProbeInterval = 60 * time.Second
51 defaultNotLiveProbeInterval = 5 * time.Second // Probe more frequently when not alive
Neha Sharmad1387da2020-05-07 20:07:28 +000052 defaultProbeAddress = ":8080"
Girish Kumar33470e82020-06-15 13:53:13 +000053 defaultTraceEnabled = false
54 defaultTraceAgentAddress = "127.0.0.1:6831"
55 defaultLogCorrelationEnabled = true
Himani Chawla9cfc4992021-03-22 12:43:01 +053056 defaultVolthaStackID = "voltha"
khenaidoocfee5f42018-07-19 22:47:38 -040057)
58
khenaidoo5c11af72018-07-20 17:21:05 -040059// RWCoreFlags represents the set of configurations used by the read-write core service
khenaidoocfee5f42018-07-19 22:47:38 -040060type RWCoreFlags struct {
61 // Command line parameters
khenaidoo2c6a0992019-04-29 13:46:56 -040062 RWCoreEndpoint string
Neha Sharmad1387da2020-05-07 20:07:28 +000063 GrpcAddress string
64 KafkaAdapterAddress string
65 KafkaClusterAddress string
khenaidoo2c6a0992019-04-29 13:46:56 -040066 KVStoreType string
Neha Sharma7d6f3a92020-04-14 15:26:22 +000067 KVStoreTimeout time.Duration
Neha Sharmad1387da2020-05-07 20:07:28 +000068 KVStoreAddress string
khenaidoo2c6a0992019-04-29 13:46:56 -040069 KVTxnKeyDelTime int
khenaidoo2c6a0992019-04-29 13:46:56 -040070 CoreTopic string
Himani Chawlab4c25912020-11-12 17:16:38 +053071 EventTopic string
Rohan Agrawal7f72f0c2020-01-14 12:05:51 +000072 LogLevel string
khenaidoo2c6a0992019-04-29 13:46:56 -040073 Banner bool
David K. Bainbridgef430cd52019-05-28 15:00:35 -070074 DisplayVersionOnly bool
khenaidoo2c6a0992019-04-29 13:46:56 -040075 RWCoreKey string
76 RWCoreCert string
77 RWCoreCA string
khenaidoo442e7c72020-03-10 16:13:48 -040078 LongRunningRequestTimeout time.Duration
79 DefaultRequestTimeout time.Duration
80 DefaultCoreTimeout time.Duration
khenaidoo2c6a0992019-04-29 13:46:56 -040081 CoreBindingKey string
khenaidoob3244212019-08-27 14:32:27 -040082 MaxConnectionRetries int
Girish Kumar4d3887d2019-11-22 14:22:05 +000083 ConnectionRetryInterval time.Duration
84 LiveProbeInterval time.Duration
85 NotLiveProbeInterval time.Duration
Neha Sharmad1387da2020-05-07 20:07:28 +000086 ProbeAddress string
Girish Kumar33470e82020-06-15 13:53:13 +000087 TraceEnabled bool
88 TraceAgentAddress string
89 LogCorrelationEnabled bool
Himani Chawla9cfc4992021-03-22 12:43:01 +053090 VolthaStackID string
khenaidoocfee5f42018-07-19 22:47:38 -040091}
92
khenaidoo5c11af72018-07-20 17:21:05 -040093// NewRWCoreFlags returns a new RWCore config
khenaidoocfee5f42018-07-19 22:47:38 -040094func NewRWCoreFlags() *RWCoreFlags {
95 var rwCoreFlag = RWCoreFlags{ // Default values
npujar1d86a522019-11-14 17:11:16 +053096 RWCoreEndpoint: defaultRWCoreEndpoint,
Neha Sharmad1387da2020-05-07 20:07:28 +000097 GrpcAddress: defaultGrpcAddress,
98 KafkaAdapterAddress: defaultKafkaAdapterAddress,
99 KafkaClusterAddress: defaultKafkaClusterAddress,
npujar1d86a522019-11-14 17:11:16 +0530100 KVStoreType: defaultKVStoreType,
101 KVStoreTimeout: defaultKVStoreTimeout,
Neha Sharmad1387da2020-05-07 20:07:28 +0000102 KVStoreAddress: defaultKVStoreAddress,
npujar1d86a522019-11-14 17:11:16 +0530103 KVTxnKeyDelTime: defaultKVTxnKeyDelTime,
104 CoreTopic: defaultCoreTopic,
Himani Chawlab4c25912020-11-12 17:16:38 +0530105 EventTopic: defaultEventTopic,
npujar1d86a522019-11-14 17:11:16 +0530106 LogLevel: defaultLogLevel,
107 Banner: defaultBanner,
108 DisplayVersionOnly: defaultDisplayVersionOnly,
109 RWCoreKey: defaultRWCoreKey,
110 RWCoreCert: defaultRWCoreCert,
111 RWCoreCA: defaultRWCoreCA,
npujar1d86a522019-11-14 17:11:16 +0530112 DefaultRequestTimeout: defaultDefaultRequestTimeout,
113 LongRunningRequestTimeout: defaultLongRunningRequestTimeout,
114 DefaultCoreTimeout: defaultCoreTimeout,
115 CoreBindingKey: defaultCoreBindingKey,
npujar1d86a522019-11-14 17:11:16 +0530116 MaxConnectionRetries: defaultMaxConnectionRetries,
117 ConnectionRetryInterval: defaultConnectionRetryInterval,
118 LiveProbeInterval: defaultLiveProbeInterval,
119 NotLiveProbeInterval: defaultNotLiveProbeInterval,
Neha Sharmad1387da2020-05-07 20:07:28 +0000120 ProbeAddress: defaultProbeAddress,
Girish Kumar33470e82020-06-15 13:53:13 +0000121 TraceEnabled: defaultTraceEnabled,
122 TraceAgentAddress: defaultTraceAgentAddress,
123 LogCorrelationEnabled: defaultLogCorrelationEnabled,
Himani Chawla9cfc4992021-03-22 12:43:01 +0530124 VolthaStackID: defaultVolthaStackID,
khenaidoocfee5f42018-07-19 22:47:38 -0400125 }
126 return &rwCoreFlag
127}
128
khenaidoo5c11af72018-07-20 17:21:05 -0400129// ParseCommandArguments parses the arguments when running read-write core service
khenaidoocfee5f42018-07-19 22:47:38 -0400130func (cf *RWCoreFlags) ParseCommandArguments() {
khenaidoocfee5f42018-07-19 22:47:38 -0400131
npujar1d86a522019-11-14 17:11:16 +0530132 help := fmt.Sprintf("RW core endpoint address")
133 flag.StringVar(&(cf.RWCoreEndpoint), "vcore-endpoint", defaultRWCoreEndpoint, help)
khenaidoocfee5f42018-07-19 22:47:38 -0400134
Neha Sharmad1387da2020-05-07 20:07:28 +0000135 help = fmt.Sprintf("GRPC server - address")
136 flag.StringVar(&(cf.GrpcAddress), "grpc_address", defaultGrpcAddress, help)
khenaidoocfee5f42018-07-19 22:47:38 -0400137
Neha Sharmad1387da2020-05-07 20:07:28 +0000138 help = fmt.Sprintf("Kafka - Adapter messaging address")
139 flag.StringVar(&(cf.KafkaAdapterAddress), "kafka_adapter_address", defaultKafkaAdapterAddress, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400140
Neha Sharmad1387da2020-05-07 20:07:28 +0000141 help = fmt.Sprintf("Kafka - Cluster messaging address")
142 flag.StringVar(&(cf.KafkaClusterAddress), "kafka_cluster_address", defaultKafkaClusterAddress, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400143
144 help = fmt.Sprintf("RW Core topic")
npujar1d86a522019-11-14 17:11:16 +0530145 flag.StringVar(&(cf.CoreTopic), "rw_core_topic", defaultCoreTopic, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400146
Himani Chawlab4c25912020-11-12 17:16:38 +0530147 help = fmt.Sprintf("RW Core Event topic")
148 flag.StringVar(&(cf.EventTopic), "event_topic", defaultEventTopic, help)
149
David Bainbridge9ae13132020-06-22 17:28:01 -0700150 flag.Bool("in_competing_mode", false, "deprecated")
khenaidoo79232702018-12-04 11:00:41 -0500151
khenaidoo5c11af72018-07-20 17:21:05 -0400152 help = fmt.Sprintf("KV store type")
npujar1d86a522019-11-14 17:11:16 +0530153 flag.StringVar(&(cf.KVStoreType), "kv_store_type", defaultKVStoreType, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400154
155 help = fmt.Sprintf("The default timeout when making a kv store request")
Neha Sharma7d6f3a92020-04-14 15:26:22 +0000156 flag.DurationVar(&(cf.KVStoreTimeout), "kv_store_request_timeout", defaultKVStoreTimeout, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400157
Neha Sharmad1387da2020-05-07 20:07:28 +0000158 help = fmt.Sprintf("KV store address")
159 flag.StringVar(&(cf.KVStoreAddress), "kv_store_address", defaultKVStoreAddress, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400160
Richard Jankowskie4d77662018-10-17 13:53:21 -0400161 help = fmt.Sprintf("The time to wait before deleting a completed transaction key")
npujar1d86a522019-11-14 17:11:16 +0530162 flag.IntVar(&(cf.KVTxnKeyDelTime), "kv_txn_delete_time", defaultKVTxnKeyDelTime, help)
Richard Jankowskie4d77662018-10-17 13:53:21 -0400163
khenaidoo5c11af72018-07-20 17:21:05 -0400164 help = fmt.Sprintf("Log level")
Rohan Agrawal7f72f0c2020-01-14 12:05:51 +0000165 flag.StringVar(&(cf.LogLevel), "log_level", defaultLogLevel, help)
khenaidoo5c11af72018-07-20 17:21:05 -0400166
khenaidoob6080322019-01-29 21:47:38 -0500167 help = fmt.Sprintf("Timeout for long running request")
Neha Sharma7d6f3a92020-04-14 15:26:22 +0000168 flag.DurationVar(&(cf.LongRunningRequestTimeout), "timeout_long_request", defaultLongRunningRequestTimeout, help)
khenaidoob6080322019-01-29 21:47:38 -0500169
170 help = fmt.Sprintf("Default timeout for regular request")
Neha Sharma7d6f3a92020-04-14 15:26:22 +0000171 flag.DurationVar(&(cf.DefaultRequestTimeout), "timeout_request", defaultDefaultRequestTimeout, help)
khenaidoob6080322019-01-29 21:47:38 -0500172
khenaidoo2c6a0992019-04-29 13:46:56 -0400173 help = fmt.Sprintf("Default Core timeout")
Neha Sharma7d6f3a92020-04-14 15:26:22 +0000174 flag.DurationVar(&(cf.DefaultCoreTimeout), "core_timeout", defaultCoreTimeout, help)
khenaidoo2c6a0992019-04-29 13:46:56 -0400175
khenaidoo5c11af72018-07-20 17:21:05 -0400176 help = fmt.Sprintf("Show startup banner log lines")
npujar1d86a522019-11-14 17:11:16 +0530177 flag.BoolVar(&cf.Banner, "banner", defaultBanner, help)
khenaidoocfee5f42018-07-19 22:47:38 -0400178
David K. Bainbridgef430cd52019-05-28 15:00:35 -0700179 help = fmt.Sprintf("Show version information and exit")
npujar1d86a522019-11-14 17:11:16 +0530180 flag.BoolVar(&cf.DisplayVersionOnly, "version", defaultDisplayVersionOnly, help)
David K. Bainbridgef430cd52019-05-28 15:00:35 -0700181
Richard Jankowski46464e92019-03-05 11:53:55 -0500182 help = fmt.Sprintf("The name of the meta-key whose value is the rw-core group to which the ofagent is bound")
npujar1d86a522019-11-14 17:11:16 +0530183 flag.StringVar(&(cf.CoreBindingKey), "core_binding_key", defaultCoreBindingKey, help)
Richard Jankowski46464e92019-03-05 11:53:55 -0500184
khenaidoob3244212019-08-27 14:32:27 -0400185 help = fmt.Sprintf("The number of retries to connect to a dependent component")
npujar1d86a522019-11-14 17:11:16 +0530186 flag.IntVar(&(cf.MaxConnectionRetries), "max_connection_retries", defaultMaxConnectionRetries, help)
khenaidoob3244212019-08-27 14:32:27 -0400187
Scott Bakeree6a0872019-10-29 15:59:52 -0700188 help = fmt.Sprintf("The number of seconds between each connection retry attempt")
npujar1d86a522019-11-14 17:11:16 +0530189 flag.DurationVar(&(cf.ConnectionRetryInterval), "connection_retry_interval", defaultConnectionRetryInterval, help)
khenaidoob3244212019-08-27 14:32:27 -0400190
Scott Bakeree6a0872019-10-29 15:59:52 -0700191 help = fmt.Sprintf("The number of seconds between liveness probes while in a live state")
npujar1d86a522019-11-14 17:11:16 +0530192 flag.DurationVar(&(cf.LiveProbeInterval), "live_probe_interval", defaultLiveProbeInterval, help)
Scott Bakeree6a0872019-10-29 15:59:52 -0700193
194 help = fmt.Sprintf("The number of seconds between liveness probes while in a not live state")
npujar1d86a522019-11-14 17:11:16 +0530195 flag.DurationVar(&(cf.NotLiveProbeInterval), "not_live_probe_interval", defaultNotLiveProbeInterval, help)
Scott Bakeree6a0872019-10-29 15:59:52 -0700196
Neha Sharmad1387da2020-05-07 20:07:28 +0000197 help = fmt.Sprintf("The address on which to listen to answer liveness and readiness probe queries over HTTP.")
198 flag.StringVar(&(cf.ProbeAddress), "probe_address", defaultProbeAddress, help)
David K. Bainbridgeb4a9ab02019-09-20 15:12:16 -0700199
Girish Kumar33470e82020-06-15 13:53:13 +0000200 help = fmt.Sprintf("Whether to send logs to tracing agent?")
201 flag.BoolVar(&(cf.TraceEnabled), "trace_enabled", defaultTraceEnabled, help)
202
203 help = fmt.Sprintf("The address of tracing agent to which span info should be sent.")
204 flag.StringVar(&(cf.TraceAgentAddress), "trace_agent_address", defaultTraceAgentAddress, help)
205
206 help = fmt.Sprintf("Whether to enrich log statements with fields denoting operation being executed for achieving correlation?")
207 flag.BoolVar(&(cf.LogCorrelationEnabled), "log_correlation_enabled", defaultLogCorrelationEnabled, help)
208
Himani Chawla9cfc4992021-03-22 12:43:01 +0530209 help = fmt.Sprintf("ID for the current voltha stack")
210 flag.StringVar(&cf.VolthaStackID, "stack_id", defaultVolthaStackID, help)
211
khenaidoocfee5f42018-07-19 22:47:38 -0400212 flag.Parse()
khenaidoocfee5f42018-07-19 22:47:38 -0400213}