Authentication

To create an Authentication object, click on the Authentications section in the sidebar, then click New Authentication.

Express Authentication

The quickest and easiest way to create authentication for your app is to first ensure that you have a Table for your users that contains at least two fields:

  • A unique field for user ID
  • A password field that is set to Password Data Type

To configure Express Authentication, select your users Table as the Authentication data source, select Express, ensure the correct username and password fields are selected.

Authentications_11

Custom Authentication

With Custom Authentication, you have access to a variety of additional configuration options. For example, you can set up a login form with more fields than just username and password. You can customize the login form’s labels and field layout, and add CAPTCHA, HTML Blocks, Header & Footer, etc.

Using Custom Authentication, you can also integrate with third-party ID Services such as Google, Facebook, Twitter and OpenID. ID Services allow your users to login with their own social profile credentials. Note that their username must still be present in your users Table, but you no longer need a password field.

Authentications can be created entirely based on a Caspio Table where all your users have their username and password in that table. You may also use one or more ID Services to allow your users to log in with their ID Service username and password.

We recommend not using more than one ID Service in an Authentication, because your users may forget which ID Service they should use to login, which may lead to double registration and user frustration. Of course, it’s ultimately up to you to decide how many ID Services to enable and whether to include a standard Caspio login or not.

To enable an ID Service, your app must be already registered with the provider. Read the article about Setting Up ID Services for more information.

Creating a Custom Authentication

Follow these steps to create a custom authentication:

  1. Anywhere in your app click Authentications on the sidebar menu and click New Authentication.
  2. In the Authentication table or view drop-down, select the table or view that contains or will contain the list of your authorized users. If you don't have one, select the Create a new table and a basic new users table will be created for you when you finish the creation of the Authentication object.
  3. Next select Custom.Authentication2
  4. Select the authentication type. The following options are available:
    • Caspio data source – Users can only be authenticated through Caspio login form by providing login credentials that can be verified in the authentication data source.
    • Caspio & ID Services –Users can be authenticated through Caspio login form or any of the enabled third party providers (Google, Twitter, Facebook, OpenID) if the unique ID of their user accounts matches the authentication data source.
    • ID Services Only – Users can only be authenticated through the ID Services you have enabled provided that the user's ID is present in your users data source.

    Authentication3

  5. If you have chosen Caspio as one of your choices, you can configure your authentication fields in this section. A username and password field are usually suggested but you need to verify that they are correct.
    The Advanced tab gives you more field options and the ability to pass or receive parameters into your authentication fields.You can also insert other virtual fields, HTML blocks, CAPTHCA and much more into your login form. Simply click + button at the top-right of the Elements panel. If ID Services is enabled, the Elements panel display the list of available ID Services.
    Authentication4
  6. To enable an ID Service, click on a service name on the Elements panel and set its options on the right.
    For Google, Facebook and Twitter after you enable the service you will be asked to map the field that contains the ID field of the Service in your users table. This is a unique field that contains values such as "Google: john.smith@google.com". Only users that are listed in this way will be able to login to your app via that ID Service.
  7. Next you will need to provide the ID and secret value that you received from the ID Service when you registered you app with them. Read the article about Setting Up ID Services for more information.
    Authentication5
    You can select how you wish the Caspio authentication and ID Services buttons are displayed on the login form. The layout options differ between authentication types. More design options are available by editing the Style object applied to your authenticated DataPages. Text of your login form can also be modified in the Localization object of your DataPages.
    Authentication6
  8.  Next, you can expand Advanced Settings and configure the following:
  • Failure message – This message is displayed to users who cannot successful login.
  • Logout destination – This page or URL is used to redirect users who logout of your authenticated app.
  • Time out and redirection – Configure session expiration after user inactivity and provide a page or URL to redirect timed out users.
  • Login redirection on success - With this option you can designate a page as the home page of your app. Once the user successfully signs in you can redirect them to the page they need to go next. This is a good way to avoid multiple login forms on the same page.
  • ID Services unrecognized user handling – You can use this option to redirect ID Services users who are not present in your users table. For example you can send them to a page to register for your app or service.
  • Enable auto-login – With this option you can enable cross app login to users who already have an active session with another one of your apps that uses the same users table for its authentication. For example if your ticketing system and your sales system are based on the same Employees table but different authentications object, authorized users who are login to one app can access the second app without another login.
  • Only one session per user – By enabling this option each of your app users can have only one active session. If another login is detected, the old session is expired immediately.
  • Show login form on failure page – When users fail to login, you can display a message and with it display the login form again.
  • Auto-focus on the first field – For usability purposes you can have the cursor sit on the first field of your login form when the page loads.
    Authentication7

Click Create when done. Enter an Authentication name then, click OK.

Your new Authentication object is saved in your app's Authentication section. You can apply this authentication to your new or existing DataPage on the second screen of your DataPage wizard.