​
Select Service
ves-io-schema-endpoint-API-Create
Published April 5, 2023 | Last modified June 17, 2026
Examples of creating endpoint
Usecase:
Create productpage endpoint
Request using vesctl:
vesctl configuration create endpoint -i endpoint.yaml
where file endpoint.yaml has following contents (endpoint.CreateRequest):
RequestJSON:
{ "metadata": { "name": "productpage-endpoint", "namespace": "documentation" }, "spec": { "where": { "virtual_site": { "ref": [ { "kind": "virtual_site", "tenant": "acmecorp", "namespace": "documentation", "name": "acmecorp-vsite" } ] } }, "protocol": "TCP", "port": 9080, "service_info": { "discovery_type": "K8S", "service_name": "productpage" } }}vesctl yaml response:
ResponseJSON:
{ "metadata": { "name": "productpage-endpoint", "namespace": "documentation", "labels": {}, "annotations": {}, "description": "", "disable": false }, "system_metadata": { "uid": "2e5765dc-c8a2-4048-bd8f-51ab405ee062", "creation_timestamp": "2026-04-13T01:59:27.976596Z", "deletion_timestamp": null, "modification_timestamp": null, "initializers": null, "finalizers": [], "tenant": "acmecorp", "creator_class": "examplesvc", "creator_id": "examplesvc", "object_index": 0, "owner_view": null, "labels": {} }, "spec": { "where": { "virtual_site": { "ref": [ { "kind": "virtual_site", "uid": "ffffffff-ffff-ffff-ffff-ffffffffffff", "tenant": "acmecorp", "namespace": "documentation", "name": "acmecorp-vsite" } ], "network_type": "VIRTUAL_NETWORK_SITE_LOCAL", "disable_internet_vip": {}, "refs": [] } }, "protocol": "TCP", "port": 9080, "health_check_port": 0, "service_info": { "discovery_type": "K8S", "service_name": "productpage" }, "snat_pool": null }}Request using curl:
curl -X 'POST' -d '{"metadata":{"name":"productpage-endpoint","namespace":"documentation"},"spec":{"where":{"virtual_site":{"ref":[{"kind":"virtual_site","tenant":"acmecorp","namespace":"documentation","name":"acmecorp-vsite"}]}},"protocol":"TCP","port":9080,"service_info":{"discovery_type":"K8S","service_name":"productpage"}}}' -H 'Content-Type: application/json' -H 'X-Volterra-Useragent: v1/pgm=_var_folders_q2_3kp8z3zs0x5_m7pk1bgb0_ph0000gp_T_go-build1414723615_b001_apidocs.test/host=MTY6VVHQPH/svc=S:examplesvc/site=mytestce01' 'https://acmecorp.console.ves.volterra.io/api/config/namespaces/documentation/endpoints'curl response:
HTTP/1.1 200 OKContent-Length: 1253Content-Type: application/jsonDate: Mon, 13 Apr 2026 01:59:27 GMTVary: Accept-Encoding
{ "metadata": { "name": "productpage-endpoint", "namespace": "documentation", "labels": { }, "annotations": { }, "description": "", "disable": false }, "system_metadata": { "uid": "2e5765dc-c8a2-4048-bd8f-51ab405ee062", "creation_timestamp": "2026-04-13T01:59:27.976596Z", "deletion_timestamp": null, "modification_timestamp": null, "initializers": null, "finalizers": [ ], "tenant": "acmecorp", "creator_class": "examplesvc", "creator_id": "examplesvc", "object_index": 0, "owner_view": null, "labels": { } }, "spec": { "where": { "virtual_site": { "ref": [ { "kind": "virtual_site", "uid": "ffffffff-ffff-ffff-ffff-ffffffffffff", "tenant": "acmecorp", "namespace": "documentation", "name": "acmecorp-vsite" } ], "network_type": "VIRTUAL_NETWORK_SITE_LOCAL", "disable_internet_vip": {
}, "refs": [ ] } }, "protocol": "TCP", "port": 9080, "health_check_port": 0, "service_info": { "discovery_type": "K8S", "service_name": "productpage" }, "snat_pool": null }}