mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* [ADF-2373] added filtering for membership on site dropdown * [ADF-2373] added test for new site service method * [ADF-2373] added filtering for site membering to the sites dropdown * [ADF-2373] added another check into sites tests * [ADF-2373] added a fix for the site dropdown tests * [ADF-2373] fixed broken test check * [ADF-2373] added PR review changes
93 lines
3.0 KiB
TypeScript
93 lines
3.0 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2016 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 { Response } from '@angular/http';
|
|
import { Observable } from 'rxjs/Observable';
|
|
import { AlfrescoApiService } from './alfresco-api.service';
|
|
import 'rxjs/add/observable/fromPromise';
|
|
import 'rxjs/add/operator/catch';
|
|
import { SitePaging, SiteEntry } from 'alfresco-js-api';
|
|
|
|
@Injectable()
|
|
export class SitesService {
|
|
|
|
constructor(
|
|
private apiService: AlfrescoApiService) { }
|
|
|
|
/**
|
|
* Gets a list of all sites in the repository.
|
|
* @param opts Options supported by JSAPI
|
|
*/
|
|
getSites(opts: any = {}): Observable<SitePaging> {
|
|
const defaultOptions = {
|
|
skipCount: 0,
|
|
include: ['properties']
|
|
};
|
|
const queryOptions = Object.assign({}, defaultOptions, opts);
|
|
return Observable.fromPromise(this.apiService.getInstance().core.sitesApi.getSites(queryOptions))
|
|
.catch(this.handleError);
|
|
}
|
|
|
|
/**
|
|
* Gets the details for a site.
|
|
* @param siteId ID of the target site
|
|
* @param opts Options supported by JSAPI
|
|
*/
|
|
getSite(siteId: string, opts?: any): Observable<SiteEntry> {
|
|
return Observable.fromPromise(this.apiService.getInstance().core.sitesApi.getSite(siteId, opts))
|
|
.catch(this.handleError);
|
|
}
|
|
|
|
/**
|
|
* Deletes a site.
|
|
* @param siteId Site to delete
|
|
* @param permanentFlag True: deletion is permanent; False: site is moved to the trash
|
|
*/
|
|
deleteSite(siteId: string, permanentFlag: boolean = true): Observable<any> {
|
|
let options: any = {};
|
|
options.permanent = permanentFlag;
|
|
return Observable.fromPromise(this.apiService.getInstance().core.sitesApi.deleteSite(siteId, options)
|
|
.catch(this.handleError));
|
|
}
|
|
|
|
/**
|
|
* Gets a site's content.
|
|
* @param siteId ID of the target site
|
|
*/
|
|
getSiteContent(siteId: string): Observable<SiteEntry> {
|
|
return this.getSite(siteId, { relations: ['containers'] });
|
|
}
|
|
|
|
/**
|
|
* Gets a list of all a site's members.
|
|
* @param siteId ID of the target site
|
|
*/
|
|
getSiteMembers(siteId: string): Observable<SiteEntry> {
|
|
return this.getSite(siteId, { relations: ['members'] });
|
|
}
|
|
|
|
getEcmCurrentLoggedUserName(): string {
|
|
return this.apiService.getInstance().ecmAuth.username;
|
|
}
|
|
|
|
private handleError(error: Response): any {
|
|
console.error(error);
|
|
return Observable.throw(error || 'Server error');
|
|
}
|
|
}
|