Walk-through: Implementing security with Windows users and roles

Complexity: Beginner Data Requirement: ArcGIS Tutorial Data Setup

This walk-through shows how to implement security for Web applications and GIS services. In this walk-through, users are stored as Windows operating system accounts on the local Web server machine or on the domain of which the Web server is a member. Roles for users are defined as groups on the local server or domain. Windows users and groups is one of several options for users and roles. This option is typically employed when users of the server are on the local network rather than connecting over the Internet. It can be a convenient approach when you want your GIS users to take advantage of the accounts they already have on your network.

In this walk-through, you will add users and groups as needed to your system, configure the user and role location in Manager, set permissions for a Web application and a GIS Web service, and enable security for GIS Web services.

CautionCaution:

Near the end of this walk-through, you enable security for GIS Web services. Once you enable services security, only users whom you have authorized, based on their Windows group membership, will be able to access any services on your system. Also from this point on, you will need to manage permissions for all services. You should not enable services security unless you want to restrict all services to authorized users and you are prepared to continue managing permissions.

These are the steps in this walkthrough:

  1. Add users and groups with operating system tools.
  2. Configure the user and role location in Manager.
  3. View users and roles.
  4. Secure a Web application.
  5. Set permissions for GIS Web services.
  6. Disable anonymous access to GIS Web services.
  7. Apply security to GIS Web services.

Add users and groups with operating system tools

To assign permissions based on Windows users and groups, you might need to add users and groups to your system. The instructions below provide basic steps. Refer to Windows documentation for details.

If you already have users and groups defined on your Web server or domain and want to use them to assign permissions for applications and services, you can skip this section.

Steps:
  1. To add users and groups to the local Web server, go to Start > Control Panel > Administrative Tools > Computer Management (alternatively, right-click the My Computer icon on the desktop and click Manage). In the Computer Management console, expand System Tools and Local Users and Groups. Click the Users folder to view the list of users.
    • In Windows Vista or Server 2008, go instead to Start > Control Panel > Administrative Tools > Server Manager. In the Server Manager, expand Configuration and then Local Users and Groups. Click the Users folder to view the list of users.
  2. Right-click the Users folder and choose New User.
    Computer Management: Adding new user
  3. Enter the user name, for example, walkthrough1. Enter a password and confirm it (for example, walkthrough1). You can uncheck the requirement that the user must change password at next logon. Set other options as desired, then click Create.
  4. Add at least one other user, for example, walkthrough2. Close the New User dialog box.
  5. Right-click the Groups folder in the Computer Management (or Server Manager) tree and choose New Group.
  6. Type the group name, for example, WTGroup1. Optionally add a description. Add members to the group:
    1. Under the Members area, click Add.
    2. On the Select Users, Computers, or Groups dialog box, click the Locations button, and in the pop-up dialog box, choose the local computer's name and click OK.
    3. On the Select Users, Computers, or Groups dialog box, under the Enter the object names to select box, type the name of the first user added above (walkthrough1).
      Computer management: Adding new group
    4. Click Check Names to verify the user exists (if necessary, click the Advanced button and Find Now to list all users; you can select the user from this list).
    5. Click OK to close the Select Users, Computers, or Groups dialog box and return to the Add Group dialog box. The New Group dialog now lists the user you selected.
  7. Click Create to create the new group.
  8. Create one more group, for example, WTGroup2, adding the second user created above (walkthrough2). Close the New Group dialog box. You can also close the Computer Management console.

Configure the user and role location in Manager

To assign permissions for Web applications and services, you must first tell ArcGIS Server where your users and roles are stored. In this walk-through, users are operating system accounts on the Web server or on the domain, and roles are Windows groups on the Web server or domain.

Steps:
  1. Start ArcGIS Server Manager and log in.
  2. In Manager, expand the Security panel and click Settings.
  3. Click the Configure button (do this even if Location already indicates Windows users and groups; the wizard performs additional essential configuration steps).
    Security Settings wizard: Configure
  4. In the panel for selecting the user store location, choose Windows users.
    Security Settings wizard: set Windows users
    Click Next.
  5. In the panel for selecting the role store location, click Windows groups. Click Finish. The wizard closes and the Location box reads Windows Users and Groups.

Notice that security for services is set to Not Enabled. Do not enable security at this point. You will enable security in the last step in this walk-through. Enabling security is the last step because you first need to set permissions for your Web services. Once security is enabled, only users whose roles you have permitted can access the GIS Web services.

View users and roles

When your users and roles are Windows users and groups, you can view them in Manager. To add, edit, or delete users or groups, you must use Windows operating system tools, as described in the first section of this walk-through.

Steps:
  1. In Manager, click the Security tab on the left side and click Users. The Users panel displays a list of users on the local Web server.
    List of Windows users in Manager
  2. If you have more users than can be displayed in a single panel, click the double right arrows (>>) to display additional users. You can also enter part or all of a user name in the Show box near the top of the panel and click Find to filter the list of users.
  3. To view a user's group membership, click the plus sign (+) next to the name. The list shows the groups of which the user is a member on the local system.
  4. If the computer is a member of a domain, you can view users on the domain by clicking the Domain button for Show users on. You can then view domain group membership for these users (the list does not show membership in local system groups).
  5. View roles by clicking Roles on the Manager Security tab. In this case, the list displays Windows groups on the local Web server. If the computer is a member of a domain, click Domain to see groups in the domain. You can page between lists of groups or filter/search for groups as with the Users dialog box.
    List of Windows groups in Manager
  6. Click the plus sign next to a group to view the users who are members of the group.

Secure a Web application

Now you will secure a Web application by limiting access to designated roles (in this case, Windows groups). The final sections of this walk-through will accomplish this goal.

Steps:
  1. Create a new Web application in Manager. The application may be simple, with just a map service and no extra tools or tasks. You can follow the Creating a Web application tutorial if you need to create an application. If you have installed an SSL certificate on the Web server, when creating the application, you might want to set the application to use HTTPS (in the application wizard, use the Advanced option on the first panel). You can use an existing application, but all users of the application will be required to log in as users in a role you permit during the walk-through.
  2. In Manager, click Applications to list the Web applications. Find the application you want to secure in the list. In the Permissions column, notice the unlocked icon
    Unlocked icon for unsecured application
    . This indicates that the application is not restricted, so that users currently are not required to log in.
    Applications list dialog
  3. Click the permissions icon
    Unlocked icon for unsecured application
    , which displays the Permissions dialog box for the Web application.
  4. Check the box Enable security for this web application. This enables the lists of available and allowed roles.
  5. If you want to allow roles based on domain groups, click the Domain option under Show roles on. Otherwise, click Local server to see groups on the local machine. You can add both domain and local groups as allowed roles.
  6. Highlight the WTGroup1 role (or other role you added above) in the Available Roles list. Click the Add button to add it to the Allowed Roles list. Optionally, add other roles to the allowed list.
  7. Click Save to save the permissions and return to the list of applications. Notice that the permissions icon changes to a locked appearance
    Locked icon for secured application
    , which shows that it now requires a login to access the application.
  8. Set the authentication method for the application using IIS Manager:
    1. Open IIS Manager by going to Start > Settings > Control Panel > Administrative Tools > Internet Information Services Manager.
    2. Expand the left-hand tree of IIS Manager, under Web Sites or Sites. Expand Default Web Site to find the Web application you just secured.
    3. On Windows XP or Server 2003: (1) Right-click the Web application and click Properties in the context menu. The Properties dialog box opens for the application.
      IIS Manager: application properties
      (2) On the Properties dialog box, click the Directory Security tab. In this panel, under Anonymous access and authentication control, click Edit. The Authentication Methods dialog box opens. (3) Uncheck the Anonymous access box. Then check at least one of the methods under Authenticated access. For the demonstration purposes of this walk-through, you can choose Basic authentication (click Yes if a warning message appears). For more information on authentication methods, see the Security overview page.
      Application authentication methods
      (4) Click OK to close the Authentication Methods dialog box and return to the application's Properties dialog box. On Windows Vista or Server 2008: (1) Click the application in the tree. On the right side of IIS Manager, double-click Authentication. (2) Click the Anonymous Authentication item to select it and click Disable in the Actions list on the right side of IIS Manager. Then enable at least one other authentication method. For more information on authentication methods, see the Security overview page.
    4. If you have installed an SSL certificate on your Web server, you can require HTTPS when using the application. This will protect the login when the authentication method is set to Basic. On Windows XP or Server 2003: On the Properties dialog box for the application, click the Directory Security tab. In the Secure communications area of this panel, click Edit (if this button is disabled, then no SSL certificate is installed). On the Secure Communications dialog box, click Require secure channel (SSL). Click OK to save the setting. Click OK to close the Properties dialog box. On Windows Vista or Server 2008: In IIS Manager, click the application in the left-hand tree to select it. In the right side of IIS Manager, double-click SSL Settings. In the SSL Settings panel that opens, check the Require SSL box.
    5. Close the IIS Manager console.
  9. Test the application by clicking its URL hyperlink in the list of Web applications. The application opens in a new browser window, and a pop-up prompts you to log in. Enter the user name and password for a user who is a member of the role you permitted (for example, the walkthrough1 user added above) and click OK. Upon successful login, the application proceeds to the ArcGIS Server Web application page. Close the application when you've finished viewing it.

Set permissions for GIS Web services

In addition to securing Web applications, you can restrict access to GIS Web services using Manager. This section shows how to set permissions for services. These permissions are not actually enforced until you complete the following section on applying security to services. This workflow enables you to configure permissions for services, then apply security, so that users will continue to be able to access services throughout the security process.

This walk-through configures security so that, by default, services on the server will allow anyone in the Users group (which typically includes all user accounts on the local server) to access services. Then a folder is configured to permit a more limited set of roles to access services within the folder. This approach may be appropriate for a site with a mix of secured and open services. Your organization might want to use a different approach than the one illustrated below.

Note that when users and roles of your services are Windows users and groups, it is not possible to have anonymous access to services, where users do not provide login credentials. In other words, all users of your services will need to have a Windows account and input the user name and password when prompted.

Steps:
  1. In Manager, ensure you have at least one service in your server's root folder. Add a service if no services exist yet. You can refer to the tutorial Publishing a map service to create the service.
  2. Add a folder to your server's services by clicking Manage Folders. In the drop-down list that appears, click Add.
    Add a service folder
    In the Add Folder text box, type a folder name such as SecurityWalkthrough. Click OK to add the folder.
  3. Add a service to the new folder. Use Publish a GIS Resource to add the service, being careful to specify the new folder (SecurityWalkthrough) as the location. (You can also use the Add New Service wizard, but ensure that the Services in list shows the SecureServices folder. You can also use ArcCatalog to add the service.) You can delete the service and folder after the walk-through if desired.
  4. Set permissions on the root folder to allow anyone in the Users group to access services. This approach is appropriate if you want to allow all users by default but restrict certain services or folders to require a valid login. To set this permission, ensure the Services in box reads Server name (root), where Server name is your server's machine name (click the drop-down list to choose this item if necessary). Then click Manage Folders, and from the drop-down list, choose Permissions. The Permissions dialog box that opens displays the folder name (root).
  5. On the Permissions dialog box, select the Users role (group) and click Add. The Users role moves to the Allowed Roles list. The Users role typically covers all users with accounts on the local server. Optionally, if you have users on the Windows domain that you want to allow, you can add them by clicking the Domain option at the top of the list (the Domain Users group typically includes all users in the domain). Note the warning that security for services is not enabled; you will enable security in the next section. Click Save to save the permissions list.
    Setting service permissions
  6. Restrict permissions on the folder you created earlier. In the Services in list choose the folder (SecurityWalkthrough). Then click Manage Folders and then Permissions.
  7. On the Permissions dialog box, click the Users role in the Allowed Roles list and click Remove. The role is moved to the Available Roles list. If you added other roles (for example, Domain Users), remove them as well. Next, click a specific role to allow, from either the local server or the domain, such as WTGroup1. You can add multiple roles as allowed if desired. Click Save to save the permissions list.

The permissions are now configured for services. However, security is not yet enforced. In other words, at this point any user can still access services in the SecureServices folder without supplying a login. The next section enables security, which enforces the access permissions you have configured.

Disable anonymous access to GIS Web services

You want the users of your GIS Web services to provide a Windows login to access services. Client applications only prompt for a login if they receive an authentication challenge from the Web server. This section of the walk-through configures the IIS Web server to obtain the user's login.

NoteNote:

You should not complete this section unless you want to require all users of your GIS Web services to have Windows accounts on your local server or on the domain.

Steps:
  1. Open IIS Manager from Control Panel > Administrative Tools > Internet Information Services.
  2. Navigate in the local computer's Web sites to the Web site containing your ArcGIS instance (typically in Default Web Site). Find the instance folder (named ArcGIS by default) and expand it.
  3. The method to disable anonymous access depends on your system.
    • In Windows Server 2003 or XP:
      1. Right-click the Services Web application and click Properties.
      2. Click the Directory Security tab. Under Anonymous access and authentication control, click Edit.
      3. Uncheck Anonymous access. Check at least one of the methods under Authenticated access. See below for more information on authentication methods. Then click OK twice to return to the IIS Manager console.
    • In Windows Server 2008 or Vista:
      1. Left-click the Services application to display its property links on the right side of IIS Manager.
      2. Double-click the Authentication item under the IIS group. This displays the authentication methods list for the application.
      3. In the list of authentication methods, right-click Anonymous Authentication, and in the shortcut menu, click Disable.
      4. Enable at least one of the other authentication methods. See below for more information on authentication methods.
  4. Repeat step 3 through 5 above, but set the properties for the Rest Web application within the ArcGIS folder.

For more information on authentication methods, see IIS documentation and other resources such as the MSDN page Authentication Methods Supported in IIS 6.0.

Apply security to GIS Web services

The final step for securing GIS Web services is to apply security to the services. This step restricts GIS Web services so that only users whose roles you have permitted can access the services. Until you perform this step, any permissions you have applied are not actually in effect, and any user can access any service. You should not do the steps here until you have configured permissions as described in the section above.

CautionCaution:

Once you enable security for services, you cannot disable it in Manager (see the Server Help page on securing services for information on manually disabling security if necessary). Security for services should be a one-way process. If you are not ready to enable security for GIS Web services, you can skip this section of the walk-through.

Steps:
  1. In Manager, click the Security tab on the left and click Settings within the Security section. This displays the settings panel for security.
  2. In the Security Settings panel, read the information under Security for GIS Services. Notice that security is set to Not Enabled when you install ArcGIS Server.
    Enable security for services
  3. Click Enable. A message cautions you to set permissions before enabling security for services. Click the Enable Security for Services button to confirm. You return to the Security Settings panel, and the indicator now shows that security is enabled.
  4. Click the Services tab on the left side of Manager. In the list of services, the permissions icons now appear as a locked icon
    Locked icon for secured services
    . If you see an icon with a red exclamation point
    Warning icon for secure service with no roles permitted
    , it indicates that the service has an empty permissions list. These services are inaccessible to all users until at least one role is added to each service's Allowed Roles list.
  5. To verify that security for services is in effect, use ArcCatalog to connect to your services. Start ArcCatalog, either on your local machine or on a machine that can access the Web server for ArcGIS Server.
  6. In ArcCatalog, expand the GIS Servers node in the Catalog tree. Double-click the Add ArcGIS Server item.
  7. Click Use GIS Services. Click Next.
  8. In the next panel, click Internet as the type of connection and enter your server's URL, for example, http://myserver/arcgis/services. In the Authentication part of the dialog box, type the user name and password for an account that is in the Users group but not in the WTGroup1, for example, MYSERVER\walkthrough2 (or if you configured security with different users and roles, use an account that does not have permission to the secured folder, SecurityWalkthrough). Click Finish. The dialog box closes and a new connection appears in your GIS Servers list, such as arcgis on myserver.
  9. Expand the node for the new connection. See the service at the root of your server. However, the folder that you secured in the previous connection (SecurityWalkthrough) is not visible. Since you permitted the Users role to access the root folder, services in the root and any folders that did not override its settings are visible to all users. Since you did not connect with an appropriate login, the SecureServices folder is not available to this connection.
  10. Add another GIS server connection in ArcCatalog, using steps 6 to 8 above. Enter the same server URL, but for step 8, type the user name and password. Use the login you created above for the user (for example, walkthrough1) in the role for which you permitted use of the SecurityWalkthrough folder. Click Finish to add the connection.
  11. Expand this connection (for example, arcgis on myserver [2]). You now see the SecurityWalkthrough folder, along with any services and folders permitted to Users.
  12. Close ArcCatalog and Manager when finished.

These steps have secured your Web application and GIS Web services based on Windows users and groups. For more details on configuring security, see the other pages on security in this section of the ArcGIS Server Help.

You can use secured services in various clients, including ArcGIS Desktop, Web ADF applications, and JavaScript API applications. To add a secured service to a Web ADF application, add a new ArcGIS Server Internet connection and type the appropriate user name and password in the Identity text box on the connection dialog box in Manager or Visual Studio.

If desired, remove any services, folders, users, or roles created during this walk-through. Keep in mind that once you enable security for services, you must manage permissions for all folders and services. If you add a service but do not add any permitted roles, it is inaccessible to all users (a warning icon

Warning icon for secure service with no roles permitted
is displayed to alert you of this problem). One way to ensure at least a default set of permissions is to add permissions to the containing folder at the root or subfolder. Services inherit the permissions of their containing folder, making it simpler to configure security for services.


8/22/2012