dotcloud/docker

View on GitHub
client/secret_inspect.go

Summary

Maintainability
A
35 mins
Test Coverage
package client // import "github.com/docker/docker/client"

import (
    "bytes"
    "context"
    "encoding/json"
    "io"

    "github.com/docker/docker/api/types/swarm"
)

// SecretInspectWithRaw returns the secret information with raw data
func (cli *Client) SecretInspectWithRaw(ctx context.Context, id string) (swarm.Secret, []byte, error) {
    if err := cli.NewVersionError(ctx, "1.25", "secret inspect"); err != nil {
        return swarm.Secret{}, nil, err
    }
    if id == "" {
        return swarm.Secret{}, nil, objectNotFoundError{object: "secret", id: id}
    }
    resp, err := cli.get(ctx, "/secrets/"+id, nil, nil)
    defer ensureReaderClosed(resp)
    if err != nil {
        return swarm.Secret{}, nil, err
    }

    body, err := io.ReadAll(resp.body)
    if err != nil {
        return swarm.Secret{}, nil, err
    }

    var secret swarm.Secret
    rdr := bytes.NewReader(body)
    err = json.NewDecoder(rdr).Decode(&secret)

    return secret, body, err
}