angular-odata
Version:
Client side OData typescript library for Angular
149 lines • 23.3 kB
JavaScript
import { map } from 'rxjs/operators';
import { PathSegment } from '../../types';
import { ODataPathSegments } from '../path';
import { ODataResource } from '../resource';
export class ODataFunctionResource extends ODataResource {
//#region Factory
static factory(api, { path, outgoingType, incomingType, bindingType, segments, }) {
segments = segments ?? new ODataPathSegments();
const segment = segments.add(PathSegment.function, path);
if (outgoingType !== undefined) {
segment.outgoingType(outgoingType);
}
if (incomingType !== undefined) {
segment.incomingType(incomingType);
}
if (bindingType !== undefined) {
segment.bindingType(bindingType);
}
return new ODataFunctionResource(api, { segments });
}
static fromResource(resource, path) {
const baseType = resource.outgoingType();
const callable = resource.api.findCallable(path, baseType);
const outgoingType = callable?.type();
const bindingType = callable?.binding()?.type;
const incomingType = callable?.returnType();
const func = ODataFunctionResource.factory(resource.api, {
path,
outgoingType,
bindingType,
incomingType,
segments: resource.cloneSegments(),
});
// Switch entitySet to binding type if available
if (bindingType !== undefined && bindingType !== baseType) {
let entitySet = resource.api.findEntitySet(bindingType);
if (entitySet !== undefined) {
func.segment((s) => s.entitySet().path(entitySet.name));
}
}
return func;
}
clone() {
return super.clone();
}
//#endregion
parameters(params, { alias } = {}) {
let parameters = params !== null ? this.encode(params) : null;
if (alias && parameters !== null) {
this.query((q) => {
parameters = Object.entries(parameters).reduce((acc, [name, param]) => {
return Object.assign(acc, { [name]: q.alias(param, name) });
}, {});
});
}
return this.clone().segment((s) => s.function().parameters(parameters));
}
//#region Requests
get(options) {
return super.get(options);
}
call(params, { alias, ...options } = {}) {
return this.parameters(params, { alias }).get(options);
}
/**
* Execute the function with the given parameters and return the result as a property
* @param params Parameters to be sent to the function
* @param alias If true, the parameters will be send using aliases
* @param options Options for the request
* @returns Observable of the result of the function
*/
callProperty(params, { alias, ...options } = {}) {
return this.call(params, {
responseType: 'property',
alias,
...options,
}).pipe(map(({ property }) => property));
}
/**
* Execute the function with the given parameters and return the result as a entity
* @param params Parameters to be sent to the function
* @param alias If true, the parameters will be send using aliases
* @param options Options for the request
* @returns Observable of the result of the function
*/
callEntity(params, { alias, ...options } = {}) {
return this.call(params, {
responseType: 'entity',
alias,
...options,
}).pipe(map(({ entity }) => entity));
}
/**
* Execute the function with the given parameters and return the result as a model
* @param params Parameters to be sent to the function
* @param alias If true, the parameters will be send using aliases
* @param options Options for the request
* @returns Observable of the result of the function
*/
callModel(params, { alias, ModelType, ...options } = {}) {
return this.call(params, {
responseType: 'entity',
alias,
...options,
}).pipe(map(({ entity, annots }) => entity ? this.asModel(entity, { annots, ModelType }) : null));
}
/**
* Execute the function with the given parameters and return the result as a entities
* @param params Parameters to be sent to the function
* @param alias If true, the parameters will be send using aliases
* @param options Options for the request
* @returns Observable of the result of the function
*/
callEntities(params, { alias, ...options } = {}) {
return this.call(params, {
responseType: 'entities',
alias,
...options,
}).pipe(map(({ entities }) => entities));
}
/**
* Execute the function with the given parameters and return the result as a collection
* @param params Parameters to be sent to the function
* @param alias If true, the parameters will be send using aliases
* @param options Options for the request
* @returns Observable of the result of the function
*/
callCollection(params, { alias, CollectionType, ...options } = {}) {
return this.call(params, {
responseType: 'entities',
alias,
...options,
}).pipe(map(({ entities, annots }) => entities
? this.asCollection(entities, { annots, CollectionType })
: null));
}
//#endregion
callArraybuffer(params, { alias, ...options } = {}) {
return this.call(params, {
responseType: 'arraybuffer',
alias,
...options,
});
}
callBlob(params, { alias, ...options } = {}) {
return this.call(params, { responseType: 'blob', alias, ...options });
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function.js","sourceRoot":"","sources":["../../../../../../projects/angular-odata/src/lib/resources/types/function.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ODataApi } from '../../api';\nimport { ODataCollection } from '../../models/collection';\nimport { ODataModel } from '../../models/model';\nimport { PathSegment } from '../../types';\nimport { ODataPathSegments } from '../path';\nimport { ODataResource } from '../resource';\nimport {\n  ODataEntitiesOptions,\n  ODataEntityOptions,\n  ODataOptions,\n  ODataPropertyOptions,\n} from './options';\nimport { ODataEntities, ODataEntity, ODataProperty } from '../response';\n\nexport class ODataFunctionResource<P, R> extends ODataResource<R> {\n  //#region Factory\n  static factory<P, R>(\n    api: ODataApi,\n    {\n      path,\n      outgoingType,\n      incomingType,\n      bindingType,\n      segments,\n    }: {\n      path: string;\n      outgoingType?: string;\n      incomingType?: string;\n      bindingType?: string;\n      segments?: ODataPathSegments;\n    },\n  ) {\n    segments = segments ?? new ODataPathSegments();\n\n    const segment = segments.add(PathSegment.function, path);\n    if (outgoingType !== undefined) {\n      segment.outgoingType(outgoingType);\n    }\n    if (incomingType !== undefined) {\n      segment.incomingType(incomingType);\n    }\n    if (bindingType !== undefined) {\n      segment.bindingType(bindingType);\n    }\n    return new ODataFunctionResource<P, R>(api, { segments });\n  }\n\n  static fromResource<P, R>(resource: ODataResource<any>, path: string) {\n    const baseType = resource.outgoingType();\n    const callable = resource.api.findCallable<R>(path, baseType);\n\n    const outgoingType = callable?.type();\n    const bindingType = callable?.binding()?.type;\n    const incomingType = callable?.returnType();\n\n    const func = ODataFunctionResource.factory<P, R>(resource.api, {\n      path,\n      outgoingType,\n      bindingType,\n      incomingType,\n      segments: resource.cloneSegments(),\n    });\n\n    // Switch entitySet to binding type if available\n    if (bindingType !== undefined && bindingType !== baseType) {\n      let entitySet = resource.api.findEntitySet(bindingType);\n      if (entitySet !== undefined) {\n        func.segment((s) => s.entitySet().path(entitySet!.name));\n      }\n    }\n\n    return func;\n  }\n\n  override clone(): ODataFunctionResource<P, R> {\n    return super.clone() as ODataFunctionResource<P, R>;\n  }\n  //#endregion\n\n  parameters(params: P | null, { alias }: { alias?: boolean } = {}) {\n    let parameters = params !== null ? this.encode(params) : null;\n    if (alias && parameters !== null) {\n      this.query((q) => {\n        parameters = Object.entries(parameters).reduce((acc, [name, param]) => {\n          return Object.assign(acc, { [name]: q.alias(param, name) });\n        }, {});\n      });\n    }\n    return this.clone().segment((s) => s.function().parameters<P>(parameters));\n  }\n\n  //#region Requests\n  protected override get(\n    options?: ODataEntityOptions & ODataEntitiesOptions & ODataPropertyOptions,\n  ): Observable<any> {\n    return super.get(options);\n  }\n  //#endregion\n\n  //#region Shortcuts\n  /**\n   * Execute the function\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   */\n  call(\n    params: P | null,\n    options?: { alias?: boolean } & ODataEntityOptions,\n  ): Observable<ODataEntity<R>>;\n  call(\n    params: P | null,\n    options?: { alias?: boolean } & ODataEntitiesOptions,\n  ): Observable<ODataEntities<R>>;\n  call(\n    params: P | null,\n    options?: { alias?: boolean } & ODataPropertyOptions,\n  ): Observable<ODataProperty<R>>;\n  call(\n    params: P | null,\n    options?: { alias?: boolean; responseType?: 'blob' } & ODataOptions,\n  ): Observable<Blob>;\n  call(\n    params: P | null,\n    options?: { alias?: boolean; responseType?: 'arraybuffer' } & ODataOptions,\n  ): Observable<ArrayBuffer>;\n  call(\n    params: P | null,\n    options?: { alias?: boolean; responseType?: 'none' } & ODataOptions,\n  ): Observable<null>;\n  call(\n    params: P | null,\n    {\n      alias,\n      ...options\n    }: {\n      alias?: boolean;\n      responseType?: 'blob' | 'arraybuffer';\n    } & ODataEntityOptions &\n      ODataEntitiesOptions &\n      ODataPropertyOptions = {},\n  ): Observable<any> {\n    return this.parameters(params, { alias }).get(options);\n  }\n\n  /**\n   * Execute the function with the given parameters and return the result as a property\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   * @returns Observable of the result of the function\n   */\n  callProperty(\n    params: P | null,\n    { alias, ...options }: { alias?: boolean } & ODataOptions = {},\n  ): Observable<R | null> {\n    return this.call(params, {\n      responseType: 'property',\n      alias,\n      ...options,\n    }).pipe(map(({ property }) => property));\n  }\n\n  /**\n   * Execute the function with the given parameters and return the result as a entity\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   * @returns Observable of the result of the function\n   */\n  callEntity(\n    params: P | null,\n    { alias, ...options }: { alias?: boolean } & ODataOptions = {},\n  ): Observable<R | null> {\n    return this.call(params, {\n      responseType: 'entity',\n      alias,\n      ...options,\n    }).pipe(map(({ entity }) => entity));\n  }\n\n  /**\n   * Execute the function with the given parameters and return the result as a model\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   * @returns Observable of the result of the function\n   */\n  callModel(\n    params: P | null,\n    {\n      alias,\n      ModelType,\n      ...options\n    }: ODataOptions & { alias?: boolean; ModelType?: typeof ODataModel } = {},\n  ) {\n    return this.call(params, {\n      responseType: 'entity',\n      alias,\n      ...options,\n    }).pipe(\n      map(({ entity, annots }) =>\n        entity ? this.asModel(entity, { annots, ModelType }) : null,\n      ),\n    );\n  }\n\n  /**\n   * Execute the function with the given parameters and return the result as a entities\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   * @returns Observable of the result of the function\n   */\n  callEntities(\n    params: P | null,\n    { alias, ...options }: { alias?: boolean } & ODataOptions = {},\n  ): Observable<R[] | null> {\n    return this.call(params, {\n      responseType: 'entities',\n      alias,\n      ...options,\n    }).pipe(map(({ entities }) => entities));\n  }\n\n  /**\n   * Execute the function with the given parameters and return the result as a collection\n   * @param params Parameters to be sent to the function\n   * @param alias If true, the parameters will be send using aliases\n   * @param options Options for the request\n   * @returns Observable of the result of the function\n   */\n  callCollection(\n    params: P | null,\n    {\n      alias,\n      CollectionType,\n      ...options\n    }: {\n      alias?: boolean;\n      CollectionType?: typeof ODataCollection;\n    } & ODataOptions = {},\n  ) {\n    return this.call(params, {\n      responseType: 'entities',\n      alias,\n      ...options,\n    }).pipe(\n      map(({ entities, annots }) =>\n        entities\n          ? this.asCollection(entities, { annots, CollectionType })\n          : null,\n      ),\n    );\n  }\n  //#endregion\n\n  callArraybuffer(\n    params: P | null,\n    { alias, ...options }: { alias?: boolean } & ODataOptions = {},\n  ): Observable<ArrayBuffer> {\n    return this.call(params, {\n      responseType: 'arraybuffer',\n      alias,\n      ...options,\n    });\n  }\n\n  callBlob(\n    params: P | null,\n    { alias, ...options }: { alias?: boolean } & ODataOptions = {},\n  ): Observable<Blob> {\n    return this.call(params, { responseType: 'blob', alias, ...options });\n  }\n}\n"]}