mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			192 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			192 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.repo.site.script;
 | |
| 
 | |
| import java.util.ArrayList;
 | |
| import java.util.List;
 | |
| 
 | |
| import org.alfresco.repo.jscript.BaseScopableProcessorExtension;
 | |
| import org.alfresco.service.ServiceRegistry;
 | |
| import org.alfresco.service.cmr.site.SiteInfo;
 | |
| import org.alfresco.service.cmr.site.SiteService;
 | |
| import org.alfresco.service.cmr.site.SiteVisibility;
 | |
| import org.springframework.extensions.surf.util.ParameterCheck;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Script object representing the site service.
 | |
|  * 
 | |
|  * @author Roy Wetherall
 | |
|  */
 | |
| public class ScriptSiteService extends BaseScopableProcessorExtension
 | |
| {
 | |
|     /** Visibility helper constants */
 | |
|     public static final String PUBLIC_SITE = "PUBLIC";
 | |
|     public static final String MODERATED_SITE = "MODERATED";
 | |
|     public static final String PRIVATE_SITE = "PRIVATE";
 | |
|     
 | |
| 	/** Service Registry */
 | |
| 	private ServiceRegistry serviceRegistry;
 | |
| 	
 | |
|     /** The site service */
 | |
|     private SiteService siteService;
 | |
| 
 | |
|     /**
 | |
|      * Sets the Service Registry
 | |
|      * 
 | |
|      * @param serviceRegistry
 | |
|      */
 | |
|     public void setServiceRegistry(ServiceRegistry serviceRegistry)
 | |
|     {
 | |
|     	this.serviceRegistry = serviceRegistry;
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Set the site service
 | |
|      * 
 | |
|      * @param siteService   the site service
 | |
|      */
 | |
|     public void setSiteService(SiteService siteService)
 | |
|     {
 | |
|         this.siteService = siteService;
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * @see {@link #createSite(String, String, String, String, String)}
 | |
|      * 
 | |
|      * @param sitePreset    site preset
 | |
|      * @param shortName     site short name
 | |
|      * @param title         site title
 | |
|      * @param description   site description
 | |
|      * @param isPublic      whether the site is public or not
 | |
|      * @return Site         the created site
 | |
|      * @deprecated          as of version 3.2, replaced by {@link #createSite(String, String, String, String, String)}
 | |
|      */    
 | |
|     public Site createSite(String sitePreset, String shortName, String title, String description, boolean isPublic)
 | |
|     {                
 | |
|         SiteInfo siteInfo = this.siteService.createSite(sitePreset, shortName, title, description, isPublic);
 | |
|         return new Site(siteInfo, this.serviceRegistry, this.siteService, getScope());
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Create a new site.
 | |
|      * <p>
 | |
|      * The site short name will be used to uniquely identify the site so it must be unique.
 | |
|      * 
 | |
|      * @param sitePreset    site preset
 | |
|      * @param shortName     site short name
 | |
|      * @param title         site title
 | |
|      * @param description   site description
 | |
|      * @param visibility    visibility of the site (public|moderated|private)
 | |
|      * @return Site         the created site
 | |
|      */
 | |
|     public Site createSite(String sitePreset, String shortName, String title, String description, String visibility)
 | |
|     { 
 | |
|         ParameterCheck.mandatoryString("visibility", visibility);
 | |
|         SiteVisibility siteVisibility = SiteVisibility.valueOf(visibility);
 | |
|         SiteInfo siteInfo = this.siteService.createSite(sitePreset, shortName, title, description, siteVisibility);
 | |
|         return new Site(siteInfo, this.serviceRegistry, this.siteService, getScope());
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * List the sites available in the repository.  The returned list can optionally be filtered by name and site
 | |
|      * preset.
 | |
|      * <p>
 | |
|      * If no filters are specified then all the available sites are returned.
 | |
|      * 
 | |
|      * @param nameFilter        name filter
 | |
|      * @param sitePresetFilter  site preset filter
 | |
|      * @return Site[]           a list of the site filtered as appropriate             
 | |
|      */
 | |
|     public Site[] listSites(String nameFilter, String sitePresetFilter)
 | |
|     {
 | |
|         return listSites(nameFilter, sitePresetFilter, 0);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * List the sites available in the repository.  The returned list can optionally be filtered by name and site
 | |
|      * preset.
 | |
|      * <p>
 | |
|      * If no filters are specified then all the available sites are returned.
 | |
|      * 
 | |
|      * @param nameFilter        name filter
 | |
|      * @param sitePresetFilter  site preset filter
 | |
|      * @param size              max results size crop if >0
 | |
|      * 
 | |
|      * @return Site[]           a list of the site filtered as appropriate             
 | |
|      */
 | |
|     public Site[] listSites(String nameFilter, String sitePresetFilter, int size)
 | |
|     {
 | |
|         List<SiteInfo> siteInfos = this.siteService.listSites(nameFilter, sitePresetFilter, size);
 | |
|         List<Site> sites = new ArrayList<Site>(siteInfos.size());
 | |
|         for (SiteInfo siteInfo : siteInfos)
 | |
|         {
 | |
|             sites.add(new Site(siteInfo, this.serviceRegistry, this.siteService, getScope()));
 | |
|         }
 | |
|         return (Site[])sites.toArray(new Site[sites.size()]);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * List all the sites that the specified user has an explicit membership to.
 | |
|      * 
 | |
|      * @param userName      user name
 | |
|      * @return Site[]       a list of sites the user has an explicit membership to
 | |
|      */
 | |
|     public Site[] listUserSites(String userName)
 | |
|     {
 | |
|         List<SiteInfo> siteInfos = this.siteService.listSites(userName);
 | |
|         List<Site> sites = new ArrayList<Site>(siteInfos.size());
 | |
|         for (SiteInfo siteInfo : siteInfos)
 | |
|         {
 | |
|             sites.add(new Site(siteInfo, this.serviceRegistry, this.siteService, getScope()));
 | |
|         }
 | |
|         return (Site[])sites.toArray(new Site[sites.size()]);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Get a site for a provided site short name.
 | |
|      * <p>
 | |
|      * Returns null if the site does not exist.
 | |
|      * 
 | |
|      * @param shortName     short name of the site
 | |
|      * @return Site         the site, null if does not exist
 | |
|      */
 | |
|     public Site getSite(String shortName)
 | |
|     {
 | |
|         Site site = null;
 | |
|         SiteInfo siteInfo = this.siteService.getSite(shortName);
 | |
|         if (siteInfo != null)
 | |
|         {
 | |
|             site = new Site(siteInfo, this.serviceRegistry, this.siteService, getScope());
 | |
|         }
 | |
|         return site;
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Returns an array of all the roles that can be assigned to a member of a site.
 | |
|      * 
 | |
|      * @return  String[]    roles available to assign to a member of a site
 | |
|      */
 | |
|     public String[] listSiteRoles()
 | |
|     {
 | |
|         List<String> roles = this.siteService.getSiteRoles();
 | |
|         return (String[])roles.toArray(new String[roles.size()]);
 | |
|     }
 | |
| }
 |