Protecting

ActiveDocument.Protect Type:=wdProtectionType.wdAllowOnlyFormFields 
                       NoReset:=False, _
                       Password:="password", _
                       UseIRM:=False, _
                       EnforceStyleLock:=False

Type - The protection type for the specified document.
NoReset - Whather to reset form fields to their default values. The default value is False. A True value will retain make sure the form fields keep their values if the document is protected. If Type is not wdAllowOnlyFormFields, the NoReset argument is ignored.
Password - The password required to remove protection from the document.
UseIRM - Specifies whether to use Information Rights Management (IRM) when protecting the document from changes.
EnforceStyleLock - Specifies whether formatting restrictions are enforced in a protected document.


When a document is protected, users can make only limited changes, such as adding annotations, making revisions, or completing a form. If the document is already protected when you use this method, an exception is thrown.
Avoid using hard-coded passwords in your applications. If a password is required in a procedure, request the password from the user, store it in a variable, and then use the variable in your code.


Shade Editable Ranges

Application.ActiveWindow.ViewShadeEditableRanges 


Removing all editable regions

ActiveDocument.SelectAllEditableRanges() 
objRegions = ActiveDocument.ActiveWIndow.Selection.Range
If (objRegions.Editors.Count > 0) Then
   objRegions.Editors,Item(Word.wdEditorType.wdEditorEveryone),DeleteAll()
End If


UnProtecting a Document

ActiveDocument.Unprotect (Password:="") 

If ActiveDocument.ProtectionType:=wdProtectionType.wdNoProtection Then 
   ActiveDocument.Protect (wdProtectionType.wdAllowOnlyComments, , "password"
   ActiveDocument.UnProtect Password:="password"
End If

Protecting a Template

Protecting a template is confusing if a template is password protected for opening.
When you try to create a new document based on that template you will need the password


If you attempt to open a document based on a password protected template you are prompted for the password although you can just press Enter and the document is still opened.
If you set the PassTemplate to an empty string you will be prompted for the password.

Documents.Open "C:\Temp\Name.doc" PasswordTemplate = "" 

If you set the PassTemplate to an invalid string you will NOT be prompted for the password.

Documents.Open "C:\Temp\Name.doc" PasswordTemplate = "invalid" 

BUG - Unable to save a style to a Protected Template

Create a new style and tick the "add to template" checkbox.
The style will not be saved to the template but will be saved to the Normal.dot instead
There is no prompt ??


BUG - Unable to add Password to a Template for modifications

If you add a password to a template to prevent modifications, pressing ESC when prompted will open the file anyway.



objDocument.ReadOnly = True / False 
objDocument.ReadOnlyRecommended = True / False
objDocument.UnProtect "password"
objDocument.Password = "password to open file"

Determines if the document has a password which is needed to modify the document.

objDocument.HasPassword = True / False 

objDocument.Protect(Type, NoReset, Password) 


© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext