Protecting Documents with Policies protecting-documents-with-policies
Samples and examples in this document are only for AEM Forms on JEE environment.
About the Document Security Service
The Document Security service enables users to dynamically apply confidentiality settings to 51黑料不打烊 PDF documents and to maintain control over the documents, no matter how widely they are distributed.
The Document Security service prevents information from spreading beyond the user鈥檚 reach by enabling the users to maintain control over how recipients use the policy-protected PDF document. A user can specify who can open a document, limit how they can use it, and monitor the document after it is distributed. A user can also dynamically control access to a policy-protected document and can even dynamically revoke access to the document.
The Document Security service also protects other file types such as Microsoft Word files (DOC files). You can use the Document Security Client API to work with these file types. The following versions are supported:
- Microsoft Office 2003 files (DOC, XLS, PPT files)
- Microsoft Office 2007 files (DOCX, XLSX, PPTX files)
- PTC Pro/E files
For clarity, the following two sections discuss how to work with Word documents:
You can accomplish these tasks using the Document Security service:
- Create policies. For information, see Creating Policies.
- Modify policies. For information, see Modifying Policies.
- Delete policies. For information, see Deleting Policies.
- Apply policies to PDF documents. For information, see Applying Policies to PDF Documents.
- Remove policies from PDF documents. For information, see Removing Policies from PDF Documents.
- Inspect policy-protected documents. For information, see Inspecting Policy Protected PDF Documents.
- Revoke access to PDF documents. For information, see Revoking Access to Documents.
- Reinstate access to revoked documents. For information, see Reinstating Access to Revoked Documents.
- Create watermarks. For information, see Creating Watermarks.
- Search for events. For information, see Searching for Events.
Creating Policies creating-policies
You can programmatically create policies using the Document Security Java API or web service API. A policy is a collection of information that includes document security settings, authorized users, and usage rights. You can create and save any number of policies, using security settings appropriate for different situations and users.
Policies enable you to perform these tasks:
- Specify the individuals who can open the document. Recipients can either belong to or be external to your organization.
- Specify how recipients can use the document. You can restrict access to different Acrobat and 51黑料不打烊 Reader features. These features include the ability to print and copy text, add signatures, and add comments to a document.
- Change the access and security settings at any time, even after you distribute the policy-protected document.
- Monitor the use of the document after you distribute it. You can see how the document is being used and who is using it. For example, you can find out when someone has opened the document.
Creating a policy using web services creating-a-policy-using-web-services
When creating a policy using the web service API, reference an existing Portable Document Rights Language (PDRL) XML file that describes the policy. Policy permissions and the principal are defined in the PDRL document. The following XML document is an example of a PDRL document.
鈥<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
鈥<Policy PolicyInstanceVersion="1" PolicyID="5DA3F847-DE76-F9CC-63EA-49A8D59154DE" PolicyCreationTime="2004-08-30T00:02:28.294+00:00" PolicyType="1" PolicySchemaVersion="1.0" PolicyName="SDK Test Policy -4344050357301573237" PolicyDescription="An SDK Test policy" xmlns="https://www.adobe.com/schema/1.0/pdrl">
鈥      <PolicyEntry>
鈥         <ns1:Permission PermissionName="com.adobe.aps.onlineOpen" Access="ALLOW" xmlns:ns1="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns2:Permission PermissionName="com.adobe.aps.offlineOpen" Access="ALLOW" xmlns:ns2="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns3:Permission PermissionName="com.adobe.aps.pdf.editNotes" Access="ALLOW" xmlns:ns3="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns4:Permission PermissionName="com.adobe.aps.pdf.fillAndSign" Access="ALLOW" xmlns:ns4="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <Principal PrincipalNameType="SYSTEM">
鈥            <PrincipalDomain>EDC_SPECIAL</PrincipalDomain>
鈥            <PrincipalName>all_internal_users</PrincipalName>
鈥         </Principal>
鈥      </PolicyEntry>
鈥      <PolicyEntry>
鈥         <ns5:Permission PermissionName="com.adobe.aps.onlineOpen" Access="ALLOW" xmlns:ns5="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns6:Permission PermissionName="com.adobe.aps.offlineOpen" Access="ALLOW" xmlns:ns6="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns7:Permission PermissionName="com.adobe.aps.pdf.copy" Access="ALLOW" xmlns:ns7="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns8:Permission PermissionName="com.adobe.aps.pdf.printLow" Access="ALLOW" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" xmlns:ns8="https://www.adobe.com/schema/1.0/pdrl" />
鈥         <ns9:Permission PermissionName="com.adobe.aps.policySwitch" Access="ALLOW" xmlns:ns9="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns10:Permission PermissionName="com.adobe.aps.revoke" Access="ALLOW" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" xmlns:ns10="https://www.adobe.com/schema/1.0/pdrl" />
鈥         <ns11:Permission PermissionName="com.adobe.aps.pdf.edit" Access="ALLOW" xmlns:ns11="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns12:Permission PermissionName="com.adobe.aps.pdf.editNotes" Access="ALLOW" xmlns:ns12="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns13:Permission PermissionName="com.adobe.aps.pdf.fillAndSign" Access="ALLOW" xmlns:ns13="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <ns14:Permission PermissionName="com.adobe.aps.pdf.printHigh" Access="ALLOW" xmlns:ns14="https://www.adobe.com/schema/1.0/pdrl" xmlns="https://www.adobe.com/schema/1.0/pdrl-ex" />
鈥         <Principal PrincipalNameType="SYSTEM">
鈥            <PrincipalDomain>EDC_SPECIAL</PrincipalDomain>
鈥            <PrincipalName>publisher</PrincipalName>
鈥         </Principal>
鈥      </PolicyEntry>
鈥      <OfflineLeasePeriod>
鈥         <Duration>P31D</Duration>
鈥      </OfflineLeasePeriod>
鈥      <AuditSettings isTracked="true" />
鈥      <PolicyValidityPeriod isAbsoluteTime="false">
鈥         <ValidityPeriodRelative>
鈥            <NotBeforeRelative>PT0S</NotBeforeRelative>
鈥            <NotAfterRelative>P20D</NotAfterRelative>
鈥         </ValidityPeriodRelative>
鈥      </PolicyValidityPeriod>
鈥虫3颁;/笔辞濒颈肠测>
Summary of steps summary-of-steps
To create a policy, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Set the policy鈥檚 attributes.
- Create a policy entry.
- Register the policy.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
The following JAR files must be added to your project鈥檚 classpath:
- adobe-rightsmanagement-client.jar
- namespace.jar (if AEM Forms is deployed on JBoss)
- jaxb-api.jar (if AEM Forms is deployed on JBoss)
- jaxb-impl.jar (if AEM Forms is deployed on JBoss)
- jaxb-libs.jar (if AEM Forms is deployed on JBoss)
- jaxb-xjc.jar (if AEM Forms is deployed on JBoss)
- relaxngDatatype.jar (if AEM Forms is deployed on JBoss)
- xsdlib.jar (if AEM Forms is deployed on JBoss)
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-utilities.jar
- jbossall-client.jar (use a different JAR file if AEM Forms is not deployed on JBoss)
For information about the location of these JAR files, see Including AEM Forms Java library files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, create a Document Security service client object.
Set the policy鈥檚 attributes
To create a policy, set policy attributes. A mandatory attribute is the policy name. Policy names must be unique for each policy set. A policy set is simply a collection of policies. There can be two policies with the same name if the policies belong to separate policy sets. However, two policies within a single policy set cannot have the same policy name.
Another useful attribute to set is the validity period. A validity period is the time period during which a policy-protected document is accessible to authorized recipients. If you do not set this attribute, then the policy is always valid.
A validity period can be set to one of these options:
- A set number of days that the document is accessible from the time which the document is published
- An end date after which the document is not accessible
- A specific date range for which the document is accessible
- Always valid
You can specify just a start date, which results in the policy being valid after the start date. If you specify just an end date, the policy is valid until the end date. However, an exception is thrown if both a start date and an end date are not defined.
When setting attributes that belong to a policy, you can also set encryption settings. These encryption settings take affect when the policy is applied to a document. You can specify the following encryption values:
- AES256: Represents the AES encryption algorithm with a 256-bit key.
- AES128: Represents the AES encryption algorithm with a 128-bit key.
- NoEncryption: Represents no encryption.
When specifying the NoEncryption option, you cannot set the PlaintextMetadata option to false. If you attempt to do so, an exception is thrown.
Policy interface description in the .Create a policy entry
A policy entry attaches principals, which are groups and users, and permissions to a policy. A policy must have at least one policy entry. Assume, for example, that you perform these tasks:
- Create and register a policy entry that enables a group to only view a document while online and prohibits recipients from copying it.
- Attach the policy entry to the policy.
- Secure a document with the policy by using Acrobat.
These actions result in recipients only being able to view the document online and not being able to copy it. The document remains secure until security is removed from it.
Register the policy
A new policy must be registered before it can be used. After you register a policy, you can use it to protect documents.
Create a policy using the Java API create-a-policy-using-the-java-api
Create a policy by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Set the policy鈥檚 attributes. - Create a Policyobject by invoking theInfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreatePolicymethod. This method returns aPolicyobject.
- Set the policy鈥檚 name attribute by invoking the Policy辞产箩别肠迟鈥檚setNamemethod and passing a string value that specifies the policy name.
- Set the policy鈥檚 description by invoking the Policy辞产箩别肠迟鈥檚setDescriptionmethod and passing a string value that specifies the policy鈥檚 description.
- Specify the policy set to which the new policy belongs by invoking the Policy辞产箩别肠迟鈥檚setPolicySetNamemethod and passing a string value that specifies the policy set name. (You can specifynullfor this parameter value that results in the policy being added to the My Policies policy set.)
- Create the policy鈥檚 validity period by invoking the InfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreateValidityPeriodmethod. This method returns aValidityPeriodobject.
- Set the number of days for which a policy-protected document is accessible by invoking the ValidityPeriod辞产箩别肠迟鈥檚setRelativeExpirationDaysmethod and passing an integer value that specifies the number of days.
- Set the policy鈥檚 validity period by invoking the Policy辞产箩别肠迟鈥檚setValidityPeriodmethod and passing theValidityPeriodobject.
 
- Create a 
- 
                  Create a policy entry. - Create a policy entry by invoking the InfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreatePolicyEntrymethod. This method returns aPolicyEntryobject.
- Specify the policy鈥檚 permissions by invoking the InfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreatePermissionmethod. Pass a static data member that belongs to thePermissioninterface that represents the permission. This method returns aPermissionobject. For example, to add the permission that enables users to copy data from a policy-protected PDF document, passPermission.COPY. (Repeat this step for each permission to add).
- Add the permission to the policy entry by invoking the PolicyEntry辞产箩别肠迟鈥檚addPermissionmethod and passing thePermissionobject. (Repeat this step for eachPermissionobject that you created).
- Create the policy principal by invoking the InfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreateSpecialPrincipalmethod. Pass a data member that belongs to theInfomodelObjectFactoryobject that represents the principal. This method returns aPrincipalobject. For example, to add the publisher of the document as the principal, passInfomodelObjectFactory.PUBLISHER_PRINCIPAL.
- Add the principal to the policy entry by invoking the PolicyEntry辞产箩别肠迟鈥檚setPrincipalmethod and passing thePrincipalobject.
- Add the policy entry to the policy by invoking the Policy辞产箩别肠迟鈥檚addPolicyEntrymethod and passing thePolicyEntryobject.
 
- Create a policy entry by invoking the 
- 
                  Register the policy. - 
                      Create a PolicyManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getPolicyManagermethod.
- 
                      Register the policy by invoking the PolicyManager辞产箩别肠迟鈥檚registerPolicymethod and passing the following values:- The Policyobject that represents the policy to register.
 
- The 
- 
                      A string value that represents the policy set that the policy belongs to. 
 If you use an AEM forms administrator account within connection settings to create the DocumentSecurityClientobject, then specify the policy set name when you invoke theregisterPolicymethod. If you pass anullvalue for the policy set, the policy is created in the administrators My Policies policy set.If you use a Document Security user within connection settings, then you can invoke the overloaded registerPolicymethod that accepts only the policy. That is, you do not need to specify the policy set name. However, the policy is added to the policy set named My Policies. If you do not want to add the new policy to this policy set, then specify a policy set name when you invoke theregisterPolicymethod.note note NOTE When creating a policy, reference an existing policy set. If you specify a policy set that does not exist, then an exception is thrown. 
- 
                      
For code examples using the Document Security service, see the following:
- 鈥淨uick Start (SOAP mode): Creating a policy using the Java API鈥
Create a policy using the web service API create-a-policy-using-the-web-service-api
Create a policy by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Set the policy鈥檚 attributes. - Create a PolicySpecobject by using its constructor.
- Set the policy鈥檚 name by assigning a string value to the PolicySpec辞产箩别肠迟鈥檚namedata member.
- Set the policy鈥檚 description by assigning a string value to the PolicySpec辞产箩别肠迟鈥檚descriptiondata member.
- Specify the policy set to which the policy belongs by assigning a string value to the PolicySpec辞产箩别肠迟鈥檚policySetNamedata member. Specify an existing policy set name. (You can specifynullfor this parameter value that results in the policy being added to My Policies.)
- Set the policy鈥檚 offline lease period by assigning an integer value to the PolicySpec辞产箩别肠迟鈥檚offlineLeasePerioddata member.
- Set the PolicySpec辞产箩别肠迟鈥檚policyXmldata member with a string value that represents PDRL XML data. To perform this task, create a .NETStreamReaderobject by using its constructor. Pass the location of a PDRL XML file that represents the policy to theStreamReaderconstructor. Next, invoke theStreamReader辞产箩别肠迟鈥檚ReadLinemethod and assign the return value to a string variable. Iterate through theStreamReaderobject until theReadLinemethod returns null. Assign the string variable to thePolicySpec辞产箩别肠迟鈥檚policyXmldata member.
 
- Create a 
- 
                  Create a policy entry. It is not necessary to create a policy entry when creating a policy using the Document Security web service API. The policy entry is defined in the PDRL document. 
- 
                  Register the policy. Register the policy by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚registerPolicymethod and passing the following values:- The PolicySpecobject that represents the policy to register.
- A string value that represents the policy set that the policy belongs to. You can specify a nullvalue which results in the policy being added to the MyPolices policy set.
 If you use an AEM forms administrator account within connection settings to create the DocumentSecurityClientobject, specify the policy set name when you invoke theregisterPolicymethod.If you use a Document SecurityDocument Security user within connection settings, then you can invoke the overloaded registerPolicymethod that accepts only the policy. That is, you do not need to specify the policy set name. However, the policy is added to the policy set named My Policies. If you do not want to add the new policy to this policy set, then specify a policy set name when you invoke theregisterPolicymethod.note note NOTE When creating a policy and you specify a policy set, ensure that you specify an existing policy set. If you specify a policy set that does not exist, then an exception is thrown. 
- The 
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Creating a policy using the web service API鈥
- 鈥淨uick Start (SwaRef): Creating a policy using the web service API鈥
Modifying Policies modifying-policies
You can modify an existing policy using the Document Security Java API or web service API. To change an existing policy, you retrieve it, modify it, and then update the policy on the server. For example, assume that you retrieve an existing policy and extend its validity period. Before the change takes effect, you must update the policy.
You can modify a policy when business requirements change and the policy no longer reflects these requirements. Instead of creating a policy, you can simply update an existing policy.
To modify policy attributes using a web service (for example, using Java proxy classes that were created with JAX-WS), you must ensure that the policy is registered with the Document Security service. You can then reference the existing policy by using the PolicySpec.getPolicyXml method and modify the policy attributes by using the applicable methods. For example, you can modify the offline lease period by invoking the PolicySpec.setOfflineLeasePeriod method.
Summary of steps summary_of_steps-1
To modify an existing policy, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve an existing policy.
- Change policies attributes.
- Update the policy.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Securityservice operation, you must create a Document Security service client object. If you are using the Java API, create a RightsManagementClient object. If you are using the Document Security web service API, create a RightsManagementServiceService object.
Retrieve an existing policy
Retrieve an existing policy to modify it. To retrieve a policy, specify the policy name and the policy set to which the policy belongs. If you specify a null value for the policy set name, the policy is retrieved from the My Policies policy set.
Set the policy鈥檚 attributes
To modify a policy, you modify the value of policy attributes. The only policy attribute that you cannot change is the name attribute. For example, to change the policy鈥檚 offline lease period, you can modify the value of the policy鈥檚 offline lease period attribute.
When modifying a policy鈥檚 offline lease period using a web service, the offlineLeasePeriod field on the PolicySpec interface is ignored. To update the offline lease period, modify the OfflineLeasePeriod element in the PDRL XML document. Then reference the updated PDRL XML document by using the PolicySpec 颈苍迟别谤蹿补肠别鈥檚 policyXML data member.
Policy interface description in the .Update the policy
Before the changes that you make to a policy take affect, you must update the policy with the Document Security service. Changes to policies that are protecting documents are updated the next time that the policy-protected document is synchronized with the Document Security service.
Modify existing policies using the Java API modify-existing-policies-using-the-java-api
Modify an existing policy by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve an existing policy. - 
                      Create a PolicyManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getPolicyManagermethod.
- 
                      Create a Policyobject that represents the policy to update by invoking thePolicyManager辞产箩别肠迟鈥檚getPolicymethod and passing the following values"- A string value that represents the policy set name to which the policy belongs. You can specify nullthat results in theMyPoliciespolicy set being used.
- A string value that represents the policy name.
 
- A string value that represents the policy set name to which the policy belongs. You can specify 
 
- 
                      
- 
                  Set the policy鈥檚 attributes. Change the policy鈥檚 attributes to meet your business requirements. For example, to change the policy鈥檚 offline lease period, invoke the Policy辞产箩别肠迟鈥檚setOfflineLeasePeriodmethod.
- 
                  Update the policy. Update the policy by invoking PolicyManager辞产箩别肠迟鈥檚updatePolicymethod. Pass thePolicyobject that represents the policy to update.
Code examples
For code examples using the Document Security service, see the Quick Start(SOAP mode): Modifying a policy using the Java API section.
Modify existing policies using the web service API modify-existing-policies-using-the-web-service-api
Modify an existing policy by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve an existing policy. Create a PolicySpecobject that represents the policy to modify by invoking theRightsManagementServiceClient辞产箩别肠迟鈥檚getPolicymethod and passing the following values:- A string value that specifies the policy set name to which the policy belongs. You can specify nullthat results in theMyPoliciespolicy set being used.
- A string value that specifies the name of the policy.
 
- A string value that specifies the policy set name to which the policy belongs. You can specify 
- 
                  Set the policy鈥檚 attributes. Change the policy鈥檚 attributes to meet your business requirements. 
- 
                  Update the policy. Update the policy by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚updatePolicyFromSDKmethod and passing thePolicySpecobject that represents the policy to update.
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Modifying a policy using the web service API鈥
- 鈥淨uick Start (SwaRef): Modifying a policy using the web service API鈥
Deleting Policies deleting-policies
You can delete an existing policy using the Document Security Java API or web service API. After a policy is deleted, it can no longer be used to protect documents. However, existing policy-protected documents that are using the policy are still protected. You can delete a policy when a newer one becomes available.
Summary of steps summary_of_steps-2
To delete an existing policy, perform the following steps:
- Include project files
- Create a Document Security Client API object.
- Delete the policy.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object. If you are using the Java API, create a RightsManagementClient object. If you are using the Document Security web service API, create a RightsManagementServiceService object.
Delete the policy
To delete a policy, you specify the policy to delete and the policy set to which the policy belongs. The user whose settings are used to invoke AEM Forms must have permission to delete the policy; otherwise an exception occurs. Likewise, if you attempt to delete a policy that does not exist, an exception occurs.
Delete policies using the Java API delete-policies-using-the-java-api
Delete a policy by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Delete the policy. - 
                      Create a PolicyManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getPolicyManagermethod.
- 
                      Delete the policy by invoking the PolicyManager辞产箩别肠迟鈥檚deletePolicymethod and passing the following values:- A string value that specifies the policy set name to which the policy belongs. You can specify nullthat results in theMyPoliciespolicy set being used.
- A string value that specifies the name of the policy to delete.
 
- A string value that specifies the policy set name to which the policy belongs. You can specify 
 
- 
                      
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Deleting a policy using the Java API鈥
Delete policies using the web service API delete-policies-using-the-web-service-api
Delete a policy by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Delete the policy. Delete a policy by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚deletePolicymethod and passing the following values:- A string value that specifies the policy set name to which the policy belongs. You can specify nullthat results in theMyPoliciespolicy set being used.
- A string value that specifies the name of the policy to delete.
 
- A string value that specifies the policy set name to which the policy belongs. You can specify 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Deleting a policy using the web service API鈥
- 鈥淨uick Start (SwaRef): Deleting a policy using the web service API鈥
Applying Policies to PDF Documents applying-policies-to-pdf-documents
You can apply a policy to a PDF document to secure the document. By applying a policy to a PDF document, you restrict access to the document. You cannot apply a policy to a document if the document is already secured with a policy.
While the document is open, you can also restrict access to Acrobat and 51黑料不打烊 Reader features, including the ability to print and copy text, make changes, and add signatures and comments to a document. In addition, you can revoke a policy-protected PDF document when you no longer want users to access the document.
You can monitor the use of a policy-protected document after you distribute it. That is, you can see how the document is being used and who is using it. For example, you can find out when somebody has opened the document.
Summary of steps summary_of_steps-3
To apply a policy to a PDF document, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve a PDF document to which a policy is applied.
- Apply an existing policy to the PDF document.
- Save the policy-protected PDF document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client APIobject
Before you can programmatically perform a Document Security service operation, create a Document Security service client object. If you are using the Java API, create a DocumentSecurityClient object. If you are using the Document Security web service API, create a DocumentSecurityServiceService object.
Retrieve a PDF document
You can retrieve a PDF document to apply a policy. After you apply a policy to the PDF document, users are restricted when using the document. For example, if the policy does not enable the document to be opened while offline, then users must be online to open the document.
Apply an existing policy to the PDF document
To apply a policy to a PDF document, reference an existing policy and specify which policy set the policy belongs to. The user who is setting the connection properties must have access to the specified policy. If not, an exception occurs.
Save the PDF document
After the Document Security service applies a policy to a PDF document, you can save the policy-protected PDF document as a PDF file.
See also
Apply a policy to a PDF document using the Java API apply-a-policy-to-a-pdf-document-using-the-java-api
Apply a policy to a PDF document by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a PDF document. - Create a java.io.FileInputStreamobject that represents the PDF document by using its constructor. Pass a string value that specifies the location of the PDF document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Apply an existing policy to the PDF document. - 
                      Create a DocumentManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- 
                      Apply a policy to the PDF document by invoking the DocumentManager辞产箩别肠迟鈥檚protectDocumentmethod and passing the following values:- The com.adobe.idp.Documentobject that contains the PDF document to which the policy is applied.
- A string value that specifies the name of the document.
- A string value that specifies the name of the policy set to which the policy belongs. You can specify a nullvalue that results in theMyPoliciespolicy set being used.
- A string value that specifies the policy name.
- A string value that represents the name of the user manager domain of the user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the next parameter value must be null).
- A string value that represents the name of the canonical name of the user manager user who is the publisher of the document. This parameter value is optional and can be null(if this parameter is null, then the previous parameter value must benull).
- A com.adobe.livecycle.rightsmanagement.Localethat represents the locale that is used for selecting the MS Office template. This parameter value is optional and not used for PDF documents. To secure a PDF document, specifynull.
 The protectDocumentmethod returns aRMSecureDocumentResultobject that contains the policy-protected PDF document.
- The 
 
- 
                      
- 
                  Save the PDF document. - Invoke the RMSecureDocumentResult辞产箩别肠迟鈥檚getProtectedDocmethod to get the policy-protected PDF document. This method returns acom.adobe.idp.Documentobject.
- Create a java.io.Fileobject and ensure that the file extension is PDF.
- Invoke the com.adobe.idp.Document辞产箩别肠迟鈥檚copyToFilemethod to copy the contents of theDocumentobject to the file (ensure that you use theDocumentobject that was returned by thegetProtectedDocmethod).
 
- Invoke the 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (EJB mode): Applying a policy to a PDF document using the Java API鈥
- 鈥淨uick Start (SOAP mode): Applying a policy to a PDF document using the Java API鈥
See also
Apply a policy to a PDF document using the web service API apply-a-policy-to-a-pdf-document-using-the-web-service-api
Apply a policy to a PDF document by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a PDF document. - Create a BLOBobject by using its constructor. TheBLOBobject is used to store a PDF document to which a policy is applied.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the PDF document and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. Determine the byte array size by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod. Pass the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Apply an existing policy to the PDF document. Apply a policy to the PDF document by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚protectDocumentmethod and passing the following values:- The BLOBobject that contains the PDF document to which the policy is applied.
- A string value that specifies the name of the document.
- A string value that specifies the name of the policy set to which the policy belongs. You can specify a nullvalue that results in theMyPoliciespolicy set being used.
- A string value that specifies the policy name.
- A string value that represents the name of the user manager domain of the user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the next parameter value must be null).
- A string value that represents the name of the canonical name of the user manager user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the previous parameter value must be null).
- A RMLocalevalue that specifies the locale value (for example,RMLocale.en).
- A string output parameter that is used to store the policy identifier value.
- A string output parameter that is used to store the policy-protected identifier value.
- A string output parameter that is used to store the mime type (for example, application/pdf).
 The protectDocumentmethod returns aBLOBobject that contains the policy-protected PDF document.
- The 
- 
                  Save the PDF document. - Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the policy-protected PDF document.
- Create a byte array that stores the data content of the BLOBobject that was returned by theprotectDocumentmethod. Populate the byte array by getting the value of theBLOB辞产箩别肠迟鈥檚MTOMdata member.
- Create a System.IO.BinaryWriterobject by invoking its constructor and passing theSystem.IO.FileStreamobject.
- Write the contents of the byte array to a PDF file by invoking the System.IO.BinaryWriter辞产箩别肠迟鈥檚Writemethod and passing the byte array.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Applying a policy to a PDF document using the web service API鈥
- "Quick Start (SwaRef): Applying a policy to a PDF document using the web service API "
Removing Policies from PDF Documents removing-policies-from-pdf-documents
You can remove a policy from a policy-protected document to remove security from the document. That is, if you no longer want the document to be protected by a policy. If you want to update a policy-protected document with a newer policy, then instead of removing the policy and adding the updated policy, it is more efficient to switch the policy.
Summary of steps summary_of_steps-4
To remove a policy from a policy-protected PDF document, perform the following steps:
- Include project files
- Create a Document Security Client API object.
- Retrieve a policy-protected PDF document.
- Remove the policy from the PDF document.
- Save the unsecured PDF document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, create a Document Security service client object.
Retrieve a policy-protected PDF document
You can retrieve a policy-protected PDF document to remove a policy. If you attempt to remove a policy from a PDF document that is not protected by a policy, you will cause an exception.
Remove the policy from the PDF document
You can remove a policy from a policy-protected PDF document provided that an administrator is specified in the connection settings. If not, then the policy used to secure a document must contain the SWITCH_POLICY permission to remove a policy from a PDF document. Also, the user specified in the AEM Forms connection settings must also have that permission. Otherwise, an exception is thrown.
Save the unsecured PDF document
After the Document Security service removes a policy from a PDF document, you can save the unsecured PDF document as a PDF file.
See also
Remove a policy from a PDF document using the Java API remove-a-policy-from-a-pdf-document-using-the-java-api
Remove a policy from a policy-protected PDF document by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a policy-protected PDF document. - Create a java.io.FileInputStreamobject that represents the policy-protected PDF document by using its constructor and passing a string value that specifies the location of the PDF document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Remove the policy from the PDF document. - Create a DocumentManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- Remove a policy from the PDF document by invoking the DocumentManager辞产箩别肠迟鈥檚removeSecuritymethod and passing thecom.adobe.idp.Documentobject that contains the policy-protected PDF document. This method returns acom.adobe.idp.Documentobject that contains an unsecured PDF document.
 
- Create a 
- 
                  Save the unsecured PDF document. - Create a java.io.Fileobject and ensure that the file extension is PDF.
- Invoke the Document辞产箩别肠迟鈥檚copyToFilemethod to copy the contents of theDocumentobject to the file (ensure that you use theDocumentobject that was returned by theremoveSecuritymethod).
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Removing a policy from a PDF document using the Java API鈥
Remove a policy using the web service API remove-a-policy-using-the-web-service-api
Remove a policy from a policy-protected PDF document using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a policy-protected PDF document. - Create a BLOBobject by using its constructor. TheBLOBobject is used to store the policy-protected PDF document from which the policy is removed.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the PDF document and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. You can determine the size of the byte array by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod and passing the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Remove the policy from the PDF document. Remove the policy from the PDF document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚removePolicySecuritymethod and passing theBLOBobject that contains the policy-protected PDF document. This method returns aBLOBobject that contains an unsecured PDF document.
- 
                  Save the unsecured PDF document. - Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the unsecured PDF document.
- Create a byte array that stores the data content of the BLOBobject that was returned by theremovePolicySecuritymethod. Populate the byte array by getting the value of theBLOB辞产箩别肠迟鈥檚MTOMfield.
- Create a System.IO.BinaryWriterobject by invoking its constructor and passing theSystem.IO.FileStreamobject.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- "Quick Start (MTOM): Removing a policy from a PDF document using the web service API "
- 鈥淨uick Start (SwaRef): Removing a policy from a PDF document using the web service API鈥
See also
Revoking Access to Documents revoking-access-to-documents
You can revoke access to a policy-protected PDF document resulting in all copies of the document being inaccessible to users. When a user attempts to open a revoked PDF document, they are redirected to a specified URL where a revised document can be viewed. The URL to where the user is redirected must be programmatically specified. When you revoke access to a document, the change takes effect the next time the user synchronizes with the Document Security service by opening the policy-protected document online.
The ability to revoke access to a document provides additional security. For example, assume a newer version of a document is available and you no longer want anyone viewing the outdated version. In this situation, access to the older document can be revoked, and nobody can view the document unless access is reinstated.
Summary of steps summary_of_steps-5
To revoke a policy-protected document, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve a policy-protected PDF document.
- Revoke the policy-protected document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object.
Retrieve a policy-protected PDF document
Retrieve a policy-protected PDF document to revoke it. You cannot revoke a document that has already been revoked or is not a policy-protected document.
If you know the license identifier value of the policy-protected document, then it is not necessary to retrieve the policy-protected PDF document. However, in most cases, you must retrieve the PDF document to obtain the license identifier value.
Revoke the policy-protected document
To revoke a policy-protected document, specify the license identifier of the policy-protected document. In addition, you can specify the URL of a document that the user can view when they attempt to open the revoked document. That is, assume that an outdated document is revoked. When a user attempts to open the revoked document, they will see an updated document instead of the revoked document.
See also
Including AEM Forms Java library files
Revoke access to documents using the Java API revoke-access-to-documents-using-the-java-api
Revoke access to a policy-protected PDF document by using the Document Security API (Java):
- 
                  Include project files Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a policy-protected PDF document - Create a java.io.FileInputStreamobject that represent the policy-protected PDF document by using its constructor and passing a string value that specifies the location of the PDF document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Revoke the policy-protected document - 
                      Create a DocumentManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- 
                      Retrieve the license identifier value of the policy-protected document by invoking the DocumentManager辞产箩别肠迟鈥檚getLicenseIdmethod. Pass thecom.adobe.idp.Documentobject that represents the policy-protected document. This method returns a string value that represents the license identifier value.
- 
                      Create a LicenseManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getLicenseManagermethod.
- 
                      Revoke the policy-protected document by invoking the LicenseManager辞产箩别肠迟鈥檚revokeLicensemethod and passing the following values:- A string value that specifies the license identifier value of the policy-protected document (specify the return value of the DocumentManager辞产箩别肠迟鈥檚getLicenseIdmethod).
- A static data member of the Licenseinterface that specifies the reason to revoke the document. For example, you can specifyLicense.DOCUMENT_REVISED.
- A java.net.URLvalue that specifies the location to where a revised document is located. If you do not want to redirect a user to another URL, then you can passnull.
 
- A string value that specifies the license identifier value of the policy-protected document (specify the return value of the 
 
- 
                      
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Revoking a document using the Java API鈥
Revoke access to documents using the web service API revoke-access-to-documents-using-the-web-service-api
Revoke access to a policy-protected PDF document by using the Document Security API (web service):
- 
                  Include project files Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a policy-protected PDF document - Create a BLOBobject by using its constructor. TheBLOBobject is used to store a policy-protected PDF document that is revoked.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the policy-protected PDF document to revoke and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. You can determine the size of the byte array by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod and passing the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Revoke the policy-protected document - 
                      Retrieve the license identifier value of the policy-protected document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚getLicenseIDmethod and passing theBLOBobject that represents the policy-protected document. This method returns a string value that represents the license identifier.
- 
                      Revoke the policy-protected document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚revokeLicensemethod and passing the following values:- A string value that specifies the license identifier value of the policy-protected document (specify the return value of the DocumentSecurityServiceService辞产箩别肠迟鈥檚getLicenseIdmethod).
- A static data member of the Reasonenum that specifies the reason to revoke the document. For example, you can specifyReason.DOCUMENT_REVISED.
- A stringvalue that specifies the URL location to where a revised document is located. If you do not want to redirect a user to another URL, then you can passnull.
 
- A string value that specifies the license identifier value of the policy-protected document (specify the return value of the 
 
- 
                      
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Revoking a document using the web service API鈥
- 鈥淨uick Start (SwaRef): Revoking a document using the web service API鈥
See also
Reinstating Access to Revoked Documents reinstating-access-to-revoked-documents
You can reinstate access to a revoked PDF document, resulting in all copies of the revoked document being accessible to users. When a user opens a reinstated document that was revoked, the user is able to view the document.
Summary of steps summary_of_steps-6
To reinstate access to a revoked PDF document, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve the license identifier of the revoked PDF document.
- Reinstate access to the revoked PDF document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object. If you are using the Java API, create a DocumentSecurityClient object. If you are using the Document Security web service API, create a DocumentSecurityServiceService object.
Retrieve the license identifier of the revoked PDF document
Retrieve the license identifier of the revoked PDF document to reinstate a revoked PDF document. After you obtain the license identifier value, you can reinstate a revoked document. If you attempt to reinstate a document that is not revoked, you will cause an exception.
Reinstate access to the revoked PDF document
To reinstate access to a revoked PDF document, you must specify the license identifier of the revoked document. If you attempt to reinstate access to a PDF document that is not revoked, you will cause an exception.
See also
Including AEM Forms Java library files
Reinstate access to revoked documents using the Java API reinstate-access-to-revoked-documents-using-the-java-api
Reinstate access to a revoked document by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve the license identifier of the revoked PDF document. - Create a java.io.FileInputStreamobject that represents the revoked PDF document by using its constructor and passing a string value that specifies the location of the PDF document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
- Create a DocumentManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- Retrieve the license identifier value of the revoked document by invoking the DocumentManager辞产箩别肠迟鈥檚getLicenseIdmethod and passing thecom.adobe.idp.Documentobject that represents the revoked document. This method returns a string value that represents the license identifier.
 
- Create a 
- 
                  Reinstate access to the revoked PDF document. - Create a LicenseManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getLicenseManagermethod.
- Reinstate access to the revoked PDF document by invoking the LicenseManager辞产箩别肠迟鈥檚unrevokeLicensemethod and passing the license identifier value of the revoked document.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Reinstating access to a revoked document using the web service API鈥
Reinstate access to revoked documents using the web service API reinstate-access-to-revoked-documents-using-the-web-service-api
Reinstate access to a revoked document using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve the license identifier of the revoked PDF document. - Create a BLOBobject by using its constructor. TheBLOBobject is used to store a revoked PDF document to which access is reinstated.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the revoked PDF document and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. You can determine the size of the byte array by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod and passing the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Reinstate access to the revoked PDF document. - Retrieve the license identifier value of the revoked document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚getLicenseIDmethod and passing theBLOBobject that represents the revoked document. This method returns a string value that represents the license identifier.
- Reinstate access to the revoked PDF document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚unrevokeLicensemethod and passing a string value that specifies the license identifier value of the revoked PDF document (pass the return value of theDocumentSecurityServiceClient辞产箩别肠迟鈥檚getLicenseIdmethod).
 
- Retrieve the license identifier value of the revoked document by invoking the 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Reinstating access to a revoked document using the web service API鈥
- 鈥淨uick Start (SwaRef): Reinstating access to a revoked document using the web service API鈥
See also
Inspecting Policy Protected PDF Documents inspecting-policy-protected-pdf-documents
You can use the Document Security Service API (Java and web service) to inspect policy-protected PDF documents. Inspecting policy-protected PDF documents returns information about the policy-protected PDF document. You can, for example, determine the policy that was used to secure the document and the date when the document was secured.
You cannot perform this task if your version of LiveCycle is 8.x or an earlier version. Support for inspecting policy-protected documents is added in AEM Forms. If you attempt to inspect a policy-protected document using LiveCycle 8.x (or earlier), an exception is thrown.
Summary of steps summary_of_steps-7
To inspect a policy-protected PDF document, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve a policy-protected document to inspect.
- Obtain information about the policy-protected document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, create a Document Security service client object. If you are using the Java API, create a RightsManagementClient object. If you are using the Document Security web service API, create a RightsManagementServiceService object.
Retrieve a policy-protected document to inspect
To inspect a policy-protected document, retrieve it. If you attempt to inspect a document that is not secured with a policy or is revoked, an exception is thrown.
Inspect the document
After you retrieve a polciy-protected document, you can inspect it.
Obtain information about the policy-protected document
After you inspect a policy-protected PDF document, you can obtain information about it. For example, you can determine the policy that is used to secure the document.
If you secure a document with a policy that belongs to My Policies and then call RMInspectResult.getPolicysetName or RMInspectResult.getPolicysetId, null is returned.
If the document is secured using a policy that is contained in a policy set (other than My Policies) then RMInspectResult.getPolicysetName and RMInspectResult.getPolicysetId return valid strings.
See also
Inspect Policy Protected PDF Documents using the Java API inspect-policy-protected-pdf-documents-using-the-java-api
Inspect a policy-protected PDF document by using the Document Security Service API (Java):
- 
                  Include project files. Include client JAR files, such as the adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. For information about the location of these files, see Including AEM Forms Java library files. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties. (See Setting connection properties.)
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a policy-protected document to inspect. - Create a java.io.FileInputStreamobject that represents the policy-protected PDF document by using its constructor. Pass a string value that specifies the location of the PDF document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Inspect the document. - Create a DocumentManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- Inspect the policy-protected document by invoking the LicenseManager辞产箩别肠迟鈥檚inspectDocumentmethod. Pass thecom.adobe.idp.Documentobject that contains the policy-protected PDF document. This method returns aRMInspectResultobject that contains information about the policy-protected document.
 
- Create a 
- 
                  Obtain information about the policy-protected document. To obtain information about the policy-protected document, invoke the appropriate method that belongs RMInspectResultobject. For example, to retrieve the policy name, invoke theRMInspectResult辞产箩别肠迟鈥檚getPolicyNamemethod.
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Inspecting policy protected PDF documents using the Java API鈥
Inspect Policy Protected PDF Documents using the web service API inspect-policy-protected-pdf-documents-using-the-web-service-api
Inspect a policy-protected PDF document by using the Document Security Service API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a policy-protected document to inspect. - Create a BLOBobject by using its constructor. TheBLOBobject is used to store a PDF document to inspect.
- Create a System.IO.FileStreamobject by invoking its constructor. Pass a string value that represents the file location of the PDF document and the mode to open the file in.
- Create a byte array that stores the content of the System.IO.FileStreamobject. You can determine the size of the byte array by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod. Pass the byte array, starting position, and stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Inspect the document. Inspect the policy-protected document by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚inspectDocumentmethod. Pass theBLOBobject that contains the policy-protected PDF document. This method returns aRMInspectResultobject that contains information about the policy-protected document.
- 
                  Obtain information about the policy-protected document. To obtain information about the policy-protected document, get the value of the appropriate field that belongs to the RMInspectResultobject. For example, to retrieve the policy name, get the value of theRMInspectResult辞产箩别肠迟鈥檚policyNamefield.
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Inspecting policy protected PDF documents using the web service API鈥
- 鈥淨uick Start (SwaRef): Inspecting policy protected PDF documents using the web service API鈥
See also
Creating Watermarks creating-watermarks
Watermarks help ensure the security of a document by uniquely identifying the document and controlling copyright infringement. For example, you can create and place a watermark that states Confidential on all pages of a document. After a watermark is created, you can include it as part of a policy. That is, you can set the policy鈥檚 watermark attribute with the newly created watermark. After a policy that contains a watermark is applied to a document, the watermark appears in the policy-protected document.
Summary of steps summary_of_steps-8
To create a watermark, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Set the watermarks attributes.
- Register the watermark with the Document Security service.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object. If you are using the Java API, create a RightsManagementClient object. If you are using the Document Security web service API, create a RightsManagementServiceService object.
Set the watermarks attributes
To create a watermark, you must set watermark attributes. The name attribute must always be defined. In addition to the name attribute, you must set at least one of the following attributes:
- Custom Text
- DateIncluded
- UserIdIncluded
- UserNameIncluded
The following table lists key and value pairs that are required when creating a watermark using web services.
WaterBackCmd:IS_USERNAME_ENABLEDWaterBackCmd:IS_USERID_ENABLEDWaterBackCmd:IS_CURRENTDATE_ENABLEDWaterBackCmd:IS_CUSTOMTEXT_ENABLEDWaterBackCmd:SRCTEXT.WaterBackCmd:OPACITYWaterBackCmd:ROTATIONWaterBackCmd:SCALEWaterBackCmd:IS_SIZE_ENABLED must be present and the value must be true. If this attribute is not specified, the default behavior is fit to page.WaterBackCmd:HORIZ_ALIGNWaterBackCmd:VERT_ALIGNWaterBackCmd:IS_USE_BACKGROUNDWaterBackCmd:IS_SIZE_ENABLEDWaterBackCmd:SRCTEXTWaterBackCmd:IS_CUSTOMTEXT_ENABLED must also be present and set to true.All watermarks must have one of the following attributes defined:
- WaterBackCmd:IS_USERNAME_ENABLED
- WaterBackCmd:IS_USERID_ENABLED
- WaterBackCmd:IS_CURRENTDATE_ENABLED
- WaterBackCmd:IS_CUSTOMTEXT_ENABLED
All other attributes are optional.
Register the watermark
A new watermark must be registered with the Document Security service before it can be used. After you register a watermark, you can use it within policies.
See also
Create watermarks using the Java API create-watermarks-using-the-java-api
Create a watermark by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as the adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path.
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Set the watermark attributes - Create a Watermarkobject by invoking theInfomodelObjectFactory辞产箩别肠迟鈥檚 staticcreateWatermarkmethod. This method returns aWatermarkobject.
- Set the watermark鈥檚 name attribute by invoking the Watermark辞产箩别肠迟鈥檚setNamemethod and passing a string value that specifies the policy name.
- Set the watermark鈥檚 background attribute by invoking the Watermark辞产箩别肠迟鈥檚setBackgroundmethod and passingtrue. By setting this attribute, the watermark appears in the background of the document.
- Set the watermark鈥檚 custom text attribute by invoking the Watermark辞产箩别肠迟鈥檚setCustomTextmethod and passing a string value that represents the watermark鈥檚 text.
- Set the watermark鈥檚 opacity attribute by invoking the Watermark辞产箩别肠迟鈥檚setOpacitymethod and passing an integer value that specifies the opacity level. A value of 100 indicates that the watermark is completely opaque and a value of 0 indicates that the watermark is completely transparent.
 
- Create a 
- 
                  Register the watermark. - Create a WatermarkManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getWatermarkManagermethod. This method returns aWatermarkManagerobject.
- Register the watermark by invoking the WatermarkManager辞产箩别肠迟鈥檚registerWatermarkmethod and passing theWatermarkobject that represents the watermark to register. This method returns a string value that represents the watermark鈥檚 identification value.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (SOAP mode): Creating a watermark using the Java API鈥
Create watermarks using the web service API create-watermarks-using-the-web-service-api
Create a watermark by using the Document Security API (web service):
- 
                  Create a Document Security Client API object. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Set the watermark attributes. - Create a WatermarkSpecobject by invoking theWatermarkSpecconstructor.
- Set the watermark鈥檚 name by assigning a string value to the WatermarkSpec辞产箩别肠迟鈥檚namedata member.
- Set the watermark鈥檚 idattribute by assigning a string value to theWatermarkSpec辞产箩别肠迟鈥檚iddata member.
- For each watermark property to set, create a separate MyMapOf_xsd_string_To_xsd_anyType_Itemobject.
- Set the key value by assigning a value to the MyMapOf_xsd_string_To_xsd_anyType_Item辞产箩别肠迟鈥檚keydata member (for example,WaterBackCmd:OPACITY).
- Set the value by assigning a value to the MyMapOf_xsd_string_To_xsd_anyType_Item辞产箩别肠迟鈥檚valuedata member (for example,.25).
- Create a MyArrayOf_xsd_anyTypeobject. For eachMyMapOf_xsd_string_To_xsd_anyType_Itemobject, invoke theMyArrayOf_xsd_anyType辞产箩别肠迟鈥檚Addmethod. Pass theMyMapOf_xsd_string_To_xsd_anyType_Itemobject.
- Assign the MyArrayOf_xsd_anyTypeobject to theWatermarkSpec辞产箩别肠迟鈥檚valuesdata member.
 
- Create a 
- 
                  Register the watermark. Register the watermark by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚registerWatermarkmethod and passing theWatermarkSpecobject that represents the watermark to register.
Code examples
For code examples using the Document Security service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Creating a watermark using the web service API鈥
- 鈥淨uick Start (SwaRef): Creating a watermark using the web service API鈥
See also
Modifying Watermarks modifying-watermarks
You can modify an existing watermark using the Document Security Java API or web service API. To change an existing watermark, you retrieve it, modify its attributes, and then update it on the server. For example, assume that you retrieve an watermark and modify its opacity attribute. Before the change takes effect, you must update the watermark.
When you modify a watermark, the change impacts future documents that have the watermark applied to them. That is, existing PDF documents that contain the watermark are not affected.
Summary of steps summary_of_steps-9
To modify a watermark, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve the watermark to modify.
- Set the watermarks attributes.
- Update the watermark.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object. If you are using the Java API, create a DocumentSecurityClient object. If you are using the Document Security web service API, create a DocumentSecurityServiceService object.
Retrieve the watermark to modify
To modify a watermark, you must retrieve an existing watermark. You can retrieve a watermark by specifying its name or by specifying its identifier value.
Set the watermarks attributes
To modify an existing watermark, change the value of one or more watermark attributes. When programmatically updating a watermark using a web service, you must set all the attributes that were originally set, even if the value does not change. For example, assume the following watermark attributes are set: WaterBackCmd:IS_USERID_ENABLED, WaterBackCmd:IS_CUSTOMTEXT_ENABLED, WaterBackCmd:OPACITY, and WaterBackCmd:SRCTEXT. Although the only attribute that you want to modify is WaterBackCmd:OPACITY, you must set the other values are well.
Update the watermark
After you modify a watermark鈥檚 attributes, you must update the watermark.
See also
Modify watermarks using the Java API modify-watermarks-using-the-java-api
Modify a watermark by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as the adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve the watermark to modify. Create a WatermarkManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getWatermarkManagermethod and pass a string value that specifies the watermark name. This method returns aWatermarkobject that represents the watermark to modify.
- 
                  Set the watermark attributes. Set the watermark鈥檚 opacity attribute by invoking the Watermark辞产箩别肠迟鈥檚setOpacitymethod and passing an integer value that specifies the opacity level. A value of 100 indicates that the watermark is completely opaque and a value of 0 indicates that the watermark is completely transparent.note note NOTE This example modifies only the opacity attribute. 
- 
                  Update the watermark. - Update the watermark by invoking the WatermarkManager辞产箩别肠迟鈥檚updateWatermarkmethod and pass theWatermarkobject whose attribute was modified.
 
- Update the watermark by invoking the 
Code examples
For code examples using the Document Security service, see the Quick Start(SOAP mode): Modifying a watermark using the Java API section.
Modify watermarks using the web service API modify-watermarks-using-the-web-service-api
Modify a watermark by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/DocumentSecurityService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve the watermark to modify. Retrieve the watermark to modify by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚getWatermarkByNamemethod. Pass a string value that specifies the watermark name. This method returns aWatermarkSpecobject that represents the watermark to modify.
- 
                  Set the watermark attributes. - For each watermark property to update, create a separate MyMapOf_xsd_string_To_xsd_anyType_Itemobject.
- Set the key value by assigning a value to the MyMapOf_xsd_string_To_xsd_anyType_Item辞产箩别肠迟鈥檚keydata member (for example,WaterBackCmd:OPACITY).
- Set the value by assigning a value to the MyMapOf_xsd_string_To_xsd_anyType_Item辞产箩别肠迟鈥檚valuedata member (for example,.50).
- Create a MyArrayOf_xsd_anyTypeobject. For eachMyMapOf_xsd_string_To_xsd_anyType_Itemobject, invoke theMyArrayOf_xsd_anyType辞产箩别肠迟鈥檚Addmethod. Pass theMyMapOf_xsd_string_To_xsd_anyType_Itemobject.
- Assign the MyArrayOf_xsd_anyTypeobject to theWatermarkSpec辞产箩别肠迟鈥檚valuesdata member.
 
- For each watermark property to update, create a separate 
- 
                  Update the watermark. Update the watermark by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚updateWatermarkmethod and passing theWatermarkSpecobject that represents the watermark to modify.
Code examples
For code examples using the Document Security service, see the following Quick Start:
- 鈥淨uick Start (MTOM): Modifying a watermark using the web service API鈥
Searching for Events searching-for-events
The Rights Management service tracks specific actions as they occur, such as applying a policy to a document, opening a policy-protected document, and revoking access to documents. Event auditing must be enabled for the Rights Management service or events are not tracked.
Events fall into one of the following categories:
- Administrator events are actions related to an administrator, such as creating an administrator account.
- Document events are actions related to a document, such as closing a policy-protected document.
- Policy events are actions related to a policy, such as creating a policy.
- Service events are actions related to the Rights Management service, such as synchronizing with the user directory.
You can search for specify specific events by using the Rights Management Java API or web service API. By searching for events, you can perform tasks, such as creating a log file of certain events.
Summary of steps summary_of_steps-10
To search for a Rights Management event, perform the following steps:
- Include project files.
- Create a Rights Management Client API object.
- Specify the event for which to search.
- Search for the event.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Rights Management Client API object
Before you can programmatically perform a Rights Management service operation, you must create a Rights Management service client object. If you are using the Java API, create a DocumentSecurityClient object. If you are using the Rights Management web service API, create a DocumentSecurityServiceService object.
Specify the events to search for
Specify the event to search for. For example, you can search for the policy create event, which occurs when a new policy is created.
Search for the event
After you specify the event to search for, you can use either the Rights Management Java API or the Rights Management web service API to search for the event.
See also
Search for events using the Java API search-for-events-using-the-java-api
Search for events by using the Rights Management API (Java):
- 
                  Include project files Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Rights Management Client API object Create a DocumentSecurityClientobject by using its constructor and passing aServiceClientFactoryobject that contains connection properties.
- 
                  Specify the events to search for - Create an EventManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getEventManagermethod. This method returns anEventManagerobject.
- Create an EventSearchFilterobject by invoking its constructor.
- Specify the event for which to search by invoking the EventSearchFilter辞产箩别肠迟鈥檚setEventCodemethod and passing a static data member that belongs to theEventManagerclass that represents the event for which to search. For example, to search for the policy create event, passEventManager.POLICY_CREATE_EVENT.
 note note NOTE You can define additional search criteria by invoking EventSearchFilterobject methods. For example, invoke thesetUserNamemethod to specify a user associated with the event.
- Create an 
- 
                  Search for the event Search for the event by invoking the EventManager辞产箩别肠迟鈥檚searchForEventsmethod and passing theEventSearchFilterobject that defines the event search criteria. This method returns an array ofEventobjects.
Code examples
For code examples using the Rights Management service, see the following Quick Starts:
- 鈥淨uick Start (SOAP): Searching for events using the Java API鈥
Search for events using the web service API search-for-events-using-the-web-service-api
Search for events by using the Rights Management API (web service):
- 
                  Include project files Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Rights Management Client API object - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Specify the events to search for - Create an EventSpecobject by using its constructor.
- Specify the start of the time period during which the event occurred by setting the EventSpec辞产箩别肠迟鈥檚firstTime.datedata member withDataTimeinstance that represents the start of the date range when the event occurred.
- Assign the value trueto theEventSpec辞产箩别肠迟鈥檚firstTime.dateSpecifieddata member.
- Specify the end of the time period during which the event occurred by setting the EventSpec辞产箩别肠迟鈥檚lastTime.datedata member withDataTimeinstance that represents the end of the date range when the event occurred.
- Assign the value trueto theEventSpec辞产箩别肠迟鈥檚lastTime.dateSpecifieddata member.
- Set the event to search for by assigning a string value to the EventSpec辞产箩别肠迟鈥檚eventCodedata member. The following table lists the numeric values that you can assign to this property:
 table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 7-row-2 8-row-2 9-row-2 10-row-2 11-row-2 12-row-2 13-row-2 14-row-2 15-row-2 16-row-2 17-row-2 18-row-2 19-row-2 20-row-2 21-row-2 22-row-2 23-row-2 24-row-2 25-row-2 26-row-2 27-row-2 28-row-2 29-row-2 30-row-2 31-row-2 32-row-2 33-row-2 34-row-2 35-row-2 36-row-2 37-row-2 38-row-2 39-row-2 40-row-2 41-row-2 42-row-2 43-row-2 44-row-2 45-row-2 46-row-2 47-row-2 Event type Value ALL_EVENTS999 USER_CHANGE_PASSWORD_EVENT1000 USER_REGISTER_EVENT1001 USER_PREREGISTER_EVENT1002 USER_ACTIVATE_EVENT1003 USER_DEACTIVATE_EVENT1004 USER_AUTHENTICATE_EVENT1005 USER_AUTHENTICATE_DENY_EVENT1006 USER_ACCOUNT_LOCK_EVENT1007 USER_DELETE_EVENT1008 USER_UPDATE_PROFILE_EVENT1009 DOCUMENT_VIEW_EVENT2000 DOCUMENT_PRINT_LOW_EVENT2001 DOCUMENT_PRINT_HIGH_EVENT2002 DOCUMENT_SIGN_EVENT2003 DOCUMENT_ADD_ANNOTATION_EVENT2004 DOCUMENT_FORM_FILL_EVENT2005 DOCUMENT_CLOSE_EVENT2006 DOCUMENT_MODIFY_EVENT2007 DOCUMENT_CHANGE_SECURITY_HANDLER_EVENT2008 DOCUMENT_SWITCH_POLICY_EVENT2009 DOCUMENT_REVOKE_EVENT2010 $12011 DOCUMENT_SECURE_EVENT2012 DOCUMENT_UNKNOWN_CLIENT_EVENT2013 DOCUMENT_CHANGE_REVOKE_URL_EVENT2014 POLICY_CHANGE_EVENT3000 POLICY_ENABLE_EVENT3001 POLICY_DISABLE_EVENT3002 POLICY_CREATE_EVENT3003 POLICY_DELETE_EVENT3004 POLICY_CHANGE_OWNER_EVENT3005 SERVER_CLIENT_SYNC_EVENT4000 SERVER_SYNC_DIR_INFO_EVENT4001 SERVER_SYNC_DIR_COMPLETE_EVENT4002 SERVER_VERSION_MISMATCH_EVENT4003 SERVER_CONFIG_CHANGE_EVENT4004 SERVER_ENABLE_OFFLINE_ACCESS_EVENT4005 ADMIN_ADD_EVENT5000 ADMIN_DELETE_EVENT5001 ADMIN_EDIT_EVENT5002 ADMIN_ACTIVATE_EVENT5003 ADMIN_DEACTIVATE_EVENT5004 ERROR_DIRECTORY_SERVICE_EVENT6000 CREATED_POLICYSET_EVENT7000 DELETED_POLICYSET_EVENT7001 MODIFIED_POLICYSET_EVENT7002 
- Create an 
- 
                  Search for the event Search for the event by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚searchForEventsmethod and passing theEventSpecobject that represents the event for which to search and the maximum number of results. This method returns aMyArrayOf_xsd_anyTypecollection where each element is anAuditSpecinstance. Using anAuditSpecinstance, you can obtain information about the event such as the time that it occurred. TheAuditSpecinstance contains atimestampdata member that specifies this information.
Code examples
For code examples using the Rights Management service, see the following Quick Starts:
- 鈥淨uick Start (MTOM): Searching for events using the web service API鈥
- 鈥淨uick Start (SwaRef): Searching for events using the web service API鈥
See also
Applying Policies to Word Documents applying-policies-to-word-documents
In addition to PDF documents, the Rights Mangement service supports additional document formats such as a Microsoft Word document (DOC file) and other Micosoft office file formats. For example, you can apply a policy to a Word document to secure it. By applying a policy to a Word document, you restrict access to the document. You cannot apply a policy to a document if the document is already secured with a policy.
You can monitor the use of a policy-protected Word document after you distribute it. That is, you can see how the document is being used and who is using it. For example, you can find out when somebody has opened the document.
Summary of steps summary_of_steps-11
To apply a policy to a Word document, perform the following steps:
- Include project files.
- Create a Document Security Client API object.
- Retrieve a Word document to which a policy is applied.
- Apply an existing policy to the Word document.
- Save the policy-protected Word document.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client APIobject
Before you can programmatically perform a Document Security service operation, you must create a Document Security service client object.
Retrieve a Word document
Retrieve a Word document to apply a policy. After you apply a policy to the Word document, users are restricted when using the document. For example, if the policy does not enable the document to be opened while offline, then users must be online to open the document.
Apply an existing policy to the Word document
To apply a policy to a Word document, you must reference an existing policy and specify which policy set the policy belongs to. The user who is setting the connection properties must have access to the specified policy. If not, an exception occurs.
Save the Word document
After the Document Security service applies a policy to a Word document, you can save the policy-protected Word document as a DOC file.
See also
Apply a policy to a Word document using the Java API apply-a-policy-to-a-word-document-using-the-java-api
Apply a policy to a Word document by using the Document Security API (Java):
- 
                  Include project files. Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object. - Create a ServiceClientFactoryobject that contains connection properties.
- Create a DocumentSecurityClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a Word document. - Create a java.io.FileInputStreamobject that represents the Word document by using its constructor and passing a string value that specifies the location of the Word document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Apply an existing policy to the Word document. - 
                      Create a DocumentManagerobject by invoking theDocumentSecurityClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- 
                      Apply a policy to the Word document by invoking the DocumentManager辞产箩别肠迟鈥檚protectDocumentmethod and passing the following values:- The com.adobe.idp.Documentobject that contains the Word document to which the policy is applied.
- A string value that specifies the name of the document.
- A string value that specifies the name of the policy set to which the policy belongs. You can specify a nullvalue that results in theMyPoliciespolicy set being used.
- A string value that specifies the policy name.
- A string value that represents the name of the user manager domain of the user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the next parameter value must be null).
- A string value that represents the name of the canonical name of the user manager user who is the publisher of the document. This parameter value is optional and can be null(if this parameter isnull, then the previous parameter value must benull).
- A com.adobe.livecycle.rightsmanagement.Localethat represents the locale that is used for selecting the MS Office template. This parameter value is optional and you can specifynull.
 The protectDocumentmethod returns aRMSecureDocumentResultobject that contains the policy-protected Word document.
- The 
 
- 
                      
- 
                  Save the Word document. - Invoke the RMSecureDocumentResult辞产箩别肠迟鈥檚getProtectedDocmethod to get the policy-protected Word document. This method returns acom.adobe.idp.Documentobject.
- Create a java.io.Fileobject and ensure that the file extension is DOC.
- Invoke the com.adobe.idp.Document辞产箩别肠迟鈥檚copyToFilemethod to copy the contents of theDocumentobject to the file (ensure that you use theDocumentobject that was returned by thegetProtectedDocmethod).
 
- Invoke the 
Code examples
For code examples using the Document Security service, see the following Quick Start:
- 鈥淨uick Start (SOAP mode): Applying a policy to a Word document using the Java API鈥
Apply a policy to a Word document using the web service API apply-a-policy-to-a-word-document-using-the-web-service-api
Apply a policy to a Word document by using the Document Security API (web service):
- 
                  Include project files. Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/DocumentSecurityService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object. - 
                      Create a DocumentSecurityServiceClientobject by using its default constructor.
- 
                      Create a DocumentSecurityServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/DocumentSecurityService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theDocumentSecurityServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field DocumentSecurityServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field DocumentSecurityServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a Word document. - Create a BLOBobject by using its constructor. TheBLOBobject is used to store a Word document to which a policy is applied.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the Word document and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. Determine the byte array size by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod. Pass the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Apply an existing policy to the Word document. Apply a policy to the Word document by invoking the DocumentSecurityServiceClient辞产箩别肠迟鈥檚protectDocumentmethod and passing the following values:- The BLOBobject that contains the Word document to which the policy is applied.
- A string value that specifies the name of the document.
- A string value that specifies the name of the policy set to which the policy belongs. You can specify a nullvalue that results in theMyPoliciespolicy set being used.
- A string value that specifies the policy name.
- A string value that represents the name of the user manager domain of the user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the next parameter value must be null).
- A string value that represents the name of the canonical name of the user manager user who is the publisher of the document. This parameter value is optional and can be null (if this parameter is null, then the previous parameter value must be null).
- A RMLocalevalue that specifies the locale value (for example,RMLocale.en).
- A string output parameter that is used to store the policy identifier value.
- A string output parameter that is used to store the policy-protected identifier value.
- A string output parameter that is used to store the mime type (for example, application/doc).
 The protectDocumentmethod returns aBLOBobject that contains the policy-protected Word document.
- The 
- 
                  Save the Word document. - Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the policy-protected Word document.
- Create a byte array that stores the data content of the BLOBobject that was returned by theprotectDocumentmethod. Populate the byte array by getting the value of theBLOB辞产箩别肠迟鈥檚MTOMdata member.
- Create a System.IO.BinaryWriterobject by invoking its constructor and passing theSystem.IO.FileStreamobject.
- Write the contents of the byte array to a Word file by invoking the System.IO.BinaryWriter辞产箩别肠迟鈥檚Writemethod and passing the byte array.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Start:
- "Quick Start (MTOM): Applying a policy to a Word document using the web service API "
Removing Policies from Word Documents removing-policies-from-word-documents
You can remove a policy from a policy-protected Word document to remove security from the document. That is, if you no longer want the document to be protected by a policy. If you want to update a policy-protected Word document with a newer policy, then instead of removing the policy and adding the updated policy, it is more efficient to switch the policy.
Summary of steps summary_of_steps-12
To remove a policy from a policy-protected Word document, perform the following steps:
- Include project files
- Create a Document Security Client API object.
- Retrieve a policy-protected Word document.
- Remove the policy from the Word document.
- Save the unsecured Word document.s
Include project files
Include necessary files into your development project. If you are creating a client application using Java, then include the necessary JAR files. If you are using web services, then make sure that you include the proxy files.
Create a Document Security Client API object
Before you can programmatically perform a Document Security service operation, create a Document Security service client object.
Retrieve a policy-protected Word document
Retrieve a policy-protected Word document to remove a policy. If you attempt to remove a policy from a Word document that is not protected by a policy, you will cause an exception.
Remove the policy from the Word document
You can remove a policy from a policy-protected Word document provided that an administrator is specified in the connection settings. If not, then the policy used to secure a document must contain the SWITCH_POLICY permission to remove a policy from a Word document. Also, the user specified in the AEM Forms connection settings must also have that permission. Otherwise, an exception is thrown.
Save the unsecured Word document
After the Document Security service removes a policy from a Word document, you can save the unsecured Word document as a DOC file.
See also
Remove a policy from a Word document using the Java API remove-a-policy-from-a-word-document-using-the-java-api
Remove a policy from a policy-protected Word document by using the Document Security API (Java):
- 
                  Include project files Include client JAR files, such as adobe-rightsmanagement-client.jar, in your Java project鈥檚 class path. 
- 
                  Create a Document Security Client API object - Create a ServiceClientFactoryobject that contains connection properties.
- Create a RightsManagementClientobject by using its constructor and passing theServiceClientFactoryobject.
 
- Create a 
- 
                  Retrieve a policy-protected Word document - Create a java.io.FileInputStreamobject that represents the policy-protected Word document by using its constructor and passing a string value that specifies the location of the Word document.
- Create a com.adobe.idp.Documentobject by using its constructor and passing thejava.io.FileInputStreamobject.
 
- Create a 
- 
                  Remove the policy from the Word document - Create a DocumentManagerobject by invoking theRightsManagementClient辞产箩别肠迟鈥檚getDocumentManagermethod.
- Remove a policy from the Word document by invoking the DocumentManager辞产箩别肠迟鈥檚removeSecuritymethod and passing thecom.adobe.idp.Documentobject that contains the policy-protected Word document. This method returns acom.adobe.idp.Documentobject that contains an unsecured Word document.
 
- Create a 
- 
                  Save the unsecured Word document - Create a java.io.Fileobject and ensure that the file extension is DOC.
- Invoke the Document辞产箩别肠迟鈥檚copyToFilemethod to copy the contents of theDocumentobject to the file (ensure that you use theDocumentobject that was returned by theremoveSecuritymethod).
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Start:
- "Quick Start (SOAP mode): Removing a policy from a Word document using the Java API "
Remove a policy from a Word document using the web service API remove-a-policy-from-a-word-document-using-the-web-service-api
Remove a policy from a policy-protected Word document by using the Document Security API (web service):
- 
                  Include project files Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition: http://localhost:8080/soap/services/RightsManagementService?WSDL&lc_version=9.0.1.note note NOTE Replace localhostwith the IP address of the server hosting AEM Forms.
- 
                  Create a Document Security Client API object - 
                      Create a RightsManagementServiceClientobject by using its default constructor.
- 
                      Create a RightsManagementServiceClient.Endpoint.Addressobject by using theSystem.ServiceModel.EndpointAddressconstructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/RightsManagementService?WSDL.) You do not need to use thelc_versionattribute. This attribute is used when you create a service reference.)
- 
                      Create a System.ServiceModel.BasicHttpBindingobject by getting the value of theRightsManagementServiceClient.Endpoint.Bindingfield. Cast the return value toBasicHttpBinding.
- 
                      Set the System.ServiceModel.BasicHttpBinding辞产箩别肠迟鈥檚MessageEncodingfield toWSMessageEncoding.Mtom. This value ensures that MTOM is used.
- 
                      Enable basic HTTP authentication by performing the following tasks: - Assign the AEM forms user name to the field RightsManagementServiceClient.ClientCredentials.UserName.UserName.
- Assign the corresponding password value to the field RightsManagementServiceClient.ClientCredentials.UserName.Password.
- Assign the constant value HttpClientCredentialType.Basicto the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType.
 
- Assign the AEM forms user name to the field 
- 
                      Assign the constant value BasicHttpSecurityMode.TransportCredentialOnlyto the fieldBasicHttpBindingSecurity.Security.Mode.
 
- 
                      
- 
                  Retrieve a policy-protected Word document - Create a BLOBobject by using its constructor. TheBLOBobject is used to store the policy-protected Word document from which the policy is removed.
- Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the Word document and the mode in which to open the file.
- Create a byte array that stores the content of the System.IO.FileStreamobject. You can determine the size of the byte array by getting theSystem.IO.FileStream辞产箩别肠迟鈥檚Lengthproperty.
- Populate the byte array with stream data by invoking the System.IO.FileStream辞产箩别肠迟鈥檚Readmethod and passing the byte array, the starting position, and the stream length to read.
- Populate the BLOBobject by assigning itsMTOMfield with the contents of the byte array.
 
- Create a 
- 
                  Remove the policy from the Word document Remove the policy from the Word document by invoking the RightsManagementServiceClient辞产箩别肠迟鈥檚removePolicySecuritymethod and passing theBLOBobject that contains the policy-protected Word document. This method returns aBLOBobject that contains an unsecured Word document.
- 
                  Save the unsecured Word document - Create a System.IO.FileStreamobject by invoking its constructor and passing a string value that represents the file location of the unsecured Word document.
- Create a byte array that stores the data content of the BLOBobject that was returned by theremovePolicySecuritymethod. Populate the byte array by getting the value of theBLOB辞产箩别肠迟鈥檚MTOMfield.
- Create a System.IO.BinaryWriterobject by invoking its constructor and passing theSystem.IO.FileStreamobject.
 
- Create a 
Code examples
For code examples using the Document Security service, see the following Quick Start:
- 鈥淨uick Start (MTOM): Removing a policy from a Word document using the web service API鈥
See also