mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-06-30 18:15:11 +00:00
* [AAE-12501] Provide an AlfrescoApiService implementation that disable the AlfrescoApi oauth initialization when we use new oidc implementation * [AAE-12501] Replace oauth2Auth with authentication service, define get username as abstract * [AAE-12501] Replace sitesService with authentication service since sitesService get the username from oauth2Auth * [AAE-12501] Call implicitLogin by authentication service * [AAE-12501] Replace Oauth2Auth with AlfrescoApi and call the custom api without using authentication * [AAE-12501] Replace oauth2Auth with authentication service to get the token * [AAE-12501] Replace oauth2Auth with alfrescoApi * remove unneeded JS-API dep move auth in the right place * [AAE-10501] Rename alfresco-api.http-client to adf-http-client * [AAE-10501] Remove config from a CoreModule, a different service is provided in AuthModule to use angular http client instead of super agent * [AAE-10501] Disable AlfrescoApi oauth initialization while using new adf oidc authentication * [AAE-12501] Replace alfresco api client with AdfHttpClient * [AAE-12501] Restore get username methods * [AAE-12501] Get username with authentication service * [AAE-12501] removee unused method * [AAE-12501] Trigger on login when token is received * [AAE-12501] Fix content-services unit test * [AAE-12501] Fix import * [AAE-12501] Fix core unit tests * [AAE-12501] Fix process-services-cloud unit tests * [AAE-12501] Create a request options interface with the needed props, remove the import from js-api, return the body from request * [AAE-12501] Fix process-services-cloud unit tests without Expectation * [AAE-12501] Fix Core secondary entrypoints unit tests are not executed: move test.ts one level up in order to find all the spec files into the secondary entrypoints folders and update path * [AAE-12501] Fix Core unit tests that weren't executed because of the previous test.ts wrong location * [AAE-12501] Fix authentication token_issued subscription * add emitters * [AAE-12501] Replace Math.random() to fix hospot security issue, fix lint issues * [AAE-12501] Install event-emitter dependency * [AAE-12501] Comment temporary setCsrfToken because is not possible to import app config service from core due to circular dependencies * [AAE-12501] Get disableCsrf from app config serviice when app configuration is loaded * [AAE-12501] Fix license-header lint issue * [AAE-14221] Regenerate lock file * [AAE-14221] Fix sonarcloud issues * [AAE-12501] Remove wrong character * [AAE-12501] Regenerate lock file * [AAE-12501] Fix BC: update alfresco api response error --------- Co-authored-by: eromano <eugenioromano16@gmail.com>
327 lines
11 KiB
TypeScript
327 lines
11 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 { from, Observable, throwError } from 'rxjs';
|
|
import { AlfrescoApiService, LogService } from '@alfresco/adf-core';
|
|
import {
|
|
MinimalNode,
|
|
SiteBodyCreate,
|
|
SiteEntry,
|
|
SiteGroupEntry,
|
|
SiteGroupPaging,
|
|
SiteMemberEntry,
|
|
SiteMemberPaging,
|
|
SiteMembershipBodyCreate,
|
|
SiteMembershipBodyUpdate,
|
|
SiteMembershipRequestWithPersonPaging,
|
|
SitePaging,
|
|
SitesApi
|
|
} from '@alfresco/js-api';
|
|
import { catchError } from 'rxjs/operators';
|
|
|
|
@Injectable({
|
|
providedIn: 'root'
|
|
})
|
|
export class SitesService {
|
|
|
|
private _sitesApi: SitesApi;
|
|
get sitesApi(): SitesApi {
|
|
this._sitesApi = this._sitesApi ?? new SitesApi(this.apiService.getInstance());
|
|
return this._sitesApi;
|
|
}
|
|
|
|
constructor(private apiService: AlfrescoApiService,
|
|
private logService: LogService) {
|
|
}
|
|
|
|
/**
|
|
* Create a site
|
|
*
|
|
* @param siteBody SiteBodyCreate to create site
|
|
* @returns site SiteEntry
|
|
*/
|
|
createSite(siteBody: SiteBodyCreate): Observable<SiteEntry> {
|
|
return from(this.sitesApi.createSite(siteBody))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Gets a list of all sites in the repository.
|
|
*
|
|
* @param opts Options supported by JS-API
|
|
* @returns List of sites
|
|
*/
|
|
getSites(opts: any = {}): Observable<SitePaging> {
|
|
const defaultOptions = {
|
|
skipCount: 0,
|
|
include: ['properties']
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return from(this.sitesApi.listSites(queryOptions))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Gets the details for a site.
|
|
*
|
|
* @param siteId ID of the target site
|
|
* @param opts Options supported by JS-API
|
|
* @returns Information about the site
|
|
*/
|
|
getSite(siteId: string, opts?: any): Observable<SiteEntry | any> {
|
|
return from(this.sitesApi.getSite(siteId, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Deletes a site.
|
|
*
|
|
* @param siteId Site to delete
|
|
* @param permanentFlag True: deletion is permanent; False: site is moved to the trash
|
|
* @returns Null response notifying when the operation is complete
|
|
*/
|
|
deleteSite(siteId: string, permanentFlag: boolean = true): Observable<any> {
|
|
const options: any = {};
|
|
options.permanent = permanentFlag;
|
|
return from(this.sitesApi.deleteSite(siteId, options))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Gets a site's content.
|
|
*
|
|
* @param siteId ID of the target site
|
|
* @returns Site content
|
|
*/
|
|
getSiteContent(siteId: string): Observable<SiteEntry | any> {
|
|
return this.getSite(siteId, { relations: ['containers'] });
|
|
}
|
|
|
|
/**
|
|
* Gets a list of all a site's members.
|
|
*
|
|
* @param siteId ID of the target site
|
|
* @returns Site members
|
|
*/
|
|
getSiteMembers(siteId: string): Observable<SiteEntry | any> {
|
|
return this.getSite(siteId, { relations: ['members'] });
|
|
}
|
|
|
|
/**
|
|
* Gets a list of all a site's members.
|
|
*
|
|
* @param siteId ID of the target site
|
|
* @param opts Optional parameters supported by JS-API
|
|
* @returns Observable<SiteMemberPaging>
|
|
*/
|
|
listSiteMemberships(siteId: string, opts: any): Observable<SiteMemberPaging> {
|
|
return from(this.sitesApi.listSiteMemberships(siteId, opts));
|
|
}
|
|
|
|
/**
|
|
* Looks for a site inside the path of a Node and returns its guid if it finds one.
|
|
* (return an empty string if no site is found)
|
|
*
|
|
* @param node Node to look for parent site
|
|
* @returns Site guid
|
|
*/
|
|
getSiteNameFromNodePath(node: MinimalNode): string {
|
|
let siteName = '';
|
|
if (node.path && node.path.elements) {
|
|
const foundNode = node.path
|
|
.elements.find((pathNode: MinimalNode) =>
|
|
pathNode.nodeType === 'st:site' &&
|
|
pathNode.name !== 'Sites');
|
|
siteName = foundNode ? foundNode.name : '';
|
|
}
|
|
return siteName.toLocaleLowerCase();
|
|
}
|
|
|
|
/**
|
|
* Gets a list of site membership requests.
|
|
*
|
|
* @param opts Options supported by JS-API
|
|
* @returns Site membership requests
|
|
*/
|
|
getSiteMembershipRequests(opts?: any): Observable<SiteMembershipRequestWithPersonPaging> {
|
|
return from(this.sitesApi.getSiteMembershipRequests(opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Creates a site membership for person **personId** on site **siteId**.
|
|
*
|
|
* @param siteId The identifier of a site
|
|
* @param siteMembershipBodyCreate The person to add and their role
|
|
* @param opts Optional parameters
|
|
* @return Observable<SiteMemberEntry>
|
|
*/
|
|
createSiteMembership(siteId: string, siteMembershipBodyCreate: SiteMembershipBodyCreate, opts?: any): Observable<SiteMemberEntry> {
|
|
return from(this.sitesApi.createSiteMembership(siteId, siteMembershipBodyCreate, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Update a site membership
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param personId The identifier of a person.
|
|
* @param siteMembershipBodyUpdate The persons new role
|
|
* @param opts Optional parameters
|
|
* @return Observable<SiteMemberEntry>
|
|
*/
|
|
updateSiteMembership(siteId: string, personId: string, siteMembershipBodyUpdate: SiteMembershipBodyUpdate, opts?: any): Observable<SiteMemberEntry> {
|
|
return from(this.sitesApi.updateSiteMembership(siteId, personId, siteMembershipBodyUpdate, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Delete a site membership
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param personId The identifier of a person.
|
|
* @return Null response notifying when the operation is complete
|
|
*/
|
|
deleteSiteMembership(siteId: string, personId: string): Observable<void> {
|
|
return from(this.sitesApi.deleteSiteMembership(siteId, personId))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Accept site membership requests.
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param inviteeId The invitee user name.
|
|
* @param opts Options supported by JS-API
|
|
* @returns Null response notifying when the operation is complete
|
|
*/
|
|
approveSiteMembershipRequest(siteId: string, inviteeId: string, opts?: any): Observable<SiteMembershipRequestWithPersonPaging> {
|
|
return from(this.sitesApi.approveSiteMembershipRequest(siteId, inviteeId, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Reject site membership requests.
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param inviteeId The invitee user name.
|
|
* @param opts Options supported by JS-API
|
|
* @returns Null response notifying when the operation is complete
|
|
*/
|
|
rejectSiteMembershipRequest(siteId: string, inviteeId: string, opts?: any): Observable<SiteMembershipRequestWithPersonPaging> {
|
|
return from(this.sitesApi.rejectSiteMembershipRequest(siteId, inviteeId, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* List group membership for site
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param opts Options supported by JS-API
|
|
* @returns Observable<SiteGroupPaging>
|
|
*/
|
|
listSiteGroups(siteId: string, opts?: any): Observable<SiteGroupPaging> {
|
|
return from(this.sitesApi.listSiteGroups(siteId, opts))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Create a site membership for group
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param siteMembershipBodyCreate The Group to add and its role
|
|
* @returns Observable<SiteGroupEntry>
|
|
*/
|
|
createSiteGroupMembership(siteId: string, siteMembershipBodyCreate: SiteMembershipBodyCreate): Observable<SiteGroupEntry> {
|
|
return from(this.sitesApi.createSiteGroupMembership(siteId, siteMembershipBodyCreate))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get information about site membership of group
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param groupId The authorityId of a group.
|
|
* @return Observable<SiteGroupEntry>
|
|
*/
|
|
getSiteGroupMembership(siteId: string, groupId: string): Observable<SiteGroupEntry> {
|
|
return from(this.sitesApi.getSiteGroupMembership(siteId, groupId))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Update site membership of group
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param groupId The authorityId of a group.
|
|
* @param siteMembershipBodyUpdate The group new role
|
|
* @return Observable<SiteGroupEntry>
|
|
*/
|
|
updateSiteGroupMembership(siteId: string, groupId: string, siteMembershipBodyUpdate: SiteMembershipBodyUpdate): Observable<SiteGroupEntry> {
|
|
return from(this.sitesApi.updateSiteGroupMembership(siteId, groupId, siteMembershipBodyUpdate))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Delete a group membership for site
|
|
*
|
|
* @param siteId The identifier of a site.
|
|
* @param groupId The authorityId of a group.
|
|
* @return Observable<void>
|
|
*/
|
|
deleteSiteGroupMembership(siteId: string, groupId: string): Observable<void> {
|
|
return from(this.sitesApi.deleteSiteGroupMembership(siteId, groupId))
|
|
.pipe(
|
|
catchError((err: any) => this.handleError(err))
|
|
);
|
|
}
|
|
|
|
private handleError(error: any): Observable<never> {
|
|
this.logService.error(error);
|
|
return throwError(error || 'Server error');
|
|
}
|
|
}
|