|
|
- /**
- * @output wp-admin/js/auth-app.js
- */
-
- /* global authApp */
-
- ( function( $, authApp ) {
- var $appNameField = $( '#app_name' ),
- $approveBtn = $( '#approve' ),
- $rejectBtn = $( '#reject' ),
- $form = $appNameField.closest( 'form' ),
- context = {
- userLogin: authApp.user_login,
- successUrl: authApp.success,
- rejectUrl: authApp.reject
- };
-
- $approveBtn.on( 'click', function( e ) {
- var name = $appNameField.val(),
- appId = $( 'input[name="app_id"]', $form ).val();
-
- e.preventDefault();
-
- if ( $approveBtn.prop( 'aria-disabled' ) ) {
- return;
- }
-
- if ( 0 === name.length ) {
- $appNameField.trigger( 'focus' );
- return;
- }
-
- $approveBtn.prop( 'aria-disabled', true ).addClass( 'disabled' );
-
- var request = {
- name: name
- };
-
- if ( appId.length > 0 ) {
- request.app_id = appId;
- }
-
- /**
- * Filters the request data used to Authorize an Application Password request.
- *
- * @since 5.6.0
- *
- * @param {Object} request The request data.
- * @param {Object} context Context about the Application Password request.
- * @param {string} context.userLogin The user's login username.
- * @param {string} context.successUrl The URL the user will be redirected to after approving the request.
- * @param {string} context.rejectUrl The URL the user will be redirected to after rejecting the request.
- */
- request = wp.hooks.applyFilters( 'wp_application_passwords_approve_app_request', request, context );
-
- wp.apiRequest( {
- path: '/wp/v2/users/me/application-passwords?_locale=user',
- method: 'POST',
- data: request
- } ).done( function( response, textStatus, jqXHR ) {
-
- /**
- * Fires when an Authorize Application Password request has been successfully approved.
- *
- * In most cases, this should be used in combination with the {@see 'wp_authorize_application_password_form_approved_no_js'}
- * action to ensure that both the JS and no-JS variants are handled.
- *
- * @since 5.6.0
- *
- * @param {Object} response The response from the REST API.
- * @param {string} response.password The newly created password.
- * @param {string} textStatus The status of the request.
- * @param {jqXHR} jqXHR The underlying jqXHR object that made the request.
- */
- wp.hooks.doAction( 'wp_application_passwords_approve_app_request_success', response, textStatus, jqXHR );
-
- var raw = authApp.success,
- url, message, $notice;
-
- if ( raw ) {
- url = raw + ( -1 === raw.indexOf( '?' ) ? '?' : '&' ) +
- 'site_url=' + encodeURIComponent( authApp.site_url ) +
- '&user_login=' + encodeURIComponent( authApp.user_login ) +
- '&password=' + encodeURIComponent( response.password );
-
- window.location = url;
- } else {
- message = wp.i18n.sprintf(
- /* translators: %s: Application name. */
- '<label for="new-application-password-value">' + wp.i18n.__( 'Your new password for %s is:' ) + '</label>',
- '<strong></strong>'
- ) + ' <input id="new-application-password-value" type="text" class="code" readonly="readonly" value="" />';
- $notice = $( '<div></div>' )
- .attr( 'role', 'alert' )
- .attr( 'tabindex', -1 )
- .addClass( 'notice notice-success notice-alt' )
- .append( $( '<p></p>' ).addClass( 'application-password-display' ).html( message ) )
- .append( '<p>' + wp.i18n.__( 'Be sure to save this in a safe location. You will not be able to retrieve it.' ) + '</p>' );
-
- // We're using .text() to write the variables to avoid any chance of XSS.
- $( 'strong', $notice ).text( response.name );
- $( 'input', $notice ).val( response.password );
-
- $form.replaceWith( $notice );
- $notice.trigger( 'focus' );
- }
- } ).fail( function( jqXHR, textStatus, errorThrown ) {
- var errorMessage = errorThrown,
- error = null;
-
- if ( jqXHR.responseJSON ) {
- error = jqXHR.responseJSON;
-
- if ( error.message ) {
- errorMessage = error.message;
- }
- }
-
- var $notice = $( '<div></div>' )
- .attr( 'role', 'alert' )
- .addClass( 'notice notice-error' )
- .append( $( '<p></p>' ).text( errorMessage ) );
-
- $( 'h1' ).after( $notice );
-
- $approveBtn.removeProp( 'aria-disabled', false ).removeClass( 'disabled' );
-
- /**
- * Fires when an Authorize Application Password request encountered an error when trying to approve the request.
- *
- * @since 5.6.0
- * @since 5.6.1 Corrected action name and signature.
- *
- * @param {Object|null} error The error from the REST API. May be null if the server did not send proper JSON.
- * @param {string} textStatus The status of the request.
- * @param {string} errorThrown The error message associated with the response status code.
- * @param {jqXHR} jqXHR The underlying jqXHR object that made the request.
- */
- wp.hooks.doAction( 'wp_application_passwords_approve_app_request_error', error, textStatus, errorThrown, jqXHR );
- } );
- } );
-
- $rejectBtn.on( 'click', function( e ) {
- e.preventDefault();
-
- /**
- * Fires when an Authorize Application Password request has been rejected by the user.
- *
- * @since 5.6.0
- *
- * @param {Object} context Context about the Application Password request.
- * @param {string} context.userLogin The user's login username.
- * @param {string} context.successUrl The URL the user will be redirected to after approving the request.
- * @param {string} context.rejectUrl The URL the user will be redirected to after rejecting the request.
- */
- wp.hooks.doAction( 'wp_application_passwords_reject_app', context );
-
- // @todo: Make a better way to do this so it feels like less of a semi-open redirect.
- window.location = authApp.reject;
- } );
-
- $form.on( 'submit', function( e ) {
- e.preventDefault();
- } );
- }( jQuery, authApp ) );
|