/*! * @license * Copyright 2019 Alfresco Software, Ltd. * * 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 } from './alfresco-api.service'; import { MinimalNode, SiteBodyCreate, SiteEntry, SiteGroupEntry, SiteGroupPaging, SiteMemberEntry, SiteMemberPaging, SiteMembershipBodyCreate, SiteMembershipBodyUpdate, SiteMembershipRequestWithPersonPaging, SitePaging, SitesApi } from '@alfresco/js-api'; import { catchError } from 'rxjs/operators'; import { LogService } from './log.service'; @Injectable({ providedIn: 'root' }) export class SitesService { _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 { 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 { 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 { 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 { 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 { 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 { 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 */ listSiteMemberships(siteId: string, opts: any): Observable { return from(this.sitesApi.listSiteMemberships(siteId, opts)); } /** * Gets the username of the user currently logged into ACS. * @returns Username string */ getEcmCurrentLoggedUserName(): string { return this.apiService.getInstance().getEcmUsername(); } /** * 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 { 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 */ createSiteMembership(siteId: string, siteMembershipBodyCreate: SiteMembershipBodyCreate, opts?: any): Observable { 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 */ updateSiteMembership(siteId: string, personId: string, siteMembershipBodyUpdate: SiteMembershipBodyUpdate, opts?: any): Observable { 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 { 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 { 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 { 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 */ listSiteGroups(siteId: string, opts?: any): Observable { 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 */ createSiteGroupMembership(siteId: string, siteMembershipBodyCreate: SiteMembershipBodyCreate): Observable { 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 */ getSiteGroupMembership(siteId: string, groupId: string): Observable { 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 */ updateSiteGroupMembership(siteId: string, groupId: string, siteMembershipBodyUpdate: SiteMembershipBodyUpdate): Observable { 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 */ deleteSiteGroupMembership(siteId: string, groupId: string): Observable { return from(this.sitesApi.deleteSiteGroupMembership(siteId, groupId)) .pipe( catchError((err: any) => this.handleError(err)) ); } private handleError(error: any): Observable { this.logService.error(error); return throwError(error || 'Server error'); } }