mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
bb0f4bfa62
* Fix wrapping when too many hosts are shown (#207) * Update npm packages, fixes CVE-2019-10757 * Revert some breaking packages * Major overhaul - Docker buildx support in CI - Cypress API Testing in CI - Restructured folder layout (insert clean face meme) - Added Swagger documentation and validate API against that (to be completed) - Use common base image for all supported archs, which includes updated nginx with ipv6 support - Updated certbot and changes required for it - Large amount of Hosts names will wrap in UI - Updated packages for frontend - Version bump 2.1.0 * Updated documentation * Fix JWT expire time going crazy. Now set to 1day * Backend JS formatting rules * Remove v1 importer, I doubt anyone is using v1 anymore * Added backend formatting rules and enforce them in Jenkins builds * Fix CI, doesn't need a tty * Thanks bcrypt. Why can't you just be normal. * Cleanup after syntax check Co-authored-by: Marcelo Castagna <margaale@users.noreply.github.com>
388 lines
9.9 KiB
JSON
388 lines
9.9 KiB
JSON
{
|
|
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
"$id": "endpoints/proxy-hosts",
|
|
"title": "Proxy Hosts",
|
|
"description": "Endpoints relating to Proxy Hosts",
|
|
"stability": "stable",
|
|
"type": "object",
|
|
"definitions": {
|
|
"id": {
|
|
"$ref": "../definitions.json#/definitions/id"
|
|
},
|
|
"created_on": {
|
|
"$ref": "../definitions.json#/definitions/created_on"
|
|
},
|
|
"modified_on": {
|
|
"$ref": "../definitions.json#/definitions/modified_on"
|
|
},
|
|
"domain_names": {
|
|
"$ref": "../definitions.json#/definitions/domain_names"
|
|
},
|
|
"forward_scheme": {
|
|
"type": "string",
|
|
"enum": ["http", "https"]
|
|
},
|
|
"forward_host": {
|
|
"type": "string",
|
|
"minLength": 1,
|
|
"maxLength": 50
|
|
},
|
|
"forward_port": {
|
|
"type": "integer",
|
|
"minimum": 1,
|
|
"maximum": 65535
|
|
},
|
|
"certificate_id": {
|
|
"$ref": "../definitions.json#/definitions/certificate_id"
|
|
},
|
|
"ssl_forced": {
|
|
"$ref": "../definitions.json#/definitions/ssl_forced"
|
|
},
|
|
"hsts_enabled": {
|
|
"$ref": "../definitions.json#/definitions/hsts_enabled"
|
|
},
|
|
"hsts_subdomains": {
|
|
"$ref": "../definitions.json#/definitions/hsts_subdomains"
|
|
},
|
|
"http2_support": {
|
|
"$ref": "../definitions.json#/definitions/http2_support"
|
|
},
|
|
"block_exploits": {
|
|
"$ref": "../definitions.json#/definitions/block_exploits"
|
|
},
|
|
"caching_enabled": {
|
|
"$ref": "../definitions.json#/definitions/caching_enabled"
|
|
},
|
|
"allow_websocket_upgrade": {
|
|
"description": "Allow Websocket Upgrade for all paths",
|
|
"example": true,
|
|
"type": "boolean"
|
|
},
|
|
"access_list_id": {
|
|
"$ref": "../definitions.json#/definitions/access_list_id"
|
|
},
|
|
"advanced_config": {
|
|
"type": "string"
|
|
},
|
|
"enabled": {
|
|
"$ref": "../definitions.json#/definitions/enabled"
|
|
},
|
|
"meta": {
|
|
"type": "object"
|
|
},
|
|
"locations": {
|
|
"type": "array",
|
|
"minItems": 0,
|
|
"items": {
|
|
"type": "object",
|
|
"required": [
|
|
"forward_scheme",
|
|
"forward_host",
|
|
"forward_port",
|
|
"path"
|
|
],
|
|
"additionalProperties": false,
|
|
"properties": {
|
|
"id": {
|
|
"type": ["integer", "null"]
|
|
},
|
|
"path": {
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"forward_scheme": {
|
|
"$ref": "#/definitions/forward_scheme"
|
|
},
|
|
"forward_host": {
|
|
"$ref": "#/definitions/forward_host"
|
|
},
|
|
"forward_port": {
|
|
"$ref": "#/definitions/forward_port"
|
|
},
|
|
"forward_path": {
|
|
"type": "string"
|
|
},
|
|
"advanced_config": {
|
|
"type": "string"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
"properties": {
|
|
"id": {
|
|
"$ref": "#/definitions/id"
|
|
},
|
|
"created_on": {
|
|
"$ref": "#/definitions/created_on"
|
|
},
|
|
"modified_on": {
|
|
"$ref": "#/definitions/modified_on"
|
|
},
|
|
"domain_names": {
|
|
"$ref": "#/definitions/domain_names"
|
|
},
|
|
"forward_scheme": {
|
|
"$ref": "#/definitions/forward_scheme"
|
|
},
|
|
"forward_host": {
|
|
"$ref": "#/definitions/forward_host"
|
|
},
|
|
"forward_port": {
|
|
"$ref": "#/definitions/forward_port"
|
|
},
|
|
"certificate_id": {
|
|
"$ref": "#/definitions/certificate_id"
|
|
},
|
|
"ssl_forced": {
|
|
"$ref": "#/definitions/ssl_forced"
|
|
},
|
|
"hsts_enabled": {
|
|
"$ref": "#/definitions/hsts_enabled"
|
|
},
|
|
"hsts_subdomains": {
|
|
"$ref": "#/definitions/hsts_subdomains"
|
|
},
|
|
"http2_support": {
|
|
"$ref": "#/definitions/http2_support"
|
|
},
|
|
"block_exploits": {
|
|
"$ref": "#/definitions/block_exploits"
|
|
},
|
|
"caching_enabled": {
|
|
"$ref": "#/definitions/caching_enabled"
|
|
},
|
|
"allow_websocket_upgrade": {
|
|
"$ref": "#/definitions/allow_websocket_upgrade"
|
|
},
|
|
"access_list_id": {
|
|
"$ref": "#/definitions/access_list_id"
|
|
},
|
|
"advanced_config": {
|
|
"$ref": "#/definitions/advanced_config"
|
|
},
|
|
"enabled": {
|
|
"$ref": "#/definitions/enabled"
|
|
},
|
|
"meta": {
|
|
"$ref": "#/definitions/meta"
|
|
},
|
|
"locations": {
|
|
"$ref": "#/definitions/locations"
|
|
}
|
|
},
|
|
"links": [
|
|
{
|
|
"title": "List",
|
|
"description": "Returns a list of Proxy Hosts",
|
|
"href": "/nginx/proxy-hosts",
|
|
"access": "private",
|
|
"method": "GET",
|
|
"rel": "self",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"targetSchema": {
|
|
"type": "array",
|
|
"items": {
|
|
"$ref": "#/properties"
|
|
}
|
|
}
|
|
},
|
|
{
|
|
"title": "Create",
|
|
"description": "Creates a new Proxy Host",
|
|
"href": "/nginx/proxy-hosts",
|
|
"access": "private",
|
|
"method": "POST",
|
|
"rel": "create",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"schema": {
|
|
"type": "object",
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"domain_names",
|
|
"forward_scheme",
|
|
"forward_host",
|
|
"forward_port"
|
|
],
|
|
"properties": {
|
|
"domain_names": {
|
|
"$ref": "#/definitions/domain_names"
|
|
},
|
|
"forward_scheme": {
|
|
"$ref": "#/definitions/forward_scheme"
|
|
},
|
|
"forward_host": {
|
|
"$ref": "#/definitions/forward_host"
|
|
},
|
|
"forward_port": {
|
|
"$ref": "#/definitions/forward_port"
|
|
},
|
|
"certificate_id": {
|
|
"$ref": "#/definitions/certificate_id"
|
|
},
|
|
"ssl_forced": {
|
|
"$ref": "#/definitions/ssl_forced"
|
|
},
|
|
"hsts_enabled": {
|
|
"$ref": "#/definitions/hsts_enabled"
|
|
},
|
|
"hsts_subdomains": {
|
|
"$ref": "#/definitions/hsts_enabled"
|
|
},
|
|
"http2_support": {
|
|
"$ref": "#/definitions/http2_support"
|
|
},
|
|
"block_exploits": {
|
|
"$ref": "#/definitions/block_exploits"
|
|
},
|
|
"caching_enabled": {
|
|
"$ref": "#/definitions/caching_enabled"
|
|
},
|
|
"allow_websocket_upgrade": {
|
|
"$ref": "#/definitions/allow_websocket_upgrade"
|
|
},
|
|
"access_list_id": {
|
|
"$ref": "#/definitions/access_list_id"
|
|
},
|
|
"advanced_config": {
|
|
"$ref": "#/definitions/advanced_config"
|
|
},
|
|
"enabled": {
|
|
"$ref": "#/definitions/enabled"
|
|
},
|
|
"meta": {
|
|
"$ref": "#/definitions/meta"
|
|
},
|
|
"locations": {
|
|
"$ref": "#/definitions/locations"
|
|
}
|
|
}
|
|
},
|
|
"targetSchema": {
|
|
"properties": {
|
|
"$ref": "#/properties"
|
|
}
|
|
}
|
|
},
|
|
{
|
|
"title": "Update",
|
|
"description": "Updates a existing Proxy Host",
|
|
"href": "/nginx/proxy-hosts/{definitions.identity.example}",
|
|
"access": "private",
|
|
"method": "PUT",
|
|
"rel": "update",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"schema": {
|
|
"type": "object",
|
|
"additionalProperties": false,
|
|
"properties": {
|
|
"domain_names": {
|
|
"$ref": "#/definitions/domain_names"
|
|
},
|
|
"forward_scheme": {
|
|
"$ref": "#/definitions/forward_scheme"
|
|
},
|
|
"forward_host": {
|
|
"$ref": "#/definitions/forward_host"
|
|
},
|
|
"forward_port": {
|
|
"$ref": "#/definitions/forward_port"
|
|
},
|
|
"certificate_id": {
|
|
"$ref": "#/definitions/certificate_id"
|
|
},
|
|
"ssl_forced": {
|
|
"$ref": "#/definitions/ssl_forced"
|
|
},
|
|
"hsts_enabled": {
|
|
"$ref": "#/definitions/hsts_enabled"
|
|
},
|
|
"hsts_subdomains": {
|
|
"$ref": "#/definitions/hsts_enabled"
|
|
},
|
|
"http2_support": {
|
|
"$ref": "#/definitions/http2_support"
|
|
},
|
|
"block_exploits": {
|
|
"$ref": "#/definitions/block_exploits"
|
|
},
|
|
"caching_enabled": {
|
|
"$ref": "#/definitions/caching_enabled"
|
|
},
|
|
"allow_websocket_upgrade": {
|
|
"$ref": "#/definitions/allow_websocket_upgrade"
|
|
},
|
|
"access_list_id": {
|
|
"$ref": "#/definitions/access_list_id"
|
|
},
|
|
"advanced_config": {
|
|
"$ref": "#/definitions/advanced_config"
|
|
},
|
|
"enabled": {
|
|
"$ref": "#/definitions/enabled"
|
|
},
|
|
"meta": {
|
|
"$ref": "#/definitions/meta"
|
|
},
|
|
"locations": {
|
|
"$ref": "#/definitions/locations"
|
|
}
|
|
}
|
|
},
|
|
"targetSchema": {
|
|
"properties": {
|
|
"$ref": "#/properties"
|
|
}
|
|
}
|
|
},
|
|
{
|
|
"title": "Delete",
|
|
"description": "Deletes a existing Proxy Host",
|
|
"href": "/nginx/proxy-hosts/{definitions.identity.example}",
|
|
"access": "private",
|
|
"method": "DELETE",
|
|
"rel": "delete",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"targetSchema": {
|
|
"type": "boolean"
|
|
}
|
|
},
|
|
{
|
|
"title": "Enable",
|
|
"description": "Enables a existing Proxy Host",
|
|
"href": "/nginx/proxy-hosts/{definitions.identity.example}/enable",
|
|
"access": "private",
|
|
"method": "POST",
|
|
"rel": "update",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"targetSchema": {
|
|
"type": "boolean"
|
|
}
|
|
},
|
|
{
|
|
"title": "Disable",
|
|
"description": "Disables a existing Proxy Host",
|
|
"href": "/nginx/proxy-hosts/{definitions.identity.example}/disable",
|
|
"access": "private",
|
|
"method": "POST",
|
|
"rel": "update",
|
|
"http_header": {
|
|
"$ref": "../examples.json#/definitions/auth_header"
|
|
},
|
|
"targetSchema": {
|
|
"type": "boolean"
|
|
}
|
|
}
|
|
]
|
|
}
|