mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-06-02 17:35:08 +00:00
* ACS-5041 Changed json to js * ACS-5041 Corrected paths * ACS-5041 Changed json to js * ACS-5041 Updated eslintrc * ACS-5041 Small correction * ACS-5041 Small correction * ACS-5041 Updated license headers * ACS-5041 Updated license headers * ACS-5041 Replaced references to alfresco * ACS-5041 Added Hyland to known words * ACS-5041 Fixed coverage issue * ACS-5041 Fixed duplication issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed duplications issue * ACS-5041 Fixed test * ACS-5041 Fixed test * ACS-5041 Reverted one change * ACS-5041 Added missing license to files after rebase
177 lines
6.1 KiB
TypeScript
177 lines
6.1 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { Injectable } from '@angular/core';
|
|
import { Observable, from, throwError } from 'rxjs';
|
|
import { AlfrescoApiService, LogService } from '@alfresco/adf-core';
|
|
import {
|
|
AuditApi,
|
|
AuditAppPaging,
|
|
AuditAppEntry,
|
|
AuditApp,
|
|
AuditBodyUpdate,
|
|
AuditEntryPaging,
|
|
AuditEntryEntry
|
|
} from '@alfresco/js-api';
|
|
import { catchError } from 'rxjs/operators';
|
|
|
|
@Injectable({
|
|
providedIn: 'root'
|
|
})
|
|
export class AuditService {
|
|
|
|
private _auditApi: AuditApi;
|
|
get auditApi(): AuditApi {
|
|
this._auditApi = this._auditApi ?? new AuditApi(this.apiService.getInstance());
|
|
return this._auditApi;
|
|
}
|
|
|
|
constructor(private apiService: AlfrescoApiService, private logService: LogService) {
|
|
}
|
|
|
|
/**
|
|
* Gets a list of audit applications.
|
|
* @param opts Options.
|
|
* @returns a list of the audit applications.
|
|
*/
|
|
getAuditApps(opts?: any): Observable<AuditAppPaging> {
|
|
const defaultOptions = {
|
|
skipCount: 0
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.listAuditApps(queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get audit application info.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param opts Options.
|
|
* @returns status of an audit application.
|
|
*/
|
|
getAuditApp(auditApplicationId: string, opts?: any): Observable<AuditAppEntry> {
|
|
const defaultOptions = {
|
|
auditApplicationId
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.getAuditApp(queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Update audit application info.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param auditAppBodyUpdate The audit application to update.
|
|
* @param opts Options.
|
|
* @returns
|
|
*/
|
|
updateAuditApp(auditApplicationId: string, auditAppBodyUpdate: boolean, opts?: any): Observable<AuditApp | any> {
|
|
const defaultOptions = {};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.updateAuditApp(auditApplicationId, new AuditBodyUpdate({ isEnabled: auditAppBodyUpdate }), queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* List audit entries for an audit application.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param opts Options.
|
|
* @returns a list of audit entries.
|
|
*/
|
|
getAuditEntries(auditApplicationId: string, opts?: any): Observable<AuditEntryPaging> {
|
|
const defaultOptions = {
|
|
skipCount: 0,
|
|
maxItems: 100
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.listAuditEntriesForAuditApp(auditApplicationId, queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get audit entry.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param auditEntryId The identifier of an audit entry.
|
|
* @param opts Options.
|
|
* @returns audit entry.
|
|
*/
|
|
getAuditEntry(auditApplicationId: string, auditEntryId: string, opts?: any): Observable<AuditEntryEntry> {
|
|
const defaultOptions = {};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.getAuditEntry(auditApplicationId, auditEntryId, queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* List audit entries for a node.
|
|
* @param nodeId The identifier of a node.
|
|
* @param opts Options.
|
|
* @returns
|
|
*/
|
|
getAuditEntriesForNode(nodeId: string, opts?: any): Observable<AuditEntryPaging> {
|
|
const defaultOptions = {
|
|
nodeId
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.auditApi.listAuditEntriesForNode(queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Permanently delete audit entries for an audit application.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param where Audit entries to permanently delete for an audit application, given an inclusive time period or range of ids.
|
|
* @returns
|
|
*/
|
|
deleteAuditEntries(auditApplicationId: string, where: string): Observable<any> {
|
|
return from(this.auditApi.deleteAuditEntriesForAuditApp(auditApplicationId, where))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Permanently delete an audit entry.
|
|
* @param auditApplicationId The identifier of an audit application.
|
|
* @param auditEntryId The identifier of an audit entry.
|
|
* @returns
|
|
*/
|
|
deleteAuditEntry(auditApplicationId: string, auditEntryId: string): Observable<any> {
|
|
return from(this.auditApi.deleteAuditEntry(auditApplicationId, auditEntryId))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
private handleError(error: any): any {
|
|
this.logService.error(error);
|
|
return throwError(error || 'Server error');
|
|
}
|
|
}
|