/
apim.go
94 lines (78 loc) · 2.59 KB
/
apim.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// Copyright (C) 2015 The Gravitee team (http://gravitee.io)
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package apim
import (
"context"
"github.com/gravitee-io/gravitee-kubernetes-operator/api/model/management"
"github.com/gravitee-io/gravitee-kubernetes-operator/internal/apim/client"
"github.com/gravitee-io/gravitee-kubernetes-operator/internal/apim/service"
"github.com/gravitee-io/gravitee-kubernetes-operator/internal/http"
)
// APIM wraps services needed to sync resources with a given environment on a Gravitee.io APIM instance.
type APIM struct {
APIs *service.APIs
Applications *service.Applications
orgID string
envID string
}
// EnvID returns the environment ID of the current managed APIM instance.
func (apim *APIM) EnvID() string {
return apim.envID
}
// OrgID returns the organization ID of the current managed APIM instance.
func (apim *APIM) OrgID() string {
return apim.orgID
}
// FromContext returns a new APIM instance from a given reconcile context and management context.
func FromContext(ctx context.Context, managementContext management.Context) (*APIM, error) {
orgID, envID := managementContext.OrgId, managementContext.EnvId
urls, err := client.NewURLs(managementContext.BaseUrl, orgID, envID)
if err != nil {
return nil, err
}
client := &client.Client{
HTTP: http.NewClient(ctx, toHttpAuth(managementContext)),
URLs: urls,
}
return &APIM{
APIs: service.NewAPIs(client),
Applications: service.NewApplications(client),
orgID: orgID,
envID: envID,
}, nil
}
func toHttpAuth(management management.Context) *http.Auth {
if !management.HasAuthentication() {
return nil
}
return &http.Auth{
Basic: toBasicAuth(management.Auth),
Token: toBearer(management.Auth),
}
}
func toBasicAuth(auth *management.Auth) *http.BasicAuth {
if auth == nil || auth.Credentials == nil {
return nil
}
return &http.BasicAuth{
Username: auth.Credentials.Username,
Password: auth.Credentials.Password,
}
}
func toBearer(auth *management.Auth) http.BearerToken {
if auth == nil {
return ""
}
return http.BearerToken(auth.BearerToken)
}