Exemple #1
0
        public UserReturnValue GetUserByUid(Guid logonId, int uid)
        {
            //UserReturnValue userReturnValue = new UserReturnValue();
            DsSystemUsers   systemUserReturnValue = new DsSystemUsers();
            UserReturnValue userReturnValue       = new UserReturnValue();

            userReturnValue.User = new User();
            //DsBranches branchReturnValue = new DsBranches();
            //OrganisationReturnValue organisationReturnValue = new OrganisationReturnValue();
            //dsDepartments departmentReturnValue = new dsDepartments();
            //DsWorkTypes workTypeReturnValue = new DsWorkTypes();
            //EarnerReturnValue earnerReturnValue = new EarnerReturnValue();
            //DsPersons personReturnValue = new DsPersons();

            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:
                        // Can do everything
                        break;

                    case DataConstants.UserType.Client:
                    case DataConstants.UserType.ThirdParty:
                        throw new Exception("Access denied");

                    default:
                        throw new Exception("Access denied");
                    }

                    systemUserReturnValue = SrvUserLookup.GetUser(uid);//SrvUserCommon.GetSystemUser();

                    userReturnValue.User.Forename           = systemUserReturnValue.Tables[0].Rows[0]["PersonName"].ToString();
                    userReturnValue.User.Lastname           = systemUserReturnValue.Tables[0].Rows[0]["PersonSurname"].ToString();
                    userReturnValue.User.MemOrOrgId         = Guid.Parse(systemUserReturnValue.Tables[0].Rows[0]["MemberID"].ToString());
                    userReturnValue.User.Name               = systemUserReturnValue.Tables[0].Rows[0]["name"].ToString();
                    userReturnValue.User.Title              = systemUserReturnValue.Tables[0].Rows[0]["PersonTitle"].ToString();
                    userReturnValue.User.Uid                = int.Parse(systemUserReturnValue.Tables[0].Rows[0]["uid"].ToString());
                    userReturnValue.User.UserDefaBranch     = Guid.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserDefaBranch"].ToString());
                    userReturnValue.User.UserDefaDepartment = int.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserDefaDepartment"].ToString());
                    userReturnValue.User.UserDefaEarner     = Guid.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserDefaEarner"].ToString());
                    userReturnValue.User.UserDefaPartner    = Guid.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserDefaPartner"].ToString());
                    userReturnValue.User.UserDefaWorkType   = Guid.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserDefaWorkType"].ToString());
                    userReturnValue.User.UserType           = int.Parse(systemUserReturnValue.Tables[0].Rows[0]["UserType"].ToString());
                }
                finally
                {
                    // Remove the logged on user's ApplicationSettings from the
                    // list of concurrent sessions
                    Host.UnloadLoggedOnUser();
                }
            }
            catch (System.Data.SqlClient.SqlException)
            {
                userReturnValue.Success = false;
                userReturnValue.Message = Functions.SQLErrorMessage;
            }
            catch (Exception ex)
            {
                userReturnValue.Success = false;
                userReturnValue.Message = ex.Message;
            }

            return(userReturnValue);
        }
Exemple #2
0
        /// <summary>
        /// Search for a user
        /// </summary>
        /// <param name="logonId"></param>
        /// <param name="collectionRequest"></param>
        /// <param name="criteria"></param>
        /// <returns></returns>
        public UserSearchReturnValue UserSearch(Guid logonId, CollectionRequest collectionRequest,
                                                IRIS.Law.WebServiceInterfaces.Utilities.UserSearchCriteria criteria)
        {
            IRIS.Law.WebServiceInterfaces.Utilities.UserSearchReturnValue returnValue = new IRIS.Law.WebServiceInterfaces.Utilities.UserSearchReturnValue();

            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:
                        // Can do everything
                        break;

                    case DataConstants.UserType.Client:
                    case DataConstants.UserType.ThirdParty:
                        throw new Exception("Access denied");

                    default:
                        throw new Exception("Access denied");
                    }


                    // Create a data list creator for a list of Users
                    DataListCreator <IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem> dataListCreator = new DataListCreator <IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem>();

                    // Declare an inline event (annonymous delegate) to read the
                    // dataset if it is required
                    dataListCreator.ReadDataSet += delegate(object Sender, ReadDataSetEventArgs e)
                    {
                        e.DataSet = SrvUserLookup.UserSearch(criteria.UserType, criteria.Name);
                    };

                    // Create the data list
                    returnValue.Users = dataListCreator.Create(logonId,
                                                               // Give the query a name so it can be cached
                                                               "UserSearch",
                                                               // 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("UserId", "uid"),
                        new ImportMapping("UserName", "name"),
                        new ImportMapping("Forename", "PersonName"),
                        new ImportMapping("Surname", "PersonSurname")
                    }
                                                               );
                }
                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);
        }
Exemple #3
0
        /// <summary>
        /// Get details about multiple Users.
        /// </summary>
        /// <param name="logonId">Logon id obtained when logging on to the logon service.</param>
        /// <param name="UserIds">Array of user ids</param>
        /// <returns></returns>
        public UserSearchReturnValue GetMultipleUserDetails(Guid logonId, int[] UserIds)
        {
            IRIS.Law.WebServiceInterfaces.Utilities.UserSearchReturnValue returnValue = new IRIS.Law.WebServiceInterfaces.Utilities.UserSearchReturnValue();

            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:
                        // Can do everything
                        break;

                    case DataConstants.UserType.Client:
                        // Can only access themself
                        if (UserIds.Length != 1)
                        {
                            throw new Exception("Access denied");
                        }

                        if (UserInformation.Instance.DbUid != UserIds[0])
                        {
                            throw new Exception("Access denied");
                        }
                        break;

                    case DataConstants.UserType.ThirdParty:
                        // Can only access themself
                        if (UserIds.Length != 1)
                        {
                            throw new Exception("Access denied");
                        }

                        if (UserInformation.Instance.DbUid != UserIds[0])
                        {
                            throw new Exception("Access denied");
                        }
                        break;

                    default:
                        throw new Exception("Access denied");
                    }

                    DataListCreator <IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem> dataListCreator = new DataListCreator <IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem>();

                    returnValue.Users = new DataList <IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem>();

                    returnValue.Users.FirstRowNumber = 0;

                    foreach (IRIS.Law.PmsCommonData.DsUsersLookup.uvw_UsersRow Row in
                             SrvUserLookup.GetMultipleUsers(UserIds).Tables[0].Rows)
                    {
                        IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem Item = new IRIS.Law.WebServiceInterfaces.Utilities.UserSearchItem();

                        Item.UserId   = Row.uid;
                        Item.UserName = Row.name;
                        Item.Forename = Row.PersonName;
                        Item.Surname  = Row.PersonSurname;

                        returnValue.Users.TotalRowCount++;
                        returnValue.Users.Rows.Add(Item);
                    }
                }
                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);
        }