Merge remote-tracking branch 'origin/master' into 14714-keep-balance-config
authorEric Biagiotti <ebiagiotti@veritasgenetics.com>
Mon, 30 Sep 2019 16:31:13 +0000 (12:31 -0400)
committerEric Biagiotti <ebiagiotti@veritasgenetics.com>
Mon, 30 Sep 2019 16:31:13 +0000 (12:31 -0400)
refs #14714

Arvados-DCO-1.1-Signed-off-by: Eric Biagiotti <ebiagiotti@veritasgenetics.com>

1  2 
lib/config/deprecated.go
lib/config/load.go

index 593a9bdcbcaf51b19a40b91a0fd083a3def2f3ba,d0e61dbca06454d3488b1f50473b55f67b2a66b1..e6b06c1314668a9662a60c74b710642f33ec5f83
@@@ -475,77 -476,29 +476,104 @@@ func (ldr *Loader) loadOldGitHttpdConfi
        return nil
  }
  
 +const defaultKeepBalanceConfigPath = "/etc/arvados/keep-balance/keep-balance.yml"
 +
 +type oldKeepBalanceConfig struct {
 +      Client              *arvados.Client
 +      Listen              *string
 +      KeepServiceTypes    *[]string
 +      KeepServiceList     *arvados.KeepServiceList
 +      RunPeriod           *arvados.Duration
 +      CollectionBatchSize *int
 +      CollectionBuffers   *int
 +      RequestTimeout      *arvados.Duration
 +      LostBlocksFile      *string
 +      ManagementToken     *string
 +}
 +
 +func (ldr *Loader) loadOldKeepBalanceConfig(cfg *arvados.Config) error {
 +      if ldr.KeepBalancePath == "" {
 +              return nil
 +      }
 +      var oc oldKeepBalanceConfig
 +      err := ldr.loadOldConfigHelper("keep-balance", ldr.KeepBalancePath, &oc)
 +      if os.IsNotExist(err) && ldr.KeepBalancePath == defaultKeepBalanceConfigPath {
 +              return nil
 +      } else if err != nil {
 +              return err
 +      }
 +
 +      cluster, err := cfg.GetCluster("")
 +      if err != nil {
 +              return err
 +      }
 +
 +      loadOldClientConfig(cluster, oc.Client)
 +
 +      if oc.Listen != nil {
 +              cluster.Services.Keepbalance.InternalURLs[arvados.URL{Host: *oc.Listen}] = arvados.ServiceInstance{}
 +      }
 +      if oc.ManagementToken != nil {
 +              cluster.ManagementToken = *oc.ManagementToken
 +      }
 +      if oc.RunPeriod != nil {
 +              cluster.Collections.BalancePeriod = *oc.RunPeriod
 +      }
 +      if oc.LostBlocksFile != nil {
 +              cluster.Collections.BlobMissingReport = *oc.LostBlocksFile
 +      }
 +      if oc.CollectionBatchSize != nil {
 +              cluster.Collections.BalanceCollectionBatch = *oc.CollectionBatchSize
 +      }
 +      if oc.CollectionBuffers != nil {
 +              cluster.Collections.BalanceCollectionBuffers = *oc.CollectionBuffers
 +      }
 +      if oc.RequestTimeout != nil {
 +              cluster.API.KeepServiceRequestTimeout = *oc.RequestTimeout
 +      }
 +
 +      msg := "The %s configuration option is no longer supported. Please remove it from your configuration file. Keep-balance will operate on all configured volumes."
 +
 +      // If the keep service type provided is "disk" silently ignore it, since
 +      // this is what ends up being done anyway.
 +      if oc.KeepServiceTypes != nil {
 +              numTypes := len(*oc.KeepServiceTypes)
 +              if numTypes != 0 && !(numTypes == 1 && (*oc.KeepServiceTypes)[0] == "disk") {
 +                      return fmt.Errorf(msg, "KeepServiceType")
 +              }
 +      }
 +
 +      if oc.KeepServiceList != nil {
 +              return fmt.Errorf(msg, "KeepServiceList")
 +      }
 +
 +      cfg.Clusters[cluster.ClusterID] = *cluster
 +      return nil
 +}
++
+ func (ldr *Loader) loadOldEnvironmentVariables(cfg *arvados.Config) error {
+       if os.Getenv("ARVADOS_API_TOKEN") == "" && os.Getenv("ARVADOS_API_HOST") == "" {
+               return nil
+       }
+       cluster, err := cfg.GetCluster("")
+       if err != nil {
+               return err
+       }
+       if tok := os.Getenv("ARVADOS_API_TOKEN"); tok != "" && cluster.SystemRootToken == "" {
+               ldr.Logger.Warn("SystemRootToken missing from cluster config, falling back to ARVADOS_API_TOKEN environment variable")
+               cluster.SystemRootToken = tok
+       }
+       if apihost := os.Getenv("ARVADOS_API_HOST"); apihost != "" && cluster.Services.Controller.ExternalURL.Host == "" {
+               ldr.Logger.Warn("Services.Controller.ExternalURL missing from cluster config, falling back to ARVADOS_API_HOST(_INSECURE) environment variables")
+               u, err := url.Parse("https://" + apihost)
+               if err != nil {
+                       return fmt.Errorf("cannot parse ARVADOS_API_HOST: %s", err)
+               }
+               cluster.Services.Controller.ExternalURL = arvados.URL(*u)
+               if i := os.Getenv("ARVADOS_API_HOST_INSECURE"); i != "" && i != "0" {
+                       cluster.TLS.Insecure = true
+               }
+       }
+       cfg.Clusters[cluster.ClusterID] = *cluster
+       return nil
+ }
Simple merge