package server import ( "context" "github.com/eduvpn/eduvpn-common/internal/api" "github.com/eduvpn/eduvpn-common/internal/config/v2" "github.com/eduvpn/eduvpn-common/types/server" "github.com/jwijenbergh/eduoauth-go" ) // AddCustom adds a custom server to the internal server list // `ctx` is the context used for cancellation // `id` is the identifier of the server, the base URL // `na` specifies whether or not we want to add the server without doing authorization now func (s *Servers) AddCustom(ctx context.Context, id string, na bool) error { sd := api.ServerData{ ID: id, Type: server.TypeCustom, BaseWK: id, BaseAuthWK: id, } err := s.config.AddServer(id, server.TypeCustom, v2.Server{}) if err != nil { return err } // no authorization should be triggered, return if na { return nil } // Authorize by creating the API object _, err = api.NewAPI(ctx, s.clientID, sd, s.cb, nil) if err != nil { // authorization has failed, remove the server again s.config.RemoveServer(id, server.TypeCustom) return err } return nil } // GetCustom gets a custom server // `ctx` is the context for cancellation // `id` is the identifier of the server // `tok` are the tokens such that we can initialize the API // `disableAuth` is set to True when authorization should not be triggered func (s *Servers) GetCustom(ctx context.Context, id string, tok *eduoauth.Token, disableAuth bool) (*Server, error) { sd := api.ServerData{ ID: id, Type: server.TypeCustom, BaseWK: id, BaseAuthWK: id, DisableAuthorize: disableAuth, } // Get the server from the config _, err := s.config.GetServer(id, server.TypeCustom) if err != nil { return nil, err } a, err := api.NewAPI(ctx, s.clientID, sd, s.cb, tok) if err != nil { return nil, err } cust := s.NewServer(id, server.TypeCustom, a) return &cust, nil }