Skip to content

Latest commit

 

History

History
117 lines (89 loc) · 4.75 KB

README.md

File metadata and controls

117 lines (89 loc) · 4.75 KB

ARO-HCP-FRONTEND

Build frontend binary for local testing

make frontend

Run the frontend binary locally (requires a local running CS to fully function)

make run

Build the frontend container

# Note: for testing changes, please use your own registry
# versus pushing images to the DEV ACR
export ARO_HCP_BASE_IMAGE="quay.io/QUAY_USERNAME"
make image

# Push the image to a container registry
make push

# all in one option
export ARO_HCP_BASE_IMAGE="quay.io/QUAY_USERNAME"
make build-push

Run the frontend container

Locally:

docker run -p 8443:8443 aro-hcp-frontend

In Cluster:

make deploy
make undeploy

To create a cluster, follow the instructions in development-setup.md

Available endpoints

Note: If you need a test cluster.json file or node_pool.json for some of the below API calls, you can generate one using utils/create.go go run utils/create.go -type cluster or go run utils/create.go -type node_pool Any Create/Get/Delete cluster calls below will expect a running CS in order to function for now

Update a subscription state (Must be Registered for other calls to function)

curl -X PUT "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000?api-version=2.0" --json '{"state":"Registered", "registrationDate": "now", "properties": { "tenantId": "00000000-0000-0000-0000-000000000000"}}'

List the Operations for the Provider

curl -X GET "localhost:8443/providers/Microsoft.RedHatOpenShift/operations?api-version=2024-06-10-preview"

List HcpOpenShiftVersions Resources by Location

curl -X GET "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/locations/YOUR_LOCATION/providers/Microsoft.RedHatOpenShift/hcpOpenShiftVersions?api-version=2024-06-10-preview"

List HcpOpenShiftClusterResource Resources by Subscription ID

curl -X GET "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters?api-version=2024-06-10-preview"

Get a HcpOpenShiftClusterResource

curl -X GET "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster?api-version=2024-06-10-preview"

Create or Update a HcpOpenShiftClusterResource

curl -X PUT "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster?api-version=2024-06-10-preview" \
  -H "X-Ms-Arm-Resource-System-Data: {\"createdBy\": \"aro-hcp-local-testing\", \"createdByType\": \"User\", \"createdAt\": \"2024-06-06T19:26:56+00:00\"}" \
  -H "X-Ms-Identity-Url": https://dummyhost.identity.azure.net" \
  --json @cluster.json

You will notice that the request contains a X-Ms-Identity-Url with the value https://dummyhost.identity.azure.net. Setting the X-Ms-Identity-Url HTTP header when interacting directly with the Frontend is required. However, for the environments where a real managed identities data plane does not exist the value can be any arbitrary/dummy HTTPS URL that ends in identity.azure.net.

Delete a HcpOpenShiftClusterResource

curl -X DELETE "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster?api-version=2024-06-10-preview"

Execute deployment preflight checks

curl -X POST "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/deployments/YOUR_DEPLOYMENT_NAME/preflight?api-version=2020-06-01" --json preflight.json

Node pool operations:

Create node pool

curl -X PUT "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster/nodePools/dev-nodepool?api-version=2024-06-10-preview" \
  -H "X-Ms-Arm-Resource-System-Data: {\"createdBy\": \"aro-hcp-local-testing\", \"createdByType\": \"User\", \"createdAt\": \"2024-06-06T19:26:56+00:00\"}" --json @node_pool.json

Get node pool

curl "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster/nodePools/dev-nodepool?api-version=2024-06-10-preview"

Delete node pool

curl -X DELETE "localhost:8443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-test-rg/providers/Microsoft.RedHatOpenShift/hcpOpenShiftClusters/dev-test-cluster/nodePools/dev-nodepool?api-version=2024-06-10-preview"