|
|
|
|
@ -1,9 +1,17 @@
|
|
|
|
|
import { HasPermissionGuard } from '@ghostfolio/api/guards/has-permission.guard';
|
|
|
|
|
import { TransformDataSourceInRequestInterceptor } from '@ghostfolio/api/interceptors/transform-data-source-in-request/transform-data-source-in-request.interceptor';
|
|
|
|
|
import { ApiService } from '@ghostfolio/api/services/api/api.service';
|
|
|
|
|
import { Export } from '@ghostfolio/common/interfaces';
|
|
|
|
|
import type { RequestWithUser } from '@ghostfolio/common/types';
|
|
|
|
|
|
|
|
|
|
import { Controller, Get, Inject, Query, UseGuards } from '@nestjs/common';
|
|
|
|
|
import {
|
|
|
|
|
Controller,
|
|
|
|
|
Get,
|
|
|
|
|
Inject,
|
|
|
|
|
Query,
|
|
|
|
|
UseGuards,
|
|
|
|
|
UseInterceptors
|
|
|
|
|
} from '@nestjs/common';
|
|
|
|
|
import { REQUEST } from '@nestjs/core';
|
|
|
|
|
import { AuthGuard } from '@nestjs/passport';
|
|
|
|
|
|
|
|
|
|
@ -19,16 +27,21 @@ export class ExportController {
|
|
|
|
|
|
|
|
|
|
@Get()
|
|
|
|
|
@UseGuards(AuthGuard('jwt'), HasPermissionGuard)
|
|
|
|
|
@UseInterceptors(TransformDataSourceInRequestInterceptor)
|
|
|
|
|
public async export(
|
|
|
|
|
@Query('accounts') filterByAccounts?: string,
|
|
|
|
|
@Query('activityIds') filterByActivityIds?: string,
|
|
|
|
|
@Query('assetClasses') filterByAssetClasses?: string,
|
|
|
|
|
@Query('dataSource') filterByDataSource?: string,
|
|
|
|
|
@Query('symbol') filterBySymbol?: string,
|
|
|
|
|
@Query('tags') filterByTags?: string
|
|
|
|
|
): Promise<Export> {
|
|
|
|
|
const activityIds = filterByActivityIds?.split(',') ?? [];
|
|
|
|
|
const filters = this.apiService.buildFiltersFromQueryParams({
|
|
|
|
|
filterByAccounts,
|
|
|
|
|
filterByAssetClasses,
|
|
|
|
|
filterByDataSource,
|
|
|
|
|
filterBySymbol,
|
|
|
|
|
filterByTags
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|