- Getting Started
- Field Types
- Email Notifications
-
Integrations
- MailerLite
- Create User Accounts with Convert Forms
- MailChimp
- HubSpot
- GetResponse
- AcyMailing
- Content App
- Webhooks Addon
- Facebook Meta Pixel
- Google Adwords
- Sync submissions with your favorite app
- Drip Ecommerce CRM
- Google Analytics
- Constant Contact
- SalesForce Web-to-Lead
- IContact
- Zoho CRM
- Elastic Email
- Zoho Campaigns
- Zapier
- ConvertKit
- Brevo (Sendinblue)
- Campaign Monitor
- AWeber
- ActiveCampaign
-
Functionality
- Scroll the Page to the Top When a Long Form is Submitted
- Display Submissions Count for a Specific Form
- Populate Drop Down, Radio Buttons or Checkboxes with a CSV File
- Automatically Delete Submissions Older Than X Days
- Silently POST Submitted Data to Any API or URL
- Automatically Save Each Submission to a JSON file
- Authenticate and Login a User with a Custom Joomla Form
- Auto-Populate a Form Field with an Article Data
- Add a placeholder text to a Dropdown
- Create Multilingual Forms in Joomla
- Create a custom Joomla User Registration Form
- Redirect User to a URL After Form Submission
- Export and Import Forms across different Websites
- Export Form Submissions to CSV
- Convert Forms
- Styling and Customization
- Payment Forms
- Advanced Features
- Developers
- Troubleshooting and Support
-
Spam, Security & Compliance
- Enforcing a Custom Password Policy in Convert Forms
- Add Cloudflare Turnstile to your Joomla Form
- Implement the Iubenda Consent Database in Joomla with Convert Forms
- Add Custom Validations to Fields and Forms
- Add Math Captcha to your Form
- Prevent a Field From Saving in the Database
- Add hCaptcha to your Form
- Enable Double Opt-in
- Allow Form Submissions in Specific Date Range
- Ensure a Unique Value is Entered Into a
- Block Form Submissions Containing Profanity (Bad Words)
- Block Email Addresses or Email Domains
- Native Convert Forms Anti-spam Protection with Honeypot
- Add reCAPTCHA to your Form
- Create GDPR Compliant Forms
Enforcing a Custom Password Policy in Convert Forms
Would you like to enforce a strict password policy in Convert Forms that requires a combination of uppercase letters, lowercase letters, numbers, and symbols? While Convert Forms doesn’t strictly enforce these requirements by default, you can easily achieve this with a custom PHP function. In this guide, we’ll walk you through adding a custom code snippet to implement your password validation rules, ensuring stronger, more secure passwords in your Joomla forms.
Setup
To force your password policy, copy the code below and place it into your form's PHP Scripts -> Form Process area.
$passwordFieldName = 'name'; // Set the name of the password field to check
$passwordLength = 8; // Set password length
$requireNumbers = true; // Check for numeric digits
$requireSymbols = true; // Check for symbols
$requireMixedCase = true; // Check for mixed case letters
$preventCommonPasswords = true; // Check for common passwords
// DO NOT EDIT BELOW
$password = $post[$passwordFieldName];
// Check password length
if (mb_strlen($password) < $passwordLength)
{
throw new Exception("Password must be at least $passwordLength characters long.");
}
// Check for numeric digits if required
if ($requireNumbers && !preg_match('/[0-9]/', $password))
{
throw new Exception('Password must contain at least one numeric digit.');
}
// Check for symbols if required
if ($requireSymbols && !preg_match('/[\W_]/u', $password))
{
throw new Exception('Password must contain at least one special character (e.g., @, #, $, %).');
}
// Check for mixed case letters if required
if ($requireMixedCase)
{
// Uppercase letters (Unicode-aware)
if (!preg_match('/\p{Lu}/u', $password))
{
throw new Exception('Password must contain at least one uppercase letter.');
}
// Lowercase letters (Unicode-aware)
if (!preg_match('/\p{Ll}/u', $password))
{
throw new Exception('Password must contain at least one lowercase letter.');
}
}
// Check for common passwords if required
if ($preventCommonPasswords)
{
$commonPasswords = [
'123456',
'password',
'qwerty',
'abc123'
];
if (in_array($password, $commonPasswords))
{
throw new Exception('Password is too common, please choose a more secure one.');
}
}
Last updated on Oct 29th 2024 14:10