當前位置: 首頁>>代碼示例>>PHP>>正文


PHP is_email_address_unsafe函數代碼示例

本文整理匯總了PHP中is_email_address_unsafe函數的典型用法代碼示例。如果您正苦於以下問題:PHP is_email_address_unsafe函數的具體用法?PHP is_email_address_unsafe怎麽用?PHP is_email_address_unsafe使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了is_email_address_unsafe函數的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: test_case_sensitivity_of_is_email_address_unsafe

	/**
	 * @ticket 25046
	 */
	function test_case_sensitivity_of_is_email_address_unsafe() {
		update_site_option( 'banned_email_domains', array( 'baR.com', 'Foo.co', 'barfoo.COM', 'BAZ.com' ) );

		foreach ( array( 'test@Bar.com', 'tEst@bar.com', 'test@barFoo.com', 'tEst@foo.bar.com', 'test@baz.Com' ) as $email_address ) {
			$this->assertTrue( is_email_address_unsafe( $email_address ), "$email_address should be UNSAFE" );
		}

		foreach ( array( 'test@Foobar.com', 'test@Foo-bar.com', 'tEst@foobar.com', 'test@Subdomain.Foo.com', 'test@fooBAz.com' ) as $email_address ) {
			$this->assertFalse( is_email_address_unsafe( $email_address ), "$email_address should be SAFE" );
		}

	}
開發者ID:staylor,項目名稱:develop.svn.wordpress.org,代碼行數:15,代碼來源:multisite.php

示例2: process_submission

 /**
  * Process the contact form's POST submission
  * Stores feedback.  Sends email.
  */
 function process_submission()
 {
     global $post;
     $plugin = Grunion_Contact_Form_Plugin::init();
     $id = $this->get_attribute('id');
     $to = $this->get_attribute('to');
     $widget = $this->get_attribute('widget');
     $contact_form_subject = $this->get_attribute('subject');
     $to = str_replace(' ', '', $to);
     $emails = explode(',', $to);
     $valid_emails = array();
     foreach ((array) $emails as $email) {
         if (!is_email($email)) {
             continue;
         }
         if (function_exists('is_email_address_unsafe') && is_email_address_unsafe($email)) {
             continue;
         }
         $valid_emails[] = $email;
     }
     // No one to send it to, which means none of the "to" attributes are valid emails.
     // Use default email instead.
     if (!$valid_emails) {
         $valid_emails = $this->defaults['to'];
     }
     $to = $valid_emails;
     // Last ditch effort to set a recipient if somehow none have been set.
     if (empty($to)) {
         $to = get_option('admin_email');
     }
     // Make sure we're processing the form we think we're processing... probably a redundant check.
     if ($widget) {
         if ('widget-' . $widget != $_POST['contact-form-id']) {
             return false;
         }
     } else {
         if ($post->ID != $_POST['contact-form-id']) {
             return false;
         }
     }
     $field_ids = $this->get_field_ids();
     // Initialize all these "standard" fields to null
     $comment_author_email = $comment_author_email_label = $comment_author = $comment_author_label = $comment_author_url = $comment_author_url_label = $comment_content = $comment_content_label = null;
     // For each of the "standard" fields, grab their field label and value.
     if (isset($field_ids['name'])) {
         $field = $this->fields[$field_ids['name']];
         $comment_author = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_name', addslashes($field->value))));
         $comment_author_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['email'])) {
         $field = $this->fields[$field_ids['email']];
         $comment_author_email = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_email', addslashes($field->value))));
         $comment_author_email_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['url'])) {
         $field = $this->fields[$field_ids['url']];
         $comment_author_url = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_url', addslashes($field->value))));
         if ('http://' == $comment_author_url) {
             $comment_author_url = '';
         }
         $comment_author_url_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['textarea'])) {
         $field = $this->fields[$field_ids['textarea']];
         $comment_content = trim(Grunion_Contact_Form_Plugin::strip_tags($field->value));
         $comment_content_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['subject'])) {
         $field = $this->fields[$field_ids['subject']];
         if ($field->value) {
             $contact_form_subject = Grunion_Contact_Form_Plugin::strip_tags($field->value);
         }
     }
     $all_values = $extra_values = array();
     $i = 1;
     // Prefix counter for stored metadata
     // For all fields, grab label and value
     foreach ($field_ids['all'] as $field_id) {
         $field = $this->fields[$field_id];
         $label = $i . '_' . $field->get_attribute('label');
         $value = $field->value;
         $all_values[$label] = $value;
         $i++;
         // Increment prefix counter for the next field
     }
     // For the "non-standard" fields, grab label and value
     // Extra fields have their prefix starting from count( $all_values ) + 1
     foreach ($field_ids['extra'] as $field_id) {
         $field = $this->fields[$field_id];
         $label = $i . '_' . $field->get_attribute('label');
         $value = $field->value;
         if (is_array($value)) {
             $value = implode(', ', $value);
         }
         $extra_values[$label] = $value;
         $i++;
//.........這裏部分代碼省略.........
開發者ID:netmagik,項目名稱:netmagik,代碼行數:101,代碼來源:grunion-contact-form.php

示例3: wpmu_validate_user_signup

/**
 * Processes new user registrations.
 *
 * Checks the data provided by the user during signup. Verifies
 * the validity and uniqueness of user names and user email addresses,
 * and checks email addresses against admin-provided domain
 * whitelists and blacklists.
 *
 * The hook 'wpmu_validate_user_signup' provides an easy way
 * to modify the signup process. The value $result, which is passed
 * to the hook, contains both the user-provided info and the error
 * messages created by the function. 'wpmu_validate_user_signup' allows
 * you to process the data in any way you'd like, and unset the
 * relevant errors if necessary.
 *
 * @since MU
 * @uses is_email_address_unsafe()
 * @uses username_exists()
 * @uses email_exists()
 *
 * @param string $user_name The login name provided by the user.
 * @param string $user_email The email provided by the user.
 * @return array Contains username, email, and error messages.
 */
function wpmu_validate_user_signup($user_name, $user_email)
{
    global $wpdb;
    $errors = new WP_Error();
    $orig_username = $user_name;
    $user_name = preg_replace('/\\s+/', '', sanitize_user($user_name, true));
    $maybe = array();
    preg_match('/[a-z0-9]+/', $user_name, $maybe);
    if ($user_name != $orig_username || $user_name != $maybe[0]) {
        $errors->add('user_name', __('Only lowercase letters (a-z) and numbers are allowed.'));
        $user_name = $orig_username;
    }
    $user_email = sanitize_email($user_email);
    if (empty($user_name)) {
        $errors->add('user_name', __('Please enter a username'));
    }
    $illegal_names = get_site_option('illegal_names');
    if (is_array($illegal_names) == false) {
        $illegal_names = array('www', 'web', 'root', 'admin', 'main', 'invite', 'administrator');
        add_site_option('illegal_names', $illegal_names);
    }
    if (in_array($user_name, $illegal_names) == true) {
        $errors->add('user_name', __('That username is not allowed'));
    }
    if (is_email_address_unsafe($user_email)) {
        $errors->add('user_email', __('You cannot use that email address to signup. We are having problems with them blocking some of our email. Please use another email provider.'));
    }
    if (strlen($user_name) < 4) {
        $errors->add('user_name', __('Username must be at least 4 characters'));
    }
    if (strpos(' ' . $user_name, '_') != false) {
        $errors->add('user_name', __('Sorry, usernames may not contain the character &#8220;_&#8221;!'));
    }
    // all numeric?
    $match = array();
    preg_match('/[0-9]*/', $user_name, $match);
    if ($match[0] == $user_name) {
        $errors->add('user_name', __('Sorry, usernames must have letters too!'));
    }
    if (!is_email($user_email)) {
        $errors->add('user_email', __('Please enter a correct email address'));
    }
    $limited_email_domains = get_site_option('limited_email_domains');
    if (is_array($limited_email_domains) && empty($limited_email_domains) == false) {
        $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
        if (in_array($emaildomain, $limited_email_domains) == false) {
            $errors->add('user_email', __('Sorry, that email address is not allowed!'));
        }
    }
    // Check if the username has been used already.
    if (username_exists($user_name)) {
        $errors->add('user_name', __('Sorry, that username already exists!'));
    }
    // Check if the email address has been used already.
    if (email_exists($user_email)) {
        $errors->add('user_email', __('Sorry, that email address is already used!'));
    }
    // Has someone already signed up for this username?
    $signup = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->signups} WHERE user_login = %s", $user_name));
    if ($signup != null) {
        $registered_at = mysql2date('U', $signup->registered);
        $now = current_time('timestamp', true);
        $diff = $now - $registered_at;
        // If registered more than two days ago, cancel registration and let this signup go through.
        if ($diff > 172800) {
            $wpdb->query($wpdb->prepare("DELETE FROM {$wpdb->signups} WHERE user_login = %s", $user_name));
        } else {
            $errors->add('user_name', __('That username is currently reserved but may be available in a couple of days.'));
        }
        if ($signup->active == 0 && $signup->user_email == $user_email) {
            $errors->add('user_email_used', __('username and email used'));
        }
    }
    $signup = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->signups} WHERE user_email = %s", $user_email));
    if ($signup != null) {
        $diff = current_time('timestamp', true) - mysql2date('U', $signup->registered);
//.........這裏部分代碼省略.........
開發者ID:nhemsley,項目名稱:wordpress,代碼行數:101,代碼來源:ms-functions.php

示例4: process_submission

 /**
  * Process the contact form's POST submission
  * Stores feedback.  Sends email.
  */
 function process_submission()
 {
     global $post;
     $plugin = Grunion_Contact_Form_Plugin::init();
     $id = $this->get_attribute('id');
     $to = $this->get_attribute('to');
     $widget = $this->get_attribute('widget');
     $contact_form_subject = $this->get_attribute('subject');
     $to = str_replace(' ', '', $to);
     $emails = explode(',', $to);
     $valid_emails = array();
     foreach ((array) $emails as $email) {
         if (!is_email($email)) {
             continue;
         }
         if (function_exists('is_email_address_unsafe') && is_email_address_unsafe($email)) {
             continue;
         }
         $valid_emails[] = $email;
     }
     // No one to send it to :(
     if (!$valid_emails) {
         return false;
     }
     $to = $valid_emails;
     // Make sure we're processing the form we think we're processing... probably a redundant check.
     if ($widget) {
         if ('widget-' . $widget != $_POST['contact-form-id']) {
             return false;
         }
     } else {
         if ($post->ID != $_POST['contact-form-id']) {
             return false;
         }
     }
     $field_ids = $this->get_field_ids();
     // Initialize all these "standard" fields to null
     $comment_author_email = $comment_author_email_label = $comment_author = $comment_author_label = $comment_author_url = $comment_author_url_label = $comment_content = $comment_content_label = null;
     // For each of the "standard" fields, grab their field label and value.
     if (isset($field_ids['name'])) {
         $field = $this->fields[$field_ids['name']];
         $comment_author = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_name', addslashes($field->value))));
         $comment_author_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['email'])) {
         $field = $this->fields[$field_ids['email']];
         $comment_author_email = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_email', addslashes($field->value))));
         $comment_author_email_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['url'])) {
         $field = $this->fields[$field_ids['url']];
         $comment_author_url = Grunion_Contact_Form_Plugin::strip_tags(stripslashes(apply_filters('pre_comment_author_url', addslashes($field->value))));
         if ('http://' == $comment_author_url) {
             $comment_author_url = '';
         }
         $comment_author_url_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['textarea'])) {
         $field = $this->fields[$field_ids['textarea']];
         $comment_content = trim(Grunion_Contact_Form_Plugin::strip_tags($field->value));
         $comment_content_label = Grunion_Contact_Form_Plugin::strip_tags($field->get_attribute('label'));
     }
     if (isset($field_ids['subject'])) {
         $field = $this->fields[$field_ids['subject']];
         if ($field->value) {
             $contact_form_subject = Grunion_Contact_Form_Plugin::strip_tags($field->value);
         }
     }
     $all_values = $extra_values = array();
     // For all fields, grab label and value
     foreach ($field_ids['all'] as $field_id) {
         $field = $this->fields[$field_id];
         $label = $field->get_attribute('label');
         $value = $field->value;
         $all_values[$label] = $value;
     }
     // For the "non-standard" fields, grab label and value
     foreach ($field_ids['extra'] as $field_id) {
         $field = $this->fields[$field_id];
         $label = $field->get_attribute('label');
         $value = $field->value;
         $extra_values[$label] = $value;
     }
     $contact_form_subject = trim($contact_form_subject);
     $comment_author_IP = Grunion_Contact_Form_Plugin::strip_tags($_SERVER['REMOTE_ADDR']);
     $vars = array('comment_author', 'comment_author_email', 'comment_author_url', 'contact_form_subject', 'comment_author_IP');
     foreach ($vars as $var) {
         ${$var} = str_replace(array("\n", "\r"), '', ${$var});
     }
     $vars[] = 'comment_content';
     $spam = '';
     $akismet_values = $plugin->prepare_for_akismet(compact($vars));
     // Is it spam?
     $is_spam = apply_filters('contact_form_is_spam', $akismet_values);
     if (is_wp_error($is_spam)) {
         // WP_Error to abort
//.........這裏部分代碼省略.........
開發者ID:ugurozer,項目名稱:little,代碼行數:101,代碼來源:grunion-contact-form.php

示例5: wpmu_validate_user_signup

/**
 * Sanitize and validate data required for a user sign-up.
 *
 * Verifies the validity and uniqueness of user names and user email addresses,
 * and checks email addresses against admin-provided domain whitelists and blacklists.
 *
 * The {@see 'wpmu_validate_user_signup'} hook provides an easy way to modify the sign-up
 * process. The value $result, which is passed to the hook, contains both the user-provided
 * info and the error messages created by the function. {@see 'wpmu_validate_user_signup'}
 * allows you to process the data in any way you'd like, and unset the relevant errors if
 * necessary.
 *
 * @since MU
 *
 * @global wpdb $wpdb
 *
 * @param string $user_name  The login name provided by the user.
 * @param string $user_email The email provided by the user.
 * @return array Contains username, email, and error messages.
 */
function wpmu_validate_user_signup($user_name, $user_email)
{
    global $wpdb;
    $errors = new WP_Error();
    $orig_username = $user_name;
    $user_name = preg_replace('/\\s+/', '', sanitize_user($user_name, true));
    if ($user_name != $orig_username || preg_match('/[^a-z0-9]/', $user_name)) {
        $errors->add('user_name', __('Only lowercase letters (a-z) and numbers are allowed.'));
        $user_name = $orig_username;
    }
    $user_email = sanitize_email($user_email);
    if (empty($user_name)) {
        $errors->add('user_name', __('Please enter a username.'));
    }
    $illegal_names = get_site_option('illegal_names');
    if (!is_array($illegal_names)) {
        $illegal_names = array('www', 'web', 'root', 'admin', 'main', 'invite', 'administrator');
        add_site_option('illegal_names', $illegal_names);
    }
    if (in_array($user_name, $illegal_names)) {
        $errors->add('user_name', __('That username is not allowed.'));
    }
    if (is_email_address_unsafe($user_email)) {
        $errors->add('user_email', __('You cannot use that email address to signup. We are having problems with them blocking some of our email. Please use another email provider.'));
    }
    if (strlen($user_name) < 4) {
        $errors->add('user_name', __('Username must be at least 4 characters.'));
    }
    if (strlen($user_name) > 60) {
        $errors->add('user_name', __('Username may not be longer than 60 characters.'));
    }
    if (strpos($user_name, '_') !== false) {
        $errors->add('user_name', __('Sorry, usernames may not contain the character &#8220;_&#8221;!'));
    }
    // all numeric?
    if (preg_match('/^[0-9]*$/', $user_name)) {
        $errors->add('user_name', __('Sorry, usernames must have letters too!'));
    }
    if (!is_email($user_email)) {
        $errors->add('user_email', __('Please enter a valid email address.'));
    }
    $limited_email_domains = get_site_option('limited_email_domains');
    if (is_array($limited_email_domains) && !empty($limited_email_domains)) {
        $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
        if (!in_array($emaildomain, $limited_email_domains)) {
            $errors->add('user_email', __('Sorry, that email address is not allowed!'));
        }
    }
    // Check if the username has been used already.
    if (username_exists($user_name)) {
        $errors->add('user_name', __('Sorry, that username already exists!'));
    }
    // Check if the email address has been used already.
    if (email_exists($user_email)) {
        $errors->add('user_email', __('Sorry, that email address is already used!'));
    }
    // Has someone already signed up for this username?
    $signup = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->signups} WHERE user_login = %s", $user_name));
    if ($signup != null) {
        $registered_at = mysql2date('U', $signup->registered);
        $now = current_time('timestamp', true);
        $diff = $now - $registered_at;
        // If registered more than two days ago, cancel registration and let this signup go through.
        if ($diff > 2 * DAY_IN_SECONDS) {
            $wpdb->delete($wpdb->signups, array('user_login' => $user_name));
        } else {
            $errors->add('user_name', __('That username is currently reserved but may be available in a couple of days.'));
        }
    }
    $signup = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->signups} WHERE user_email = %s", $user_email));
    if ($signup != null) {
        $diff = current_time('timestamp', true) - mysql2date('U', $signup->registered);
        // If registered more than two days ago, cancel registration and let this signup go through.
        if ($diff > 2 * DAY_IN_SECONDS) {
            $wpdb->delete($wpdb->signups, array('user_email' => $user_email));
        } else {
            $errors->add('user_email', __('That email address has already been used. Please check your inbox for an activation email. It will become available in a couple of days if you do nothing.'));
        }
    }
    $result = array('user_name' => $user_name, 'orig_username' => $orig_username, 'user_email' => $user_email, 'errors' => $errors);
//.........這裏部分代碼省略.........
開發者ID:Jitsufreak,項目名稱:PJ,代碼行數:101,代碼來源:ms-functions.php

示例6: bp_core_validate_email_address

/**
 * Check that an email address is valid for use.
 *
 * Performs the following checks:
 *   - Is the email address well-formed?
 *   - Is the email address already used?
 *   - If there's an email domain blacklist, is the current domain on it?
 *   - If there's an email domain whitelest, is the current domain on it?
 *
 * @since 1.6.2
 *
 * @param string $user_email The email being checked.
 * @return bool|array True if the address passes all checks; otherwise an array
 *                    of error codes.
 */
function bp_core_validate_email_address($user_email)
{
    $errors = array();
    $user_email = sanitize_email($user_email);
    // Is the email well-formed?
    if (!is_email($user_email)) {
        $errors['invalid'] = 1;
    }
    // Is the email on the Banned Email Domains list?
    // Note: This check only works on Multisite.
    if (function_exists('is_email_address_unsafe') && is_email_address_unsafe($user_email)) {
        $errors['domain_banned'] = 1;
    }
    // Is the email on the Limited Email Domains list?
    // Note: This check only works on Multisite.
    $limited_email_domains = get_site_option('limited_email_domains');
    if (is_array($limited_email_domains) && empty($limited_email_domains) == false) {
        $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
        if (!in_array($emaildomain, $limited_email_domains)) {
            $errors['domain_not_allowed'] = 1;
        }
    }
    // Is the email alreday in use?
    if (email_exists($user_email)) {
        $errors['in_use'] = 1;
    }
    $retval = !empty($errors) ? $errors : true;
    return $retval;
}
開發者ID:CompositeUK,項目名稱:clone.BuddyPress,代碼行數:44,代碼來源:bp-members-functions.php

示例7: invite_anyone_validate_email

function invite_anyone_validate_email($user_email)
{
    $status = 'okay';
    if (invite_anyone_check_is_opt_out($user_email)) {
        $status = 'opt_out';
    } else {
        if ($user = get_user_by('email', $user_email)) {
            $status = 'used';
        } else {
            if (function_exists('is_email_address_unsafe') && is_email_address_unsafe($user_email)) {
                $status = 'unsafe';
            } else {
                if (function_exists('is_email') && !is_email($user_email)) {
                    $status = 'invalid';
                }
            }
        }
    }
    if (function_exists('get_site_option')) {
        if ($limited_email_domains = get_site_option('limited_email_domains')) {
            if (is_array($limited_email_domains) && empty($limited_email_domains) == false) {
                $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
                if (in_array($emaildomain, $limited_email_domains) == false) {
                    $status = 'limited_domain';
                }
            }
        }
    }
    return apply_filters('invite_anyone_validate_email', $status, $user_email);
}
開發者ID:kd5ytx,項目名稱:Empirical-Wordpress,代碼行數:30,代碼來源:by-email.php

示例8: contact_form_shortcode

function contact_form_shortcode($atts, $content)
{
    global $post;
    $default_to = get_option('admin_email');
    $default_subject = "[" . get_option('blogname') . "]";
    if (!empty($atts['widget']) && $atts['widget']) {
        $default_subject .= " Sidebar";
    } elseif ($post->ID) {
        $default_subject .= " " . wp_kses($post->post_title, array());
        $post_author = get_userdata($post->post_author);
        $default_to = $post_author->user_email;
    }
    extract(shortcode_atts(array('to' => $default_to, 'subject' => $default_subject, 'show_subject' => 'no', 'widget' => 0), $atts));
    $widget = esc_attr($widget);
    if (function_exists('faux_faux') && faux_faux() || is_feed()) {
        return '[contact-form]';
    }
    global $wp_query, $grunion_form, $contact_form_errors, $contact_form_values, $user_identity, $contact_form_last_id, $contact_form_message;
    // used to store attributes, configuration etc for access by contact-field shortcodes
    $grunion_form = new stdClass();
    $grunion_form->to = $to;
    $grunion_form->subject = $subject;
    $grunion_form->show_subject = $show_subject;
    if ($widget) {
        $id = 'widget-' . $widget;
    } elseif (is_singular()) {
        $id = $wp_query->get_queried_object_id();
    } else {
        $id = $GLOBALS['post']->ID;
    }
    if (!$id) {
        // something terrible has happened
        return '[contact-form]';
    }
    if ($id == $contact_form_last_id) {
        return;
    } else {
        $contact_form_last_id = $id;
    }
    ob_start();
    wp_nonce_field('contact-form_' . $id);
    $nonce = ob_get_contents();
    ob_end_clean();
    $body = contact_form_parse($content);
    $r = "<div id='contact-form-{$id}'>\n";
    $errors = array();
    if (is_wp_error($contact_form_errors) && ($errors = (array) $contact_form_errors->get_error_codes())) {
        $r .= "<div class='form-error'>\n<h3>" . __('Error!', "mm") . "</h3>\n<ul class='form-errors'>\n";
        foreach ($contact_form_errors->get_error_messages() as $message) {
            $r .= "\t<li class='form-error-message' style='color: red;'>{$message}</li>\n";
        }
        $r .= "</ul>\n</div>\n\n";
    }
    $r .= "<form action='#contact-form-{$id}' method='post' class='contact-form commentsblock'>\n";
    $r .= $body;
    $r .= "\t<p class='contact-submit'>\n";
    $r .= "\t\t<input type='submit' value='" . __("Submit &#187;", "mm") . "' class='pushbutton-wide'/>\n";
    $r .= "\t\t{$nonce}\n";
    $r .= "\t\t<input type='hidden' name='contact-form-id' value='{$id}' />\n";
    $r .= "\t</p>\n";
    $r .= "</form>\n</div>";
    // form wasn't submitted, just a GET
    if (empty($_POST)) {
        return $r;
    }
    if (is_wp_error($contact_form_errors)) {
        return $r;
    }
    $emails = str_replace(' ', '', $to);
    $emails = explode(',', $emails);
    foreach ((array) $emails as $email) {
        if (is_email($email) && (!function_exists('is_email_address_unsafe') || !is_email_address_unsafe($email))) {
            $valid_emails[] = $email;
        }
    }
    $to = $valid_emails ? $valid_emails : $default_to;
    $message_sent = contact_form_send_message($to, $subject, $widget);
    if (is_array($contact_form_values)) {
        extract($contact_form_values);
    }
    if (!isset($comment_content)) {
        $comment_content = '';
    } else {
        $comment_content = wp_kses($comment_content, array());
    }
    $r = "<div id='contact-form-{$id}'>\n";
    $errors = array();
    if (is_wp_error($contact_form_errors) && ($errors = (array) $contact_form_errors->get_error_codes())) {
        $r .= "<div class='form-error'>\n<h3>" . __('Error!', "mm") . "</h3>\n<p>\n";
        foreach ($contact_form_errors->get_error_messages() as $message) {
            $r .= "\t{$message}<br />\n";
        }
        $r .= "</p>\n</div>\n\n";
    } else {
        $r .= "<h3>" . __('Message Sent', "mm") . "</h3>\n\n";
        $r .= wp_kses($contact_form_message, array('br' => array(), 'blockquote' => array())) . "</div>";
        // Reset for multiple contact forms. Hacky
        $contact_form_values['comment_content'] = '';
        return $r;
    }
//.........這裏部分代碼省略.........
開發者ID:m-godefroid76,項目名稱:devrestofactory,代碼行數:101,代碼來源:grunion-contact-form.php

示例9: bp_core_validate_user_signup

/**
 * Validate a user name and email address when creating a new user.
 *
 * @global object $wpdb DB Layer
 * @param string $user_name Username to validate
 * @param string $user_email Email address to validate
 * @return array Results of user validation including errors, if any
 */
function bp_core_validate_user_signup($user_name, $user_email)
{
    global $wpdb;
    $errors = new WP_Error();
    $user_email = sanitize_email($user_email);
    if (empty($user_name)) {
        $errors->add('user_name', __('Please enter a username', 'buddypress'));
    }
    $maybe = array();
    preg_match("/[a-z0-9]+/", $user_name, $maybe);
    // Make sure illegal names include BuddyPress slugs and values
    bp_core_flush_illegal_names();
    $illegal_names = get_site_option('illegal_names');
    if (!validate_username($user_name) || in_array($user_name, (array) $illegal_names) || !empty($maybe[0]) && $user_name != $maybe[0]) {
        $errors->add('user_name', __('Only lowercase letters and numbers allowed', 'buddypress'));
    }
    if (strlen($user_name) < 4) {
        $errors->add('user_name', __('Username must be at least 4 characters', 'buddypress'));
    }
    if (strpos(' ' . $user_name, '_') != false) {
        $errors->add('user_name', __('Sorry, usernames may not contain the character "_"!', 'buddypress'));
    }
    // Is the user_name all numeric?
    $match = array();
    preg_match('/[0-9]*/', $user_name, $match);
    if ($match[0] == $user_name) {
        $errors->add('user_name', __('Sorry, usernames must have letters too!', 'buddypress'));
    }
    if (!is_email($user_email)) {
        $errors->add('user_email', __('Please check your email address.', 'buddypress'));
    }
    if (function_exists('is_email_address_unsafe') && is_email_address_unsafe($user_email)) {
        $errors->add('user_email', __('Sorry, that email address is not allowed!', 'buddypress'));
    }
    $limited_email_domains = get_site_option('limited_email_domains', 'buddypress');
    if (is_array($limited_email_domains) && empty($limited_email_domains) == false) {
        $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
        if (in_array($emaildomain, (array) $limited_email_domains) == false) {
            $errors->add('user_email', __('Sorry, that email address is not allowed!', 'buddypress'));
        }
    }
    // Check if the username has been used already.
    if (username_exists($user_name)) {
        $errors->add('user_name', __('Sorry, that username already exists!', 'buddypress'));
    }
    // Check if the email address has been used already.
    if (email_exists($user_email)) {
        $errors->add('user_email', __('Sorry, that email address is already used!', 'buddypress'));
    }
    $result = array('user_name' => $user_name, 'user_email' => $user_email, 'errors' => $errors);
    // Apply WPMU legacy filter
    $result = apply_filters('wpmu_validate_user_signup', $result);
    return apply_filters('bp_core_validate_user_signup', $result);
}
開發者ID:newington,項目名稱:buddypress,代碼行數:62,代碼來源:bp-members-signup.php

示例10: test_is_email_address_unsafe

 /**
  * @ticket 21570
  */
 function test_is_email_address_unsafe()
 {
     update_site_option('banned_email_domains', 'bar.com');
     foreach (array('test@bar.com', 'test@foo.bar.com') as $email_address) {
         $this->assertTrue(is_email_address_unsafe($email_address), "{$email_address} should be UNSAFE");
     }
     foreach (array('test@foobar.com', 'test@foo-bar.com') as $email_address) {
         $this->assertFalse(is_email_address_unsafe($email_address), "{$email_address} should be SAFE");
     }
 }
開發者ID:rmccue,項目名稱:wordpress-unit-tests,代碼行數:13,代碼來源:ms.php

示例11: invite_anyone_validate_email

function invite_anyone_validate_email($user_email)
{
    //if ( email_exists($user_email) )
    //	return 'used';
    if (invite_anyone_check_is_opt_out($user_email)) {
        return 'opt_out';
    }
    if ($user = get_user_by_email($user_email)) {
        return 'used';
    }
    // Many of he following checks can only be run on WPMU
    if (function_exists('is_email_address_unsafe')) {
        if (is_email_address_unsafe($user_email)) {
            return 'unsafe';
        }
    }
    if (function_exists('validate_email')) {
        if (!validate_email($user_email)) {
            return 'invalid';
        }
    }
    if (function_exists('get_site_option')) {
        if ($limited_email_domains = get_site_option('limited_email_domains')) {
            if (is_array($limited_email_domains) && empty($limited_email_domains) == false) {
                $emaildomain = substr($user_email, 1 + strpos($user_email, '@'));
                if (in_array($emaildomain, $limited_email_domains) == false) {
                    return 'limited_domain';
                }
            }
        }
    }
    return 'safe';
}
開發者ID:hnla,項目名稱:invite-anyone,代碼行數:33,代碼來源:by-email.php

示例12: test_safe_emails

 /**
  * @dataProvider data_safe
  * @ticket 25046
  * @ticket 21570
  */
 public function test_safe_emails($banned, $email)
 {
     update_site_option('banned_email_domains', $banned);
     $this->assertFalse(is_email_address_unsafe($email));
 }
開發者ID:boonebgorges,項目名稱:develop.wordpress,代碼行數:10,代碼來源:isEmailAddressUnsafe.php

示例13: validate_email_change_of_address

 /**
  * Is this a valid email address change?
  *
  * @param string $email A possible email address to validate.
  * @param string $existing_email The user's existing email address (possibly the same).
  *
  * @return boolean|errors TRUE if `$email` is a valid (available) email address.
  *    Otherwise, this returns an errors object on failure.
  *
  * @note Emails may NEVER exceed 100 chars (the max DB column size).
  *
  * @throws exception If invalid types are passed through arguments list.
  */
 public function validate_email_change_of_address($email, $existing_email)
 {
     $this->check_arg_types('string', 'string', func_get_args());
     $form_field_code = 'email';
     // For form errors.
     $user = (string) strstr($email, '@', TRUE);
     $domain = ltrim((string) strstr($email, '@'), '@');
     if (!$email) {
         return $this->©error($this->method(__FUNCTION__) . '#missing_email', get_defined_vars(), $this->_x('Missing email address (empty).'));
     }
     if (is_multisite()) {
         if (!preg_match($this->regex_valid_email, $email) || !is_email($email) || $email !== sanitize_email($email) || strlen($email) > 100) {
             return $this->©error($this->method(__FUNCTION__) . '#invalid_multisite_email', get_defined_vars(), sprintf($this->_x('Invalid email address: `%1$s`.'), $email));
         }
         if (strcasecmp($email, $existing_email) !== 0 && email_exists($email)) {
             return $this->©error($this->method(__FUNCTION__) . '#multisite_email_exists', get_defined_vars(), sprintf($this->_x('Email address: `%1$s`, is already in use.'), $email));
         }
         if ($this->©array->¤is_not_empty($limited_email_domains = get_site_option('limited_email_domains')) && !in_array(strtolower($domain), $limited_email_domains, TRUE)) {
             return $this->©error($this->method(__FUNCTION__) . '#unapproved_multisite_email', get_defined_vars(), sprintf($this->_x('Unapproved email domain: `%1$s`.'), $domain) . ' ' . $this->_x('You cannot use an email address with this domain.'));
         }
         if (is_email_address_unsafe($email)) {
             return $this->©error($this->method(__FUNCTION__) . '#restricted_multisite_email', get_defined_vars(), sprintf($this->_x('Restricted email domain: `%1$s`.'), $domain) . ' ' . $this->_x('We are having problems with this domain blocking some of our email.') . ' ' . $this->_x('Please use another email service provider.'));
         }
         if (strcasecmp($email, $existing_email) !== 0) {
             $query = "SELECT" . " `signups`.*" . " FROM" . " `" . $this->©string->esc_sql($this->©db_tables->get_wp('signups')) . "` AS `signups`" . " WHERE" . " `signups`.`user_email` = '" . $this->©string->esc_sql($email) . "'" . " LIMIT 1";
             // Only need one row here.
             if (is_object($signup = $this->©db->get_row($query, OBJECT))) {
                 if ($signup->active) {
                     return $this->©error($this->method(__FUNCTION__) . '#multisite_email_exists', get_defined_vars(), sprintf($this->_x('Email address: `%1$s`, is already in use.'), $email));
                 }
                 if (strtotime($signup->registered) < strtotime('-2 days')) {
                     $this->©db->delete($this->©db_tables->get_wp('signups'), array('user_email' => $email));
                 } else {
                     return $this->©error($this->method(__FUNCTION__) . '#reserved_multisite_email', get_defined_vars(), sprintf($this->_x('Reserved email address: `%1$s`.'), $email) . ' ' . $this->_x('This email address is already associated with another account holder.') . ' ' . $this->_x('However, there\'s a chance it will become available again in a couple of days;') . ' ' . $this->_x('should the other account holder fail to complete activation for some reason.'));
                 }
             }
         }
     } else {
         if (!preg_match($this->regex_valid_email, $email) || !is_email($email) || $email !== sanitize_email($email) || strlen($email) > 100) {
             return $this->©error($this->method(__FUNCTION__) . '#invalid_email', get_defined_vars(), sprintf($this->_x('Invalid email address: `%1$s`.'), $email));
         }
         if (strcasecmp($email, $existing_email) !== 0 && email_exists($email)) {
             return $this->©error($this->method(__FUNCTION__) . '#email_exists', get_defined_vars(), sprintf($this->_x('Email address: `%1$s`, is already in use.'), $email));
         }
     }
     return TRUE;
     // Default return value.
 }
開發者ID:panvagenas,項目名稱:x-related-posts,代碼行數:61,代碼來源:user-utils.php


注:本文中的is_email_address_unsafe函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。