forked from SchemaStore/schemastore
-
Notifications
You must be signed in to change notification settings - Fork 0
/
chart.json
232 lines (232 loc) · 11.6 KB
/
chart.json
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
{
"$id": "https://json.schemastore.org/chart.json",
"$schema": "http://json-schema.org/draft-07/schema#",
"additionalProperties": false,
"properties": {
"apiVersion": {
"description": "The apiVersion field should be v2 for Helm charts that require at least Helm 3. Charts supporting previous Helm versions have an apiVersion set to v1 and are still installable by Helm 3.",
"enum": ["v1", "v2"]
},
"name": {
"description": "The name of the chart",
"type": "string"
},
"version": {
"description": "A SemVer 2 version",
"type": "string"
},
"kubeVersion": {
"description": "The optional kubeVersion field can define semver constraints on supported Kubernetes versions. Helm will validate the version constraints when installing the chart and fail if the cluster runs an unsupported Kubernetes version.",
"type": "string"
},
"description": {
"description": "A single-sentence description of this project",
"type": "string"
},
"type": {
"description": "The type of the chart",
"default": "application",
"enum": ["application", "library"]
},
"keywords": {
"type": "array",
"description": "A list of keywords about this project",
"items": {
"type": "string"
}
},
"home": {
"description": "The URL of this projects home page",
"type": "string",
"format": "uri"
},
"sources": {
"type": "array",
"description": "A list of URLs to source code for this project",
"items": {
"type": "string",
"format": "uri"
}
},
"dependencies": {
"type": "array",
"description": "In Helm, one chart may depend on any number of other charts. These dependencies can be dynamically linked using the dependencies field in Chart.yaml or brought in to the charts/ directory and managed manually.\nThe charts required by the current chart are defined as a list in the dependencies field.",
"items": {
"type": "object",
"additionalProperties": false,
"required": ["name"],
"properties": {
"name": {
"description": "The name of the chart",
"type": "string"
},
"version": {
"description": "The version of the chart",
"type": "string"
},
"repository": {
"description": "The repository URL or alias",
"anyOf": [
{
"type": "string",
"format": "uri"
},
{
"type": "string",
"pattern": "^@"
}
]
},
"condition": {
"description": "A yaml path that resolves to a boolean, used for enabling/disabling charts",
"type": "string"
},
"tags": {
"description": "Tags can be used to group charts for enabling/disabling together",
"type": "array",
"items": {
"type": "string"
}
},
"import-values": {
"description": "ImportValues holds the mapping of source values to parent key to be imported. Each item can be a string or pair of child/parent sublist items.",
"type": "array",
"items": {
"oneOf": [
{
"type": "string"
},
{
"type": "object",
"additionalProperties": false,
"required": ["parent", "child"],
"properties": {
"parent": {
"description": "The destination path in the parent chart's values",
"type": "string"
},
"child": {
"description": "The source key of the values to be imported",
"type": "string"
}
}
}
]
}
},
"alias": {
"description": "Alias to be used for the chart. Useful when you have to add the same chart multiple times",
"type": "string"
}
}
}
},
"maintainers": {
"type": "array",
"items": {
"type": "object",
"additionalProperties": false,
"required": ["name"],
"properties": {
"name": {
"description": "The maintainers name",
"type": "string"
},
"email": {
"description": "The maintainers email",
"type": "string",
"format": "email"
},
"url": {
"description": "A URL for the maintainer",
"type": "string",
"format": "uri"
}
}
}
},
"icon": {
"description": "A URL to an SVG or PNG image to be used as an icon",
"type": "string",
"format": "uri"
},
"appVersion": {
"description": "Note that the appVersion field is not related to the version field. It is a way of specifying the version of the application. For example, the drupal chart may have an appVersion: \"8.2.1\", indicating that the version of Drupal included in the chart (by default) is 8.2.1. This field is informational, and has no impact on chart version calculations. Wrapping the version in quotes is highly recommended. It forces the YAML parser to treat the version number as a string. Leaving it unquoted can lead to parsing issues in some cases. For example, YAML interprets 1.0 as a floating point value, and a git commit SHA like 1234e10 as scientific notation.",
"type": "string"
},
"deprecated": {
"description": "When managing charts in a Chart Repository, it is sometimes necessary to deprecate a chart. The optional deprecated field in Chart.yaml can be used to mark a chart as deprecated. If the latest version of a chart in the repository is marked as deprecated, then the chart as a whole is considered to be deprecated. The chart name can be later reused by publishing a newer version that is not marked as deprecated.",
"type": "boolean"
},
"annotations": {
"description": "A list of annotations keyed by name",
"type": "object",
"additionalProperties": {
"type": "string"
},
"properties": {
"artifacthub.io/changes": {
"description": "This annotation is used to provide some details about the changes introduced by a given chart version. Artifact Hub can generate and display a ChangeLog based on the entries in the changes field in all your chart versions.\nThis annotation can be provided using two different formats: using a plain list of strings with the description of the change or using a list of objects with some extra structured information (see example below). Please feel free to use the one that better suits your needs. The UI experience will be slightly different depending on the choice. When using the list of objects option the valid supported kinds are added, changed, deprecated, removed, fixed and security.",
"type": "string"
},
"artifacthub.io/containsSecurityUpdates": {
"description": "Use this annotation to indicate that this chart version contains security updates. When a package release contains security updates, a special message will be displayed in the Artifact Hub UI as well as in the new release email notification.",
"enum": ["true", "false"]
},
"artifacthub.io/crds": {
"description": "By default, Artifact Hub will try to extract the containers images used by Helm charts from the manifests generated from a dry-run install using the default values. If you prefer, you can also provide a list of containers images manually by using this annotation.\nContainers images will be scanned for security vulnerabilities. The security report generated will be available in the package detail view. It is possible to whitelist images so that they are not scanned by setting the whitelisted flag to true.",
"type": "string"
},
"artifacthub.io/images": {
"description": "This annotation can be used to list the operator's CRDs. They will be visible in the package's detail view as cards.",
"type": "string"
},
"artifacthub.io/crdsExamples": {
"description": "Use this annotation to provide a list of example CRs for the operator's CRDs. Each of the examples can be opened from the corresponding CRD card in the package's detail view.",
"type": "string"
},
"artifacthub.io/license": {
"description": "Use this annotation to indicate the chart's license. By default, Artifact Hub tries to read the chart's license from the LICENSE file in the chart, but it's possible to override or provide it with this annotation. It must be a valid SPDX identifier.",
"type": "string"
},
"artifacthub.io/links": {
"description": "This annotation allows including named links, which will be rendered nicely in Artifact Hub. You can use this annotation to include links not included previously in the Chart.yaml file, or you can use it to name links already present (in the sources section, for example).",
"type": "string"
},
"artifacthub.io/maintainers": {
"description": "This annotation can be used if you want to display a different name for a given user in Artifact Hub than the one used in the Chart.yaml file. If the email used matches, the name used in the annotations entry will be displayed in Artifact Hub. It's also possible to include maintainers that should only be listed in Artifact Hub by adding additional entries.",
"type": "string"
},
"artifacthub.io/operator": {
"description": "Use this annotation to indicate that your chart represents an operator. Artifact Hub at the moment also considers your chart to represent an operator if the word operator appears in the chart name.",
"enum": ["true", "false"]
},
"artifacthub.io/operatorCapabilities": {
"description": "Use this annotation to indicate the capabilities of the operator your chart provides. It must be one of the following options: Basic Install, Seamless Upgrades, Full Lifecycle, Deep Insights or Auto Pilot. For more information please see the capability level diagram.",
"enum": [
"Basic Install",
"Seamless Upgrades",
"Full Lifecycle",
"Deep Insights",
"Auto Pilot"
]
},
"artifacthub.io/prerelease": {
"description": "Use this annotation to indicate that this chart version is a pre-release. This status will be displayed in the UI's package view, as well as in new releases notifications emails.",
"enum": ["true", "false"]
},
"artifacthub.io/recommendations": {
"description": "This annotation allows recommending other related packages. Recommended packages will be featured in the package detail view in Artifact Hub.",
"type": "string"
},
"artifacthub.io/signKey": {
"description": "This annotation can be used to provide some information about the key used to sign a given chart version. This information will be displayed on the Artifact Hub UI, making it easier for users to get the information they need to verify the integrity and origin of your chart. The url field indicates where users can find the public key and it is mandatory when a sign key entry is provided.",
"type": "string"
}
}
}
},
"required": ["apiVersion", "name", "version"],
"title": "Helm Chart.yaml",
"type": "object"
}