mirror of
https://github.com/moby/moby.git
synced 2026-01-11 10:41:43 +00:00
These fields store the raw JSON data that we received, and should
never container bytes that are non-JSON (as we'd error out when
failing to unmarshal).
Change the type to a json.RawMessage, which:
- Is more explicit on intent
- Can still be used as a regular []byte in all cases
And, while it's not expected to be marshaled to JSON, doing so will also
print the output in a readable format instead of base64 encoding;
package main
import (
"encoding/json"
"fmt"
)
func main() {
foo := struct {
Bytes []byte
Raw json.RawMessage
}{
Bytes: []byte(`{"hello": "world"}`),
Raw: json.RawMessage(`{"hello": "world"}`),
}
out, _ := json.MarshalIndent(foo, "", " ")
fmt.Println(string(out))
}
Will print:
{
"Bytes": "eyJoZWxsbyI6ICJ3b3JsZCJ9",
"Raw": {
"hello": "world"
}
}
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
38 lines
966 B
Go
38 lines
966 B
Go
package client
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
|
|
"github.com/moby/moby/api/types/volume"
|
|
)
|
|
|
|
// VolumeInspectOptions holds options for inspecting a volume.
|
|
type VolumeInspectOptions struct {
|
|
// Add future optional parameters here
|
|
}
|
|
|
|
// VolumeInspectResult holds the result from the [Client.VolumeInspect] method.
|
|
type VolumeInspectResult struct {
|
|
Volume volume.Volume
|
|
Raw json.RawMessage
|
|
}
|
|
|
|
// VolumeInspect returns the information about a specific volume in the docker host.
|
|
func (cli *Client) VolumeInspect(ctx context.Context, volumeID string, options VolumeInspectOptions) (VolumeInspectResult, error) {
|
|
volumeID, err := trimID("volume", volumeID)
|
|
if err != nil {
|
|
return VolumeInspectResult{}, err
|
|
}
|
|
|
|
resp, err := cli.get(ctx, "/volumes/"+volumeID, nil, nil)
|
|
defer ensureReaderClosed(resp)
|
|
if err != nil {
|
|
return VolumeInspectResult{}, err
|
|
}
|
|
|
|
var out VolumeInspectResult
|
|
out.Raw, err = decodeWithRaw(resp, &out.Volume)
|
|
return out, err
|
|
}
|