@punks/backend-entity-manager 0.0.131 → 0.0.132

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -17,6 +17,10 @@ export declare abstract class TypeOrmQueryBuilder<TEntity extends ObjectLiteral,
17
17
  exists(filters: NonNullable<TEntitySearchParameters["filters"]>, context?: IAuthenticationContext<TUserContext> | undefined): Promise<boolean>;
18
18
  count(filters: NonNullable<TEntitySearchParameters["filters"]>, context?: IAuthenticationContext<TUserContext> | undefined): Promise<number>;
19
19
  delete(filters: NonNullable<TEntitySearchParameters["filters"]>, context?: IAuthenticationContext<TUserContext> | undefined): Promise<IEntitiesDeleteResult>;
20
+ find(request: {
21
+ filters?: TEntitySearchParameters["filters"];
22
+ sorting?: TEntitySearchParameters["sorting"];
23
+ }, context?: IAuthenticationContext<TUserContext>): Promise<TEntity>;
20
24
  search(request: TEntitySearchParameters, context?: IAuthenticationContext<TUserContext>): Promise<IEntitiesSearchResults<TEntitySearchParameters, TEntity, TSorting, number, TFacets>>;
21
25
  protected getFieldFacet(): Promise<void>;
22
26
  protected findPagedQueryResults(request: TEntitySearchParameters, context?: IAuthenticationContext<TUserContext>): Promise<TEntity[]>;
@@ -12,6 +12,10 @@ export declare abstract class QueryBuilderBase<TEntity, TEntityId, TEntitySearch
12
12
  abstract count(filters: NonNullable<TEntitySearchParameters["filters"]>, context?: IAuthenticationContext<TUserContext> | undefined): Promise<number>;
13
13
  abstract delete(filters: NonNullable<TEntitySearchParameters["filters"]>, context?: IAuthenticationContext<TUserContext> | undefined): Promise<IEntitiesDeleteResult>;
14
14
  abstract search(request: TEntitySearchParameters, context?: IAuthenticationContext<TUserContext>): Promise<IEntitiesSearchResults<TEntitySearchParameters, TEntity, TSorting, TCursor, TFacets>>;
15
+ abstract find(request: {
16
+ filters?: TEntitySearchParameters["filters"];
17
+ sorting?: TEntitySearchParameters["sorting"];
18
+ }, context?: IAuthenticationContext<TUserContext>): Promise<TEntity>;
15
19
  protected getIndexBasedPagingResult({ paging, totResults, currentPageResults, }: {
16
20
  paging?: ISearchRequestPaging<number>;
17
21
  totResults: number;
package/dist/esm/index.js CHANGED
@@ -22055,6 +22055,16 @@ class TypeOrmQueryBuilder extends QueryBuilderBase {
22055
22055
  ...this.buildWhereClause(request),
22056
22056
  });
22057
22057
  }
22058
+ async find(request, context) {
22059
+ const results = await this.findPagedQueryResults({
22060
+ filters: request.filters,
22061
+ sorting: request.sorting,
22062
+ paging: {
22063
+ pageSize: 1,
22064
+ },
22065
+ }, context);
22066
+ return results[0];
22067
+ }
22058
22068
  async search(request, context) {
22059
22069
  // todo: execute inside read transaction in order to perform the three queries on the same dataset
22060
22070
  const queryResults = await this.countQueryResults(request, context);