All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sakaiproject.tool.assessment.facade.AgentFacade Maven / Gradle / Ivy

There is a newer version: 23.3
Show newest version
/**********************************************************************************
 * $URL$
 * $Id$
 ***********************************************************************************
 *
 * Copyright (c) 2004, 2005, 2006, 2008 The Sakai Foundation
 *
 * Licensed under the Educational Community 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.opensource.org/licenses/ECL-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.
 *
 **********************************************************************************/

package org.sakaiproject.tool.assessment.facade;

import java.io.Serializable;
import java.util.Collection;
import java.util.Map;

import lombok.extern.slf4j.Slf4j;

import org.sakaiproject.tool.assessment.data.ifc.shared.AgentDataIfc;
import org.sakaiproject.tool.assessment.integration.context.IntegrationContextFactory;
import org.sakaiproject.tool.assessment.integration.helper.ifc.AgentHelper;
import org.sakaiproject.tool.assessment.osid.shared.impl.AgentImpl;
import org.sakaiproject.tool.assessment.osid.shared.impl.IdImpl;

/**
 * 

Description: Facade for agent. * Uses helper to determine integration context implementation.

*

Sakai Project Copyright (c) 2005

*

* @author Ed Smiley * */ @Slf4j public class AgentFacade implements Serializable, AgentDataIfc { /** * */ private static final long serialVersionUID = 1L; private static final AgentHelper helper = IntegrationContextFactory.getInstance().getAgentHelper(); private static final boolean integrated = IntegrationContextFactory.getInstance().isIntegrated(); private AgentImpl agent; private String agentString; private String eid; private boolean accessViaUrl; private String displayId; private String displayIdString; /** * Create AgentFacade for agent Id * @param agentId the agent Id */ public AgentFacade(String agentId) { agent = new AgentImpl(agentId, null, new IdImpl(agentId)); agentString = agentId; eid = helper.getEid(agentId); displayId = helper.getDisplayId(agentId); } /** * Create AgentFacade and have it look up its own agentString (id). */ public AgentFacade() { // If an agent string is available, UNASSIGNED_AGENT_STRING willbe replaced String agentId = helper.getAgentString(AgentHelper.UNASSIGNED_AGENT_STRING); agent = new AgentImpl(agentId, null, new IdImpl(agentId)); agentString = agentId; eid = helper.getEid(AgentHelper.UNASSIGNED_AGENT_STRING); } /** * Get an osid Agent implementation class instance. * * @return an AgentImpl: osid Agent implementation class. */ public static AgentImpl getAgent() { return helper.getAgent(); } /** * Get the agent string. * Static convenience method. * @return the agent string. */ public static String getAgentString() { AgentFacade facade =new AgentFacade(); return facade.agentString; } /** * Get the current user's Eid. * Static convenience method. * @return the eid. */ public static String getEid() { AgentFacade facade =new AgentFacade(); return facade.eid; } /** * Get the agent string. * Preferred approach: instantiate and then call this. * @return the agent string. */ public String getAgentInstanceString() { return this.agentString; } // /** // * Get the agent string. // * @param req the HttpServletRequest // * @param res the HttpServletResponse // * @return the agent string. // */ // public static String getAgentString(HttpServletRequest req, // HttpServletResponse res) // { // return helper.getAgentString(agentString); // } /** * Get the Eid String of an Agent. * @return the Agent Eid. */ public String getEidString() { log.debug("agentfacade.getEid(agentS) agentString = " + agentString); return helper.getEidById(agentString); } /** * Get the Agent display name. * @param agentS the Agent string. * @return the Agent display name. */ public static String getDisplayName(String agentS) { return helper.getDisplayName(agentS); } /** * Get the Agent display name for this agent. * @return the Agent display name. */ public String getDisplayName() { return helper.getDisplayName(this.agentString); } /** * Get the Agent first name. * @return the Agent first name. */ public String getFirstName() { return helper.getFirstName(agentString); } /** * Get the Agent last name. * @return the Agent last name. */ public String getLastName() { return helper.getLastName(agentString); } /** * Get the Agent last name. * @return the Agent last name. */ public String getEmail() { return helper.getEmail(agentString); } /** * Get role for this agent. * @return role string */ public String getRole() { return helper.getRoleForCurrentAgent(agentString); } /** * Get role for agent. * @param agentString the agent string. * @return role string */ public static String getRole(String agentString) { return helper.getRole(agentString); } /** * Get the current site id. * @return the site id. */ public static String getCurrentSiteId() { AgentFacade facade = new AgentFacade(); boolean accessViaUrl = facade.isAccessViaUrl(); return helper.getCurrentSiteId(accessViaUrl); } /** * Get the current site name. * @return the site name. */ public static String getCurrentSiteName() { AgentFacade facade = new AgentFacade(); boolean accessViaUrl = facade.isAccessViaUrl(); return helper.getCurrentSiteName(accessViaUrl); } /** * Get the site name. * @param siteId site id * @return the site name. */ public static String getSiteName(String siteId) { return helper.getSiteName(siteId); } public String getIdString() { return agentString; } // should phrase out this one -daisyf /** * Get the display name for a specific agent id string. * @param agentId the agent id string. * @return the display name. */ public static String getDisplayNameByAgentId(String agentId) { return helper.getDisplayNameByAgentId(agentId); } /** * Create anonymous user and return the anonymous user id. * @return the anonymous user id. */ public static String createAnonymous() { AgentFacade facade = new AgentFacade(); return helper.createAnonymous(facade); } /** * Is this an integrated environment? * @return true, in this implementation */ public static boolean isIntegratedEnvironment() { return integrated; } // /** // * Get current site id from within an external servlet. // * @param req the HttpServletRequest // * @param res the HttpServletResponse // * @return teh site id. // */ // public static String getCurrentSiteIdFromExternalServlet(HttpServletRequest // req, HttpServletResponse res) // { // return helper.getCurrentSiteIdFromExternalServlet(req, res); // } /** * Get the anonymous user id. * @return the anonymous user id. */ public static String getAnonymousId() { AgentFacade facade = new AgentFacade(); String agentString = facade.getAgentInstanceString(); return helper.getAnonymousId(agentString); } /** * Change the agent string * @param idString the id string. */ public void setIdString(String idString) { agentString = idString; } /** * Get the anonymous user id. * @return the anonymous user id. */ public static Map getUserRolesFromContextRealm(Collection inUsers) { return helper.getUserRolesFromContextRealm(inUsers); } //cwen public static String getRoleForAgentAndSite(String agentString, String siteId) { return helper.getRoleForAgentAndSite(agentString, siteId); } public boolean isAccessViaUrl() { return (agentString.startsWith("anonymous_")); } public void setAccessViaUrl(boolean accessViaUrl) { this.accessViaUrl = accessViaUrl; } public void setAgentInstanceString(String agentInstanceString) { this.agentString = agentInstanceString; } /** * This is a kludge to work around a JSF scriptlet dependency introduced by cwen * on org.sakaiproject.service.component.cover.ServerConfigurationService. * @todo for 2.2 remove method when done with refactor. * @deprecated * * @return true unless it is turned off */ public static boolean isFileUploadAvailable() { return helper.isFileUploadAvailable(); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((agentString == null) ? 0 : agentString.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; AgentFacade other = (AgentFacade) obj; if (agentString == null) { if (other.agentString != null) return false; } else if (!agentString.equals(other.agentString)) return false; return true; } public static String getDisplayId() { AgentFacade facade =new AgentFacade(); return facade.displayId; } public String getDisplayIdString() { return helper.getDisplayId(agentString); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy