mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
CloudMigrations: Obtain gcom plugins to enable plugins migration (#97784)
* just api * preallocate
This commit is contained in:
parent
b2987021b4
commit
b9d6af34cd
@ -23,3 +23,24 @@ func (client *gcomStub) GetInstanceByID(_ context.Context, _ string, instanceID
|
|||||||
ClusterSlug: "fake-cluser",
|
ClusterSlug: "fake-cluser",
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (client *gcomStub) GetPlugins(ctx context.Context, requestID string) (map[string]gcom.Plugin, error) {
|
||||||
|
plugins := map[string]gcom.Plugin{
|
||||||
|
"plugin-external-valid-grafana": {
|
||||||
|
Slug: "plugin-external-valid-grafana",
|
||||||
|
Status: "active",
|
||||||
|
SignatureType: "grafana",
|
||||||
|
},
|
||||||
|
"plugin-external-valid-commercial": {
|
||||||
|
Slug: "plugin-external-valid-commercial",
|
||||||
|
Status: "active",
|
||||||
|
SignatureType: "commercial",
|
||||||
|
},
|
||||||
|
"plugin-external-valid-community": {
|
||||||
|
Slug: "active-plugin",
|
||||||
|
Status: "active",
|
||||||
|
SignatureType: "community",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
return plugins, nil
|
||||||
|
}
|
||||||
|
@ -18,6 +18,7 @@ var ErrTokenNotFound = errors.New("gcom: token not found")
|
|||||||
|
|
||||||
type Service interface {
|
type Service interface {
|
||||||
GetInstanceByID(ctx context.Context, requestID string, instanceID string) (Instance, error)
|
GetInstanceByID(ctx context.Context, requestID string, instanceID string) (Instance, error)
|
||||||
|
GetPlugins(ctx context.Context, requestID string) (map[string]Plugin, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type Instance struct {
|
type Instance struct {
|
||||||
@ -28,6 +29,15 @@ type Instance struct {
|
|||||||
OrgId int `json:"orgId"`
|
OrgId int `json:"orgId"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Plugin struct {
|
||||||
|
Slug string `json:"slug"`
|
||||||
|
Status string `json:"status"`
|
||||||
|
SignatureType string `json:"signatureType"`
|
||||||
|
}
|
||||||
|
type listPluginsResponse struct {
|
||||||
|
Items []Plugin `json:"items"`
|
||||||
|
}
|
||||||
|
|
||||||
type GcomClient struct {
|
type GcomClient struct {
|
||||||
log log.Logger
|
log log.Logger
|
||||||
cfg Config
|
cfg Config
|
||||||
@ -85,3 +95,47 @@ func (client *GcomClient) GetInstanceByID(ctx context.Context, requestID string,
|
|||||||
|
|
||||||
return instance, nil
|
return instance, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (client *GcomClient) GetPlugins(ctx context.Context, requestID string) (map[string]Plugin, error) {
|
||||||
|
endpoint, err := url.JoinPath(client.cfg.ApiURL, "/plugins")
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("building gcom instance url: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
request, err := http.NewRequestWithContext(ctx, http.MethodGet, endpoint, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("creating http request: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
request.Header.Set("x-request-id", requestID)
|
||||||
|
request.Header.Set("Content-Type", "application/json")
|
||||||
|
|
||||||
|
response, err := client.httpClient.Do(request)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("sending http request to get plugins: %w", err)
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
if err := response.Body.Close(); err != nil {
|
||||||
|
client.log.Error("closing http response body", "err", err.Error())
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
if response.StatusCode != http.StatusOK {
|
||||||
|
body, _ := io.ReadAll(response.Body)
|
||||||
|
return nil, fmt.Errorf("unexpected response when obtaining plugins: code=%d body=%s", response.StatusCode, body)
|
||||||
|
}
|
||||||
|
|
||||||
|
var body listPluginsResponse
|
||||||
|
if err := json.NewDecoder(response.Body).Decode(&body); err != nil {
|
||||||
|
return nil, fmt.Errorf("unmarshaling response body: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return only active or enterprise plugins
|
||||||
|
resPlugins := make(map[string]Plugin, len(body.Items))
|
||||||
|
for _, plugin := range body.Items {
|
||||||
|
if plugin.Status == "active" || plugin.Status == "enterprise" {
|
||||||
|
resPlugins[plugin.Slug] = plugin
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return resPlugins, nil
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user