pkg/graphql/client/client.go (39 lines of code) (raw):
// 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"
)
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))
}
client := graphql.NewClient(ctx.Value(contextkey.BaseURL{}).(string), 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 := ctx.Value(contextkey.Username{}).(string)
password := ctx.Value(contextkey.Password{}).(string)
authorization := ctx.Value(contextkey.Authorization{}).(string)
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
}