Preventing Account Creation Spam in Ares

Print Friendly and PDF Follow

By default, all Ares installations are set up with standard Ares authentication. This type of authentication allows anyone with access to the Create Account web form (GCreateAccount.html) to register for a new account, choose a username and password, and then use that username and password to immediately log into the Ares web interface. As standard Ares authentication does not verify user information against any external system upon registration or login before creating the user's account, you may experience periods of bot-driven automatic account creation spam wherein bots use the Create Account form to create a large number of accounts in a short period of time. 

The release of Ares Server v5.0.9/Web DLL v5.0.6 includes several new options for preventing excessive new user account creation spam on the Create Account form (GCreateAccount.html). This article will detail these options and how to configure them for your Ares installation after updating.

Option 1: Add Captcha Requirement to the Create Account Form

The captcha requirement is only supported for use on the Create Account form (GCreateAccount.html) and cannot be added to other Ares web forms.

Extra security against spam account creation can be provided by adding a captcha requirement to the Create Account form (GCreateAccount.html). Once added, users will need to solve the captcha requirement to submit the form and create their Ares account, which will prevent bot-driven account creation spam. To add the captcha requirement, Ares must be configured to integrate with one of three supported third-party captcha providers. Once a provider is selected, your institution will need to create an account with that provider and use the account details to configure the captcha integration in the Ares Customization Manager. Ares supports the following third-party captcha providers and plans:

  • Google reCAPTCHA: The reCAPTCHA v2 (both the "invisible" and "checkbox" variants) and reCAPTCHA v3 are supported options
    • Note that reCAPTCHA Enterprise is not supported by Ares
    Due to a Google bug, HTML5 validation configured on the Create Account form will no longer properly display the tooltips notifying the user of any missing/invalid information that is preventing the submission of the form when using the "invisible" reCAPTCHA v2 variant. Users may also experience a delay before they are allowed to re-submit the form after their first invalid form submission.
  • hCaptcha: The free "Publisher" plan is supported
  • MTCaptcha: The free plan is supported
Note that only the free captcha account options offered by the captcha providers listed above are supported by Ares at this time. Atlas Systems cannot guarantee support for any of the paid account options from these providers. Certain limits may apply based on the provider selected. Please review each provider's documentation for complete details.

Accessibility Information

For complete details on the accessibility features offered by each captcha provider, please see the captcha provider's documentation:

Configuration Overview

After choosing a captcha provider and plan, the captcha requirement can be added to the Create Account form following the steps below (click each step to view each process in more detail):

  1. Creating an account with the captcha provider of your choice
  2. Configuring the captcha customization keys in the Ares Customization Manager
  3. Updating your web pages to add the new captcha web page files and to update GCreateAccount.html to include the new captcha field

1. Create a Captcha Account

Before a captcha integration can be configured for Ares, you must first create an account with one of the three supported third-party captcha providers. After creating the account, you will use the account information to configure your captcha integration in the Customization Manager. Note that only the free plans offered by each captcha provider are supported by Ares at this time. See each provider's section below for more detailed instructions on how to create your account.

Google reCAPTCHA | hCaptcha | MTCaptcha

Google reCAPTCHA

To create a Google reCAPTCHA account:

  1. Visit https://www.google.com/recaptcha/about/ and optionally review the listed features for reCAPTCHA v2 and reCAPTCHA v3 on this page to decide which option to use for your captcha requirement on the user registration form. For more information, see the reCAPTCHA documentation.

    reCAPTCHA Enterprise is not supported by Ares at this time.
  2. Click v3 Admin Console at the top of the page when you are ready to create an account. You will be asked to sign-in/create a Google account before beginning the reCAPTCHA sign-up process if you are not already signed in to Google.
  3. Under Label, enter a label or name to use to identify your account.
  4. Under reCAPTCHA type, select either the reCAPTCHA v3 or reCAPTCHA v2 option
    • If reCAPTCHA v2 is selected, you must then select either the "'I'm not a robot' checkbox" or the "invisible reCAPTCHA badge" variant
  5. Under Domains, type the domain of the server that hosts your Ares web pages (e.g., https://<your.AresWeb.domain>/)
  6. Click the plus sign (+) to add the domain
  7. Agree to the terms and conditions and click Submit to create the account
  8. Once registration is completed, you will be shown a page containing the Site Key and Secret Key values associated with your new account. Save these values as they will be used to configure the CaptchaSiteId and CaptchaSecret customization keys in the Ares Customization Manager during the next step of the configuration process.

hCaptcha

To create an hCaptcha account:

  1. Visit https://www.hcaptcha.com
  2. Click the Sign-Up button to begin the account creation process
  3. Click the Add hCaptcha to your service (free) option
  4. Follow the prompts to register for a free account
  5. Once registration is completed, you will be shown a page containing the Sitekey and Secret values associated with your new account. Save these values as they will be used to configure the CaptchaSiteId and CaptchaSecret customization keys in the Ares Customization Manager during the next step of the configuration process.

MTCaptcha

To create an MTCaptcha account:

  1. Visit https://www.mtcaptcha.com 
  2. Click the Free Account button to begin the account creation process
  3. Follow the prompts to register for an account. When prompted for the Domain Name, type the domain of the server that hosts your Ares web pages (e.g., https://<your.AresWeb.domain>/)
  4. Once registration is completed, you will be shown a page containing the Site Key and Private Key values associated with your new account. Save these values as they will be used to configure the CaptchaSiteId and CaptchaSecret customization keys in the Ares Customization Manager during the next step of the configuration process.

2. Configure Captcha Customization Keys

Once your captcha account is created using one of the providers above, you will then need to use information from the captcha account to configure a series of customization keys in the Ares Customization Manager (all keys are located under Web | Settings):

  • CaptchaProvider: Select one of the following options from the dropdown based on the captcha provider and plan you selected:
    • reCaptcha_v2_Checkbox
    • reCaptcha_v2_Invisible
    • reCaptcha_v3
    • hCaptcha
    • MTCaptcha
  • CaptchaSecret: Enter the Private Key (MTCaptcha)/Secret Key (reCAPTCHA)/Secret (hCaptcha) value associated with your captcha account. 
  • CaptchaSiteId: Enter the Site Key value associated with your captcha account.

Next, optionally review and modify the status line text that will appear on the Ares web interface if a user fails the captcha challenge on the user registration form:

  • SLCaptchaFailure (located under Web Status Lines | Users)

3. Edit Web Pages

After the new customization keys have been configured, follow the instructions below to update your web pages and add the captcha requirement to GCreateAccount.html:

The captcha requirement is only supported for use on the Create Account form (GCreateAccount.html) and cannot be added to other Ares web forms.
  1. Visit the Ares Downloads page and download the latest version of the Ares 5.0 Default Web Pages
  2. Unzip the downloaded zip file containing the new web page files
  3. Navigate into the folder containing the new web page files
  4. Copy the templates subfolder and add this entire folder as a new subfolder within your Ares web directory (in GitHub or at the default location on the Ares server: C:\Ares\Web\WebPages). Note that within the templates folder is a captcha subfolder that contains several important new captcha files. Please ensure that the captcha subfolder and all of these files are copied over to your web directory when adding the templates folder:
    • include_captcha_none.html
    • include_hcaptcha.html
    • include_mtcaptcha.html
    • include_recaptcha_v2_checkbox.html
    • include_recaptcha_v2_invisible.html
    • include_recaptcha_v3.html
  5. Locate and make the following changes to the GCreateAccount.html file in your Ares web directory:

    Change this (default line 13):

    <form action="ares.dll" method="post" 
    name="CreateAccount"
    class="f-wrap-request"  >
     

    To this:

    <form action="ares.dll" method="post" 
    name="CreateAccount"
    class="f-wrap-request" id="registration-form">

    And change this (default line 170):

    <input class="f-submit" type="submit" 
    name="SubmitButton" value="Create account" />
     

    To this:

     
    <#CAPTCHA>
  6. Save your changes
  7. The captcha challenge requirement is now implemented on the Create Account form. View and test the new captcha requirement on the form to ensure the integration has been properly configured.

Option 2: Disable New User Registration for Accounts Using Standard Ares Authentication

This option should not be chosen if you only allow users to register for accounts through standard Ares authentication (AresAuth) from the Create Account form.

User registration can be completely disabled for accounts created through standard Ares authentication (AresAuth) from the Create Account form (GCreateAccount.html) using the AresAuthUserRegistrationEnabled customization key. This option will prevent the creation of spam accounts by completely blocking account creation for users who are not pre-authorized for an Ares account via an LDAP or Remote Authentication configuration.

After disabling user registration for new AresAuth accounts, the Create Account form will still be accessible to users on the web interface. However, when these users attempt to submit the form to register for a new account, the form will not be submitted and the SLUserRegistrationDisabled status line will display to indicate that user registration has been disabled and to contact staff for assistance.

When AresAuth user registration is disabled, this will only disable self-registration for these users from the Create Account form on the Ares web pages. Staff will still be able to manually create new user accounts from the Ares Client for these users, if necessary or preferred. 
Note: The AresAuthUserRegistrationEnabled key will only enable/disable user registration from your production Ares web pages and will not affect your TestWeb web pages. After updating to Ares Server v5.0.9/Web DLL v5.0.6, users will not be able to register for an Ares account using any authentication type from the TestWeb pages by default. This option is not configurable. 

Configuration Steps

To use the AresAuthUserRegistrationEnabled customization key to disable new user registration for accounts created via standard Ares authentication (AresAuth):

  1. Open the Ares Customization Manager
  2. Navigate to the AresAuthUserRegistrationEnabled customization key located under Web | Settings
  3. Set the value of this key to No
  4. Click Save to save your changes
  5. User registration is now disabled for standard Ares accounts created through the Create Account form
Note that users who are pre-authorized for account creation via an LDAP or Remote Authentication (RemoteAuth) integration will not be affected by configuring the AresAuthUserRegistrationEnabled key to disable new user registration. These users will continue to be permitted to create Ares accounts following the usual account creation process.

Questions?

If this article didn’t resolve your issue, please contact Atlas Support for assistance:

Contact Support