-
Notifications
You must be signed in to change notification settings - Fork 5
/
blob.go
121 lines (104 loc) · 3.31 KB
/
blob.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// Copyright © 2018 SENETAS SECURITY PTY LTD
//
// Licensed 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 distribution
import (
"io"
"os"
digest "github.com/opencontainers/go-digest"
"github.com/Senetas/crypto-cli/crypto"
)
// Blob represents an entry for a blob in the image manifest
type Blob interface {
GetMediaType() string
GetDigest() digest.Digest
GetSize() int64
GetFilename() string
SetFilename(filename string)
ReadCloser() (io.ReadCloser, error)
}
// NoncryptedBlob is a vanilla blob with no encryption data
// Despite appearnces, the MediaType type is not indicative of whether
// the blob is compressed or not
type NoncryptedBlob struct {
MediaType string `json:"mediaType"`
Size int64 `json:"size"`
Digest digest.Digest `json:"digest"`
Filename string `json:"-"`
}
// GetDigest returnts the digest
func (b *NoncryptedBlob) GetDigest() digest.Digest { return b.Digest }
//GetMediaType returns the content type
func (b *NoncryptedBlob) GetMediaType() string { return b.MediaType }
// GetSize returns the size
func (b *NoncryptedBlob) GetSize() int64 { return b.Size }
// SetFilename set the filename of the file that the blob is stored in
func (b *NoncryptedBlob) SetFilename(filename string) { b.Filename = filename }
// GetFilename retun the filename of the file that the blob is stored in
func (b *NoncryptedBlob) GetFilename() string { return b.Filename }
// ReadCloser opens the file that backs the blob and returns a handle to it
// It is the user's responsibility to close the file handle
func (b *NoncryptedBlob) ReadCloser() (io.ReadCloser, error) { return os.Open(b.Filename) }
func newPlainBlob(
filename string,
d digest.Digest,
size int64,
mediaType string,
) *NoncryptedBlob {
return &NoncryptedBlob{
Size: size,
Digest: d,
MediaType: mediaType,
Filename: filename,
}
}
// NewConfig creates a new blob for a config
func NewConfig(
filename string,
d digest.Digest,
size int64,
dec *crypto.DeCrypto,
) DecryptedBlob {
return &decryptedConfig{
NoncryptedBlob: newPlainBlob(filename, d, size, MediaTypeImageConfig),
DeCrypto: dec,
}
}
// NewLayer creates a new LayerJSON for a data layer
func NewLayer(
filename string,
d digest.Digest,
size int64,
dec *crypto.DeCrypto,
) DecryptedBlob {
return &decryptedBlob{
NoncryptedBlob: newPlainBlob(filename, d, size, MediaTypeLayer),
DeCrypto: dec,
}
}
// NewPlainLayer creates a new LayerJSON for an unencrypted data layer
func NewPlainLayer(
filename string,
d digest.Digest,
size int64,
) DecompressedBlob {
return newPlainBlob(filename, d, size, MediaTypeLayer)
}
// NewPlainConfig creates a new LayerJSON for an unencrypted data layer
func NewPlainConfig(
filename string,
d digest.Digest,
size int64,
) DecompressedBlob {
return newPlainBlob(filename, d, size, MediaTypeImageConfig)
}