// Copyright (C) The Arvados Authors. All rights reserved.
//
// SPDX-License-Identifier: AGPL-3.0

package main

import (
	"context"
	"net"
	"net/http"

	"git.arvados.org/arvados.git/sdk/go/arvados"
	"git.arvados.org/arvados.git/sdk/go/httpserver"
	"github.com/prometheus/client_golang/prometheus"
	"github.com/sirupsen/logrus"
)

type server struct {
	httpserver.Server
	Config *Config
}

func (srv *server) Start(ctx context.Context, logger *logrus.Logger) error {
	h := &handler{Config: srv.Config}
	reg := prometheus.NewRegistry()
	h.Config.Cache.registry = reg
	// Warning: when updating this to use Command() from
	// lib/service, make sure to implement an exemption in
	// httpserver.HandlerWithDeadline() so large file uploads are
	// allowed to take longer than the usual API.RequestTimeout.
	// See #13697.
	mh := httpserver.Instrument(reg, logger, httpserver.AddRequestIDs(httpserver.LogRequests(h)))
	h.MetricsAPI = mh.ServeAPI(h.Config.cluster.ManagementToken, http.NotFoundHandler())
	srv.Handler = mh
	srv.BaseContext = func(net.Listener) context.Context { return ctx }
	var listen arvados.URL
	for listen = range srv.Config.cluster.Services.WebDAV.InternalURLs {
		break
	}
	if len(srv.Config.cluster.Services.WebDAV.InternalURLs) > 1 {
		logrus.Warn("Services.WebDAV.InternalURLs has more than one key; picked: ", listen)
	}
	srv.Addr = listen.Host
	return srv.Server.Start()
}