UNPKG

service-activities2-node

Version:

Party activities tracking microservice in Node.js / ES2017 V2

113 lines (90 loc) 4.3 kB
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 ); } }