Model
The Model
class represents a data model in the RushDB SDK. It provides methods for performing CRUD operations, managing relationships, and validating records according to a defined schema.
Type Definition
class Model<S extends Schema = Schema, R extends Relations = Relations> extends RestApiProxy {
private readonly label: string;
public schema: S;
public relationships: R;
private validator?: Validator;
constructor(modelName: string, schema: S, relationships: R = {} as R) {
super();
this.label = modelName;
this.schema = schema;
this.relationships = relationships;
}
}
Constructor Parameters
modelName
- Type:
string
- Required: Yes
A unique string identifier for the model. It's used to reference the model within the SDK and to associate records with their corresponding model type in the database.
schema
- Type:
Schema
- Required: Yes
The schema definition based on Schema
, which dictates the structure and rules of the data stored.
relationships
- Type:
Relations
- Optional: Yes
Defines how this model relates to other models, which is essential for establishing connections between different data types.
Methods
find
Finds multiple records based on specified query parameters.
Signature:
find(params?: SearchQuery<S> & { labels?: never }, transaction?: Transaction | string): Promise<DBRecordsArrayInstance<S>>;
findOne
Finds a single record based on specified query parameters.
Signature:
findOne(params?: SearchQuery<S> & { labels?: never }, transaction?: Transaction | string): Promise<DBRecordInstance<S>>;
findById
Finds a single record by its ID.
Signature:
findById(id: string, transaction?: Transaction | string): Promise<DBRecordInstance<S>>;
create
Creates a single record.
Signature:
create(record: InferSchemaTypesWrite<S>, transaction?: Transaction | string, options?: { validate: boolean }): Promise<DBRecordInstance<InferSchemaTypesWrite<S>>>;
attach
Attaches a target record to the source record.
Signature:
attach(sourceId: string, target: RelationTarget, transaction?: Transaction | string): Promise<ApiResponse<{ message: string }>>;
detach
Detaches a target record from the source record.
Signature:
detach(sourceId: string, target: RelationTarget, transaction?: Transaction | string): Promise<ApiResponse<{ message: string }>>;
updateById
Updates a single record by its ID.
Signature:
updateById(id: string, record: InferSchemaTypesWrite<S>, transaction?: Transaction | string, options?: { validate: boolean }): Promise<DBRecordInstance<S>>;
createMany
Creates multiple records in a single operation.
Signature:
createMany(records: InferSchemaTypesWrite<S>[], transaction?: Transaction | string, options?: { validate: boolean }): Promise<DBRecordsArrayInstance<S>>;
delete
Deletes multiple records based on specified query parameters.
Signature:
delete<T extends InferSchemaTypesWrite<S> = InferSchemaTypesWrite<S>>(params?: Omit<SearchQuery<T>, 'labels'>, transaction?: Transaction | string): Promise<ApiResponse<{ message: string }>>;
validate
Validates a record according to the schema rules.
Signature:
validate(data: InferSchemaTypesWrite<S>): Promise<unknown>;
Example Usage
const Author = new Model('author', {
name: { type: 'string' },
email: { type: 'string', uniq: true }
});
// Find multiple records
Author.find({ where: { name: { $contains: 'Doe' } } }).then(records => {
console.log(records.data);
// Expected output: Array of authors with name containing 'Doe'
});
// Find one record
Author.findOne({ where: { email: 'john.doe@example.com' } }).then(record => {
console.log(record.data);
// Expected output: Single author record with email 'john.doe@example.com'
});
// Find by ID
Author.findById('some-id').then(record => {
console.log(record.data);
// Expected output: Author record with the specified ID
});
// Create a record
Author.create({ name: 'John Doe', email: 'john.doe@example.com' }).then(record => {
console.log(record.data);
// Expected output: Newly created author record
});
// Attach a related record
const Blog = new Model('blog', {
title: { type: 'string' },
description: { type: 'string' }
});
Author.attach('author-id', { model: 'blog', __id: 'blog-id' }).then(response => {
console.log(response.message);
// Expected output: "Attached successfully" or similar message
});
// Detach a related record
Author.detach('author-id', { model: 'blog', __id: 'blog-id' }).then(response => {
console.log(response.message);
// Expected output: "Detached successfully" or similar message
});
// Update a record by ID
Author.updateById('some-id', { name: 'John Smith' }).then(record => {
console.log(record.data);
// Expected output: Updated author record with name 'John Smith'
});
// Create multiple records
Author.createMany([
{ name: 'John Doe', email: 'john.doe@example.com' },
{ name: 'Jane Doe', email: 'jane.doe@example.com' }
]).then(records => {
console.log(records.data);
// Expected output: Array of newly created author records
});
// Delete records
Author.delete({ where: { name: { $contains: 'Doe' } } }).then(response => {
console.log(response.message);
// Expected output: "Deleted successfully" or similar message
});