Click here to Skip to main content
15,886,422 members
Articles / Web Development / ASP.NET

Using Silverlight in Enterprise: RAD of User Friendly Database Access

Rate me:
Please Sign up or sign in to vote.
4.81/5 (19 votes)
31 Jul 2009CPOL8 min read 58.1K   7K   81  
This article introduces FulcrumWeb RAD Framework - A Silverlight UI Engine to build user friendly database driven applications
/********************************************************************
 *  FulcrumWeb RAD Framework - Fulcrum of your business             *
 *  Copyright (c) 2002-2009 FulcrumWeb, ALL RIGHTS RESERVED         *
 *                                                                  *
 *  THE SOURCE CODE CONTAINED WITHIN THIS FILE AND ALL RELATED      *
 *  FILES OR ANY PORTION OF ITS CONTENTS SHALL AT NO TIME BE        *
 *  COPIED, TRANSFERRED, SOLD, DISTRIBUTED, OR OTHERWISE MADE       *
 *  AVAILABLE TO OTHER INDIVIDUALS WITHOUT EXPRESS WRITTEN CONSENT  *
 *  AND PERMISSION FROM FULCRUMWEB. CONSULT THE END USER LICENSE    *
 *  AGREEMENT FOR INFORMATION ON ADDITIONAL RESTRICTIONS.           *
 ********************************************************************/

using System;
using System.Collections;
using Framework.Utils;

namespace Framework.Metadata
{
	/// <summary>
	/// Cache for store previously calculated entity rules defined by WHERE clause.
	/// </summary>
	public class CxEntityRuleCache
	{
    //-------------------------------------------------------------------------
    protected Hashtable m_Cache = new Hashtable();
    //-------------------------------------------------------------------------
    /// <summary>
    /// Constructor.
    /// </summary>
		public CxEntityRuleCache()
		{
		}
    //-------------------------------------------------------------------------
    /// <summary>
    /// Returns entity primary key value.
    /// </summary>
    /// <param name="entityUsage">entity usage metadata</param>
    /// <param name="entityValueProvider">entity value provider</param>
    /// <returns>primary key value</returns>
    protected string GetEntityPkValue(
      CxEntityUsageMetadata entityUsage,
      IxValueProvider entityValueProvider)
    {
      if (entityUsage != null && entityValueProvider != null)
      {
        return entityUsage.EncodePrimaryKeyValuesAsString(entityValueProvider);
      }
      return null;
    }
    //-------------------------------------------------------------------------
    /// <summary>
    /// Returns cached rule calculation value.
    /// </summary>
    /// <param name="rule">rule to get value for</param>
    /// <param name="entityUsage">entity usage metadata</param>
    /// <param name="entityValueProvider">value provider to get entity values</param>
    /// <returns>True, False or Undefined (if value was not cached)</returns>
    public NxBoolEx GetCachedValue(
      CxPermissionRule rule,
      CxEntityUsageMetadata entityUsage,
      IxValueProvider entityValueProvider)
    {
      if (rule != null && 
          entityUsage != null && 
          entityValueProvider != null)
      {
        string entityPkValue = GetEntityPkValue(entityUsage, entityValueProvider);
        if (CxUtils.NotEmpty(entityPkValue))
        {
          Hashtable entityUsageCache = (Hashtable) m_Cache[rule];
          if (entityUsageCache != null)
          {
            Hashtable entityCache = (Hashtable) entityUsageCache[entityUsage];
            if (entityCache != null)
            {
              object result = entityCache[entityPkValue];
              if (result is NxBoolEx)
              {
                return (NxBoolEx) result;
              }
            }
          }
        }
      }
      return NxBoolEx.Undefined;
    }
    //-------------------------------------------------------------------------
    /// <summary>
    /// Saves calculated value in the cache.
    /// </summary>
    /// <param name="rule">rule to set value for</param>
    /// <param name="entityUsage">entity usage metadata</param>
    /// <param name="entityValueProvider">value provider to get entity values</param>
    /// <param name="isAllowed">calculated rule result</param>
    public void AddValueToCache(
      CxPermissionRule rule,
      CxEntityUsageMetadata entityUsage,
      IxValueProvider entityValueProvider,
      NxBoolEx isAllowed)
    {
      if (rule != null && 
          entityUsage != null && 
          entityValueProvider != null &&
          isAllowed != NxBoolEx.Undefined)
      {
        string entityPkValue = GetEntityPkValue(entityUsage, entityValueProvider);
        if (CxUtils.NotEmpty(entityPkValue))
        {
          Hashtable entityUsageCache = (Hashtable) m_Cache[rule];
          if (entityUsageCache == null)
          {
            entityUsageCache = new Hashtable();
            m_Cache[rule] = entityUsageCache;
          }
          Hashtable entityCache = (Hashtable) entityUsageCache[entityUsage];
          if (entityCache == null)
          {
            entityCache = new Hashtable();
            entityUsageCache[entityUsage] = entityCache;
          }
          entityCache[entityPkValue] = isAllowed;
        }
      }
    }
    //-------------------------------------------------------------------------
  }
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Ukraine Ukraine
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions