Android Open Source - android-core Resource Manager






From Project

Back to project page android-core.

License

The source code is released under:

Apache License

If you think the Android project android-core listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/** 
 * [SIMINOV FRAMEWORK]//from w w  w  .  java  2s.com
 * Copyright [2015] [Siminov Software Solution LLP|support@siminov.com]
 *
 * 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.
 **/

package siminov.core.resource;

import java.util.Collection;
import java.util.Iterator;
import java.util.LinkedList;

import siminov.core.database.DatabaseBundle;
import siminov.core.database.DatabaseFactory;
import siminov.core.events.EventHandler;
import siminov.core.events.IDatabaseEvents;
import siminov.core.events.ISiminovEvents;
import siminov.core.exception.DeploymentException;
import siminov.core.exception.SiminovCriticalException;
import siminov.core.exception.SiminovException;
import siminov.core.log.Log;
import siminov.core.model.ApplicationDescriptor;
import siminov.core.model.DatabaseDescriptor;
import siminov.core.model.DatabaseMappingDescriptor;
import siminov.core.reader.QuickDatabaseMappingDescriptorReader;
import android.content.Context;



/**
 * It handles and provides all resources needed by SIMINOV.
 * <p>
 * Such As: Provides Application Descriptor, Database Descriptor, Library Descriptor, Database Mapping Descriptor.
 */
public class ResourceManager {

  /*
   * Resources.
   */
  private Context applicationContext = null;
  
  private ApplicationDescriptor applicationDescriptor = null;
  private DatabaseFactory databaseFactory = null;
  
  private static ResourceManager resources = null;
  
  /**
   * Resource Private Constructor
   */
  private ResourceManager() {

    databaseFactory = DatabaseFactory.getInstance();
  }

  /**
   * It provides an singleton instance of ResourceManager class.
   * 
   * @return Resources instance.
   */
  public static ResourceManager getInstance() {
    if(resources == null) {
      resources = new ResourceManager();
    }
    
    return resources;
  }
  

  /**
   * Returns Application Context provided by application.
   * 
   * @return Application Context (android.content.Context).
   */
  public Context getApplicationContext() {
    return this.applicationContext;
  }
  
  /**
   * Set Application context provided by application.
   * @param context Application Context (android.content.Context).
   */
  public void setApplicationContext(final Context context) {
    this.applicationContext = context;
  }
  
  /**
   * Get Application Descriptor object of application.
   * @return Application Descriptor.
   */
  public ApplicationDescriptor getApplicationDescriptor() {
    return this.applicationDescriptor;
  }
  
  /**
   * Set Application Descriptor of application.
   * @param applicationDescriptor Application Descriptor object.
   */
  public void setApplicationDescriptor(final ApplicationDescriptor applicationDescriptor) {
    this.applicationDescriptor = applicationDescriptor;
  }
  
  /**
   * Get iterator of all database descriptors provided in Application Descriptor file.
    <p>
      <pre>
Example: ApplicationDescriptor.si.xml
  
  {@code
  <siminov>
  
    <database-descriptors>
      <database-descriptor>DatabaseDescriptor.si.xml</database-descriptor>
    </database-descriptors>

  </siminov>
  }
  
      </pre>
    </p>
   * @return Iterator which contains all database descriptor paths provided.
   */
  public Iterator<String> getDatabaseDescriptorPaths() {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorsPaths", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND.");
    }

    return this.applicationDescriptor.getDatabaseDescriptorPaths();
  }

  /**
   * Get DatabaseDescriptor based on path provided as per defined in Application Descriptor file.
    <p>
      <pre>
      
Example: ApplicationDescriptor.si.xml
  
  {@code
  <siminov>
  
    <database-descriptors>
      <database-descriptor>DatabaseDescriptor.si.xml</database-descriptor>
    </database-descriptors>

  </siminov>
  }
  
      </pre>
    </p>
   
   * @param databaseDescriptorPath Iterator which contains all database descriptor paths provided.
   * @return Database Descriptor
   */
  public DatabaseDescriptor getDatabaseDescriptorBasedOnPath(final String databaseDescriptorPath) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorBasedOnPath", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND.");
    }

    return this.applicationDescriptor.getDatabaseDescriptorBasedOnPath(databaseDescriptorPath);
  }

  
  /**
   * Get Database Descriptor based on database descriptor name provided as per defined in Database Descriptor file.
    <p>
      <pre>
      
Example: DatabaseDescriptor.xml
  
  {@code
  <database-descriptor>
  
    <property name="database_name">SIMINOV-CORE-SAMPLE</property>
    
  </database-descriptor>
  }
  
      </pre>
    </p>
   
   * 
   * @param databaseDescriptorName Database Descriptor object based on database descriptor name provided.
   */
  public DatabaseDescriptor getDatabaseDescriptorBasedOnName(final String databaseDescriptorName) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorBasedOnName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND.");
    }

    return this.applicationDescriptor.getDatabaseDescriptorBasedOnName(databaseDescriptorName);
  }
  
  /**
   * Get all Database Descriptors object.
   * @return Iterator which contains all Database Descriptors.
   */
  public Iterator<DatabaseDescriptor> getDatabaseDescriptors() {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptors", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    return this.applicationDescriptor.getDatabaseDescriptors();
  }
  
  /**
   * Get Database Descriptor based on POJO class name provided.
   * 
   * @param className POJO class name.
   * @return Database Descriptor object in respect to POJO class name.
   */
  public DatabaseDescriptor getDatabaseDescriptorBasedOnClassName(final String className) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorBasedOnClassName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnClassName(className);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor;
      }
    }
    
    return null;
  }


  /**
   * Get database descriptor name based on class name
   * @param className Name of Class
   * @return Database Descriptor Name
   */
  public String getDatabaseDescriptorNameBasedOnClassName(final String className) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorNameBasedOnClassName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnClassName(className);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor.getDatabaseName();
      }
    }
    
    return null;
  }

  
  /**
   * Get Database Descriptor based on table name provided.
   * 
   * @param tableName Name of table.
   * @return Database Descriptor object in respect to table name.
   */
  public DatabaseDescriptor getDatabaseDescriptorBasedOnTableName(final String tableName) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorBasedOnTableName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnTableName(tableName);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor;
      }
    }
    
    return null;
  }

  
  /**
   * Get database descriptor name based on table name
   * @param tableName Name of Table
   * @return Database Descriptor Name
   */
  public String getDatabaseDescriptorNameBasedOnTableName(final String tableName) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseDescriptorNameBasedOnTableName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnTableName(tableName);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor.getDatabaseName();
      }
    }
    
    return null;
  }

  /**
   * Get Database Mapping based on POJO class name provided.
   * 
   * @param className POJO class name.
   * @return Database Mapping object in respect to POJO class name.
   */
  public DatabaseMappingDescriptor getDatabaseMappingDescriptorBasedOnClassName(final String className) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseMappingBasedOnClassName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnClassName(className);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor.getDatabseMappingDescriptorBasedOnClassName(className);
      }
    }
    
    return null;
  }
  
  
  /**
   * Get Database Mapping based on table name provided.
   * 
   * @param tableName Name of table.
   * @return Database Descriptor object in respect to table name.
   */
  public DatabaseMappingDescriptor getDatabaseMappingDescriptorBasedOnTableName(final String tableName) {
    if(this.applicationDescriptor == null) {
      throw new DeploymentException(ResourceManager.class.getName(), "getDatabaseMappingBasedOnTableName", "Siminov Not Active, INVALID APPLICATION-DESCRIPTOR FOUND");
    }

    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      boolean containsDatabaseMappingInDatabaseDescriptor = databaseDescriptor.containsDatabaseMappingDescriptorBasedOnTableName(tableName);

      if(containsDatabaseMappingInDatabaseDescriptor) {
        return databaseDescriptor.getDatabseMappingDescriptorBasedOnTableName(tableName);
      }
    }
    
    return null;
  }

  
  /**
   * Get all database mapping descriptors
   * @return Database Mapping Descriptors
   */
  public Iterator<DatabaseMappingDescriptor> getDatabaseMappingDescriptors() {
    Collection<DatabaseMappingDescriptor> databaseMappingDescriptors = new LinkedList<DatabaseMappingDescriptor>();
    Iterator<DatabaseDescriptor> databaseDescriptors = this.applicationDescriptor.getDatabaseDescriptors();
  
    while(databaseDescriptors.hasNext()) {
      DatabaseDescriptor databaseDescriptor = databaseDescriptors.next();
      
      Iterator<DatabaseMappingDescriptor> databaseMappings = databaseDescriptor.getDatabaseMappingDescriptors();
      while(databaseMappings.hasNext()) {
        DatabaseMappingDescriptor databaseMappingDescriptor = databaseMappings.next();
        databaseMappingDescriptors.add(databaseMappingDescriptor);
      }
    }
    
    return databaseMappingDescriptors.iterator();
  }

  
  /**
   * Get database mapping descriptor Object based on class name provided. If database mapping descriptor object not present in resource layer, it will parse DatabaseMappingDescriptor.si.xml file defined by application and will place it in resource layer.
   * @param className Full name of class.
   * @return DatabaseMappingDescriptor object.
   * @throws SiminovException If any exception occur while getting database mapping descriptor object.
   */
  public DatabaseMappingDescriptor requiredDatabaseMappingDescriptorBasedOnClassName(final String className) {
    DatabaseMappingDescriptor databaseMapping = getDatabaseMappingDescriptorBasedOnClassName(className);

    if(databaseMapping == null) {
      Log.debug(getClass().getName(), "requiredDatabaseMappingDescriptorBasedOnClassName(" + className + ")", "Database Mapping Model Not registered With Siminov, MODEL: " + className);
      
      QuickDatabaseMappingDescriptorReader quickDatabaseMappingDescriptorParser = null;
      try {
        quickDatabaseMappingDescriptorParser = new QuickDatabaseMappingDescriptorReader(className);
        quickDatabaseMappingDescriptorParser.process();
      } catch(SiminovException ce) {
        Log.error(getClass().getName(), "requiredDatabaseMappingDescriptorBasedOnClassName(" + className + ")", "SiminovException caught while doing quick database mapping parsing, DATABASE-MAPPING-CLASS-NAME: " + className + ", " + ce.getMessage());
        throw new SiminovCriticalException(getClass().getName(), "requiredDatabaseMappingDescriptorBasedOnClassName(" + className + ")", "SiminovException caught while doing quick database mapping parsing, DATABASE-MAPPING-CLASS-NAME: " + className  + ", " + ce.getMessage());
      }
      
      DatabaseMappingDescriptor foundDatabaseMapping = quickDatabaseMappingDescriptorParser.getDatabaseMapping();
      if(foundDatabaseMapping == null) {
        Log.error(getClass().getName(), "requiredDatabaseMappingDescriptorBasedOnClassName(" + className + ")", "Database Mapping Model Not registered With Siminov, DATABASE-MAPPING-MODEL: " + className);
        throw new SiminovCriticalException(getClass().getName(), "requiredDatabaseMappingDescriptorBasedOnClassName(" + className + ")", "Database Mapping Model Not registered With Siminov, DATABASE-MAPPING-MODEL: " + className);
      }
      
      return foundDatabaseMapping;
    }
    
    return databaseMapping;
  }

  
  
  /**
   * Get IDatabase object based on Database Descriptor name.
   * @param databaseName Name of Database Descriptor.
   * @return IDatabase object.
   */
  public DatabaseBundle getDatabaseBundle(final String databaseName) {
    
    DatabaseDescriptor databaseDescriptor = getDatabaseDescriptorBasedOnName(databaseName);
    return this.databaseFactory.getDatabaseBundle(databaseDescriptor);
  }

  /**
   * Get all IDatabase objects contain by application.
   * @return Iterator which contains all IDatabase objects.
   */
  public Iterator<DatabaseBundle> getDatabaseBundles() {
    return this.databaseFactory.getDatabaseBundles();
  }
  

  /**
   * Remove IDatabase object from Resources based on Database Descriptor name.
   * @param databaseDescriptorName Database Descriptor name.
   */
  public void removeDatabaseBundle(final String databaseDescriptorName) {
    
    DatabaseDescriptor databaseDescriptor = getDatabaseDescriptorBasedOnName(databaseDescriptorName);
    this.databaseFactory.removeDatabaseBundle(databaseDescriptor);
  }
  

  

  /**
   * Get SIMINOV-EVENT Handler
   * @return ISiminovEvents implementation object as per defined by application.
   */
  public ISiminovEvents getSiminovEventHandler() {
    return EventHandler.getInstance().getSiminovEventHandler();
  }
  
  /**
   * Get DATABASE-EVENT Handler
   * @return IDatabaseEvents implementation object as per defined by application.
   */
  public IDatabaseEvents getDatabaseEventHandler() {
    return EventHandler.getInstance().getDatabaseEventHandler();
  }
}




Java Source Code List

siminov.core.Constants.java
siminov.core.IInitializer.java
siminov.core.Initializer.java
siminov.core.Siminov.java
siminov.core.database.Clause.java
siminov.core.database.DatabaseBundle.java
siminov.core.database.DatabaseFactory.java
siminov.core.database.DatabaseHelper.java
siminov.core.database.DatabaseUtils.java
siminov.core.database.Database.java
siminov.core.database.Where.java
siminov.core.database.design.IAverageClause.java
siminov.core.database.design.IAverage.java
siminov.core.database.design.ICountClause.java
siminov.core.database.design.ICount.java
siminov.core.database.design.IDataTypeHandler.java
siminov.core.database.design.IDatabaseImpl.java
siminov.core.database.design.IDatabase.java
siminov.core.database.design.IDeleteClause.java
siminov.core.database.design.IDelete.java
siminov.core.database.design.IGroupConcatClause.java
siminov.core.database.design.IGroupConcat.java
siminov.core.database.design.IMaxClause.java
siminov.core.database.design.IMax.java
siminov.core.database.design.IMinClause.java
siminov.core.database.design.IMin.java
siminov.core.database.design.IQueryBuilder.java
siminov.core.database.design.ISelectClause.java
siminov.core.database.design.ISelect.java
siminov.core.database.design.ISumClause.java
siminov.core.database.design.ISum.java
siminov.core.database.design.ITotalClause.java
siminov.core.database.design.ITotal.java
siminov.core.database.sqlite.DataTypeHandler.java
siminov.core.database.sqlite.DatabaseImpl.java
siminov.core.database.sqlite.QueryBuilder.java
siminov.core.events.EventHandler.java
siminov.core.events.IDatabaseEvents.java
siminov.core.events.ISiminovEvents.java
siminov.core.exception.DatabaseException.java
siminov.core.exception.DeploymentException.java
siminov.core.exception.IException.java
siminov.core.exception.PrematureEndOfParseException.java
siminov.core.exception.SiminovCriticalException.java
siminov.core.exception.SiminovException.java
siminov.core.log.Log.java
siminov.core.model.ApplicationDescriptor.java
siminov.core.model.DatabaseDescriptor.java
siminov.core.model.DatabaseMappingDescriptor.java
siminov.core.model.IDescriptor.java
siminov.core.model.LibraryDescriptor.java
siminov.core.reader.ApplicationDescriptorReader.java
siminov.core.reader.DatabaseDescriptorReader.java
siminov.core.reader.DatabaseMappingDescriptorReader.java
siminov.core.reader.LibraryDescriptorReader.java
siminov.core.reader.QuickDatabaseMappingDescriptorReader.java
siminov.core.reader.SiminovSAXDefaultHandler.java
siminov.core.resource.ResourceManager.java
siminov.core.utils.ClassUtils.java
siminov.core.utils.EmptyIterator.java
siminov.core.utils.Utils.java