blob: a2ad60a6cfb3ff5dbfc322315eb9e64906697e80 [file] [log] [blame]
// Licensed to Apache Software Foundation (ASF) under one or more contributor
// license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright
// ownership. Apache Software Foundation (ASF) licenses this file to you 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 client
import (
"context"
"crypto/tls"
"encoding/base64"
"net/http"
"github.com/machinebox/graphql"
"github.com/apache/skywalking-cli/pkg/contextkey"
"github.com/apache/skywalking-cli/pkg/logger"
)
// newClient creates a new GraphQL client with configuration from context.
func newClient(ctx context.Context) *graphql.Client {
options := []graphql.ClientOption{}
insecure := ctx.Value(contextkey.Insecure{}).(bool)
if insecure {
customTransport := http.DefaultTransport.(*http.Transport).Clone()
customTransport.TLSClientConfig = &tls.Config{InsecureSkipVerify: insecure} // #nosec G402
httpClient := &http.Client{Transport: customTransport}
options = append(options, graphql.WithHTTPClient(httpClient))
}
baseURL := getValue(ctx, contextkey.BaseURL{}, "http://127.0.0.1:12800/graphql")
client := graphql.NewClient(baseURL, options...)
client.Log = func(msg string) {
logger.Log.Debugln(msg)
}
return client
}
// ExecuteQuery executes the `request` and parse to the `response`, returning `error` if there is any.
func ExecuteQuery(ctx context.Context, request *graphql.Request, response any) error {
username := getValue(ctx, contextkey.Username{}, "")
password := getValue(ctx, contextkey.Password{}, "")
authorization := getValue(ctx, contextkey.Authorization{}, "")
if authorization == "" && username != "" && password != "" {
authorization = "Basic " + base64.StdEncoding.EncodeToString([]byte(username+":"+password))
}
if authorization != "" {
request.Header.Set("Authorization", authorization)
}
client := newClient(ctx)
err := client.Run(ctx, request, response)
return err
}
// getValue safely extracts a value from the context.
func getValue[T any](ctx context.Context, key any, defaultValue T) T {
val := ctx.Value(key)
if v, ok := val.(T); ok {
return v
}
return defaultValue
}