ves-io-schema-api_credential-CustomAPI-Renew

Examples of performing api_credential CustomAPI Renew

Usecase:

Create API Token for user-1 of acmecorp

Request:

Request using vesctl:

vesctl request rpc api_credential.CustomAPI.Renew -i request.yaml --uri /public/namespaces/system/api_credentials --http-method POST

where file request.yaml has following contents:

expirationTimestamp: "2021-08-03T08:06:27.207787662Z"
name: user-1-token-2
spec:
  type: API_TOKEN

vesctl yaml response:

{}

Request using curl:

curl -X 'POST' -d '{"name":"user-1-token-2","spec":{"type":"API_TOKEN"},"expirationTimestamp":"2021-08-03T08:06:27.207787662Z"}' -H 'Content-Type: application/json' -H 'X-Volterra-Useragent: v1/pgm=_tmp_go-build381173587_b001_apidocs.test/host=docker-desktop' 'https://acmecorp.console.ves.volterra.io/api/web/namespaces/system/api_credentials'

curl response:

HTTP/1.1 200 OK
Content-Length: 30
Content-Type: application/json
Date: Wed, 14 Jul 2021 08:06:34 GMT
Vary: Accept-Encoding

{
  "data": "",
  "name": ""
}

Usecase:

Renew above api credential object with new expiry

Request:

Request using vesctl:

vesctl request rpc api_credential.CustomAPI.Renew -i request.yaml --uri /public/namespaces/system/renew/api_credentials --http-method POST

where file request.yaml has following contents:

expirationTimestamp: "2021-08-23T08:06:27.207788212Z"
name: user-1-token-2-396f90e7-37a2-489f-8f2d-138c2124833c

vesctl yaml response:

{}

Request using curl:

curl -X 'POST' -d '{"name":"user-1-token-2-396f90e7-37a2-489f-8f2d-138c2124833c","expirationTimestamp":"2021-08-23T08:06:27.207788212Z"}' -H 'Content-Type: application/json' -H 'X-Volterra-Useragent: v1/pgm=_tmp_go-build381173587_b001_apidocs.test/host=docker-desktop' 'https://acmecorp.console.ves.volterra.io/api/web/namespaces/system/renew/api_credentials'

curl response:

HTTP/1.1 200 OK
Content-Length: 21
Content-Type: application/json
Date: Wed, 14 Jul 2021 08:06:34 GMT
Vary: Accept-Encoding

{
  "status": false
}