From a23c3e61c5d89ef67973891b5b3a176c06e1b174 Mon Sep 17 00:00:00 2001 From: jwijenbergh Date: Wed, 12 Apr 2023 22:52:49 +0200 Subject: Refactor: Split internal server into multiple packages - Pass contexts - Have separate packages for e.g. custom, institute and secure - internet servers, profiles.... - Return types from the public ./types package with a Public() method --- internal/server/custom/custom.go | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 internal/server/custom/custom.go (limited to 'internal/server/custom') diff --git a/internal/server/custom/custom.go b/internal/server/custom/custom.go new file mode 100644 index 0000000..14a72a5 --- /dev/null +++ b/internal/server/custom/custom.go @@ -0,0 +1,31 @@ +package custom + +import ( + "context" + + "github.com/eduvpn/eduvpn-common/internal/server/api" + "github.com/eduvpn/eduvpn-common/internal/server/base" + "github.com/eduvpn/eduvpn-common/internal/server/institute" + "github.com/eduvpn/eduvpn-common/types/server" +) + +type ( + Server = institute.Server + Servers = institute.Servers +) + +func New(ctx context.Context, url string) (*Server, error) { + b := base.Base{ + URL: url, + DisplayName: map[string]string{"en": url}, + Type: server.TypeCustom, + } + if err := api.Endpoints(ctx, &b); err != nil { + return nil, err + } + API := b.Endpoints.API.V3 + + s := &Server{Basic: b} + s.Auth.Init(url, API.Authorization, API.Token) + return s, nil +} -- cgit v1.2.3