-
Notifications
You must be signed in to change notification settings - Fork 261
Expand file tree
/
Copy pathIndex.swift
More file actions
64 lines (54 loc) · 2.96 KB
/
Index.swift
File metadata and controls
64 lines (54 loc) · 2.96 KB
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
//===----------------------------------------------------------------------===//
// Copyright © 2025-2026 Apple Inc. and the Containerization project authors.
//
// 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
//
// https://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.
//===----------------------------------------------------------------------===//
// Source: https://github.com/opencontainers/image-spec/blob/main/specs-go/v1/index.go
import Foundation
/// Index references manifests for various platforms.
/// This structure provides `application/vnd.oci.image.index.v1+json` mediatype when marshalled to JSON.
public struct Index: Codable, Sendable {
/// schemaVersion is the image manifest schema that this image follows
public let schemaVersion: Int
/// mediaType specifies the type of this document data structure e.g. `application/vnd.oci.image.index.v1+json`
/// This field is optional per the OCI Image Index Specification (omitempty)
public let mediaType: String
/// manifests references platform specific manifests.
public var manifests: [Descriptor]
/// annotations contains arbitrary metadata for the image index.
public var annotations: [String: String]?
/// `subject` references another manifest this index is an artifact of.
public let subject: Descriptor?
/// `artifactType` specifies the IANA media type of the artifact this index represents.
public let artifactType: String?
public init(
schemaVersion: Int = 2, mediaType: String = MediaTypes.index, manifests: [Descriptor],
annotations: [String: String]? = nil, subject: Descriptor? = nil, artifactType: String? = nil
) {
self.schemaVersion = schemaVersion
self.mediaType = mediaType
self.manifests = manifests
self.annotations = annotations
self.subject = subject
self.artifactType = artifactType
}
public init(from decoder: Decoder) throws {
let container = try decoder.container(keyedBy: CodingKeys.self)
self.schemaVersion = try container.decode(Int.self, forKey: .schemaVersion)
self.mediaType = try container.decodeIfPresent(String.self, forKey: .mediaType) ?? ""
self.manifests = try container.decode([Descriptor].self, forKey: .manifests)
self.annotations = try container.decodeIfPresent([String: String].self, forKey: .annotations)
self.subject = try container.decodeIfPresent(Descriptor.self, forKey: .subject)
self.artifactType = try container.decodeIfPresent(String.self, forKey: .artifactType)
}
}