mirror of https://github.com/ghostfolio/ghostfolio
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
1.3 KiB
55 lines
1.3 KiB
import { redactPaths } from '@ghostfolio/api/helper/object.helper';
|
|
import {
|
|
DEFAULT_REDACTED_PATHS,
|
|
HEADER_KEY_IMPERSONATION
|
|
} from '@ghostfolio/common/config';
|
|
import {
|
|
hasReadRestrictedAccessPermission,
|
|
isRestrictedView
|
|
} from '@ghostfolio/common/permissions';
|
|
import { UserWithSettings } from '@ghostfolio/common/types';
|
|
|
|
import {
|
|
CallHandler,
|
|
ExecutionContext,
|
|
Injectable,
|
|
NestInterceptor
|
|
} from '@nestjs/common';
|
|
import { Observable } from 'rxjs';
|
|
import { map } from 'rxjs/operators';
|
|
|
|
@Injectable()
|
|
export class RedactValuesInResponseInterceptor<T> implements NestInterceptor<
|
|
T,
|
|
any
|
|
> {
|
|
public intercept(
|
|
context: ExecutionContext,
|
|
next: CallHandler<T>
|
|
): Observable<any> {
|
|
return next.handle().pipe(
|
|
map((data: any) => {
|
|
const { headers, user }: { headers: Headers; user: UserWithSettings } =
|
|
context.switchToHttp().getRequest();
|
|
|
|
const impersonationId =
|
|
headers?.[HEADER_KEY_IMPERSONATION.toLowerCase()];
|
|
|
|
if (
|
|
hasReadRestrictedAccessPermission({
|
|
impersonationId,
|
|
user
|
|
}) ||
|
|
isRestrictedView(user)
|
|
) {
|
|
data = redactPaths({
|
|
object: data,
|
|
paths: DEFAULT_REDACTED_PATHS
|
|
});
|
|
}
|
|
|
|
return data;
|
|
})
|
|
);
|
|
}
|
|
}
|
|
|