[ Index ]

PHP Cross Reference of WordPress Trunk (Updated Daily)

Search

title

Body

[close]

/ -> wp-activate.php (source)

   1  <?php
   2  /**
   3   * Confirms that the activation key that is sent in an email after a user signs
   4   * up for a new site matches the key for that user and then displays confirmation.
   5   *
   6   * @package WordPress
   7   */
   8  
   9  define( 'WP_INSTALLING', true );
  10  
  11  /** Sets up the WordPress Environment. */
  12  require  __DIR__ . '/wp-load.php';
  13  
  14  require  __DIR__ . '/wp-blog-header.php';
  15  
  16  if ( ! is_multisite() ) {
  17      wp_redirect( wp_registration_url() );
  18      die();
  19  }
  20  
  21  $valid_error_codes = array( 'already_active', 'blog_taken' );
  22  
  23  list( $activate_path ) = explode( '?', wp_unslash( $_SERVER['REQUEST_URI'] ) );
  24  $activate_cookie       = 'wp-activate-' . COOKIEHASH;
  25  
  26  $key    = '';
  27  $result = null;
  28  
  29  if ( isset( $_GET['key'] ) && isset( $_POST['key'] ) && $_GET['key'] !== $_POST['key'] ) {
  30      wp_die( __( 'A key value mismatch has been detected. Please follow the link provided in your activation email.' ), __( 'An error occurred during the activation' ), 400 );
  31  } elseif ( ! empty( $_GET['key'] ) ) {
  32      $key = sanitize_text_field( $_GET['key'] );
  33  } elseif ( ! empty( $_POST['key'] ) ) {
  34      $key = sanitize_text_field( $_POST['key'] );
  35  }
  36  
  37  if ( $key ) {
  38      $redirect_url = remove_query_arg( 'key' );
  39  
  40      if ( remove_query_arg( false ) !== $redirect_url ) {
  41          setcookie( $activate_cookie, $key, 0, $activate_path, COOKIE_DOMAIN, is_ssl(), true );
  42          wp_safe_redirect( $redirect_url );
  43          exit;
  44      } else {
  45          $result = wpmu_activate_signup( $key );
  46      }
  47  }
  48  
  49  if ( null === $result && isset( $_COOKIE[ $activate_cookie ] ) ) {
  50      $key    = $_COOKIE[ $activate_cookie ];
  51      $result = wpmu_activate_signup( $key );
  52      setcookie( $activate_cookie, ' ', time() - YEAR_IN_SECONDS, $activate_path, COOKIE_DOMAIN, is_ssl(), true );
  53  }
  54  
  55  if ( null === $result || ( is_wp_error( $result ) && 'invalid_key' === $result->get_error_code() ) ) {
  56      status_header( 404 );
  57  } elseif ( is_wp_error( $result ) ) {
  58      $error_code = $result->get_error_code();
  59  
  60      if ( ! in_array( $error_code, $valid_error_codes, true ) ) {
  61          status_header( 400 );
  62      }
  63  }
  64  
  65  nocache_headers();
  66  
  67  // Fix for page title.
  68  $wp_query->is_404 = false;
  69  
  70  /**
  71   * Fires before the Site Activation page is loaded.
  72   *
  73   * @since 3.0.0
  74   */
  75  do_action( 'activate_header' );
  76  
  77  /**
  78   * Adds an action hook specific to this page.
  79   *
  80   * Fires on {@see 'wp_head'}.
  81   *
  82   * @since MU (3.0.0)
  83   */
  84  function do_activate_header() {
  85      /**
  86       * Fires within the `<head>` section of the Site Activation page.
  87       *
  88       * Fires on the {@see 'wp_head'} action.
  89       *
  90       * @since 3.0.0
  91       */
  92      do_action( 'activate_wp_head' );
  93  }
  94  add_action( 'wp_head', 'do_activate_header' );
  95  
  96  /**
  97   * Loads styles specific to this page.
  98   *
  99   * @since MU (3.0.0)
 100   */
 101  function wpmu_activate_stylesheet() {
 102      ?>
 103      <style>
 104          .wp-activate-container { width: 90%; margin: 0 auto; text-align: start; padding: 24px; box-sizing: border-box; }
 105          .wp-activate-container form { margin: 24px 0; }
 106          .wp-activate-container p { font-size: 18px; }
 107          #key, #submit { font-size: 24px; box-sizing: border-box; margin: 5px 0; }
 108          #key { width: 100%; direction: ltr; }
 109          #submit { width: auto; }
 110          span.h3 { font-weight: 600; }
 111      </style>
 112      <?php
 113  }
 114  add_action( 'wp_head', 'wpmu_activate_stylesheet' );
 115  add_action( 'wp_head', 'wp_strict_cross_origin_referrer' );
 116  add_filter( 'wp_robots', 'wp_robots_sensitive_page' );
 117  
 118  get_header( 'wp-activate' );
 119  
 120  $blog_details = get_site();
 121  ?>
 122  
 123  <div id="signup-content" class="widecolumn">
 124      <div class="wp-activate-container">
 125      <?php if ( ! $key ) { ?>
 126  
 127          <h2><?php _e( 'Activation Key Required' ); ?></h2>
 128          <form name="activateform" id="activateform" method="post" action="<?php echo esc_url( network_site_url( $blog_details->path . 'wp-activate.php' ) ); ?>">
 129              <p>
 130                  <label for="key"><?php _e( 'Activation Key:' ); ?></label>
 131                  <br /><input type="text" name="key" id="key" value="" size="50" autofocus="autofocus" />
 132              </p>
 133              <p class="submit">
 134                  <input id="submit" type="submit" name="Submit" class="submit" value="<?php esc_attr_e( 'Activate' ); ?>" />
 135              </p>
 136          </form>
 137  
 138          <?php
 139      } else {
 140          if ( is_wp_error( $result ) && in_array( $result->get_error_code(), $valid_error_codes, true ) ) {
 141              $signup = $result->get_error_data();
 142              ?>
 143              <h2><?php _e( 'Your account is now active!' ); ?></h2>
 144              <?php
 145              echo '<p class="lead-in">';
 146              if ( '' === $signup->domain . $signup->path ) {
 147                  printf(
 148                      /* translators: 1: Login URL, 2: Username, 3: User email address, 4: Lost password URL. */
 149                      __( 'Your account has been activated. You may now <a href="%1$s">log in</a> to the site using your chosen username of &#8220;%2$s&#8221;. Please check your email inbox at %3$s for your password and login instructions. If you do not receive an email, please check your junk or spam folder. If you still do not receive an email within an hour, you can <a href="%4$s">reset your password</a>.' ),
 150                      esc_url( network_site_url( $blog_details->path . 'wp-login.php', 'login' ) ),
 151                      esc_html( $signup->user_login ),
 152                      esc_html( $signup->user_email ),
 153                      esc_url( wp_lostpassword_url() )
 154                  );
 155              } else {
 156                  printf(
 157                      /* translators: 1: Site URL, 2: Username, 3: User email address, 4: Lost password URL. */
 158                      __( 'Your site at %1$s is active. You may now log in to your site using your chosen username of &#8220;%2$s&#8221;. Please check your email inbox at %3$s for your password and login instructions. If you do not receive an email, please check your junk or spam folder. If you still do not receive an email within an hour, you can <a href="%4$s">reset your password</a>.' ),
 159                      sprintf( '<a href="http://%1$s">%1$s</a>', esc_url( $signup->domain . $blog_details->path ) ),
 160                      esc_html( $signup->user_login ),
 161                      esc_html( $signup->user_email ),
 162                      esc_url( wp_lostpassword_url() )
 163                  );
 164              }
 165              echo '</p>';
 166          } elseif ( null === $result || is_wp_error( $result ) ) {
 167              ?>
 168              <h2><?php _e( 'An error occurred during the activation' ); ?></h2>
 169              <?php if ( is_wp_error( $result ) ) : ?>
 170                  <p><?php echo esc_html( $result->get_error_message() ); ?></p>
 171              <?php endif; ?>
 172              <?php
 173          } else {
 174              $url  = isset( $result['blog_id'] ) ? esc_url( get_home_url( (int) $result['blog_id'] ) ) : '';
 175              $user = get_userdata( (int) $result['user_id'] );
 176              ?>
 177              <h2><?php _e( 'Your account is now active!' ); ?></h2>
 178  
 179              <div id="signup-welcome">
 180              <p><span class="h3"><?php _e( 'Username:' ); ?></span> <?php echo esc_html( $user->user_login ); ?></p>
 181              <p><span class="h3"><?php _e( 'Password:' ); ?></span> <?php echo esc_html( $result['password'] ); ?></p>
 182              </div>
 183  
 184              <?php
 185              if ( $url && network_home_url( '', 'http' ) !== $url ) :
 186                  switch_to_blog( (int) $result['blog_id'] );
 187                  $login_url = wp_login_url();
 188                  restore_current_blog();
 189                  ?>
 190                  <p class="view">
 191                  <?php
 192                      /* translators: 1: Site URL, 2: Login URL. */
 193                      printf( __( 'Your account is now activated. <a href="%1$s">View your site</a> or <a href="%2$s">Log in</a>' ), esc_url( $url ), esc_url( $login_url ) );
 194                  ?>
 195                  </p>
 196              <?php else : ?>
 197                  <p class="view">
 198                  <?php
 199                      printf(
 200                          /* translators: 1: Login URL, 2: Network home URL. */
 201                          __( 'Your account is now activated. <a href="%1$s">Log in</a> or go back to the <a href="%2$s">homepage</a>.' ),
 202                          esc_url( network_site_url( $blog_details->path . 'wp-login.php', 'login' ) ),
 203                          esc_url( network_home_url( $blog_details->path ) )
 204                      );
 205                  ?>
 206                  </p>
 207                  <?php
 208                  endif;
 209          }
 210      }
 211      ?>
 212      </div>
 213  </div>
 214  <?php
 215  get_footer( 'wp-activate' );


Generated : Thu Apr 16 08:20:10 2026 Cross-referenced by PHPXref