Example #1
0
        /// <summary>
        /// Businesses the source search.
        /// </summary>
        /// <param name="oHostSecurityToken">HostSecurityToken obtained when security provider of IWS is called</param>
        /// <param name="collectionRequest">Information about the collection being requested.</param>
        /// <param name="criteria">Business Source search criteria</param>
        /// <returns></returns>
        public BusinessSourceReturnValue BusinessSourceSearch(HostSecurityToken oHostSecurityToken, CollectionRequest collectionRequest,
                                                              BusinessSourceSearchCriteria criteria)
        {
            BusinessSourceReturnValue returnValue = null;

            if (Functions.ValidateIWSToken(oHostSecurityToken))
            {
                oContactService = new ContactService();
                returnValue     = oContactService.BusinessSourceSearch(Functions.GetLogonIdFromToken(oHostSecurityToken), collectionRequest, criteria);
            }
            else
            {
                returnValue         = new BusinessSourceReturnValue();
                returnValue.Success = false;
                returnValue.Message = "Invalid Token";
            }
            return(returnValue);
        }
        /// <summary>
        /// Businesses the source search.
        /// </summary>
        /// <param name="logonId">Logon id obtained when logging on to the logon service.</param>
        /// <param name="collectionRequest">Information about the collection being requested.</param>
        /// <param name="criteria">Business Source search criteria</param>
        /// <returns></returns>
        public BusinessSourceReturnValue BusinessSourceSearch(Guid logonId, CollectionRequest collectionRequest,
                                BusinessSourceSearchCriteria criteria)
        {
            BusinessSourceReturnValue returnValue = new BusinessSourceReturnValue();

            try
            {
                // Get the logged on user from the current logons and add their
                // ApplicationSettings the list of concurrent sessions.
                Host.LoadLoggedOnUser(logonId);

                try
                {
                    Functions.RestrictRekoopIntegrationUser(UserInformation.Instance.DbUid);
                    switch (UserInformation.Instance.UserType)
                    {
                        case DataConstants.UserType.Staff:
                        case DataConstants.UserType.Client:
                        case DataConstants.UserType.ThirdParty:
                            // Can do everything
                            break;
                        default:
                            throw new Exception("Access denied");
                    }

                    // Create a data list creator for a list of business sources
                    DataListCreator<BusinessSourceSearchItem> dataListCreator = new DataListCreator<BusinessSourceSearchItem>();

                    // Declare an inline event (annonymous delegate) to read the dataset
                    dataListCreator.ReadDataSet += delegate(object Sender, ReadDataSetEventArgs e)
                    {
                        e.DataSet = SrvBusinessSourceLookup.GetBusinessSourceLookup();

                        DataTable dt = Functions.SortDataTable(e.DataSet.Tables[0], "SourceDesc");
                        e.DataSet.Tables.Remove(e.DataSet.Tables[0]);
                        e.DataSet.Tables.Add(dt);
                    };

                    // Create the data list
                    returnValue.BusinessSources = dataListCreator.Create(logonId,
                        // Give the query a name so it can be cached
                        "BusinessSources",
                        // Tell it the query criteria used so if the cache is accessed
                        // again it knows if it is the same query
                        criteria.ToString(),
                        collectionRequest,
                        // Import mappings to map the dataset row fields to the data
                        // list entity properties
                        new ImportMapping[] {
                            new ImportMapping("Id", "SourceId"),
                            new ImportMapping("Description", "SourceDesc"),
                            new ImportMapping("IsArchived", "SourceArchived")
                            }
                        );
                }
                finally
                {
                    // Remove the logged on user's ApplicationSettings from the
                    // list of concurrent sessions
                    Host.UnloadLoggedOnUser();
                }
            }
            catch (System.Data.SqlClient.SqlException)
            {
                returnValue.Success = false;
                returnValue.Message = Functions.SQLErrorMessage;
            }
            catch (Exception Ex)
            {
                returnValue.Success = false;
                returnValue.Message = Ex.Message;
            }

            return returnValue;
        }
        /// <summary>
        /// Gets the business sources.
        /// </summary>
        private void GetBusinessSources()
        {
            ContactServiceClient contactService = null;

            try
            {
                contactService = new ContactServiceClient();
                CollectionRequest collectionRequest = new CollectionRequest();
                BusinessSourceSearchCriteria searchCriteria = new BusinessSourceSearchCriteria();
                BusinessSourceReturnValue returnValue = contactService.BusinessSourceSearch(_logonSettings.LogonId,
                                                        collectionRequest, searchCriteria);
                if (returnValue.Success)
                {
                    _ddlBusinessSource.DataSource = returnValue.BusinessSources.Rows;
                    _ddlBusinessSource.DataTextField = "Description";
                    _ddlBusinessSource.DataValueField = "Id";
                    _ddlBusinessSource.DataBind();
                }
                else
                {
                    throw new Exception(returnValue.Message);
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                if (contactService != null)
                {
                    if (contactService.State != System.ServiceModel.CommunicationState.Faulted)
                        contactService.Close();
                }
            }
        }
 /// <summary>
 /// Businesses the source search.
 /// </summary>
 /// <param name="oHostSecurityToken">HostSecurityToken obtained when security provider of IWS is called</param>
 /// <param name="collectionRequest">Information about the collection being requested.</param>
 /// <param name="criteria">Business Source search criteria</param>
 /// <returns></returns>
 public BusinessSourceReturnValue BusinessSourceSearch(HostSecurityToken oHostSecurityToken, CollectionRequest collectionRequest,
                         BusinessSourceSearchCriteria criteria)
 {
     BusinessSourceReturnValue returnValue = null;
     if (Functions.ValidateIWSToken(oHostSecurityToken))
     {
         oContactService = new ContactService();
         returnValue = oContactService.BusinessSourceSearch(Functions.GetLogonIdFromToken(oHostSecurityToken), collectionRequest, criteria);
     }
     else
     {
         returnValue = new BusinessSourceReturnValue();
         returnValue.Success = false;
         returnValue.Message = "Invalid Token";
     }
     return returnValue;
 }