> ## Documentation Index
> Fetch the complete documentation index at: https://docs.mayar.id/llms.txt
> Use this file to discover all available pages before exploring further.

# Cancel Membership Member

> Endpoint to cancel a membership member (sets status to stopped).

<RequestExample>
  ```bash Request Example (productId in body) theme={null}
  curl --request POST 'https://api.mayar.id/hl/v2/memberships/members/MBR8X2QK/cancel' \
  --header 'Authorization: Bearer Paste-Your-API-Key-Here' \
  --header 'Content-Type: application/json' \
  --data-raw '{
      "productId": "7c9d2e1f-4a5b-4c6d-8e9f-0a1b2c3d4e5f"
  }'
  ```

  ```bash Request Example (productId in query) theme={null}
  curl --request POST 'https://api.mayar.id/hl/v2/memberships/members/MBR8X2QK/cancel?productId=7c9d2e1f-4a5b-4c6d-8e9f-0a1b2c3d4e5f' \
  --header 'Authorization: Bearer Paste-Your-API-Key-Here'
  ```
</RequestExample>

<ResponseExample>
  ```json Response Example 200 theme={null}
  {
      "statusCode": 200,
      "message": "success",
      "data": {
          "membershipCustomer": {
              "id": "c4d5e6f7-a8b9-4c0d-8e1f-2a3b4c5d6e7f",
              "memberId": "MBR8X2QK",
              "userId": "348e083d-315a-4e5c-96b1-5a2a98c48413",
              "customerId": "a1b2c3d4-e5f6-4789-a012-3456789abcde",
              "membershipTierId": "9b2d4f6a-8c1e-4a3b-bd5c-6e7f8a9b0c1d",
              "paymentLinkId": "7c9d2e1f-4a5b-4c6d-8e9f-0a1b2c3d4e5f",
              "monthlyPaymentPeriod": 1,
              "status": "stopped",
              "nextPayment": "2026-07-20T09:10:57.994Z",
              "expiredAt": null,
              "createdAt": "2026-06-20T09:10:57.994Z",
              "updatedAt": "2026-06-23T10:30:00.000Z"
          }
      }
  }
  ```
</ResponseExample>

Endpoint:

<CodeGroup>
  ```Production Production theme={null}
  https://api.mayar.id/hl/v2/memberships/members/(memberId)/cancel
  ```

  ```Sandbox Sandbox theme={null}
  https://api.mayar.club/hl/v2/memberships/members/(memberId)/cancel
  ```
</CodeGroup>

## Authorization

<ResponseField name="Authorization" type="string" required>
  Example:

  `Authorization | Bearer Paste-Your-API-Key-Here`
</ResponseField>

## Path Parameters

<ParamField path="memberId" type="string" required>
  The public membership code of the member to cancel.

  Example:

  `MBR8X2QK`
</ParamField>

## Request Body

`productId` may be supplied **in the request body OR as a query parameter** (see
[Query Parameters](#query-parameters)). At least one location is required.

<ParamField body="productId" type="string" required>
  The unique identifier of the product the member belongs to. Accepted here in the
  JSON body, or alternatively as a query parameter.

  Example:

  `7c9d2e1f-4a5b-4c6d-8e9f-0a1b2c3d4e5f`
</ParamField>

## Query Parameters

<ParamField query="productId" path="productId" type="string">
  Alternative location for `productId` when you prefer not to send a request body.
  Use either the body field or this query parameter.

  Example:

  `?productId=7c9d2e1f-4a5b-4c6d-8e9f-0a1b2c3d4e5f`
</ParamField>

## Response

Successful Response — HTTP `200`

### Main Structure (Root Object)

<ResponseField name="statusCode" type="integer">
  Status code from the API. `200` on success.
</ResponseField>

<ResponseField name="message" type="string">
  Status message that describes the result. Note the **singular** `message` key
  (write endpoints use `message`; read/list endpoints use the plural `messages`).
</ResponseField>

<ResponseField name="data" type="object">
  The cancellation result wrapper.
</ResponseField>

<ResponseField name="data.membershipCustomer" type="object">
  The cancelled membership customer record. Its `status` is now `stopped`.
</ResponseField>

## Errors

All errors use the envelope `{ "statusCode": <code>, "message": "<reason>" }` (singular `message`).

```json Error Example 400 theme={null}
{
    "statusCode": 400,
    "message": "Membership member ini sudah tidak aktif (status: stopped)."
}
```

<ResponseField name="statusCode" type="integer">
  The HTTP status code of the error.
</ResponseField>

<ResponseField name="message" type="string">
  A human-readable description of the error.
</ResponseField>

Common errors:

| Status | `message`                                                     | When                                                                                                                         |
| ------ | ------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| `400`  | `Invalid path parameter`                                      | `memberId` is missing or malformed in the path.                                                                              |
| `400`  | `Invalid request body`                                        | `productId` is missing from both the body and the query, or the request fails validation.                                    |
| `400`  | `Membership member ini sudah tidak aktif (status: <status>).` | The member is already inactive — its status is already `stopped` or `finished` (the value is interpolated into the message). |
| `404`  | `Member dengan ID <memberId> tidak ditemukan.`                | No membership member matches the given `memberId`.                                                                           |
