service-activities2-node
Version:
Party activities tracking microservice in Node.js / ES2017 V2
113 lines (90 loc) • 4.3 kB
text/typescript
import { IContext } from 'pip-services4-components-node';
import { DataPage } from 'pip-services4-data-node';
import { FilterParams } from 'pip-services4-data-node';
import { PagingParams } from 'pip-services4-data-node';
import { IdentifiableMongoDbPersistence } from 'pip-services4-mongodb-node';
import { PartyActivityV1 } from '../data/version1/PartyActivityV1';
import { IActivitiesPersistence } from './IActivitiesPersistence';
export class ActivitiesMongoDbPersistence
extends IdentifiableMongoDbPersistence<PartyActivityV1, string> implements IActivitiesPersistence {
constructor() {
super('party_activities');
super.ensureIndex({ time: -1 });
}
private composeFilter(filter: FilterParams): any {
filter = filter || new FilterParams();
let criteria = [];
let search = filter.getAsNullableString('search');
if (search != null) {
let searchRegex = new RegExp(search, "i");
let searchCriteria = [];
searchCriteria.push({ type: { $regex: searchRegex } });
searchCriteria.push({ 'party.name': { $regex: searchRegex } });
searchCriteria.push({ 'ref_item.name': { $regex: searchRegex } });
searchCriteria.push({ 'ref_party.name': { $regex: searchRegex } });
criteria.push({ $or: searchCriteria });
}
let id = filter.getAsNullableString('id') || filter.getAsNullableString('activity_id');
if (id != null)
criteria.push({ _id: id });
let orgId = filter.getAsNullableString('org_id');
if (orgId != null)
criteria.push({ org_id: orgId });
let type = filter.getAsNullableString('type');
if (type != null)
criteria.push({ type: type });
// Decode include types
let includeTypes = filter.getAsObject('include_types');
if (includeTypes) {
if (Array.isArray(includeTypes))
includeTypes = ('' + includeTypes).split(',');
criteria.push({ type: { $in: includeTypes } });
}
// Decode exclude types
let excludeTypes = filter.getAsObject('exclude_types');
if (excludeTypes) {
if (Array.isArray(excludeTypes))
excludeTypes = ('' + excludeTypes).split(',');
criteria.push({ type: { $nin: excludeTypes } });
}
// Decode party_id
let partyId = filter.getAsNullableString('party_id');
if (partyId)
criteria.push({ 'party.id': partyId });
// Decode ref_item_id
let refItemId = filter.getAsNullableString('ref_item_id');
if (refItemId)
criteria.push({ 'ref_item.id': refItemId });
// Decode ref_parent_id and ref_item_id
let refParentId = filter.getAsNullableString('ref_parent_id');
if (refParentId)
criteria.push({ 'ref_parents.id': refParentId });
// Decode party
let refPartyId = filter.getAsNullableString('ref_party_id');
if (refPartyId)
criteria.push({ 'ref_party.id': refPartyId });
let fromTime = filter.getAsNullableDateTime('from_time');
if (fromTime != null)
criteria.push({ time: { $gte: fromTime } });
let toTime = filter.getAsNullableDateTime('to_time');
if (toTime != null)
criteria.push({ time: { $lt: toTime } });
return criteria.length > 0 ? { $and: criteria } : {};
}
public async getPageByFilter(ctx: IContext, filter: FilterParams, paging: PagingParams): Promise<DataPage<PartyActivityV1>> {
let criteria = this.composeFilter(filter);
return await super.getPageByFilter(ctx, criteria, paging, '-time', { parent_ids: 0 });
}
public async create(ctx: IContext, activity: PartyActivityV1): Promise<PartyActivityV1> {
activity.ref_parents = activity.ref_parents || [];
if (activity.ref_item)
activity.ref_parents.push(activity.ref_item);
return await super.create(ctx, activity);
}
public async deleteByFilter(ctx: IContext, filter: FilterParams): Promise<void> {
let criteria = this.composeFilter(filter);
await this._collection.deleteMany(
criteria
);
}
}