Add JSON schema generation for kubeconform CRD validation
ci/woodpecker/pr/kubeconform Pipeline failed
ci/woodpecker/pr/pre-commit Pipeline was successful

- ci/generate-schemas.sh extracts schemas from live cluster CRDs via kubectl
- Generated schemas committed to schemas/ for CI use
- Run `make schemas` to regenerate after CRD or K8s version changes
- validate-apps.sh and validate-clusters.sh check local schemas first
- Remove all kubeconform skip lists — all resource types now have schemas
This commit is contained in:
2026-06-28 16:53:11 +10:00
parent cfca1e5278
commit 041016fc80
264 changed files with 142907 additions and 2 deletions
@@ -0,0 +1,235 @@
{
"$schema": "http://json-schema.org/draft-07/schema#",
"properties": {
"apiVersion": {
"type": "string"
},
"kind": {
"type": "string"
},
"metadata": {
"type": "object"
},
"spec": {
"properties": {
"clusterName": {
"nullable": true,
"type": "string"
},
"template": {
"properties": {
"spec": {
"properties": {
"accessKey": {
"nullable": true,
"type": "string"
},
"ami": {
"nullable": true,
"type": "string"
},
"blockDurationMinutes": {
"nullable": true,
"type": "string"
},
"common": {
"properties": {
"cloudCredentialSecretName": {
"maxLength": 317,
"nullable": true,
"type": "string"
},
"labels": {
"additionalProperties": {
"type": "string"
},
"nullable": true,
"type": "object"
},
"taints": {
"items": {
"properties": {
"effect": {
"type": "string"
},
"key": {
"type": "string"
},
"timeAdded": {
"format": "date-time",
"type": "string"
},
"value": {
"type": "string"
}
},
"required": [
"effect",
"key"
],
"type": "object"
},
"nullable": true,
"type": "array"
}
},
"type": "object"
},
"deviceName": {
"nullable": true,
"type": "string"
},
"enablePrimaryIpv6": {
"type": "boolean"
},
"encryptEbsVolume": {
"type": "boolean"
},
"endpoint": {
"nullable": true,
"type": "string"
},
"httpEndpoint": {
"nullable": true,
"type": "string"
},
"httpProtocolIpv6": {
"nullable": true,
"type": "string"
},
"httpTokens": {
"nullable": true,
"type": "string"
},
"iamInstanceProfile": {
"nullable": true,
"type": "string"
},
"insecureTransport": {
"type": "boolean"
},
"instanceType": {
"nullable": true,
"type": "string"
},
"ipv6AddressCount": {
"nullable": true,
"type": "string"
},
"ipv6AddressOnly": {
"type": "boolean"
},
"keypairName": {
"nullable": true,
"type": "string"
},
"kmsKey": {
"nullable": true,
"type": "string"
},
"monitoring": {
"type": "boolean"
},
"openPort": {
"items": {
"nullable": true,
"type": "string"
},
"nullable": true,
"type": "array"
},
"privateAddressOnly": {
"type": "boolean"
},
"providerID": {
"nullable": true,
"type": "string"
},
"region": {
"nullable": true,
"type": "string"
},
"requestSpotInstance": {
"type": "boolean"
},
"retries": {
"nullable": true,
"type": "string"
},
"rootSize": {
"nullable": true,
"type": "string"
},
"secretKey": {
"nullable": true,
"type": "string"
},
"securityGroup": {
"items": {
"nullable": true,
"type": "string"
},
"nullable": true,
"type": "array"
},
"securityGroupReadonly": {
"type": "boolean"
},
"sessionToken": {
"nullable": true,
"type": "string"
},
"spotPrice": {
"nullable": true,
"type": "string"
},
"sshKeyContents": {
"nullable": true,
"type": "string"
},
"sshUser": {
"nullable": true,
"type": "string"
},
"subnetId": {
"nullable": true,
"type": "string"
},
"tags": {
"nullable": true,
"type": "string"
},
"useEbsOptimizedInstance": {
"type": "boolean"
},
"usePrivateAddress": {
"type": "boolean"
},
"userdata": {
"nullable": true,
"type": "string"
},
"volumeType": {
"nullable": true,
"type": "string"
},
"vpcId": {
"nullable": true,
"type": "string"
},
"zone": {
"nullable": true,
"type": "string"
}
},
"type": "object"
}
},
"type": "object"
}
},
"type": "object"
}
},
"type": "object"
}