Skip to content

Commit

Permalink
feat(repository): add interface for hasManyThrough repository
Browse files Browse the repository at this point in the history
The hasManyThrough repository interface defines the actions that can be performed on a many-to-many model relation.

This PR is a continuation of loopbackio#2359 and implements a step from loopbackio#2359 (comment).
  • Loading branch information
kv979w committed Dec 17, 2019
1 parent 58c331c commit 6a2fce6
Showing 1 changed file with 82 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
import {Count, DataObject, Entity, Filter, Options, Where} from '../..';

/**
* CRUD operations for a target repository of a HasManyThrough relation
*/
export interface HasManyThroughRepository<
Target extends Entity,
TargetID,
Through extends Entity
> {
/**
* Create a target model instance
* @param targetModelData - The target model data
* @param throughModelData - The through model data
* @param options - Options for the operation
* @param throughOptions - Options passed to create through
* @returns A promise which resolves to the newly created target model instance
*/
create(
targetModelData: DataObject<Target>,
throughModelData?: DataObject<Through>,
options?: Options,
throughOptions?: Options,
): Promise<Target>;
/**
* Find target model instance(s)
* @param filter - A filter object for where, order, limit, etc.
* @param options - Options for the operation
* @returns A promise which resolves with the found target instance(s)
*/
find(
filter?: Filter<Target>,
options?: Options,
throughOptions?: Options,
): Promise<Target[]>;
/**
* Delete multiple target model instances
* @param where - Instances within the where scope are deleted
* @param options
* @returns A promise which resolves the deleted target model instances
*/
delete(
where?: Where<Target>,
options?: Options,
throughOptions?: Options,
): Promise<Count>;
/**
* Patch multiple target model instances
* @param dataObject - The fields and their new values to patch
* @param where - Instances within the where scope are patched
* @param options
* @returns A promise which resolves the patched target model instances
*/
patch(
dataObject: DataObject<Target>,
where?: Where<Target>,
options?: Options,
throughOptions?: Options,
): Promise<Count>;

/**
* Creates a new many-to-many association to an existing target model instance
* @param targetModel - The target model to link
* @returns A promise which resolves to the linked target model instance
*/
add(targetModel: Target): Promise<Target>;

/**
* Removes an association to an existing target model instance
* @param targetModel - The target model to unlink
* @returns A promise which resolves to null
*/
remove(targetModel: Target): Promise<void>;

/**
* Checks if the given target model instance is associated with the source model.
* @param targetModel - The target model to check
* @returns A promise which resolves to true when the association exists
* and false otherwise.
*/
exists(targetModel: Target): Promise<boolean>;
}

0 comments on commit 6a2fce6

Please sign in to comment.