ves-io-schema-network_policy_rule-API-Create

Examples of creating network_policy_rule

Usecase:

Create network-policy-rule-1

Request using vesctl:

vesctl configuration create network_policy_rule -i network_policy_rule.yaml

where file network_policy_rule.yaml has following contents (network_policy_rule.CreateRequest):

RequestJSON:

          {
    "metadata": {
        "name": "network-policy-rule-1",
        "namespace": "documentation"
    },
    "spec": {
        "action": "ALLOW",
        "ports": [
            "80"
        ],
        "protocol": "TCP",
        "prefix_selector": {
            "expressions": [
                "app == web"
            ]
        },
        "label_matcher": {
            "keys": [
                "app"
            ]
        }
    }
}
        

vesctl yaml response:

ResponseJSON:

          {
    "metadata": {
        "name": "network-policy-rule-1",
        "namespace": "documentation",
        "labels": {},
        "annotations": {},
        "description": "",
        "disable": false
    },
    "system_metadata": {
        "uid": "91c043bc-86b9-48cd-9370-1d30c8a057a3",
        "creation_timestamp": "2024-03-21T14:06:18.458072Z",
        "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": {
        "action": "ALLOW",
        "ports": [
            "80"
        ],
        "protocol": "TCP",
        "prefix_selector": {
            "expressions": [
                "app == web"
            ]
        },
        "label_matcher": {
            "keys": [
                "app"
            ]
        },
        "advanced_action": null
    }
}
        

Request using curl:

          curl -X 'POST' -d '{"metadata":{"name":"network-policy-rule-1","namespace":"documentation"},"spec":{"action":"ALLOW","ports":["80"],"protocol":"TCP","prefix_selector":{"expressions":["app == web"]},"label_matcher":{"keys":["app"]}}}' -H 'Content-Type: application/json' -H 'X-Volterra-Useragent: v1/pgm=_var_folders_2__8qnt6fwd5dvglr1xqq6l8b7w0000gp_T_go-build3109416560_b001_apidocs.test/host=C02FN35BMD6R/svc=S:examplesvc/site=mytestce01' 'https://acmecorp.console.ves.volterra.io/api/config/namespaces/documentation/network_policy_rules'
        

curl response:

          HTTP/1.1 200 OK
Content-Length: 884
Content-Type: application/json
Date: Thu, 21 Mar 2024 14:06:18 GMT
Vary: Accept-Encoding

{
  "metadata": {
    "name": "network-policy-rule-1",
    "namespace": "documentation",
    "labels": {
    },
    "annotations": {
    },
    "description": "",
    "disable": false
  },
  "system_metadata": {
    "uid": "91c043bc-86b9-48cd-9370-1d30c8a057a3",
    "creation_timestamp": "2024-03-21T14:06:18.458072Z",
    "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": {
    "action": "ALLOW",
    "ports": [
      "80"
    ],
    "protocol": "TCP",
    "prefix_selector": {
      "expressions": [
        "app == web"
      ]
    },
    "label_matcher": {
      "keys": [
        "app"
      ]
    },
    "advanced_action": null
  }
}