Create a new AppMirror resource for an app
POST /accounts/{account_id}/k8s/v1/apps/{app_id}/appMirrors
Indicates the desired values for the AppMirror API resource to be created.
Parameters
| Name | Type | In | Required | Description | 
|---|---|---|---|---|
| account_id | string | path | True | ID of the containing account resource 
 | 
| app_id | string | path | True | ID of the containing app resource | 
Request Body
Indicates the desired values for the AppMirror API resource to be created.
| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | Media type of the resource. Defined values are: 
 | 
| version | string | True | Version of the resource. Defined values are: 
 | 
| sourceAppID | string | True | Identifier of the source application. Only updated when swapping the sourceAppID with the destinationAppID. Defined values are: 
 | 
| destinationClusterID | string | True | Identifier of the managed cluster to host the destination application. Must be provided on create because it determines what cluster the destination application will be created on. If provided on update, it must match the cluster ID of the destination application, so it can only change when swapping sourceAppID with destinationAppID. Defined values are: 
 | 
| namespaceMapping | array[namespaceMapping] | False | The namespace or namespaces to use when creating the destination application, corresponding to the namespaces of the source application. Each JSON object contains the fields "clusterID" and "namespaces", where the "clusterID" value is the JSON string ID of the source or destination cluster, and the "namespaces" value is a JSON array of JSON strings. There must be exactly one JSON object for each cluster, and the namespaces will be correlated by index. If not provided, the same namespace from the source cluster will be used in the destination cluster. Defined values are: 
 | 
| storageClasses | array[storageClasses] | False | The storage class to be used on the destination cluster when creating new Persistent Volume Claims (PVCs). Each JSON object contains the fields "clusterID" and "storageClassName", where the "clusterID" value is the JSON string ID of the source or destination cluster, and the "storageClassName" is the storage class to use when creating PVCs on that cluster. If not provided or if the value is missing for a cluster, the default storage class will be used for that cluster. Defined values are: 
 | 
| stateDesired | string | True | The desired state for the relationship. At creation, the only valid value is "established". Defined values are: 
 | 
| metadata | False | Client and service-specified metadata associated with the resource. Defined values are: 
 | 
Example request
{
  "type": "application/astra-appMirror",
  "version": "1.0",
  "sourceAppID": "efd639b6-fc92-4112-8841-0c0ab7890ae0",
  "destinationClusterID": "c5d023a9-4061-4a8a-bfbf-3be11ff06226",
  "stateDesired": "established"
}Response
Status: 201, Returns the newly created appMirror resource in the JSON response body.| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | Media type of the resource. Defined values are: 
 | 
| version | string | True | Version of the resource. Defined values are: 
 | 
| id | string | True | Globally unique identifier of the resource. Defined values are: 
 | 
| sourceAppID | string | True | Identifier of the source application. Only updated when swapping the sourceAppID with the destinationAppID. Defined values are: 
 | 
| sourceClusterID | string | True | Identifier of the managed cluster hosting the source application. This field is read-only and is determined based on the host cluster of the source application. If provided in an update, it must match the cluster ID of the source application, so it can only change when swapping the sourceAppID with destinationAppID. Defined values are: 
 | 
| destinationAppID | string | False | Identifier of the destination application. Cannot be provided on create because a new app ID will be generated as part of relationship initialization. Can only be updated when swapping sourceAppID with the destinationAppID. Defined values are: 
 | 
| destinationClusterID | string | True | Identifier of the managed cluster to host the destination application. Must be provided on create because it determines what cluster the destination application will be created on. If provided on update, it must match the cluster ID of the destination application, so it can only change when swapping sourceAppID with destinationAppID. Defined values are: 
 | 
| namespaceMapping | array[namespaceMapping] | False | The namespace or namespaces to use when creating the destination application, corresponding to the namespaces of the source application. Each JSON object contains the fields "clusterID" and "namespaces", where the "clusterID" value is the JSON string ID of the source or destination cluster, and the "namespaces" value is a JSON array of JSON strings. There must be exactly one JSON object for each cluster, and the namespaces will be correlated by index. If not provided, the same namespace from the source cluster will be used in the destination cluster. Defined values are: 
 | 
| storageClasses | array[storageClasses] | False | The storage class to be used on the destination cluster when creating new Persistent Volume Claims (PVCs). Each JSON object contains the fields "clusterID" and "storageClassName", where the "clusterID" value is the JSON string ID of the source or destination cluster, and the "storageClassName" is the storage class to use when creating PVCs on that cluster. If not provided or if the value is missing for a cluster, the default storage class will be used for that cluster. Defined values are: 
 | 
| state | string | True | The state of the relationship. Defined values are: 
 | 
| stateTransitions | array[type_astra_stateTransition] | False | Permitted state transitions. The following state transitions are possible for this resource: 
 | 
| stateDesired | string | True | The desired state for the relationship. At creation, the only valid value is "established". Defined values are: 
 | 
| stateAllowed | array[string] | False | States that can be requested in a given state. The following states can be requested in each defined state: 
 | 
| stateDetails | array[type_astra_stateDetail] | True | Additional details about the current state, including why the current state was reached. If no details are available, this array will be empty. Defined values are: 
 | 
| transferState | string | False | State of the current or most recent snapshot transfer. Defined values are: 
 | 
| transferStateTransitions | array[type_astra_stateTransition] | False | Permitted state transitions from a given defined state. The following state transitions are possible for this resource: 
 | 
| transferStateDetails | array[type_astra_stateDetail] | False | Additional details about the current state including why the current state was reached. If no details are available, this array will be empty. Defined values are: 
 | 
| healthState | string | True | Health state of the resource. Defined values are: 
 | 
| healthStateTransitions | array[type_astra_stateTransition] | True | Permitted state transitions from a given defined state. The following state transitions are possible for this resource: 
 | 
| healthStateDetails | array[type_astra_stateDetail] | True | Additional details about the current state including why the current state was reached. If no details are available, this array will be empty. Defined values are: 
 | 
| metadata | True | Client and service-specified metadata associated with the resource. Defined values are: 
 | 
Example response
{
  "type": "application/astra-appMirror",
  "version": "1.0",
  "id": "c5fbadd4-5d9e-5942-bb7f-f5386b6b6253",
  "sourceAppID": "efd639b6-fc92-4112-8841-0c0ab7890ae0",
  "sourceClusterID": "5789e026-c2e2-41e9-ab00-9766bcfa8951",
  "destinationAppID": "cd7b6d91-fc19-4983-a754-9a7bb4d80a7b",
  "destinationClusterID": "c5d023a9-4061-4a8a-bfbf-3be11ff06226",
  "state": "establishing",
  "stateTransitions": [
    {
      "from": "establishing",
      "to": [
        "established",
        "deleting"
      ]
    },
    {
      "from": "established",
      "to": [
        "failingOver",
        "deleting"
      ]
    },
    {
      "from": "failingOver",
      "to": [
        "failedOver",
        "deleting"
      ]
    },
    {
      "from": "failedOver",
      "to": [
        "establishing",
        "deleting"
      ]
    },
    {
      "from": "deleting",
      "to": [
        "deleted"
      ]
    }
  ],
  "stateDesired": "established",
  "stateAllowed": [
    "deleted"
  ],
  "stateDetails": [
    {
      "type": "https://astra.netapp.io/stateDetails/3",
      "title": "AppMirror is being established",
      "detail": "The AppMirror relationship is in the process of being established."
    }
  ],
  "healthState": "warning",
  "healthStateTransitions": [
    {
      "from": "indeterminate",
      "to": [
        "normal",
        "warning",
        "critical"
      ]
    },
    {
      "from": "normal",
      "to": [
        "indeterminate",
        "warning",
        "critical"
      ]
    },
    {
      "from": "warning",
      "to": [
        "indeterminate",
        "normal",
        "critical"
      ]
    },
    {
      "from": "critical",
      "to": [
        "indeterminate",
        "normal",
        "warning"
      ]
    }
  ],
  "healthStateDetails": [
    {
      "type": "https://astra.netapp.io/stateDetails/4",
      "title": "AppMirror not yet established",
      "detail": "The relationship is in the process of being established, so it's not protecting the app data yet."
    }
  ],
  "metadata": {
    "labels": [],
    "creationTimestamp": "2022-10-06T20:58:16.305662Z",
    "modificationTimestamp": "2022-10-06T20:58:16.305662Z",
    "createdBy": "8f84cf09-8036-51e4-b579-bd30cb07b269"
  }
}Response
Status: 401, Unauthorized| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | |
| status | string | True | |
| correlationID | string | False | 
Example response
{
  "type": "https://astra.netapp.io/problems/3",
  "title": "Missing bearer token",
  "detail": "The request is missing the required bearer token.",
  "status": "401"
}Response
Status: 400, Bad request| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | |
| status | string | True | |
| correlationID | string | False | |
| invalidFields | array[invalidFields] | False | List of invalid request body fields | 
Example response
{
  "type": "https://astra.netapp.io/problems/5",
  "title": "Invalid query parameters",
  "detail": "The supplied query parameters are invalid.",
  "status": "400"
}Response
Status: 409, Conflict| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | |
| status | string | True | |
| correlationID | string | False | 
Example response
{
  "type": "https://astra.netapp.io/problems/10",
  "title": "JSON resource conflict",
  "detail": "The request body JSON contains a field that conflicts with an idempotent value.",
  "status": "409"
}Response
Status: 403, Forbidden| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | |
| status | string | True | |
| correlationID | string | False | 
Example response
{
  "type": "https://astra.netapp.io/problems/11",
  "title": "Operation not permitted",
  "detail": "The requested operation isn't permitted.",
  "status": "403"
}Error
Status: 404, Not found| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | |
| status | string | True | |
| correlationID | string | False | 
Example error response
{
  "type": "https://astra.netapp.io/problems/2",
  "title": "Collection not found",
  "detail": "The collection specified in the request URI wasn't found.",
  "status": "404"
}Definitions
See Definitions
namespaceMapping
| Name | Type | Required | Description | 
|---|---|---|---|
| clusterID | string | False | Identifier of the cluster for which the namespaces are specified. Defined values are: 
 | 
| namespaces | array[string] | False | List of namespaces to use on the cluster. Correlated with the other cluster namespace list by index. Defined values are: 
 | 
storageClasses
| Name | Type | Required | Description | 
|---|---|---|---|
| clusterID | string | False | Identifier of the cluster for which the storage class is specified. Defined values are: 
 | 
| storageClassName | string | False | Name of the storage class to use when creating PVCs on the cluster specified in "clusterID". Defined values are: 
 | 
type_astra_label
| Name | Type | Required | Description | 
|---|---|---|---|
| name | string | True | |
| value | string | True | 
type_astra_metadata_update
Client and service-specified metadata associated with the resource. Defined values are:
- 
Conforms to the Astra Metadata Schema If not specified on create, a metadata object will be created with no labels. If not specified on update, the metadata object's labels, creationTimestamp and createdBy, will be preserved without modification. 
| Name | Type | Required | Description | 
|---|---|---|---|
| labels | array[type_astra_label] | False | |
| creationTimestamp | string | False | |
| modificationTimestamp | string | False | |
| createdBy | string | False | |
| modifiedBy | string | False | 
type_astra_stateTransition
| Name | Type | Required | Description | 
|---|---|---|---|
| from | string | True | |
| to | array[string] | True | 
type_astra_stateDetail
| Name | Type | Required | Description | 
|---|---|---|---|
| type | string | True | |
| title | string | True | |
| detail | string | True | 
invalidParams
| Name | Type | Required | Description | 
|---|---|---|---|
| name | string | True | Name of the invalid query parameter | 
| reason | string | True | Reason why the query parameter is invalid | 
invalidFields
| Name | Type | Required | Description | 
|---|---|---|---|
| name | string | True | Name of the invalid request body field | 
| reason | string | True | Reason why the request body field is invalid | 
 PDF
PDF