Skip to content

Latest commit

 

History

History
92 lines (81 loc) · 4.51 KB

README.md

File metadata and controls

92 lines (81 loc) · 4.51 KB

reCAPTCHA-netFORUM

Easily add Google reCAPTCHA to your netFORUM forms

Installation

Create reCAPTCHA Account

  1. Navigate to Google reCAPTCHA page
  2. Sign up for an account
  3. Follow the instructions. Note: for testing, you can specify "localhost" for your URL. Important: You must specify your production domain urls in the Domains list for your reCAPTCHA site for the reCAPTCHA to work on your non-localhost url.

Install netFORUM Components

Option 1: Download Compiled Release

  1. Download Latest Release
  2. Copy contents of release to eWeb folder
  3. Execute reCAPTCHA_MD.sql SQL Script in Added.Recaptcha.netFORUM project /SQL Scripts/ folder
  4. Update reCAPTCHA-PublicKey, reCAPTCHA-PrivateKey, and reCAPTCHA-Enabled system options from iWeb with the values specified by your Google reCAPTCHA Account. Note: Site Key and Public Key are synonymous. Important: the reCAPTCHA-PrivateKey is encrypted so it must be updated through iWeb and not a SQL Script. Also, this value should not be shared.

Option 2: Clone Repo and Compile Yourself

  1. Download or Clone Repo
  2. Build Added.Recaptcha.netFORUM Project
  3. Copy Added.Recaptcha.dll and Added.Recaptcha.netFORUM.dll to /eWeb/bin/ directory
  4. Copy contents of Added Recaptcha.netFORUM project /Scripts/AddedInnovation/* to your eWeb Site Root/Scripts/AddedInnovation
  5. Execute reCAPTCHA_MD.sql SQL Script in Added.Recaptcha.netFORUM project /SQL Scripts/ folder
  6. Update reCAPTCHA-PublicKey, reCAPTCHA-PrivateKey, and reCAPTCHA-Enabled system options from iWeb with the values specified by your Google reCAPTCHA Account. Note: Site Key and Public Key are synonymous. Important: the reCAPTCHA-PrivateKey is encrypted so it must be updated through iWeb and not a SQL Script. Also, this value should not be shared.

Configure netFORUM Components

Add Form Extension

  1. Add Form Extension to form
  2. Control Class: Div
  3. Control ID: addedRecaptcha (name it whatever you want)
  4. Object Assembly: Added.Recaptcha.netFORUM
  5. Oject Typename: Added.Recaptcha.netFORUM.RecaptchaExtensions
  6. See V2 reCAPTCHA and Invisible reCAPTCHA below for Methods
  7. Add form extension control to form (Form Designer) in the location it should display

V2 reCAPTCHA

  1. Load Method: OnLoad_RenderRecaptcha
  2. Load Parameters: Page:Page;Control:Control
  3. Before Save Method: BeforeSave_ValidateRecaptcha
  4. Before Save Parameters: Page:Page;Control:Control

Invisible reCAPTCHA

  1. Load Method: OnLoad_RenderInvisibleRecaptcha
  2. Load Parameters: Page:Page;Control:Control
  3. Before Save Method: BeforeSave_ValidateRecaptcha
  4. Before Save Parameters: Page:Page;Control:Control
  5. Navigate to wizard buttons which should trigger invisible reCAPTCHA
  6. Add "invoke-recaptcha" css class to all wizard buttons which should trigger reCAPTCHA

Back to Top Button

To deal with the Back to top button and the Invisible reCAPTCHA overlap, you can use the following code to move the reCAPTCHA out of the way of the back to top button:

Note: there are curly braces that are netFORUM-escaped with [| or |] to be able to be dropped into an eWeb page detail easily.

<script type="text/javascript">
var handler = function () [|
        var offset = 20; // offset used by FormFunctions for the Back To Top link.
        var duration = 400; // duration used by FormFunctions for the Back To Top link.
        var enabled = false;

        function _tryAttach() [|
            if($('.grecaptcha-badge').length == 0) [|
                window.setTimeout(_tryAttach, duration);
            |]
            else [|
                window.setTimeout(function () [|
                    _handler();
                    $(window).scroll(_handler);
                |], duration);
            |]
        |];

        var _handler = function () [|
            if (enabled === false && $(window).scrollTop() > offset) [|
                enabled = true;
                $('.grecaptcha-badge').animate([| bottom: '100px' |], duration);
            |] 
            else if (enabled === true && $(window).scrollTop() <= offset) [|
                enabled = false;
                $('.grecaptcha-badge').animate([| bottom: '14px' |], duration);
            |]
        |];

        _tryAttach();
|]

if (typeof (Sys) !== 'undefined' && typeof (Sys.WebForms) !== 'undefined' && typeof (Sys.WebForms.PageRequestManager) !== 'undefined') [|
    Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(handler);
|]
else [|
    $(handler);
|]
</script>