LicenseManager Class
Provides properties and methods to add a license to a component and to manage a LicenseProvider. This class cannot be inherited.
Namespace: System.ComponentModel
Assembly: System (in System.dll)
The LicenseManager type exposes the following members.
| Name | Description | |
|---|---|---|
![]() ![]() | CurrentContext | Gets or sets the current LicenseContext, which specifies when you can use the licensed object. |
![]() ![]() | UsageMode | Gets the LicenseUsageMode which specifies when you can use the licensed object for the CurrentContext. |
| Name | Description | |
|---|---|---|
![]() ![]() | CreateWithContext(Type, LicenseContext) | Creates an instance of the specified type, given a context in which you can use the licensed instance. |
![]() ![]() | CreateWithContext(Type, LicenseContext, Object[]) | Creates an instance of the specified type with the specified arguments, given a context in which you can use the licensed instance. |
![]() | Equals(Object) | Determines whether the specified object is equal to the current object. (Inherited from Object.) |
![]() | GetHashCode | Serves as a hash function for a particular type. (Inherited from Object.) |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() ![]() | IsLicensed | Returns whether the given type has a valid license. |
![]() ![]() | IsValid(Type) | Determines whether a valid license can be granted for the specified type. |
![]() ![]() | IsValid(Type, Object, License) | Determines whether a valid license can be granted for the specified instance of the type. This method creates a valid License. |
![]() ![]() | LockContext | Prevents changes being made to the current LicenseContext of the given object. |
![]() | ToString | Returns a string that represents the current object. (Inherited from Object.) |
![]() ![]() | UnlockContext | Allows changes to be made to the current LicenseContext of the given object. |
![]() ![]() | Validate(Type) | Determines whether a license can be granted for the specified type. |
![]() ![]() | Validate(Type, Object) | Determines whether a license can be granted for the instance of the specified type. |
The LicenseManager class provides the following static properties: CurrentContext and UsageMode. The class also provides the following static methods: CreateWithContext, IsValid, and Validate.
When you create a component that you want to license, you must do the following:
Specify the LicenseProvider by marking the component with a LicenseProviderAttribute.
Call Validate or IsValid in the constructor of the component. Validate throws a LicenseException when it tries to create an instance without a valid license. IsValid does not throw an exception.
Call Dispose on any license that is granted when the component is disposed or finalized.
For more information on licensing, see How to: License Components and Controls.
Note |
|---|
The HostProtectionAttribute attribute applied to this type or member has the following Resources property value: ExternalProcessMgmt. The HostProtectionAttribute does not affect desktop applications (which are typically started by double-clicking an icon, typing a command, or entering a URL in a browser). For more information, see the HostProtectionAttribute class or SQL Server Programming and Host Protection Attributes. |
The following code example creates a licensed control using the Validate method. It uses a LicenseProvider that is implemented by the LicFileLicenseProvider class.
using System; using System.ComponentModel; using System.Windows.Forms; // Adds the LicenseProviderAttribute to the control. [LicenseProvider(typeof(LicFileLicenseProvider))] public class MyControl : Control { // Creates a new, null license. private License license = null; public MyControl () { // Adds Validate to the control's constructor. license = LicenseManager.Validate(typeof(MyControl), this); // Insert code to perform other instance creation tasks here. } protected override void Dispose(bool disposing) { if(disposing) { if (license != null) { license.Dispose(); license = null; } } } }
Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role supported with SP1 or later; Itanium not supported)
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.



Note