ArcObjects Library Reference  

LicenseInitializer

About the Service area application using the NAServer extension in ArcGIS Server via a GIS server Sample

[C#]

LicenseInitializer.cs

using System;
using System.Collections.Generic;
using System.Text;
using ESRI.ArcGIS.esriSystem;

//FILE AUTOMATICALLY GENERATED BY ESRI LICENSE INITIALIZATION ADDIN
//YOU SHOULD NOT NORMALLY EDIT OR REMOVE THIS FILE FROM THE PROJECT

namespace ServiceArea_GISServerAPI
{
	internal sealed class LicenseInitializer
	{
		private IAoInitialize m_AoInit = new AoInitializeClass();

		#region Private members
		private const string MessageNoLicensesRequested = "Product: No licenses were requested";
		private const string MessageProductAvailable = "Product: {0}: Available";
		private const string MessageProductNotLicensed = "Product: {0}: Not Licensed";
		private const string MessageExtensionAvailable = " Extension: {0}: Available";
		private const string MessageExtensionNotLicensed = " Extension: {0}: Not Licensed";
		private const string MessageExtensionFailed = " Extension: {0}: Failed";
		private const string MessageExtensionUnavailable = " Extension: {0}: Unavailable";

		private bool m_hasShutDown = false;
		private bool m_hasInitializeProduct = false;

		private List<int> m_requestedProducts;
		private List<esriLicenseExtensionCode> m_requestedExtensions;
		private Dictionary<esriLicenseProductCode, esriLicenseStatus> m_productStatus = new Dictionary<esriLicenseProductCode, esriLicenseStatus>();
		private Dictionary<esriLicenseExtensionCode, esriLicenseStatus> m_extensionStatus = new Dictionary<esriLicenseExtensionCode, esriLicenseStatus>();

		private bool m_productCheckOrdering = true; //default from low to high
		#endregion

		public bool InitializeApplication(esriLicenseProductCode[] productCodes, esriLicenseExtensionCode[] extensionLics)
		{
			//Cache product codes by enum int so can be sorted without custom sorter
			m_requestedProducts = new List<int>();
			foreach (esriLicenseProductCode code in productCodes)
			{
				int requestCodeNum = Convert.ToInt32(code);
				if (!m_requestedProducts.Contains(requestCodeNum))
				{
					m_requestedProducts.Add(requestCodeNum);
				}
			}

			AddExtensions(extensionLics);
			return Initialize();
		}

		/// <summary>
		/// A summary of the status of product and extensions initialization.
		/// </summary>
		public string LicenseMessage()
		{
			string prodStatus = string.Empty;
			if (m_productStatus == null || m_productStatus.Count == 0)
			{
				prodStatus = MessageNoLicensesRequested + Environment.NewLine;
			}
			else if (m_productStatus.ContainsValue(esriLicenseStatus.esriLicenseAlreadyInitialized)
				|| m_productStatus.ContainsValue(esriLicenseStatus.esriLicenseCheckedOut))
			{
				prodStatus = ReportInformation(m_AoInit as ILicenseInformation,
					m_AoInit.InitializedProduct(),
					esriLicenseStatus.esriLicenseCheckedOut) + Environment.NewLine;
			}
			else
			{
				//Failed...
				foreach (KeyValuePair<esriLicenseProductCode, esriLicenseStatus> item in m_productStatus)
				{
					prodStatus += ReportInformation(m_AoInit as ILicenseInformation,
						item.Key, item.Value) + Environment.NewLine;
				}
			}

			string extStatus = string.Empty;
			foreach (KeyValuePair<esriLicenseExtensionCode, esriLicenseStatus> item in m_extensionStatus)
			{
				string info = ReportInformation(m_AoInit as ILicenseInformation, item.Key, item.Value);
				if (!string.IsNullOrEmpty(info))
					extStatus += info + Environment.NewLine;
			}

			string status = prodStatus + extStatus;
			return status.Trim();
		}

		/// <summary>
		/// Shuts down AoInitialize object and check back in extensions to ensure
		/// any ESRI libraries that have been used are unloaded in the correct order.
		/// </summary>
		/// <remarks>Once Shutdown has been called, you cannot re-initialize the product license
		/// and should not make any ArcObjects call.</remarks>
		public void ShutdownApplication()
		{
			if (m_hasShutDown)
				return;

			//Check back in extensions
			foreach (KeyValuePair<esriLicenseExtensionCode, esriLicenseStatus> item in m_extensionStatus)
			{
				if (item.Value == esriLicenseStatus.esriLicenseCheckedOut)
					m_AoInit.CheckInExtension(item.Key);
			}

			m_requestedProducts.Clear();
			m_requestedExtensions.Clear();
			m_extensionStatus.Clear();
			m_productStatus.Clear();
			m_AoInit.Shutdown();
			m_hasShutDown = true;
			//m_hasInitializeProduct = false;
		}

		/// <summary>
		/// Indicates if the extension is currently checked out.
		/// </summary>
		public bool IsExtensionCheckedOut(esriLicenseExtensionCode code)
		{
			return m_AoInit.IsExtensionCheckedOut(code);
		}

		/// <summary>
		/// Set the extension(s) to be checked out for your ArcObjects code. 
		/// </summary>
		public bool AddExtensions(params esriLicenseExtensionCode[] requestCodes)
		{
			if (m_requestedExtensions == null)
				m_requestedExtensions = new List<esriLicenseExtensionCode>();
			foreach (esriLicenseExtensionCode code in requestCodes)
			{
				if (!m_requestedExtensions.Contains(code))
					m_requestedExtensions.Add(code);
			}

			if (m_hasInitializeProduct)
				return CheckOutLicenses(this.InitializedProduct);

			return false;
		}

		/// <summary>
		/// Check in extension(s) when it is no longer needed.
		/// </summary>
		public void RemoveExtensions(params esriLicenseExtensionCode[] requestCodes)
		{
			if (m_extensionStatus == null || m_extensionStatus.Count == 0)
				return;

			foreach (esriLicenseExtensionCode code in requestCodes)
			{
				if (m_extensionStatus.ContainsKey(code))
				{
					if (m_AoInit.CheckInExtension(code) == esriLicenseStatus.esriLicenseCheckedIn)
					{
						m_extensionStatus[code] = esriLicenseStatus.esriLicenseCheckedIn;
					}
				}
			}
		}

		/// <summary>
		/// Get/Set the ordering of product code checking. If true, check from lowest to 
		/// highest license. True by default.
		/// </summary>
		public bool InitializeLowerProductFirst
		{
			get
			{
				return m_productCheckOrdering;
			}
			set
			{
				m_productCheckOrdering = value;
			}
		}

		/// <summary>
		/// Retrieves the product code initialized in the ArcObjects application
		/// </summary>
		public esriLicenseProductCode InitializedProduct
		{
			get
			{
				try
				{
					return m_AoInit.InitializedProduct();
				}
				catch
				{
					return 0;
				}
			}
		}

		#region Helper methods
		private bool Initialize()
		{
			if (m_requestedProducts == null || m_requestedProducts.Count == 0)
				return false;

			esriLicenseProductCode currentProduct = new esriLicenseProductCode();
			bool productInitialized = false;

			//Try to initialize a product
			ILicenseInformation licInfo = (ILicenseInformation)m_AoInit;

			m_requestedProducts.Sort();
			if (!InitializeLowerProductFirst) //Request license from highest to lowest
				m_requestedProducts.Reverse();

			foreach (int prodNumber in m_requestedProducts)
			{
				esriLicenseProductCode prod = (esriLicenseProductCode)Enum.ToObject(typeof(esriLicenseProductCode), prodNumber);
				esriLicenseStatus status = m_AoInit.IsProductCodeAvailable(prod);
				if (status == esriLicenseStatus.esriLicenseAvailable)
				{
					status = m_AoInit.Initialize(prod);
					if (status == esriLicenseStatus.esriLicenseAlreadyInitialized ||
						status == esriLicenseStatus.esriLicenseCheckedOut)
					{
						productInitialized = true;
						currentProduct = m_AoInit.InitializedProduct();
					}
				}

				m_productStatus.Add(prod, status);

				if (productInitialized)
					break;
			}

			m_hasInitializeProduct = productInitialized;
			m_requestedProducts.Clear();

			//No product is initialized after trying all requested licenses, quit
			if (!productInitialized)
			{
				return false;
			}

			//Check out extension licenses
			return CheckOutLicenses(currentProduct);
		}

		private bool CheckOutLicenses(esriLicenseProductCode currentProduct)
		{
			bool allSuccessful = true;
			//Request extensions
			if (m_requestedExtensions != null && currentProduct != 0)
			{
				foreach (esriLicenseExtensionCode ext in m_requestedExtensions)
				{
					esriLicenseStatus licenseStatus = m_AoInit.IsExtensionCodeAvailable(currentProduct, ext);
					if (licenseStatus == esriLicenseStatus.esriLicenseAvailable)//skip unavailable extensions
					{
						licenseStatus = m_AoInit.CheckOutExtension(ext);
					}
					allSuccessful = (allSuccessful && licenseStatus == esriLicenseStatus.esriLicenseCheckedOut);
					if (m_extensionStatus.ContainsKey(ext))
						m_extensionStatus[ext] = licenseStatus;
					else
						m_extensionStatus.Add(ext, licenseStatus);
				}

				m_requestedExtensions.Clear();
			}

			return allSuccessful;
		}


		private string ReportInformation(ILicenseInformation licInfo,
		   esriLicenseProductCode code, esriLicenseStatus status)
		{
			string prodName = string.Empty;
			try
			{
				prodName = licInfo.GetLicenseProductName(code);
			}
			catch
			{
				prodName = code.ToString();
			}

			string statusInfo = string.Empty;

			switch (status)
			{
				case esriLicenseStatus.esriLicenseAlreadyInitialized:
				case esriLicenseStatus.esriLicenseCheckedOut:
					statusInfo = string.Format(MessageProductAvailable, prodName);
					break;
				default:
					statusInfo = string.Format(MessageProductNotLicensed, prodName);
					break;
			}

			return statusInfo;
		}
		private string ReportInformation(ILicenseInformation licInfo,
			esriLicenseExtensionCode code, esriLicenseStatus status)
		{
			string extensionName = string.Empty;
			try
			{
				extensionName = licInfo.GetLicenseExtensionName(code);
			}
			catch
			{
				extensionName = code.ToString();
			}

			string statusInfo = string.Empty;

			switch (status)
			{
				case esriLicenseStatus.esriLicenseAlreadyInitialized:
				case esriLicenseStatus.esriLicenseCheckedOut:
					statusInfo = string.Format(MessageExtensionAvailable, extensionName);
					break;
				case esriLicenseStatus.esriLicenseCheckedIn:
					break;
				case esriLicenseStatus.esriLicenseUnavailable:
					statusInfo = string.Format(MessageExtensionUnavailable, extensionName);
					break;
				case esriLicenseStatus.esriLicenseFailure:
					statusInfo = string.Format(MessageExtensionFailed, extensionName);
					break;
				default:
					statusInfo = string.Format(MessageExtensionNotLicensed, extensionName);
					break;
			}

			return statusInfo;
		}
		#endregion

	}
}
[Visual Basic .NET]

LicenseInitializer.vb

Option Explicit On
Imports ESRI.ArcGIS.esriSystem
Imports System
Imports System.Collections.Generic
Imports System.Diagnostics

'FILE AUTOMATICALLY GENERATED BY ESRI LICENSE INITIALIZATION ADDIN
'YOU SHOULD NOT NORMALLY EDIT OR REMOVE THIS FILE FROM THE PROJECT

Friend Class LicenseInitializer
	Private m_AoInit As IAoInitialize = New AoInitializeClass()
#Region "Private members"
	Private Const MessageNoLicensesRequested As String = "Product: No licenses were requested"
	Private Const MessageProductAvailable As String = "Product: {0}: Available"
	Private Const MessageProductNotLicensed As String = "Product: {0}: Not Licensed"
	Private Const MessageExtensionAvailable As String = " Extension: {0}: Available"
	Private Const MessageExtensionNotLicensed As String = " Extension: {0}: Not Licensed"
	Private Const MessageExtensionFailed As String = " Extension: {0}: Failed"
	Private Const MessageExtensionUnavailable As String = " Extension: {0}: Unavailable"

	Private m_hasShutDown As Boolean = False
	Private m_hasInitializeProduct As Boolean = False

	Private m_requestedProducts As List(Of Integer)
	Private m_requestedExtensions As List(Of esriLicenseExtensionCode)
	Private m_productStatus As Dictionary(Of esriLicenseProductCode, esriLicenseStatus) = New Dictionary(Of esriLicenseProductCode, esriLicenseStatus)()
	Private m_extensionStatus As Dictionary(Of esriLicenseExtensionCode, esriLicenseStatus) = New Dictionary(Of esriLicenseExtensionCode, esriLicenseStatus)()

	Private m_productCheckOrdering As Boolean = True 'default from low to high
#End Region

	Public Function InitializeApplication(ByVal productCodes As esriLicenseProductCode(), ByVal extensionLics() As esriLicenseExtensionCode) As Boolean
		'Cache product codes by enum int so can be sorted without custom sorter
		m_requestedProducts = New List(Of Integer)()
		For Each code As esriLicenseProductCode In productCodes
			Dim requestCodeNum As Integer = CInt(code)
			If Not m_requestedProducts.Contains(requestCodeNum) Then
				m_requestedProducts.Add(requestCodeNum)
			End If
		Next

		AddExtensions(extensionLics)
		Return Initialize()
	End Function

	''' <summary>
	''' A summary of the status of product and extensions initialization.
	''' </summary>
	Public Function LicenseMessage() As String
		Dim prodStatus As String = String.Empty
		Dim licenseInfo As ILicenseInformation = CType(m_AoInit, ILicenseInformation)
		If m_productStatus Is Nothing OrElse m_productStatus.Count = 0 Then
			prodStatus = MessageNoLicensesRequested + Environment.NewLine
		ElseIf (m_productStatus.ContainsValue(esriLicenseStatus.esriLicenseAlreadyInitialized) _
			Or m_productStatus.ContainsValue(esriLicenseStatus.esriLicenseCheckedOut)) Then

			prodStatus = ReportInformation(licenseInfo, _
					m_AoInit.InitializedProduct(), esriLicenseStatus.esriLicenseCheckedOut) _
					+ Environment.NewLine
		Else
			'Failed...
			For Each item As KeyValuePair(Of esriLicenseProductCode, esriLicenseStatus) In m_productStatus
				prodStatus += ReportInformation(licenseInfo, item.Key, item.Value) + Environment.NewLine
			Next
		End If

		Dim extStatus As String = String.Empty
		For Each item As KeyValuePair(Of esriLicenseExtensionCode, esriLicenseStatus) In m_extensionStatus
			Dim info As String = ReportInformation(licenseInfo, item.Key, item.Value)
			If Not String.IsNullOrEmpty(info) Then
				extStatus += info + Environment.NewLine
			End If
		Next

		Dim status As String = prodStatus + extStatus
		Return status.Trim()
	End Function

	''' <summary>
	''' Shuts down AoInitialize object and check back in extensions to ensure
	''' any ESRI libraries that have been used are unloaded in the correct order.
	''' </summary>
	''' <remarks>Once Shutdown has been called, you cannot re-initialize the product license
	''' and should not make any ArcObjects call.</remarks>
	Public Sub ShutdownApplication()
		If m_hasShutDown Then Return

		'Check back in extensions
		For Each item As KeyValuePair(Of esriLicenseExtensionCode, esriLicenseStatus) In m_extensionStatus
			If item.Value = esriLicenseStatus.esriLicenseCheckedOut Then
				m_AoInit.CheckInExtension(item.Key)
			End If
		Next

		m_requestedProducts.Clear()
		m_requestedExtensions.Clear()
		m_extensionStatus.Clear()
		m_productStatus.Clear()
		m_AoInit.Shutdown()
		m_hasShutDown = True
	End Sub

	''' <summary>
	''' Indicates if the extension is currently checked out.
	''' </summary>    
	Public Function IsExtensionCheckedOut(ByVal code As esriLicenseExtensionCode) As Boolean
		Return m_AoInit.IsExtensionCheckedOut(code)
	End Function

	''' <summary>
	''' Set the extension(s) to be checked out for your ArcObjects code. 
	''' </summary>
	Public Function AddExtensions(ByVal ParamArray requestCodes As esriLicenseExtensionCode()) As Boolean
		If m_requestedExtensions Is Nothing Then
			m_requestedExtensions = New List(Of esriLicenseExtensionCode)()
		End If

		For Each code As esriLicenseExtensionCode In requestCodes
			If Not m_requestedExtensions.Contains(code) Then
				m_requestedExtensions.Add(code)
			End If
		Next

		If m_hasInitializeProduct Then
			Return CheckOutLicenses(Me.InitializedProduct)
		Else
			Return False
		End If
	End Function

	''' <summary>
	''' Check in extension(s) when it is no longer needed.
	''' </summary>
	Public Sub RemoveExtensions(ByVal ParamArray requestCodes As esriLicenseExtensionCode())
		If m_extensionStatus Is Nothing OrElse m_extensionStatus.Count = 0 Then
			Return
		End If

		For Each code As esriLicenseExtensionCode In requestCodes
			If m_extensionStatus.ContainsKey(code) Then
				If m_AoInit.CheckInExtension(code) = esriLicenseStatus.esriLicenseCheckedIn Then
					m_extensionStatus(code) = esriLicenseStatus.esriLicenseCheckedIn
				End If
			End If
		Next
	End Sub

	''' <summary>
	''' Get/Set the ordering of product code checking. If true, check from lowest to 
	''' highest license. True by default.
	''' </summary>
	Public Property InitializeLowerProductFirst() As Boolean
		Get
			Return m_productCheckOrdering
		End Get
		Set(ByVal value As Boolean)
			m_productCheckOrdering = value
		End Set
	End Property

	''' <summary>
	''' Retrieves the product code initialized in the ArcObjects application
	''' </summary>
	Public ReadOnly Property InitializedProduct() As esriLicenseProductCode
		Get
			Try
				Return m_AoInit.InitializedProduct()
			Catch
				Return 0
			End Try
		End Get
	End Property

#Region "Helper methods"
	Private Function Initialize() As Boolean
		If m_requestedProducts Is Nothing OrElse m_requestedProducts.Count = 0 Then
			m_hasInitializeProduct = True
			Return False
		End If

		Dim currentProduct As esriLicenseProductCode = New esriLicenseProductCode
		Dim productInitialized As Boolean = False

		'Try to initialize a product
		Dim licInfo As ILicenseInformation = CType(m_AoInit, ILicenseInformation)

		m_requestedProducts.Sort()
		If Not InitializeLowerProductFirst Then	'Request license from highest to lowest
			m_requestedProducts.Reverse()
		End If

		For Each prodNumber As Integer In m_requestedProducts
			Dim prod As esriLicenseProductCode = CType(System.Enum.ToObject(GetType(esriLicenseProductCode), prodNumber), esriLicenseProductCode)
			Dim status As esriLicenseStatus = m_AoInit.IsProductCodeAvailable(prod)
			If (status = esriLicenseStatus.esriLicenseAvailable) Then
				status = m_AoInit.Initialize(prod)
				If (status = esriLicenseStatus.esriLicenseAlreadyInitialized Or _
						status = esriLicenseStatus.esriLicenseCheckedOut) Then
					productInitialized = True
					currentProduct = m_AoInit.InitializedProduct()
				End If
			End If

			m_productStatus.Add(prod, status)

			If productInitialized Then Exit For
		Next

		m_hasInitializeProduct = productInitialized
		m_requestedProducts.Clear()

		'No product is initialized after trying all requested licenses, quit
		If Not productInitialized Then Return False

		'Check out extension licenses
		Return CheckOutLicenses(currentProduct)
	End Function

	Private Function CheckOutLicenses(ByVal currentProduct As esriLicenseProductCode) As Boolean
		Dim allSuccessful As Boolean = True

		'Request extensions
		If m_requestedExtensions IsNot Nothing AndAlso currentProduct <> 0 Then

			For Each ext As esriLicenseExtensionCode In m_requestedExtensions
				Dim licenseStatus As esriLicenseStatus = m_AoInit.IsExtensionCodeAvailable(currentProduct, ext)
				If (licenseStatus = esriLicenseStatus.esriLicenseAvailable) Then 'skip unavailable extensions
					licenseStatus = m_AoInit.CheckOutExtension(ext)
				End If
				allSuccessful = (allSuccessful And licenseStatus = esriLicenseStatus.esriLicenseCheckedOut)
				If (m_extensionStatus.ContainsKey(ext)) Then
					m_extensionStatus(ext) = licenseStatus
				Else
					m_extensionStatus.Add(ext, licenseStatus)
				End If
			Next

			m_requestedExtensions.Clear()
		End If

		Return allSuccessful
	End Function

	Private Function ReportInformation(ByVal licInfo As ILicenseInformation, ByVal code As esriLicenseProductCode, ByVal status As esriLicenseStatus) As String
		Dim prodName As String = String.Empty
		Try
			prodName = licInfo.GetLicenseProductName(code)
		Catch
			prodName = code.ToString()
		End Try
		Dim statusInfo As String = String.Empty

		Select Case status
			Case esriLicenseStatus.esriLicenseAlreadyInitialized, esriLicenseStatus.esriLicenseCheckedOut
				statusInfo = String.Format(MessageProductAvailable, prodName)
			Case Else
				statusInfo = String.Format(MessageProductNotLicensed, prodName)
		End Select

		Return statusInfo
	End Function

	Private Function ReportInformation(ByVal licInfo As ILicenseInformation, ByVal code As esriLicenseExtensionCode, ByVal status As esriLicenseStatus) As String
		Dim extensionName As String = String.Empty
		Try
			extensionName = licInfo.GetLicenseExtensionName(code)
		Catch
			extensionName = code.ToString()
		End Try
		Dim statusInfo As String = String.Empty

		Select Case status
			Case esriLicenseStatus.esriLicenseAlreadyInitialized, esriLicenseStatus.esriLicenseCheckedOut
				statusInfo = String.Format(MessageExtensionAvailable, extensionName)
			Case esriLicenseStatus.esriLicenseCheckedIn
				Exit Select
			Case esriLicenseStatus.esriLicenseUnavailable
				statusInfo = String.Format(MessageExtensionUnavailable, extensionName)
			Case esriLicenseStatus.esriLicenseFailure
				statusInfo = String.Format(MessageExtensionFailed, extensionName)
			Case Else
				statusInfo = String.Format(MessageExtensionNotLicensed, extensionName)
		End Select

		Return statusInfo
	End Function
#End Region
End Class