mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
210 lines
4.4 KiB
Go
210 lines
4.4 KiB
Go
|
package schema
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"npm/internal/entity/certificate"
|
||
|
)
|
||
|
|
||
|
// This validation is strictly for Custom certificates
|
||
|
// and the combination of values that must be defined
|
||
|
func createCertificateCustom() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"required": [
|
||
|
"type",
|
||
|
"name",
|
||
|
"domain_names"
|
||
|
],
|
||
|
"properties": {
|
||
|
"type": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, strictString("custom"), stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
// This validation is strictly for HTTP certificates
|
||
|
// and the combination of values that must be defined
|
||
|
func createCertificateHTTP() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"required": [
|
||
|
"type",
|
||
|
"certificate_authority_id",
|
||
|
"name",
|
||
|
"domain_names"
|
||
|
],
|
||
|
"properties": {
|
||
|
"type": %s,
|
||
|
"certificate_authority_id": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
},
|
||
|
"is_ecc": {
|
||
|
"type": "integer",
|
||
|
"minimum": 0,
|
||
|
"maximum": 1
|
||
|
}
|
||
|
}
|
||
|
}`, strictString("http"), intMinOne, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
// This validation is strictly for DNS certificates
|
||
|
// and the combination of values that must be defined
|
||
|
func createCertificateDNS() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"required": [
|
||
|
"type",
|
||
|
"certificate_authority_id",
|
||
|
"dns_provider_id",
|
||
|
"name",
|
||
|
"domain_names"
|
||
|
],
|
||
|
"properties": {
|
||
|
"type": %s,
|
||
|
"certificate_authority_id": %s,
|
||
|
"dns_provider_id": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
},
|
||
|
"is_ecc": {
|
||
|
"type": "integer",
|
||
|
"minimum": 0,
|
||
|
"maximum": 1
|
||
|
}
|
||
|
}
|
||
|
}`, strictString("dns"), intMinOne, intMinOne, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
// This validation is strictly for MKCERT certificates
|
||
|
// and the combination of values that must be defined
|
||
|
func createCertificateMkcert() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"required": [
|
||
|
"type",
|
||
|
"name",
|
||
|
"domain_names"
|
||
|
],
|
||
|
"properties": {
|
||
|
"type": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, strictString("mkcert"), stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
func updateCertificateHTTP() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"minProperties": 1,
|
||
|
"properties": {
|
||
|
"certificate_authority_id": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, intMinOne, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
func updateCertificateDNS() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"minProperties": 1,
|
||
|
"properties": {
|
||
|
"certificate_authority_id": %s,
|
||
|
"dns_provider_id": %s,
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, intMinOne, intMinOne, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
func updateCertificateCustom() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"minProperties": 1,
|
||
|
"properties": {
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
func updateCertificateMkcert() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"type": "object",
|
||
|
"additionalProperties": false,
|
||
|
"minProperties": 1,
|
||
|
"properties": {
|
||
|
"name": %s,
|
||
|
"domain_names": %s,
|
||
|
"meta": {
|
||
|
"type": "object"
|
||
|
}
|
||
|
}
|
||
|
}`, stringMinMax(1, 100), domainNames())
|
||
|
}
|
||
|
|
||
|
// CreateCertificate is the schema for incoming data validation
|
||
|
func CreateCertificate() string {
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"oneOf": [%s, %s, %s, %s]
|
||
|
}`, createCertificateHTTP(), createCertificateDNS(), createCertificateCustom(), createCertificateMkcert())
|
||
|
}
|
||
|
|
||
|
// UpdateCertificate is the schema for incoming data validation
|
||
|
func UpdateCertificate(certificateType string) string {
|
||
|
switch certificateType {
|
||
|
case certificate.TypeHTTP:
|
||
|
return updateCertificateHTTP()
|
||
|
case certificate.TypeDNS:
|
||
|
return updateCertificateDNS()
|
||
|
case certificate.TypeCustom:
|
||
|
return updateCertificateCustom()
|
||
|
case certificate.TypeMkcert:
|
||
|
return updateCertificateMkcert()
|
||
|
default:
|
||
|
return fmt.Sprintf(`
|
||
|
{
|
||
|
"oneOf": [%s, %s, %s, %s]
|
||
|
}`, updateCertificateHTTP(), updateCertificateDNS(), updateCertificateCustom(), updateCertificateMkcert())
|
||
|
}
|
||
|
}
|