packages/core/src/resources/AuditEvents.ts
import { BaseResource } from '@gitbeaker/requester-utils';
import { RequestHelper, endpoint } from '../infrastructure';
import type {
GitlabAPIResponse,
OneOrNoneOf,
PaginationRequestOptions,
PaginationTypes,
ShowExpanded,
Sudo,
} from '../infrastructure';
export interface AuditEventSchema extends Record<string, unknown> {
id: number;
author_id: number;
entity_id: number;
entity_type: string;
details: {
change?: string;
from?: string;
to?: string;
custom_message?: string;
author_name: string;
author_email: string;
target_id: string;
target_type: string;
target_details: string;
ip_address: string;
entity_path: string;
};
created_at: string;
}
function url({
projectId,
groupId,
}: { projectId?: string | number; groupId?: string | number } = {}): string {
let prefix = '';
if (projectId) prefix = endpoint`projects/${projectId}/`;
else if (groupId) prefix = endpoint`groups/${groupId}/`;
return `${prefix}audit_events`;
}
export interface AllAuditEventOptions {
createdAfter?: string;
createdBefore?: string;
entityType?: string;
entityId?: number;
}
export class AuditEvents<C extends boolean = false> extends BaseResource<C> {
all<E extends boolean = false, P extends PaginationTypes = 'offset'>(
{
projectId,
groupId,
...options
}: OneOrNoneOf<{ projectId: string | number; groupId: string | number }> &
AllAuditEventOptions &
Sudo &
ShowExpanded<E> &
PaginationRequestOptions<P> = {} as any,
): Promise<GitlabAPIResponse<AuditEventSchema[], C, E, P>> {
const uri = url({ projectId, groupId });
return RequestHelper.get<AuditEventSchema[]>()(
this,
uri,
options as AllAuditEventOptions & Sudo & ShowExpanded<E> & PaginationRequestOptions<P>,
);
}
show<E extends boolean = false>(
auditEventId: number,
{
projectId,
groupId,
...options
}: OneOrNoneOf<{ projectId: string | number; groupId: string | number }> &
Sudo &
ShowExpanded<E> = {},
): Promise<GitlabAPIResponse<AuditEventSchema, C, E, void>> {
const uri = url({ projectId, groupId });
return RequestHelper.get<AuditEventSchema>()(this, `${uri}/${auditEventId}`, options);
}
}