# Requirements

Handles all Security Token Compliance Requirements related functionality

## Hierarchy

* Namespace‹[SecurityToken](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)›

  ↳ **Requirements**

## Index

### Properties

* [context](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#protected-context)
* [parent](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#protected-parent)
* [pause](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#pause)
* [reset](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#reset)
* [set](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#set)
* [unpause](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#unpause)

### Methods

* [arePaused](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#arepaused)
* [checkSettle](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#checksettle)
* [get](/polymesh-sdk-api-reference/docs-v4/classes/requirements.md#get)

## Properties

### `Protected` context

• **context**: [*Context*](/polymesh-sdk-api-reference/docs-v4/classes/context.md)

*Inherited from void*

*Defined in* [*src/api/entities/Namespace.ts:11*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/Namespace.ts#L11)

### `Protected` parent

• **parent**: [*SecurityToken*](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)

*Inherited from void*

*Defined in* [*src/api/entities/Namespace.ts:9*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/Namespace.ts#L9)

### pause

• **pause**: *ProcedureMethod‹void,* [*SecurityToken*](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:160*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L160)

Pause all the Security Token's requirements. This means that all transfers will be allowed until requirements are unpaused

**`note`** required role:

* Security Token Owner

### reset

• **reset**: *ProcedureMethod‹void,* [*SecurityToken*](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:152*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L152)

Detele all the current requirements for the Security Token.

**`note`** required role:

* Security Token Owner

### set

• **set**: *ProcedureMethod‹*[*SetAssetRequirementsParams*](/polymesh-sdk-api-reference/docs-v4/interfaces/setassetrequirementsparams.md)*,* [*SecurityToken*](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:68*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L68)

Configure asset compliance requirements for the Security Token. This operation will replace all existing requirements with a new requirement set

This requires two transactions

**`param`** array of array of conditions. For a transfer to be successful, it must comply with all the conditions of at least one of the arrays. In other words, higher level arrays are *OR* between them, while conditions inside each array are *AND* between them

**`example`** Say A, B, C, D and E are requirements and we arrange them as `[[A, B], [C, D], [E]]`. For a transfer to succeed, it must either comply with A AND B, C AND D, OR E.

**`note`** required role:

* Security Token Owner

### unpause

• **unpause**: *ProcedureMethod‹void,* [*SecurityToken*](/polymesh-sdk-api-reference/docs-v4/classes/securitytoken.md)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:165*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L165)

Un-pause all the Security Token's current requirements

## Methods

### arePaused

▸ **arePaused**(): *Promise‹boolean›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:204*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L204)

Check whether asset compliance requirements are paused or not

**Returns:** *Promise‹boolean›*

### checkSettle

▸ **checkSettle**(`args`: object): *Promise‹*[*Compliance*](/polymesh-sdk-api-reference/docs-v4/classes/compliance.md)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:175*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L175)

Check whether the sender and receiver Identities in a transfer comply with all the requirements of this asset

**`note`** this does not take balances into account

**Parameters:**

▪ **args**: *object*

| Name    | Type                                                                          | Description                                                  |
| ------- | ----------------------------------------------------------------------------- | ------------------------------------------------------------ |
| `from?` | string \| [Identity](/polymesh-sdk-api-reference/docs-v4/classes/identity.md) | sender Identity (optional, defaults to the current Identity) |
| `to`    | string \| [Identity](/polymesh-sdk-api-reference/docs-v4/classes/identity.md) | receiver Identity                                            |

**Returns:** *Promise‹*[*Compliance*](/polymesh-sdk-api-reference/docs-v4/classes/compliance.md)*›*

### get

▸ **get**(): *Promise‹*[*Requirement*](/polymesh-sdk-api-reference/docs-v4/interfaces/requirement.md)*\[]›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:75*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L75)

Retrieve all of the Security Token's requirements

**`note`** can be subscribed to

**Returns:** *Promise‹*[*Requirement*](/polymesh-sdk-api-reference/docs-v4/interfaces/requirement.md)*\[]›*

▸ **get**(`callback`: [SubCallback](/polymesh-sdk-api-reference/docs-v4/globals.md#subcallback)‹[Requirement](/polymesh-sdk-api-reference/docs-v4/interfaces/requirement.md)\[]›): *Promise‹*[*UnsubCallback*](/polymesh-sdk-api-reference/docs-v4/globals.md#unsubcallback)*›*

*Defined in* [*src/api/entities/SecurityToken/Compliance/Requirements.ts:76*](https://github.com/PolymathNetwork/polymesh-sdk/blob/a0872cf4/src/api/entities/SecurityToken/Compliance/Requirements.ts#L76)

**Parameters:**

| Name       | Type                                                                                                                                                       |
| ---------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `callback` | [SubCallback](/polymesh-sdk-api-reference/docs-v4/globals.md#subcallback)‹[Requirement](/polymesh-sdk-api-reference/docs-v4/interfaces/requirement.md)\[]› |

**Returns:** *Promise‹*[*UnsubCallback*](/polymesh-sdk-api-reference/docs-v4/globals.md#unsubcallback)*›*


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://developers.polymath.network/polymesh-sdk-api-reference/docs-v4/classes/requirements.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
