Click or drag to resize

PFGroup Class

Represents a Packflow group, containing other groups and users.

A group can be organisational (under the site) or role (under an application).

All groups can only include organisational groups, not role groups.

A role group is always related to an application context and a modeling role.

Groups are referenced in RLS and user fields, e.g. for permissions and distribution.

Inheritance Hierarchy

Namespace:  Packflow.Core
Assembly:  MicaSystems.Packflow.Core (in MicaSystems.Packflow.Core.dll) Version: 1.0.0.0 (3.2.0.306)
Syntax
C#
public class PFGroup : PFBaseObject

The PFGroup type exposes the following members.

Constructors
  NameDescription
Public methodPFGroup
Top
Properties
  NameDescription
Public propertyApplicationContextGuid
Gets the parent application context GUID.
Public propertyApplicationContextId
Gets the parent application context id.
Public propertyApplicationGuid
Gets the parent application GUID.
Public propertyApplicationId
Gets the parent application id.
Public propertyBeforeSaveValues
Gets the previous values of modified fields before the latest Save.

Note: this feature is NOT persisted in the database and therefore only concerns this instance.

(Inherited from PFBaseObject.)
Public propertyCanDelete
Checks if the current permission context allows current user to delete this object.
(Inherited from PFBaseObject.)
Public propertyCanRead
Checks if the current permission context allows current user to access this object.
(Inherited from PFBaseObject.)
Public propertyCanUpdate
Checks if the current permission context allows current user to update this object.
(Inherited from PFBaseObject.)
Public propertyCreated
Indicates if this object has been created and is still in database (positive Id).
(Inherited from PFBaseObject.)
Public propertyCreatedAt
Gets the date of creation of this object in the database.
(Inherited from PFBaseObject.)
Public propertyCreatedBy
Gets the user who created this object in the database.
(Inherited from PFBaseObject.)
Public propertyData
Gets the data collection of this object.
(Inherited from PFBaseObject.)
Public propertyDateObjectCreation
Gets the date of the creation of this object in memory.
(Inherited from PFManagedObject.)
Public propertyDeleted
True if this object is flagged as deleted.
(Inherited from PFBaseObject.)
Public propertyDeletedAt
Date of the suppression of this object.
(Inherited from PFBaseObject.)
Public propertyDeletedBy
The user who deleted this object.
(Inherited from PFBaseObject.)
Public propertyDisplayName
Gets the display name.
Public propertyDomainGroup
Gets or sets the domain group.
Public propertyDomainGroupCreateDisabledUsers
Gets or sets a value indicating whether the domain group synchronization can create users, even disabled.
Public propertyDomainGroupSynchronised
Gets a value indicating whether this group is synchronized with a domain group.
Public propertyDomainGroupSyncMode
Gets or sets a value indicating how the group is synchronized with its domain group.
Public propertyDomainGroupSyncModeText
Gets a value indicating how the group is synchronized with its domain group.
Public propertyEnableVersionMergeToResolveSaveConflicts
Gets a value indicating whether versions can be merged to resolve save conflicts. If an object is saved with an older version than the last persisted (in database), the system will try to merge the versions values (if no conflicts between values) and will then save the merged item to database. Note : this setting is NOT persisted and will affect this object instance only.
(Inherited from PFBaseObject.)
Public propertyExists
Indicates if this object has been created, still exists in database and is not flagged for suppression.
(Inherited from PFBaseObject.)
Public propertyGuid
Gets the GUID identifying this object. Must be used if Id is no more viable, example if content were merged.
(Inherited from PFBaseObject.)
Public propertyHasPendingModifications
Checks if there is pending changes. Will check if the values are different from the currently persisted values.
(Inherited from PFBaseObject.)
Public propertyHasPendingPermissionsModifications
Checks if there is pending modifications in permissions. Will compute permissions (RUD) and check if there is differences with current persisted permissions.
(Inherited from PFBaseObject.)
Public propertyId
Gets the id identifying this object. Must be used to find or identify an object because faster than Guid.
(Inherited from PFBaseObject.)
Public propertyIncludedGroups
Gets the list of organisational groups included in this group.
Public propertyKeepBeforeSaveValues
Gets or sets a value indicating whether the Save should keep a collection of the modified fields previous values.

Note: this feature is NOT persisted in the database and therefore only concerns this instance.

(Inherited from PFBaseObject.)
Public propertyLogger
Gets the logger, used to log any useful warning, error or information in the database.
(Inherited from PFManagedObject.)
Public propertyLogIdentification
Gets a technical text representing this object.
(Inherited from PFBaseObject.)
Public propertyName
Gets the name.
Public propertyOrganisationalType
Gets or sets the organisational type.
Public propertyOrganisationalTypeGuid
Gets the organisational type GUID.
Public propertyOrganisationalTypeId
Gets the organisational type id.
Public propertyParentObject
Gets the parent object (site or application depending on the scope).
Public propertyPermissionContext
Gets an object calculating permissions on demand.
Public propertyPermissions
Gets the permission set (RUD permissions) of this item.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetDeleteId
Id of the permission set for Delete access.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetDeleteXml
XML of serialized permission set for Delete access.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetReadId
Id of the permission set for Read access.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetReadXml
XML of serialized permission set for Read access.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetUpdateId
Id of the permission set for Update access.
(Inherited from PFBaseObject.)
Protected propertyPermissionSetUpdateXml
XML of serialized permission set for Update access.
(Inherited from PFBaseObject.)
Public propertyRoleGuid
Gets the role GUID. Only applies when the parent is an application.
Public propertyScope
Gets the scope, identifying the parent type of a PFGroup.
Public propertySite
Gets the root of the persisted objects tree.
(Inherited from PFBaseObject.)
Public propertySiteGuid
Gets the parent site GUID.
Public propertySiteId
Gets the parent site id.
Public propertyStandardGroup
Gets a value indicating whether this group is one of the standard groups.
Public propertyUpdatedAt
Gets the date of the last update of this object.
(Inherited from PFBaseObject.)
Public propertyUpdatedBy
Gets the user who last updated this object in the database.
(Inherited from PFBaseObject.)
Public propertyUsers
Gets the list of users included in this group.
Public propertyVersionNumber
Gets the version number of this object in database. Incremented after each save.
(Inherited from PFBaseObject.)
Top
Methods
  NameDescription
Public methodCheckForCycles
Checks all children for cycles. NOTE : slow method, do not use on user-production-features.
Public methodDelete
Flags this object as deleted.

If it fails, throws an error.

If the object could not be deleted because it does not yet exist in database, returns false.

If successful, returns true.

(Inherited from PFBaseObject.)
Public methodGetGroups
Gets the list of organisational groups included in this group. Note: this method executes a query in the database.
Public methodGetGroupsListRecursive
Gets the recursive list of groups included in this group and its children groups.
Public methodGetGroupsRecursive
Gets the recursive list of groups included in this group and its children groups. More optimized than GetGroupsListRecursive because avoid to load the PFGroups.
Public methodGetGroupUrl
Gets the group form URL.
Public methodStatic memberGetGroupUrl(PFStructureObject, Int64)
Gets the form URL of the specified group having the specified parent object.
Protected methodGetNewPermissionContext
Creates a new permission context based on current object type.
(Overrides PFBaseObjectGetNewPermissionContext.)
Public methodGetUsers
Gets the list of users included in this group. Note: this method executes a query in the database.
Public methodGetUsersListRecursive
Gets the recursive list of users included in this group and its children groups.
Public methodGetUsersRecursive
Gets the recursive list of users included in this group and its children groups. More optimized than GetUsersListRecursive because avoid to load the PFUsers.
Protected methodInitializeLogger
Use this method to override the way the logger is initialized.
(Inherited from PFBaseObject.)
Protected methodProcessPermissions
Compute permissions from permission context and set in data properties.
(Inherited from PFBaseObject.)
Public methodRunInTransactionArea
Runs a code with a transaction on object connection. If there is no current transaction and if the code succeed, transaction is committed. If an exception is thrown, transaction is rollback.
(Inherited from PFBaseObject.)
Public methodSave
Applies the data of this object in the database.

This method will also:

-Update the RLS table referencing links between groups and users for this group.

-Update relative applications (referencing this group through the roles).

-Create a log entry about the changes.

(Overrides PFBaseObjectSave.)
Protected methodSaveObjectsInDataCollection
Saves data loaded from temp specialized object in data properties collection before save or check hasPendingChanges.
(Overrides PFBaseObjectSaveObjectsInDataCollection.)
Public methodSyncWithDomainGroup

Synchronizes all users referenced by this group with the corresponding Active Directory group.

Note : this method does nothing if synchronization info are not available.

Public methodToString
Returns a string that represents the current object.
(Overrides ObjectToString.)
Top
Fields
  NameDescription
Public fieldStatic memberFieldName_ApplicationContextGuid
Column name in database.
Public fieldStatic memberFieldName_ApplicationContextId
Column name in database.
Public fieldStatic memberFieldName_ApplicationGuid
Column name in database.
Public fieldStatic memberFieldName_ApplicationId
Column name in database.
Public fieldStatic memberFieldName_DisplayName
Column name in database.
Public fieldStatic memberFieldName_DomainGroup
Column name in database.
Public fieldStatic memberFieldName_DomainGroupCreateDisabledUsers
Column name in database.
Public fieldStatic memberFieldName_DomainGroupSyncMode
Column name in database.
Public fieldStatic memberFieldName_Name
Column name in database.
Public fieldStatic memberFieldName_OrganisationalTypeGuid
Column name in database.
Public fieldStatic memberFieldName_OrganisationalTypeId
Column name in database.
Public fieldStatic memberFieldName_RoleGuid
Column name in database.
Public fieldStatic memberStandardGroupName_SiteAdmins
Name of the SiteAdmins standard group.
Public fieldStatic memberStandardGroupName_SiteMembers
Name of the SiteMembers standard group.
Public fieldStatic memberStandardGroupName_SiteOwners
Name of the SiteOwners standard group.
Public fieldStatic memberStandardGroupName_SiteVisitors
Name of the SiteVisitors standard group.
Top
Extension Methods
  NameDescription
Public Extension MethodAsT
Casts an object to another type. Returns default(T) if the object is null.
(Defined by Utils_Other.)
Public Extension MethodEqualsAll
Checks that this object is equal to every object in parameters.
(Defined by Utils_Other.)
Public Extension MethodEqualsAny
Checks that this object is equal to at least one of the parameters.
(Defined by Utils_Other.)
Public Extension MethodGetString
Converts an object to String using ToString() method, else returns String.Empty.
(Defined by Utils_Other.)
Public Extension MethodIsGenericListOverloaded.
Checks if this object is a System.Collections.Generic.List.
(Defined by Utils_Linq.)
Public Extension MethodIsGenericList(Type)Overloaded.
Checks if this object is a System.Collections.Generic.List using type as T.
(Defined by Utils_Linq.)
Public Extension MethodSerializeOverloaded.
Serializes an object into an XML document.
(Defined by Utils_Xml.)
Public Extension MethodSerialize(String)Overloaded.
Serializes an object into an XML document.
(Defined by Utils_Xml.)
Public Extension MethodSerializeJsonOverloaded.
Serializes an object using a DataContractJsonSerializer.
(Defined by Utils_String.)
Public Extension MethodSerializeJson(ListType)Overloaded.
Serializes an object using a DataContractJsonSerializer.
(Defined by Utils_String.)
Public Extension MethodSerializeJson(DataContractJsonSerializerSettings)Overloaded.
Serializes an object using a DataContractJsonSerializer.
(Defined by Utils_String.)
Top
See Also