X7ROOT File Manager
Current Path:
/home/notabjze/boatingnight.com/wp-includes
home
/
notabjze
/
boatingnight.com
/
wp-includes
/
ðŸ“
..
ðŸ“
ID3
ðŸ“
IXR
ðŸ“
PHPMailer
ðŸ“
Requests
ðŸ“
SimplePie
ðŸ“
Text
📄
admin-bar.php
(36.24 KB)
ðŸ“
assets
📄
atomlib.php
(11.79 KB)
📄
author-template.php
(18.51 KB)
ðŸ“
block-bindings
📄
block-bindings.php
(5.46 KB)
📄
block-editor.php
(28.12 KB)
📄
block-i18n.json
(316 B)
ðŸ“
block-patterns
📄
block-patterns.php
(12.9 KB)
ðŸ“
block-supports
📄
block-template-utils.php
(60.46 KB)
📄
block-template.php
(15 KB)
ðŸ“
blocks
📄
blocks.php
(109.11 KB)
📄
bookmark-template.php
(12.47 KB)
📄
bookmark.php
(15.07 KB)
📄
cache-compat.php
(5.83 KB)
📄
cache.php
(13.16 KB)
📄
canonical.php
(33.71 KB)
📄
capabilities.php
(41.72 KB)
📄
category-template.php
(55.67 KB)
📄
category.php
(12.53 KB)
ðŸ“
certificates
📄
class-IXR.php
(2.55 KB)
📄
class-avif-info.php
(28.92 KB)
📄
class-feed.php
(539 B)
📄
class-http.php
(367 B)
📄
class-json.php
(42.66 KB)
📄
class-oembed.php
(401 B)
📄
class-phpass.php
(6.61 KB)
📄
class-phpmailer.php
(664 B)
📄
class-pop3.php
(20.63 KB)
📄
class-requests.php
(2.18 KB)
📄
class-simplepie.php
(453 B)
📄
class-smtp.php
(457 B)
📄
class-snoopy.php
(36.83 KB)
📄
class-walker-category-dropdown.php
(2.41 KB)
📄
class-walker-category.php
(8.28 KB)
📄
class-walker-comment.php
(13.89 KB)
📄
class-walker-nav-menu.php
(11.76 KB)
📄
class-walker-page-dropdown.php
(2.65 KB)
📄
class-walker-page.php
(7.43 KB)
📄
class-wp-admin-bar.php
(17.46 KB)
📄
class-wp-ajax-response.php
(5.14 KB)
📄
class-wp-application-passwords.php
(16.7 KB)
📄
class-wp-block-bindings-registry.php
(8.26 KB)
📄
class-wp-block-bindings-source.php
(2.92 KB)
📄
class-wp-block-editor-context.php
(1.32 KB)
📄
class-wp-block-list.php
(4.65 KB)
📄
class-wp-block-metadata-registry.php
(11.62 KB)
📄
class-wp-block-parser-block.php
(2.5 KB)
📄
class-wp-block-parser-frame.php
(1.97 KB)
📄
class-wp-block-parser.php
(11.26 KB)
📄
class-wp-block-pattern-categories-registry.php
(5.25 KB)
📄
class-wp-block-patterns-registry.php
(10.53 KB)
📄
class-wp-block-styles-registry.php
(6.25 KB)
📄
class-wp-block-supports.php
(5.49 KB)
📄
class-wp-block-template.php
(1.99 KB)
📄
class-wp-block-templates-registry.php
(7.06 KB)
📄
class-wp-block-type-registry.php
(4.9 KB)
📄
class-wp-block-type.php
(16.86 KB)
📄
class-wp-block.php
(22.5 KB)
📄
class-wp-classic-to-block-menu-converter.php
(3.99 KB)
📄
class-wp-comment-query.php
(47.26 KB)
📄
class-wp-comment.php
(9.22 KB)
📄
class-wp-customize-control.php
(25.25 KB)
📄
class-wp-customize-manager.php
(197.84 KB)
📄
class-wp-customize-nav-menus.php
(56.07 KB)
📄
class-wp-customize-panel.php
(10.46 KB)
📄
class-wp-customize-section.php
(10.95 KB)
📄
class-wp-customize-setting.php
(29.26 KB)
📄
class-wp-customize-widgets.php
(70.52 KB)
📄
class-wp-date-query.php
(34.89 KB)
📄
class-wp-dependencies.php
(14.78 KB)
📄
class-wp-dependency.php
(2.57 KB)
📄
class-wp-duotone.php
(39.83 KB)
📄
class-wp-editor.php
(70.64 KB)
📄
class-wp-embed.php
(15.56 KB)
📄
class-wp-error.php
(7.33 KB)
📄
class-wp-exception.php
(253 B)
📄
class-wp-fatal-error-handler.php
(7.96 KB)
📄
class-wp-feed-cache-transient.php
(3.1 KB)
📄
class-wp-feed-cache.php
(969 B)
📄
class-wp-hook.php
(15.63 KB)
📄
class-wp-http-cookie.php
(7.22 KB)
📄
class-wp-http-curl.php
(12.25 KB)
📄
class-wp-http-encoding.php
(6.53 KB)
📄
class-wp-http-ixr-client.php
(3.42 KB)
📄
class-wp-http-proxy.php
(5.84 KB)
📄
class-wp-http-requests-hooks.php
(1.97 KB)
📄
class-wp-http-requests-response.php
(4.3 KB)
📄
class-wp-http-response.php
(2.91 KB)
📄
class-wp-http-streams.php
(16.46 KB)
📄
class-wp-http.php
(40.6 KB)
📄
class-wp-image-editor-gd.php
(19.69 KB)
📄
class-wp-image-editor-imagick.php
(33.92 KB)
📄
class-wp-image-editor.php
(17.12 KB)
📄
class-wp-list-util.php
(7.27 KB)
📄
class-wp-locale-switcher.php
(6.62 KB)
📄
class-wp-locale.php
(16.49 KB)
📄
class-wp-matchesmapregex.php
(1.79 KB)
📄
class-wp-meta-query.php
(29.82 KB)
📄
class-wp-metadata-lazyloader.php
(6.67 KB)
📄
class-wp-navigation-fallback.php
(9 KB)
📄
class-wp-network-query.php
(19.39 KB)
📄
class-wp-network.php
(12.01 KB)
📄
class-wp-object-cache.php
(17.11 KB)
📄
class-wp-oembed-controller.php
(6.74 KB)
📄
class-wp-oembed.php
(30.91 KB)
📄
class-wp-paused-extensions-storage.php
(4.99 KB)
📄
class-wp-phpmailer.php
(3.71 KB)
📄
class-wp-plugin-dependencies.php
(24.72 KB)
📄
class-wp-post-type.php
(29.96 KB)
📄
class-wp-post.php
(6.34 KB)
📄
class-wp-query.php
(154.32 KB)
📄
class-wp-recovery-mode-cookie-service.php
(6.72 KB)
📄
class-wp-recovery-mode-email-service.php
(10.92 KB)
📄
class-wp-recovery-mode-key-service.php
(4.77 KB)
📄
class-wp-recovery-mode-link-service.php
(3.38 KB)
📄
class-wp-recovery-mode.php
(11.18 KB)
📄
class-wp-rewrite.php
(62.2 KB)
📄
class-wp-role.php
(2.46 KB)
📄
class-wp-roles.php
(8.38 KB)
📄
class-wp-script-modules.php
(19.01 KB)
📄
class-wp-scripts.php
(27.68 KB)
📄
class-wp-session-tokens.php
(7.15 KB)
📄
class-wp-simplepie-file.php
(3.33 KB)
📄
class-wp-simplepie-sanitize-kses.php
(1.87 KB)
📄
class-wp-site-query.php
(30.88 KB)
📄
class-wp-site.php
(7.28 KB)
📄
class-wp-speculation-rules.php
(7.35 KB)
📄
class-wp-styles.php
(10.75 KB)
📄
class-wp-tax-query.php
(19.1 KB)
📄
class-wp-taxonomy.php
(18.12 KB)
📄
class-wp-term-query.php
(39.91 KB)
📄
class-wp-term.php
(5.17 KB)
📄
class-wp-text-diff-renderer-inline.php
(979 B)
📄
class-wp-text-diff-renderer-table.php
(18.44 KB)
📄
class-wp-textdomain-registry.php
(10.24 KB)
📄
class-wp-theme-json-data.php
(1.77 KB)
📄
class-wp-theme-json-resolver.php
(34.9 KB)
📄
class-wp-theme-json-schema.php
(7.19 KB)
📄
class-wp-theme-json.php
(159.71 KB)
📄
class-wp-theme.php
(64.27 KB)
📄
class-wp-token-map.php
(27.95 KB)
📄
class-wp-url-pattern-prefixer.php
(4.69 KB)
📄
class-wp-user-meta-session-tokens.php
(2.92 KB)
📄
class-wp-user-query.php
(42.63 KB)
📄
class-wp-user-request.php
(2.25 KB)
📄
class-wp-user.php
(22.46 KB)
📄
class-wp-walker.php
(13.01 KB)
📄
class-wp-widget-factory.php
(3.27 KB)
📄
class-wp-widget.php
(18 KB)
📄
class-wp-xmlrpc-server.php
(210.39 KB)
📄
class-wp.php
(25.7 KB)
📄
class-wpdb.php
(115.51 KB)
📄
class.wp-dependencies.php
(373 B)
📄
class.wp-scripts.php
(343 B)
📄
class.wp-styles.php
(338 B)
📄
comment-template.php
(100.47 KB)
📄
comment.php
(128.46 KB)
📄
compat.php
(15.99 KB)
📄
cron.php
(41.66 KB)
ðŸ“
css
ðŸ“
customize
📄
date.php
(400 B)
📄
default-constants.php
(11.1 KB)
📄
default-filters.php
(35.84 KB)
📄
default-widgets.php
(2.24 KB)
📄
deprecated.php
(187.07 KB)
📄
embed-template.php
(338 B)
📄
embed.php
(37.28 KB)
📄
error-protection.php
(4.02 KB)
📄
error_log
(503.4 KB)
📄
feed-atom-comments.php
(5.38 KB)
📄
feed-atom.php
(3.05 KB)
📄
feed-rdf.php
(2.61 KB)
📄
feed-rss.php
(1.16 KB)
📄
feed-rss2-comments.php
(4.04 KB)
📄
feed-rss2.php
(3.71 KB)
📄
feed.php
(22.86 KB)
ðŸ“
fonts
📄
fonts.php
(9.52 KB)
📄
formatting.php
(334.24 KB)
📄
functions.php
(280.81 KB)
📄
functions.wp-scripts.php
(14.22 KB)
📄
functions.wp-styles.php
(8.38 KB)
📄
general-template.php
(168.46 KB)
📄
global-styles-and-settings.php
(20.76 KB)
ðŸ“
html-api
📄
http.php
(24.72 KB)
📄
https-detection.php
(5.72 KB)
📄
https-migration.php
(4.63 KB)
ðŸ“
images
ðŸ“
interactivity-api
ðŸ“
js
📄
kses.php
(72.73 KB)
ðŸ“
l10n
📄
l10n.php
(66.92 KB)
📄
link-template.php
(154.1 KB)
📄
load.php
(55.12 KB)
📄
locale.php
(162 B)
📄
media-template.php
(61.58 KB)
📄
media.php
(215.12 KB)
📄
meta.php
(63.71 KB)
📄
ms-blogs.php
(25.24 KB)
📄
ms-default-constants.php
(4.81 KB)
📄
ms-default-filters.php
(6.48 KB)
📄
ms-deprecated.php
(21.25 KB)
📄
ms-files.php
(2.68 KB)
📄
ms-functions.php
(89.44 KB)
📄
ms-load.php
(19.42 KB)
📄
ms-network.php
(3.69 KB)
📄
ms-settings.php
(4.1 KB)
📄
ms-site.php
(40.35 KB)
📄
nav-menu-template.php
(25.38 KB)
📄
nav-menu.php
(43.33 KB)
📄
option.php
(100.65 KB)
ðŸ“
php-compat
📄
pluggable-deprecated.php
(6.18 KB)
📄
pluggable.php
(119.82 KB)
📄
plugin.php
(34.63 KB)
ðŸ“
pomo
📄
post-formats.php
(6.94 KB)
📄
post-template.php
(67.04 KB)
📄
post-thumbnail-template.php
(10.62 KB)
📄
post.php
(284.88 KB)
📄
query.php
(36.17 KB)
📄
registration-functions.php
(200 B)
📄
registration.php
(200 B)
ðŸ“
rest-api
📄
rest-api.php
(97.91 KB)
📄
revision.php
(30.02 KB)
📄
rewrite.php
(19.08 KB)
📄
robots-template.php
(5.06 KB)
📄
rss-functions.php
(255 B)
📄
rss.php
(22.57 KB)
📄
script-loader.php
(130.14 KB)
📄
script-modules.php
(7.53 KB)
📄
session.php
(258 B)
📄
shortcodes.php
(23.49 KB)
ðŸ“
sitemaps
📄
sitemaps.php
(3.16 KB)
ðŸ“
sodium_compat
📄
speculative-loading.php
(8.36 KB)
📄
spl-autoload-compat.php
(441 B)
ðŸ“
style-engine
📄
style-engine.php
(7.39 KB)
📄
taxonomy.php
(172.1 KB)
📄
template-canvas.php
(544 B)
📄
template-loader.php
(2.94 KB)
📄
template.php
(23.59 KB)
ðŸ“
theme-compat
📄
theme-i18n.json
(1.49 KB)
📄
theme-previews.php
(2.77 KB)
📄
theme-templates.php
(6.09 KB)
📄
theme.json
(8.5 KB)
📄
theme.php
(131.16 KB)
📄
update.php
(36.62 KB)
📄
user.php
(171.7 KB)
📄
vars.php
(6.41 KB)
📄
version.php
(1.06 KB)
ðŸ“
widgets
📄
widgets.php
(69.06 KB)
📄
wp-db.php
(445 B)
📄
wp-diff.php
(799 B)
Editing: class-wp-application-passwords.php
<?php /** * WP_Application_Passwords class * * @package WordPress * @since 5.6.0 */ /** * Class for displaying, modifying, and sanitizing application passwords. * * @package WordPress */ #[AllowDynamicProperties] class WP_Application_Passwords { /** * The application passwords user meta key. * * @since 5.6.0 * * @var string */ const USERMETA_KEY_APPLICATION_PASSWORDS = '_application_passwords'; /** * The option name used to store whether application passwords are in use. * * @since 5.6.0 * * @var string */ const OPTION_KEY_IN_USE = 'using_application_passwords'; /** * The generated application password length. * * @since 5.6.0 * * @var int */ const PW_LENGTH = 24; /** * Checks if application passwords are being used by the site. * * This returns true if at least one application password has ever been created. * * @since 5.6.0 * * @return bool */ public static function is_in_use() { $network_id = get_main_network_id(); return (bool) get_network_option( $network_id, self::OPTION_KEY_IN_USE ); } /** * Creates a new application password. * * @since 5.6.0 * @since 5.7.0 Returns WP_Error if application name already exists. * @since 6.8.0 The hashed password value now uses wp_fast_hash() instead of phpass. * * @param int $user_id User ID. * @param array $args { * Arguments used to create the application password. * * @type string $name The name of the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * } * @return array|WP_Error { * Application password details, or a WP_Error instance if an error occurs. * * @type string $0 The generated application password in plain text. * @type array $1 { * The details about the created password. * * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type null $last_used Null. * @type null $last_ip Null. * } * } */ public static function create_new_application_password( $user_id, $args = array() ) { if ( ! empty( $args['name'] ) ) { $args['name'] = sanitize_text_field( $args['name'] ); } if ( empty( $args['name'] ) ) { return new WP_Error( 'application_password_empty_name', __( 'An application name is required to create an application password.' ), array( 'status' => 400 ) ); } $new_password = wp_generate_password( static::PW_LENGTH, false ); $hashed_password = self::hash_password( $new_password ); $new_item = array( 'uuid' => wp_generate_uuid4(), 'app_id' => empty( $args['app_id'] ) ? '' : $args['app_id'], 'name' => $args['name'], 'password' => $hashed_password, 'created' => time(), 'last_used' => null, 'last_ip' => null, ); $passwords = static::get_user_application_passwords( $user_id ); $passwords[] = $new_item; $saved = static::set_user_application_passwords( $user_id, $passwords ); if ( ! $saved ) { return new WP_Error( 'db_error', __( 'Could not save application password.' ) ); } $network_id = get_main_network_id(); if ( ! get_network_option( $network_id, self::OPTION_KEY_IN_USE ) ) { update_network_option( $network_id, self::OPTION_KEY_IN_USE, true ); } /** * Fires when an application password is created. * * @since 5.6.0 * @since 6.8.0 The hashed password value now uses wp_fast_hash() instead of phpass. * * @param int $user_id The user ID. * @param array $new_item { * The details about the created password. * * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type null $last_used Null. * @type null $last_ip Null. * } * @param string $new_password The generated application password in plain text. * @param array $args { * Arguments used to create the application password. * * @type string $name The name of the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * } */ do_action( 'wp_create_application_password', $user_id, $new_item, $new_password, $args ); return array( $new_password, $new_item ); } /** * Gets a user's application passwords. * * @since 5.6.0 * * @param int $user_id User ID. * @return array { * The list of application passwords. * * @type array ...$0 { * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type int|null $last_used The Unix timestamp of the GMT date the application password was last used. * @type string|null $last_ip The IP address the application password was last used by. * } * } */ public static function get_user_application_passwords( $user_id ) { $passwords = get_user_meta( $user_id, static::USERMETA_KEY_APPLICATION_PASSWORDS, true ); if ( ! is_array( $passwords ) ) { return array(); } $save = false; foreach ( $passwords as $i => $password ) { if ( ! isset( $password['uuid'] ) ) { $passwords[ $i ]['uuid'] = wp_generate_uuid4(); $save = true; } } if ( $save ) { static::set_user_application_passwords( $user_id, $passwords ); } return $passwords; } /** * Gets a user's application password with the given UUID. * * @since 5.6.0 * * @param int $user_id User ID. * @param string $uuid The password's UUID. * @return array|null { * The application password if found, null otherwise. * * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type int|null $last_used The Unix timestamp of the GMT date the application password was last used. * @type string|null $last_ip The IP address the application password was last used by. * } */ public static function get_user_application_password( $user_id, $uuid ) { $passwords = static::get_user_application_passwords( $user_id ); foreach ( $passwords as $password ) { if ( $password['uuid'] === $uuid ) { return $password; } } return null; } /** * Checks if an application password with the given name exists for this user. * * @since 5.7.0 * * @param int $user_id User ID. * @param string $name Application name. * @return bool Whether the provided application name exists. */ public static function application_name_exists_for_user( $user_id, $name ) { $passwords = static::get_user_application_passwords( $user_id ); foreach ( $passwords as $password ) { if ( strtolower( $password['name'] ) === strtolower( $name ) ) { return true; } } return false; } /** * Updates an application password. * * @since 5.6.0 * @since 6.8.0 The actual password should now be hashed using wp_fast_hash(). * * @param int $user_id User ID. * @param string $uuid The password's UUID. * @param array $update { * Information about the application password to update. * * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type int|null $last_used The Unix timestamp of the GMT date the application password was last used. * @type string|null $last_ip The IP address the application password was last used by. * } * @return true|WP_Error True if successful, otherwise a WP_Error instance is returned on error. */ public static function update_application_password( $user_id, $uuid, $update = array() ) { $passwords = static::get_user_application_passwords( $user_id ); foreach ( $passwords as &$item ) { if ( $item['uuid'] !== $uuid ) { continue; } if ( ! empty( $update['name'] ) ) { $update['name'] = sanitize_text_field( $update['name'] ); } $save = false; if ( ! empty( $update['name'] ) && $item['name'] !== $update['name'] ) { $item['name'] = $update['name']; $save = true; } if ( $save ) { $saved = static::set_user_application_passwords( $user_id, $passwords ); if ( ! $saved ) { return new WP_Error( 'db_error', __( 'Could not save application password.' ) ); } } /** * Fires when an application password is updated. * * @since 5.6.0 * @since 6.8.0 The password is now hashed using wp_fast_hash() instead of phpass. * Existing passwords may still be hashed using phpass. * * @param int $user_id The user ID. * @param array $item { * The updated application password details. * * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type int|null $last_used The Unix timestamp of the GMT date the application password was last used. * @type string|null $last_ip The IP address the application password was last used by. * } * @param array $update The information to update. */ do_action( 'wp_update_application_password', $user_id, $item, $update ); return true; } return new WP_Error( 'application_password_not_found', __( 'Could not find an application password with that id.' ) ); } /** * Records that an application password has been used. * * @since 5.6.0 * * @param int $user_id User ID. * @param string $uuid The password's UUID. * @return true|WP_Error True if the usage was recorded, a WP_Error if an error occurs. */ public static function record_application_password_usage( $user_id, $uuid ) { $passwords = static::get_user_application_passwords( $user_id ); foreach ( $passwords as &$password ) { if ( $password['uuid'] !== $uuid ) { continue; } // Only record activity once a day. if ( $password['last_used'] + DAY_IN_SECONDS > time() ) { return true; } $password['last_used'] = time(); $password['last_ip'] = $_SERVER['REMOTE_ADDR']; $saved = static::set_user_application_passwords( $user_id, $passwords ); if ( ! $saved ) { return new WP_Error( 'db_error', __( 'Could not save application password.' ) ); } return true; } // Specified application password not found! return new WP_Error( 'application_password_not_found', __( 'Could not find an application password with that id.' ) ); } /** * Deletes an application password. * * @since 5.6.0 * * @param int $user_id User ID. * @param string $uuid The password's UUID. * @return true|WP_Error Whether the password was successfully found and deleted, a WP_Error otherwise. */ public static function delete_application_password( $user_id, $uuid ) { $passwords = static::get_user_application_passwords( $user_id ); foreach ( $passwords as $key => $item ) { if ( $item['uuid'] === $uuid ) { unset( $passwords[ $key ] ); $saved = static::set_user_application_passwords( $user_id, $passwords ); if ( ! $saved ) { return new WP_Error( 'db_error', __( 'Could not delete application password.' ) ); } /** * Fires when an application password is deleted. * * @since 5.6.0 * * @param int $user_id The user ID. * @param array $item The data about the application password. */ do_action( 'wp_delete_application_password', $user_id, $item ); return true; } } return new WP_Error( 'application_password_not_found', __( 'Could not find an application password with that id.' ) ); } /** * Deletes all application passwords for the given user. * * @since 5.6.0 * * @param int $user_id User ID. * @return int|WP_Error The number of passwords that were deleted or a WP_Error on failure. */ public static function delete_all_application_passwords( $user_id ) { $passwords = static::get_user_application_passwords( $user_id ); if ( $passwords ) { $saved = static::set_user_application_passwords( $user_id, array() ); if ( ! $saved ) { return new WP_Error( 'db_error', __( 'Could not delete application passwords.' ) ); } foreach ( $passwords as $item ) { /** This action is documented in wp-includes/class-wp-application-passwords.php */ do_action( 'wp_delete_application_password', $user_id, $item ); } return count( $passwords ); } return 0; } /** * Sets a user's application passwords. * * @since 5.6.0 * * @param int $user_id User ID. * @param array $passwords { * The list of application passwords. * * @type array ...$0 { * @type string $uuid The unique identifier for the application password. * @type string $app_id A UUID provided by the application to uniquely identify it. * @type string $name The name of the application password. * @type string $password A one-way hash of the password. * @type int $created Unix timestamp of when the password was created. * @type int|null $last_used The Unix timestamp of the GMT date the application password was last used. * @type string|null $last_ip The IP address the application password was last used by. * } * } * @return int|bool User meta ID if the key didn't exist (ie. this is the first time that an application password * has been saved for the user), true on successful update, false on failure or if the value passed * is the same as the one that is already in the database. */ protected static function set_user_application_passwords( $user_id, $passwords ) { return update_user_meta( $user_id, static::USERMETA_KEY_APPLICATION_PASSWORDS, $passwords ); } /** * Sanitizes and then splits a password into smaller chunks. * * @since 5.6.0 * * @param string $raw_password The raw application password. * @return string The chunked password. */ public static function chunk_password( #[\SensitiveParameter] $raw_password ) { $raw_password = preg_replace( '/[^a-z\d]/i', '', $raw_password ); return trim( chunk_split( $raw_password, 4, ' ' ) ); } /** * Hashes a plaintext application password. * * @since 6.8.0 * * @param string $password Plaintext password. * @return string Hashed password. */ public static function hash_password( #[\SensitiveParameter] string $password ): string { return wp_fast_hash( $password ); } /** * Checks a plaintext application password against a hashed password. * * @since 6.8.0 * * @param string $password Plaintext password. * @param string $hash Hash of the password to check against. * @return bool Whether the password matches the hashed password. */ public static function check_password( #[\SensitiveParameter] string $password, string $hash ): bool { if ( ! str_starts_with( $hash, '$generic$' ) ) { /* * If the hash doesn't start with `$generic$`, it is a hash created with `wp_hash_password()`. * This is the case for application passwords created before 6.8.0. */ return wp_check_password( $password, $hash ); } return wp_verify_fast_hash( $password, $hash ); } }
Upload File
Create Folder