The Databases service allows you to create structured collection of documents, query and filter lists of documents, and manage an advanced set of read and write access permissions.
All data returned by the Databases service are represented as structured JSON documents.
The Databases service can contain multiple databases, each database can contain multiple collections. A collection is a group of similarly structured documents. The accepted structure of documents is defined by collection attributes. The collection attributes help you ensure all your user-submitted data is validated and stored according to the collection structure.
Using Appwrite permissions architecture, you can assign read or write access to each collection or document in your project for either a specific user, team, user role, or even grant it with public access (any). You can learn more about how Appwrite handles permissions and access control.
https://<REGION>.cloud.appwrite.io/v1
Create collections
Create a new Collection. Before using this route, you should create a new database resource using either a server integration API or directly from your database console.
- Request- databaseId string required- Database ID. 
- collectionId string required- Unique Id. Choose a custom ID or generate a random ID with - ID.unique(). Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.
- name string required- Collection name. Max length: 128 chars. 
- permissions array - An array of permissions strings. By default, no user is granted with any permissions. Learn more about permissions. 
- documentSecurity boolean - Enables configuring permissions for individual documents. A user needs one of document or collection level permissions to access a document. Learn more about permissions. 
- enabled boolean - Is collection enabled? When set to 'disabled', users cannot access the collection but Server SDKs with and API key can still read and write to the collection. No data is lost when this is toggled. 
 
- Response- 201 application/json 
 
POST /databases/{databaseId}/collections
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createCollection({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    name: '<NAME>',
    permissions: ["read("any")"], // optional
    documentSecurity: false, // optional
    enabled: false // optional
});
Get collection
Get a collection by its unique ID. This endpoint response returns a JSON object with the collection metadata.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.getCollection({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>'
});
List collections
Get a list of all collections that belong to the provided databaseId. You can use the search parameter to filter your results.
- Request- databaseId string required- Database ID. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, enabled, documentSecurity 
- search string - Search term to filter your list results. Max length: 256 chars. 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.listCollections({
    databaseId: '<DATABASE_ID>',
    queries: [], // optional
    search: '<SEARCH>' // optional
});
Update collection
Update a collection by its unique ID.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- name string required- Collection name. Max length: 128 chars. 
- permissions array - An array of permission strings. By default, the current permissions are inherited. Learn more about permissions. 
- documentSecurity boolean - Enables configuring permissions for individual documents. A user needs one of document or collection level permissions to access a document. Learn more about permissions. 
- enabled boolean - Is collection enabled? When set to 'disabled', users cannot access the collection but Server SDKs with and API key can still read and write to the collection. No data is lost when this is toggled. 
 
- Response- 200 application/json 
 
PUT /databases/{databaseId}/collections/{collectionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateCollection({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    name: '<NAME>',
    permissions: ["read("any")"], // optional
    documentSecurity: false, // optional
    enabled: false // optional
});
Delete collection
Delete a collection by its unique ID. Only users with write permissions have access to delete this resource.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
 
- Response- 204 no content 
 
DELETE /databases/{databaseId}/collections/{collectionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.deleteCollection({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>'
});
Get document
Get a document by its unique ID. This endpoint response returns a JSON object with the document data.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- documentId string required- Document ID. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. 
- transactionId string - Transaction ID to read uncommitted changes within the transaction. 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}/documents/{documentId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.getDocument({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    documentId: '<DOCUMENT_ID>',
    queries: [], // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
List documents
Get a list of all the user's documents in a given collection. You can use the query params to filter your results.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. 
- transactionId string - Transaction ID to read uncommitted changes within the transaction. 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}/documents
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.listDocuments({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    queries: [], // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Update document
Update a document by its unique ID. Using the patch method you can pass only specific fields that will get updated.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- documentId string required- Document ID. 
- data object - Document data as JSON object. Include only attribute and value pairs to be updated. 
- permissions array - An array of permissions strings. By default, the current permissions are inherited. Learn more about permissions. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 200 application/json 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 120 requests - IP + METHOD + URL + USER ID 
PATCH /databases/{databaseId}/collections/{collectionId}/documents/{documentId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.updateDocument({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    documentId: '<DOCUMENT_ID>',
    data: {}, // optional
    permissions: ["read("any")"], // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Update documents
Update all documents that match your queries, if no queries are submitted then all documents are updated. You can pass only specific fields to be updated.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- data object - Document data as JSON object. Include only attribute and value pairs to be updated. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 200 application/json 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 120 requests - IP + METHOD + URL + USER ID 
PATCH /databases/{databaseId}/collections/{collectionId}/documents
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateDocuments({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    data: {}, // optional
    queries: [], // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Delete document
Delete a document by its unique ID.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- documentId string required- Document ID. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 204 no content 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 60 requests - IP + METHOD + URL + USER ID 
DELETE /databases/{databaseId}/collections/{collectionId}/documents/{documentId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.deleteDocument({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    documentId: '<DOCUMENT_ID>',
    transactionId: '<TRANSACTION_ID>' // optional
});
Delete documents
Bulk delete documents using queries, if no queries are passed then all documents are deleted.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 200 application/json 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 60 requests - IP + METHOD + URL + USER ID 
DELETE /databases/{databaseId}/collections/{collectionId}/documents
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.deleteDocuments({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    queries: [], // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Increment document attribute
Increment a specific attribute of a document by a given value.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- documentId string required- Document ID. 
- attribute string required- Attribute key. 
- value number - Value to increment the attribute by. The value must be a number. 
- max number - Maximum value for the attribute. If the current value is greater than this value, an error will be thrown. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 200 application/json 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 120 requests - IP + METHOD + URL + USER ID 
PATCH /databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/increment
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.incrementDocumentAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    documentId: '<DOCUMENT_ID>',
    attribute: '',
    value: null, // optional
    max: null, // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Decrement document attribute
Decrement a specific attribute of a document by a given value.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- documentId string required- Document ID. 
- attribute string required- Attribute key. 
- value number - Value to increment the attribute by. The value must be a number. 
- min number - Minimum value for the attribute. If the current value is lesser than this value, an exception will be thrown. 
- transactionId string - Transaction ID for staging the operation. 
 
- Response- 200 application/json 
 
- Rate limits- This endpoint is not limited when using Server SDKs with API keys. If you are using SSR with - setSession, these rate limits will still apply. Learn more about SSR rate limits.- The limit is applied for each unique limit key. Time frameAttemptsKey- 1 minutes - 120 requests - IP + METHOD + URL + USER ID 
PATCH /databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/decrement
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setSession(''); // The user session to authenticate with
const databases = new sdk.Databases(client);
const result = await databases.decrementDocumentAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    documentId: '<DOCUMENT_ID>',
    attribute: '',
    value: null, // optional
    min: null, // optional
    transactionId: '<TRANSACTION_ID>' // optional
});
Create boolean attribute
Create a boolean attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new table using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default boolean - Default value for attribute when not provided. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/boolean
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createBooleanAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: false, // optional
    array: false // optional
});
Create datetime attribute
Create a date time attribute according to the ISO 8601 standard.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string - Default value for the attribute in ISO 8601 format. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/datetime
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createDatetimeAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: '', // optional
    array: false // optional
});
Create email attribute
Create an email attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string - Default value for attribute when not provided. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/email
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createEmailAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: 'email@example.com', // optional
    array: false // optional
});
Create enum attribute
Create an enum attribute. The elements param acts as a white-list of accepted values for this attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- elements array required- Array of enum values. 
- required boolean required- Is attribute required? 
- default string - Default value for attribute when not provided. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/enum
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createEnumAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    elements: [],
    required: false,
    default: '<DEFAULT>', // optional
    array: false // optional
});
Create float attribute
Create a float attribute. Optionally, minimum and maximum values can be provided.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- min number - Minimum value. 
- max number - Maximum value. 
- default number - Default value. Cannot be set when required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/float
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createFloatAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    min: null, // optional
    max: null, // optional
    default: null, // optional
    array: false // optional
});
Create integer attribute
Create an integer attribute. Optionally, minimum and maximum values can be provided.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- min integer - Minimum value 
- max integer - Maximum value 
- default integer - Default value. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/integer
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createIntegerAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    min: null, // optional
    max: null, // optional
    default: null, // optional
    array: false // optional
});
Create IP address attribute
Create IP address attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string - Default value. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/ip
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createIpAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: '', // optional
    array: false // optional
});
Create line attribute
Create a geometric line attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, two-dimensional array of coordinate pairs, [[longitude, latitude], [longitude, latitude], …], listing the vertices of the line in order. Cannot be set when attribute is required. 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/line
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createLineAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [[1, 2], [3, 4], [5, 6]] // optional
});
Create point attribute
Create a geometric point attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, array of two numbers [longitude, latitude], representing a single coordinate. Cannot be set when attribute is required. 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/point
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createPointAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [1, 2] // optional
});
Create polygon attribute
Create a geometric polygon attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, three-dimensional array where the outer array holds one or more linear rings, [[[longitude, latitude], …], …], the first ring is the exterior boundary, any additional rings are interior holes, and each ring must start and end with the same coordinate pair. Cannot be set when attribute is required. 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/polygon
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createPolygonAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [[[1, 2], [3, 4], [5, 6], [1, 2]]] // optional
});
Create relationship attribute
Create relationship attribute. Learn more about relationship attributes.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- relatedCollectionId string required- Related Collection ID. 
- type string required- Relation type 
- twoWay boolean - Is Two Way? 
- key string - Attribute Key. 
- twoWayKey string - Two Way Attribute Key. 
- onDelete string - Constraints option 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/relationship
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createRelationshipAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    relatedCollectionId: '<RELATED_COLLECTION_ID>',
    type: sdk.RelationshipType.OneToOne,
    twoWay: false, // optional
    key: '', // optional
    twoWayKey: '', // optional
    onDelete: sdk.RelationMutate.Cascade // optional
});
Create string attribute
Create a string attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new table using the Database service server integration. 
- key string required- Attribute Key. 
- size integer required- Attribute size for text attributes, in number of characters. 
- required boolean required- Is attribute required? 
- default string - Default value for attribute when not provided. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
- encrypt boolean - Toggle encryption for the attribute. Encryption enhances security by not storing any plain text values in the database. However, encrypted attributes cannot be queried. 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/string
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createStringAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    size: 1,
    required: false,
    default: '<DEFAULT>', // optional
    array: false, // optional
    encrypt: false // optional
});
Create URL attribute
Create a URL attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string - Default value for attribute when not provided. Cannot be set when attribute is required. 
- array boolean - Is attribute an array? 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/attributes/url
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createUrlAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: 'https://example.com', // optional
    array: false // optional
});
Get attribute
Get attribute by ID.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
 
GET /databases/{databaseId}/collections/{collectionId}/attributes/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.getAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: ''
});
List attributes
List attributes in the collection.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: key, type, size, required, array, status, error 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}/attributes
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.listAttributes({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    queries: [] // optional
});
Update boolean attribute
Update a boolean attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default boolean required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- newKey string - New attribute key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/boolean/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateBooleanAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: false,
    newKey: '' // optional
});
Update datetime attribute
Update a date time attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- newKey string - New attribute key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/datetime/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateDatetimeAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: '',
    newKey: '' // optional
});
Update email attribute
Update an email attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/email/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateEmailAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: 'email@example.com',
    newKey: '' // optional
});
Update enum attribute
Update an enum attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- elements array required- Updated list of enum values. 
- required boolean required- Is attribute required? 
- default string required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/enum/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateEnumAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    elements: [],
    required: false,
    default: '<DEFAULT>',
    newKey: '' // optional
});
Update float attribute
Update a float attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default number required- Default value. Cannot be set when required. 
- min number - Minimum value. 
- max number - Maximum value. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/float/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateFloatAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: null,
    min: null, // optional
    max: null, // optional
    newKey: '' // optional
});
Update integer attribute
Update an integer attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default integer required- Default value. Cannot be set when attribute is required. 
- min integer - Minimum value 
- max integer - Maximum value 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/integer/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateIntegerAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: null,
    min: null, // optional
    max: null, // optional
    newKey: '' // optional
});
Update IP address attribute
Update an ip attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string required- Default value. Cannot be set when attribute is required. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/ip/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateIpAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: '',
    newKey: '' // optional
});
Update line attribute
Update a line attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, two-dimensional array of coordinate pairs, [[longitude, latitude], [longitude, latitude], …], listing the vertices of the line in order. Cannot be set when attribute is required. 
- newKey string - New attribute key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/line/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateLineAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [[1, 2], [3, 4], [5, 6]], // optional
    newKey: '' // optional
});
Update point attribute
Update a point attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, array of two numbers [longitude, latitude], representing a single coordinate. Cannot be set when attribute is required. 
- newKey string - New attribute key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/point/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updatePointAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [1, 2], // optional
    newKey: '' // optional
});
Update polygon attribute
Update a polygon attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default array - Default value for attribute when not provided, three-dimensional array where the outer array holds one or more linear rings, [[[longitude, latitude], …], …], the first ring is the exterior boundary, any additional rings are interior holes, and each ring must start and end with the same coordinate pair. Cannot be set when attribute is required. 
- newKey string - New attribute key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/polygon/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updatePolygonAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: [[[1, 2], [3, 4], [5, 6], [1, 2]]], // optional
    newKey: '' // optional
});
Update relationship attribute
Update relationship attribute. Learn more about relationship attributes.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- onDelete string - Constraints option 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/{key}/relationship
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateRelationshipAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    onDelete: sdk.RelationMutate.Cascade, // optional
    newKey: '' // optional
});
Update string attribute
Update a string attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new table using the Database service server integration. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- size integer - Maximum size of the string attribute. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/string/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateStringAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: '<DEFAULT>',
    size: 1, // optional
    newKey: '' // optional
});
Update URL attribute
Update an url attribute. Changing the default value will not update already existing documents.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
- required boolean required- Is attribute required? 
- default string required- Default value for attribute when not provided. Cannot be set when attribute is required. 
- newKey string - New Attribute Key. 
 
- Response- 200 application/json 
 
PATCH /databases/{databaseId}/collections/{collectionId}/attributes/url/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateUrlAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    required: false,
    default: 'https://example.com',
    newKey: '' // optional
});
Delete attribute
Deletes an attribute.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. 
- key string required- Attribute Key. 
 
- Response- 204 no content 
 
DELETE /databases/{databaseId}/collections/{collectionId}/attributes/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.deleteAttribute({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: ''
});
Create index
Creates an index on the attributes listed. Your index should include all the attributes you will query in a single request.
Attributes can be key, fulltext, and unique.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Index Key. 
- type string required- Index type. 
- attributes array required- Array of attributes to index. Maximum of 100 attributes are allowed, each 32 characters long. 
- orders array - Array of index orders. Maximum of 100 orders are allowed. 
- lengths array - Length of index. Maximum of 100 
 
- Response- 202 application/json 
 
POST /databases/{databaseId}/collections/{collectionId}/indexes
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createIndex({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: '',
    type: sdk.IndexType.Key,
    attributes: [],
    orders: [], // optional
    lengths: [] // optional
});
Get index
Get an index by its unique ID.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Index Key. 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}/indexes/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.getIndex({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: ''
});
List indexes
List indexes in the collection.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: key, type, status, attributes, error 
 
- Response- 200 application/json 
 
GET /databases/{databaseId}/collections/{collectionId}/indexes
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.listIndexes({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    queries: [] // optional
});
Delete index
Delete an index.
- Request- databaseId string required- Database ID. 
- collectionId string required- Collection ID. You can create a new collection using the Database service server integration. 
- key string required- Index Key. 
 
- Response- 204 no content 
 
DELETE /databases/{databaseId}/collections/{collectionId}/indexes/{key}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.deleteIndex({
    databaseId: '<DATABASE_ID>',
    collectionId: '<COLLECTION_ID>',
    key: ''
});
Create operations
Create multiple operations in a single transaction.
- Request- transactionId string required- Transaction ID. 
- operations array - Array of staged operations. 
 
- Response- 201 application/json 
 
POST /databases/transactions/{transactionId}/operations
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createOperations({
    transactionId: '<TRANSACTION_ID>',
    operations: [
	    {
	        "action": "create",
	        "databaseId": "<DATABASE_ID>",
	        "collectionId": "<COLLECTION_ID>",
	        "documentId": "<DOCUMENT_ID>",
	        "data": {
	            "name": "Walter O'Brien"
	        }
	    }
	] // optional
});
Create transaction
Create a new transaction.
- Request- ttl integer - Seconds before the transaction expires. 
 
- Response- 201 application/json 
 
POST /databases/transactions
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.createTransaction({
    ttl: 60 // optional
});
Get transaction
Get a transaction by its unique ID.
- Request- transactionId string required- Transaction ID. 
 
- Response- 200 application/json 
 
GET /databases/transactions/{transactionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.getTransaction({
    transactionId: '<TRANSACTION_ID>'
});
List transactions
List transactions across all databases.
- Request- queries array - Array of query strings generated using the Query class provided by the SDK. Learn more about queries. 
 
- Response- 200 application/json 
 
GET /databases/transactions
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.listTransactions({
    queries: [] // optional
});
Update transaction
Update a transaction, to either commit or roll back its operations.
- Request- transactionId string required- Transaction ID. 
- commit boolean - Commit transaction? 
- rollback boolean - Rollback transaction? 
 
- Response- 200 application/json 
 
PATCH /databases/transactions/{transactionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.updateTransaction({
    transactionId: '<TRANSACTION_ID>',
    commit: false, // optional
    rollback: false // optional
});
Delete transaction
Delete a transaction by its unique ID.
- Request- transactionId string required- Transaction ID. 
 
- Response- 204 no content 
 
DELETE /databases/transactions/{transactionId}
const sdk = require('node-appwrite');
const client = new sdk.Client()
    .setEndpoint('https://<REGION>.cloud.appwrite.io/v1') // Your API Endpoint
    .setProject('<YOUR_PROJECT_ID>') // Your project ID
    .setKey('<YOUR_API_KEY>'); // Your secret API key
const databases = new sdk.Databases(client);
const result = await databases.deleteTransaction({
    transactionId: '<TRANSACTION_ID>'
});