DRMGetUnboundLicenseObjectCount function

[The AD RMS SDK leveraging functionality exposed by the client in Msdrm.dll is available for use in Windows Server 2008, Windows Vista, Windows Server 2008 R2, Windows 7, Windows Server 2012, and Windows 8. It may be altered or unavailable in subsequent versions. Instead, use Active Directory Rights Management Services SDK 2.1, which leverages functionality exposed by the client in Msipc.dll.]

The DRMGetUnboundLicenseObjectCount function counts the instances of an object within a specified branch of the license.

Syntax


HRESULT DRMGetUnboundLicenseObjectCount(
  _In_  DRMQUERYHANDLE hQueryRoot,
  _In_  PWSTR          wszSubObjectType,
  _Out_ UINT           *pcSubObjects
);

Parameters

hQueryRoot [in]

A handle to a license or object in the license, created using DRMGetUnboundLicenseObject or DRMParseUnboundLicense.

wszSubObjectType [in]

The type of XrML object to find. For more information, see Remarks.

pcSubObjects [out]

Count of object instances one level down within the specified branch.

Return value

If the function succeeds, the function returns S_OK.

If the function fails, it returns an HRESULT value that indicates the error. Possible values include, but are not limited to, those in the following list. For a list of common error codes, see Common HRESULT Values.

E_DRM_NO_MORE_DATA

No license or certificate exists at the specified index.

Remarks

Certain objects, such as rights, may have multiple instances in a license. This function allows an application to iterate through instances of an object type by providing an upper bound in a loop when calling DRMGetUnboundLicenseObject. The value returned by this function, however, is one-based; subtract one from it when using it as a loop boundary.

This query will search only at the level immediately below the passed in object. So, for example, if the root license handle is passed in and the attribute to find is g_wszQUERY_OWNER, the query will find nothing because the OWNER appears at the second level or deeper (counting the license root as level 0).

Requirements

Product

Rights Management Services client 1.0 SP2 or later

Header

Msdrm.h

Library

Msdrm.lib

DLL

Msdrm.dll

See also

Querying Licenses
DRMGetUnboundLicenseAttribute
DRMGetUnboundLicenseAttributeCount
DRMGetUnboundLicenseObject

 

 

Show: