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

com.untzuntz.ustack.data.SiteAccount Maven / Gradle / Ivy

There is a newer version: 2.0.14
Show newest version
package com.untzuntz.ustack.data;

import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.Hashtable;
import java.util.List;
import java.util.Vector;

import org.apache.log4j.Logger;
import org.bson.types.ObjectId;

import com.Ostermiller.util.CSVParser;
import com.Ostermiller.util.LabeledCSVParser;
import com.mongodb.BasicDBList;
import com.mongodb.BasicDBObject;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.untzuntz.ustack.aaa.ResourceDefinition;
import com.untzuntz.ustack.aaa.ResourceLink;
import com.untzuntz.ustack.exceptions.AccountExistsException;
import com.untzuntz.ustack.exceptions.InvalidSiteAccountName;
import com.untzuntz.ustack.exceptions.PasswordLengthException;
import com.untzuntz.ustack.main.UAppCfg;
import com.untzuntz.ustack.main.UOpts;

/**
 * A 'Site'
 * 
 * @author jdanner
 *
 */
public class SiteAccount extends UntzDBObject {

	private static final long serialVersionUID = 1L;
	private static Logger logger = Logger.getLogger(SiteAccount.class);
	
	public static final String STATUS_DISABLED = "Disabled";
	public static final String STATUS_ACTIVE = "Active";
	
	public String getCollectionName() { return "sites"; }
	
	public static DBCollection getDBCollection() {
		return new SiteAccount().getCollection();
	}
	
	public static SiteAccount getTestObject() {
		
		SiteAccount u = new SiteAccount();
		
		u.setSiteName("Test Site");
		u.setAddress1("123 Main St.");
		u.setAddress2("Suite 123");
		u.setCity("San Francisco");
		u.setState("California");
		u.setPostalCode("98401");
		u.setCountry("United States");
		u.setTimeZone("Usa/Pacific");
		u.setPrimaryTelephone(new BasicDBObject("countryCode", "1").append("phoneNumber", "333-444-5555"));
		
		return u;
		
	}

	private SiteAccount()
	{
		// setup basic values on account
		put("created", new Date());
	}
	
	public String getSiteId() {
		return get("_id") + "";
	}

	/** Return the name of the database that houses the 'users' collection */
	public static final String getDatabaseName() {
		
		if (UOpts.getString(UAppCfg.DATABASE_SITES_COL) != null)
			return UOpts.getString(UAppCfg.DATABASE_SITES_COL);
		
		return UOpts.getAppName();
		
	}

	/**
	 * Generate a SiteAccount object from the MongoDB object
	 * @param user
	 */
	public SiteAccount(DBObject site) {
		super(site);
	}
	
	/** Rename the site - this runs a check to verify the new name isn't in use */
	public void renameSite(String siteName) throws AccountExistsException,InvalidSiteAccountName
	{
		if (siteName == null || siteName.length() == 0)
			throw new InvalidSiteAccountName("Site");
		
		SiteAccount site = getSite(siteName);
		if (site != null) // already exists
			throw new AccountExistsException("Site");

		put("siteName", siteName);
	}

	/** Internal set site's name */
	private void setSiteName(String siteName)
	{
		put("siteName", siteName);
	}

	/** Return the site name */
	public String getSiteName()
	{
		return (String)get("siteName");
	}
	
	public void setPrimaryTelephone(DBObject phone)
	{
		if (phone == null)
			removeField("primaryTelephone");
		else
			put("primaryTelephone", phone);
	}
	
	public DBObject getPrimaryTelephone() {
		return (DBObject)get("primaryTelephone");
	}
	
	public String getPrimaryTelephoneString()
	{
		DBObject phone = getPrimaryTelephone();
		if (phone == null)
			return "";
		return (String)phone.get("countryCode") + " " + (String)phone.get("phoneNumber");
	}
	
	public void setFaxNumber(DBObject phone)
	{
		if (phone == null)
			removeField("faxNumber");
		else
			put("faxNumber", phone);
	}
	
	public DBObject getFaxNumber() {
		return (DBObject)get("faxNumber");
	}
	
	public String getFaxNumberString()
	{
		DBObject phone = getFaxNumber();
		if (phone == null)
			return "";
		return (String)phone.get("countryCode") + " " + (String)phone.get("phoneNumber");
	}
	
	/**
	 * Sets the address book value for this object
	 * @param book
	 */
	public void setAddressBook(AddressBook book)
	{
		if (book == null)
			removeField("addrBookId");
		else
			put("addrBookId", book.getAddressBookId());
	}

	/**
	 * Returns the address book for this object
	 * @return
	 */
	public AddressBook getAddressBook()
	{
		AddressBook ret = null;
		String id = getString("addrBookId");
		
		if (id == null)
		{
			try {
				ret = AddressBook.getBySiteId(getSiteId());
				ret.save();
				setAddressBook(ret);
				save();
			} catch (Exception er) {
				logger.error("General failure while trying to create an address book", er);
			}
		}
		else
			ret = AddressBook.getById( id );
		
		return ret;
	}
	
	public String getSuffix()
	{
		return getString("suffix");
	}
	
	public String getTimeZone()
	{
		return getString("timeZone");
	}
	
	public void setTimeZone(String tz)
	{
		if (tz != null && tz.length() > 0)
			put("timeZone", tz);
		else
			removeField("timeZone");
	}
	
	public boolean isPayOnReceive()
	{
		if ("true".equalsIgnoreCase(getString("payOnReceive")))
			return true;
		
		return false;
	}
	
	public void setPayOnReceive(boolean pay)
	{
		put("payOnReceive", pay);
	}
	
	public String getCreditAccount()
	{
		return getString("creditAccountId");
	}
	
	public void setCreditAccount(String c)
	{
		if (c != null && c.length() > 0)
			put("creditAccountId", c);
		else
			removeField("creditAccountId");
	}

	public String getCountry()
	{
		return getString("country");
	}
	
	public void setCountry(String c)
	{
		if (c != null && c.length() > 0)
			put("country", c);
		else
			removeField("country");
	}
	
	public String getAddressString() {
		
		String a1 = getAddress1();
		if (getAddress2() != null && getAddress2().length() > 0)
			a1 += " - " + getAddress2();
		
		return a1;
		
	}
	
	public String getAddress1()
	{
		return getString("address1");
	}
	
	public void setAddress1(String data)
	{
		if (data != null && data.length() > 0)
			put("address1", data);
		else
			removeField("address1");
	}
	
	public String getAddress2()
	{
		return getString("address2");
	}
	
	public void setAddress2(String data)
	{
		if (data != null && data.length() > 0)
			put("address2", data);
		else
			removeField("address2");
	}
	
	public String getCity()
	{
		return getString("city");
	}
	
	public void setCity(String data)
	{
		if (data != null && data.length() > 0)
			put("city", data);
		else
			removeField("city");
	}
	
	public String getState()
	{
		return getString("state");
	}
	
	public void setState(String data)
	{
		if (data != null && data.length() > 0)
			put("state", data);
		else
			removeField("state");
	}

	public String getPostalCode()
	{
		return getString("postalCode");
	}
	
	public void setPostalCode(String data)
	{
		if (data != null && data.length() > 0)
			put("postalCode", data);
		else
			removeField("postalCode");
	}

	/**
	 * Returns the total number of user accounts
	 * 
	 * @return
	 */
	public static long getAccountCount()
	{
		return MongoDB.getCollection(getDatabaseName(), "sites").count();
	}
	
	/**
	 * Determines if the site account is disabled by the site account status
	 * @return
	 */
	public boolean isDisabled()
	{
		String status = getStatus();
		
		if (STATUS_DISABLED.equalsIgnoreCase(status))
			return true;
		
		return false;
	}

	/**
	 * Returns the current site status
	 * 
	 * @return
	 */
	public String getStatus()
	{
		String status = (String)get("status");
		if (status == null)
			return STATUS_ACTIVE;
		
		return status;
	}

	/** Resets and rebuilds the manage and can manage lists */
	protected void calculateManageLists()
	{
		setManagedByList(new BasicDBList());
		
		BasicDBList resourceLinkList = getResourceLinkList();
		for (int q = 0; q < resourceLinkList.size(); q++)
		{
			ResourceLink resourceLink = new ResourceLink( (DBObject)resourceLinkList.get(q) );
			if (resourceLink == null || resourceLink.getResourceDefinition() == null)
				continue;
			
			BasicDBList managedByList = resourceLink.getResourceDefinition().getManagedByList();
			for (int i = 0; i < managedByList.size(); i++)
				addManagedBy( (String)managedByList.get(i) );
			
			BasicDBList resLinkMgBy = (BasicDBList)resourceLink.get("managedBy");
			for (int i = 0; resLinkMgBy != null && i < resLinkMgBy.size(); i++)
			{
				String mgmtBy = (String)resLinkMgBy.get(i);
				addManagedBy( mgmtBy );
			}
		}
	}

	public static SiteAccount createSite(String siteName) throws AccountExistsException,InvalidSiteAccountName
	{
		return createSite(siteName, true);
	}
	
	/**
	 * Create a new site account
	 * 
	 * @param userName
	 * @param password
	 * @return
	 * @throws AccountExistsException
	 * @throws PasswordLengthException
	 */
	public static SiteAccount createSite(String siteName, boolean checkForDupe) throws AccountExistsException,InvalidSiteAccountName
	{
		if (siteName == null || siteName.length() == 0)
			throw new InvalidSiteAccountName("Site");
		
		SiteAccount site = null;
		
		if (checkForDupe)
			site = getSite(siteName);
		
		if (site != null) // already exists
			throw new AccountExistsException("Site");
		
		// create the actual account
		site = new SiteAccount();
		site.setSiteName(siteName);
		logger.info("Creating site account '" + siteName + "'");
		
		return site;
	}
	
	public static List getAll()
	{
		List ret = new Vector();
		
		DBCursor cur = new SiteAccount().getCollection().find();
		while (cur.hasNext())
			ret.add(new SiteAccount(cur.next()));
		
		return ret;
	}

	/**
	 * Get a site account by name
	 * 
	 * @param userName
	 * @return
	 */
	public static SiteAccount getSite(String siteName)
	{
		DBObject site = new SiteAccount().getCollection().findOne(BasicDBObjectBuilder.start("siteName", siteName).get());
		
		if (site == null)
			return null;
		
		return new SiteAccount(site);
	}
	
	/**
	 * Get a site account by id
	 * 
	 * @param id
	 * @return
	 */
	public static SiteAccount getSiteById(String id)
	{
		if (id == null)
			return null;

		try {
			
			DBObject site = new SiteAccount().getCollection().findOne(BasicDBObjectBuilder.start("_id", new ObjectId(id)).get());
			
			if (site == null)
				return null;
			
			return new SiteAccount(site);
			
		} catch (IllegalArgumentException iae) {}
		return null;
	}
	
	public static SiteAccount getByField(String field, String value)
	{
		DBObject search = BasicDBObjectBuilder.start(field, value).get();
		DBObject site = new SiteAccount().getCollection().findOne(search);
		
		if (site == null)
			return null;
		
		return new SiteAccount(site);
	}
	
	/**
	 * Import Data
	 * 
	 * @param col
	 * @param in
	 * @throws IOException
	 */
	public static int importData(DBCollection col, InputStream in, String userName) throws IOException
	{
		LabeledCSVParser myParser = new LabeledCSVParser( new CSVParser(in) );

		Country usa = Country.getCountryByName("United States");
		Hashtable found = new Hashtable();
		Hashtable defs = new Hashtable();
		
		int cnt = 0;
		SiteAccount site = null;
		while(myParser.getLine() != null)
		{
			logger.info("Importing " +  cnt + "...");
			
			String pk = myParser.getValueByLabel("primaryKey");
			if (pk == null || pk.length() == 0)
				continue;

			if (found.get(pk) != null)
				continue;

			String siteName = myParser.getValueByLabel("siteName");
			site = null;
			DBObject obj = col.findOne(BasicDBObjectBuilder.start("primaryKey", pk).get());
			if (obj != null)
				site = new SiteAccount(obj);
			if (site == null)
			{
				try {
					site = SiteAccount.createSite(siteName); 
				} catch (Exception er) { }
				
				if (site == null)
				{
					// try to create the site with a - Street Name in it
					String addr1 = myParser.getValueByLabel("address1");
					if (addr1 != null && addr1.length() > 0)
					{
						if (addr1.indexOf(" ") > -1)
							addr1 = addr1.substring( addr1.indexOf(" ") + 1 );
	
						try{
							siteName = siteName + " - " + addr1;
							site = SiteAccount.createSite(siteName); 
						} catch (Exception er) { 
							logger.warn("Could not create site: '" + siteName + "'"); 
						}
					}
				}
				
				// we failed --- add an index
				if (site == null)
				{
					int idx = 1;
					while (site == null && idx < 20)
					{
						try { 
							if (idx > 1)
								site = SiteAccount.createSite(siteName + " " + idx); 
							else
								site = SiteAccount.createSite(siteName); 
						} catch (Exception er) { 
							logger.warn("Could not create site: '" + siteName + "'"); 
							idx++;
						}
					}
				}
			}
			
			if (site == null)
				continue;
			
			String[] labels = myParser.getLabels();
			for (String hdr : labels)
			{
				String val = myParser.getValueByLabel(hdr);
				if (val != null)
				{
					if ("primaryTelephone".equalsIgnoreCase(hdr))
					{
						if (val.length() > 0)
							site.setPrimaryTelephone(UntzDBObject.getPhoneObject("1", val));
					}
					else if ("faxNumber".equalsIgnoreCase(hdr))
					{
						if (val.length() > 0)
							site.setFaxNumber(UntzDBObject.getPhoneObject("1", val));
					}
					else if ("resourceRole".equalsIgnoreCase(hdr)) {}
					else if ("siteName".equalsIgnoreCase(hdr)) {}
					else if ("resourceName".equalsIgnoreCase(hdr))
					{
						ResourceDefinition def = defs.get(val);
						if (def == null)
							def = ResourceDefinition.getByName(val);

						ResourceLink link = new ResourceLink(def, myParser.getValueByLabel("resourceRole"));
						site.addResourceLink(userName, link);
					}
					else if ("stateAbbrev".equalsIgnoreCase(hdr))
					{
						if (site.get("state") == null)
						{
							if ("United States".equalsIgnoreCase(myParser.getValueByLabel("country")))
							{
								DBObject state = usa.getStateByAbbrev(val);
								if (state != null)
									site.put("state", (String)state.get("state"));
							}
						}
					}
					else if ("managedBy".equalsIgnoreCase(hdr))
						site.addManagedBy(val);
					else
						site.put(hdr, val);
				}
			}

			UDataMgr.calculateLatLong(site);
			SiteAccount.save(site, userName);
			found.put(pk, "T");
			
			cnt++;
		}		

		in.close();

		return cnt;
	}

	/**
	 * Returns a list of users that are part of this site and match the resource/role
	 * 
	 * @param resource
	 * @param role
	 * @return
	 */
	public List getUsersByResourceRole(String resource, String role)
	{
		ResourceDefinition def = ResourceDefinition.getByName(resource);
		if (def == null)
			def = ResourceDefinition.getByInternalName(resource);
		
		DBObject elem = new BasicDBObject();
		elem.put("resDefId", def.get("_id") + "");
		elem.put("role", role);
		elem.put("siteId", "" + get("_id"));
		
		DBObject extras = BasicDBObjectBuilder.start("resourceLinkList", BasicDBObjectBuilder.start("$elemMatch", elem).get()).get();
		
		return UserAccount.search(null, null, UserAccount.getDBCollection(), extras);
	}

	/**
	 * Returns the first user found that is part of this site and matches the resource/role
	 * 
	 * @param resource
	 * @param role
	 * @return
	 */
	public UserAccount getUserByResourceRole(String resource, String role)
	{
		List objects = getUsersByResourceRole(resource, role);
		if (objects.size() > 0)
			return new UserAccount(objects.get(0));

		return null;
	}
	
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy