Current Path: > home > > transcarter > www > > > wp-includes
Operation : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64 Software : Apache Server IP : 198.54.126.42 | Your IP: 216.73.216.135 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
ID3 | Directory | - | - | |
IXR | Directory | - | - | |
PHPMailer | Directory | - | - | |
Requests | Directory | - | - | |
SimplePie | Directory | - | - | |
Text | Directory | - | - | |
assets | Directory | - | - | |
block-bindings | Directory | - | - | |
block-patterns | Directory | - | - | |
block-supports | Directory | - | - | |
blocks | Directory | - | - | |
certificates | Directory | - | - | |
css | Directory | - | - | |
customize | Directory | - | - | |
fonts | Directory | - | - | |
html-api | Directory | - | - | |
images | Directory | - | - | |
interactivity-api | Directory | - | - | |
js | Directory | - | - | |
l10n | Directory | - | - | |
php-compat | Directory | - | - | |
pomo | Directory | - | - | |
rest-api | Directory | - | - | |
sitemaps | Directory | - | - | |
sodium_compat | Directory | - | - | |
style-engine | Directory | - | - | |
theme-compat | Directory | - | - | |
widgets | Directory | - | - | |
admin-bar.php | File | 37100 bytes | September 03 2024 19:45:16. | |
atomlib.php | File | 11950 bytes | April 21 2022 10:24:18. | |
author-template.php | File | 18951 bytes | May 14 2023 16:58:24. | |
block-bindings.php | File | 5594 bytes | June 12 2024 11:44:14. | |
block-editor.php | File | 28166 bytes | June 04 2024 10:55:14. | |
block-i18n.json | File | 316 bytes | August 11 2021 08:08:02. | |
block-patterns.php | File | 13162 bytes | February 27 2024 21:05:12. | |
block-template-utils.php | File | 56559 bytes | July 24 2024 13:40:16. | |
block-template.php | File | 12376 bytes | March 06 2024 05:05:12. | |
blocks.php | File | 97472 bytes | June 25 2024 11:45:18. | |
bookmark-template.php | File | 12934 bytes | March 20 2024 11:49:10. | |
bookmark.php | File | 15427 bytes | March 23 2024 13:20:12. | |
cache-compat.php | File | 5969 bytes | October 10 2022 17:22:12. | |
cache.php | File | 13474 bytes | October 10 2022 17:22:12. | |
canonical.php | File | 34513 bytes | February 16 2024 23:34:12. | |
capabilities.php | File | 40016 bytes | May 05 2024 13:35:20. | |
category-template.php | File | 57003 bytes | September 25 2023 23:27:12. | |
category.php | File | 12709 bytes | August 24 2023 08:01:16. | |
class-IXR.php | File | 2543 bytes | February 06 2020 06:33:12. | |
class-avif-info.php | File | 29615 bytes | April 26 2024 14:02:14. | |
class-feed.php | File | 529 bytes | February 06 2020 06:33:12. | |
class-http.php | File | 367 bytes | June 17 2022 10:20:14. | |
class-json.php | File | 43684 bytes | February 03 2023 13:35:20. | |
class-oembed.php | File | 401 bytes | June 17 2022 10:20:14. | |
class-phpass.php | File | 6708 bytes | February 13 2023 09:08:24. | |
class-phpmailer.php | File | 664 bytes | July 21 2020 11:58:02. | |
class-pop3.php | File | 20969 bytes | February 11 2023 12:43:22. | |
class-requests.php | File | 2237 bytes | April 05 2023 12:12:26. | |
class-simplepie-interface.php | File | 1079 bytes | September 12 2022 14:47:14. | |
class-simplepie.php | File | 98061 bytes | February 17 2024 13:25:10. | |
class-smtp.php | File | 457 bytes | January 26 2021 13:45:58. | |
class-snoopy.php | File | 37715 bytes | February 03 2023 13:35:20. | |
class-walker-category-dropdown.php | File | 2469 bytes | September 14 2023 11:46:20. | |
class-walker-category.php | File | 8477 bytes | September 08 2023 08:32:24. | |
class-walker-comment.php | File | 14221 bytes | March 18 2024 14:46:14. | |
class-walker-nav-menu.php | File | 11313 bytes | June 27 2023 14:26:28. | |
class-walker-page-dropdown.php | File | 2710 bytes | September 14 2023 11:46:20. | |
class-walker-page.php | File | 7612 bytes | September 14 2023 11:46:20. | |
class-wp-admin-bar.php | File | 17874 bytes | July 18 2024 15:45:14. | |
class-wp-ajax-response.php | File | 5266 bytes | September 12 2022 14:47:14. | |
class-wp-application-passwords.php | File | 12854 bytes | May 08 2023 21:37:24. | |
class-wp-block-bindings-registry.php | File | 8944 bytes | June 12 2024 11:44:14. | |
class-wp-block-bindings-source.php | File | 2178 bytes | May 02 2024 12:19:14. | |
class-wp-block-editor-context.php | File | 1350 bytes | September 12 2022 14:47:14. | |
class-wp-block-list.php | File | 4757 bytes | November 01 2023 23:04:24. | |
class-wp-block-parser-block.php | File | 2555 bytes | June 26 2023 23:45:38. | |
class-wp-block-parser-frame.php | File | 1916 bytes | June 26 2023 23:45:38. | |
class-wp-block-parser.php | File | 11532 bytes | May 02 2024 19:09:16. | |
class-wp-block-pattern-categories-registry.php | File | 5371 bytes | September 12 2022 14:47:14. | |
class-wp-block-patterns-registry.php | File | 11738 bytes | May 23 2024 17:35:14. | |
class-wp-block-styles-registry.php | File | 6262 bytes | May 30 2024 07:54:08. | |
class-wp-block-supports.php | File | 5566 bytes | May 06 2024 20:25:16. | |
class-wp-block-template.php | File | 1951 bytes | June 23 2023 05:29:24. | |
class-wp-block-type-registry.php | File | 5013 bytes | October 12 2023 11:34:34. | |
class-wp-block-type.php | File | 17265 bytes | May 01 2024 23:01:10. | |
class-wp-block.php | File | 19691 bytes | June 13 2024 07:57:16. | |
class-wp-classic-to-block-menu-converter.php | File | 4088 bytes | August 21 2023 16:51:20. | |
class-wp-comment-query.php | File | 48395 bytes | June 21 2024 16:26:14. | |
class-wp-comment.php | File | 9372 bytes | August 24 2023 07:44:24. | |
class-wp-customize-control.php | File | 25730 bytes | May 14 2024 15:49:10. | |
class-wp-customize-manager.php | File | 202413 bytes | June 10 2024 21:12:18. | |
class-wp-customize-nav-menus.php | File | 57384 bytes | June 03 2024 19:35:14. | |
class-wp-customize-panel.php | File | 10670 bytes | September 10 2023 08:04:18. | |
class-wp-customize-section.php | File | 11244 bytes | September 10 2023 08:04:18. | |
class-wp-customize-setting.php | File | 29889 bytes | September 10 2023 08:04:18. | |
class-wp-customize-widgets.php | File | 71520 bytes | May 14 2024 15:49:10. | |
class-wp-date-query.php | File | 35726 bytes | February 16 2024 21:47:12. | |
class-wp-dependencies.php | File | 14062 bytes | September 08 2023 08:32:24. | |
class-wp-dependency.php | File | 2627 bytes | November 25 2022 15:12:16. | |
class-wp-duotone.php | File | 40783 bytes | June 14 2024 11:18:12. | |
class-wp-editor.php | File | 72177 bytes | June 20 2024 19:27:12. | |
class-wp-embed.php | File | 15994 bytes | July 09 2023 19:17:30. | |
class-wp-error.php | File | 7502 bytes | February 21 2023 16:39:20. | |
class-wp-fatal-error-handler.php | File | 7948 bytes | December 16 2023 09:38:26. | |
class-wp-feed-cache-transient.php | File | 2586 bytes | September 12 2022 14:47:14. | |
class-wp-feed-cache.php | File | 969 bytes | August 10 2023 00:06:22. | |
class-wp-hook.php | File | 16000 bytes | September 18 2023 11:41:18. | |
class-wp-http-cookie.php | File | 7389 bytes | June 24 2023 16:17:24. | |
class-wp-http-curl.php | File | 12541 bytes | September 21 2023 17:29:12. | |
class-wp-http-encoding.php | File | 6689 bytes | June 22 2023 13:57:24. | |
class-wp-http-ixr-client.php | File | 3501 bytes | September 12 2022 14:47:14. | |
class-wp-http-proxy.php | File | 5980 bytes | June 22 2023 13:36:26. | |
class-wp-http-requests-hooks.php | File | 2022 bytes | December 15 2022 21:32:18. | |
class-wp-http-requests-response.php | File | 4400 bytes | October 11 2023 06:05:26. | |
class-wp-http-response.php | File | 2977 bytes | September 12 2022 14:47:14. | |
class-wp-http-streams.php | File | 16859 bytes | September 21 2023 17:29:12. | |
class-wp-http.php | File | 40760 bytes | April 07 2024 10:18:18. | |
class-wp-image-editor-gd.php | File | 18943 bytes | June 03 2024 19:27:12. | |
class-wp-image-editor-imagick.php | File | 32104 bytes | June 14 2024 14:26:10. | |
class-wp-image-editor.php | File | 17606 bytes | February 02 2024 17:48:16. | |
class-wp-list-util.php | File | 7443 bytes | February 27 2024 22:38:16. | |
class-wp-locale-switcher.php | File | 6630 bytes | January 25 2024 07:53:18. | |
class-wp-locale.php | File | 16111 bytes | May 26 2024 19:51:14. | |
class-wp-matchesmapregex.php | File | 1828 bytes | February 06 2024 01:25:14. | |
class-wp-meta-query.php | File | 30531 bytes | April 22 2024 19:25:08. | |
class-wp-metadata-lazyloader.php | File | 6833 bytes | May 11 2023 10:15:24. | |
class-wp-navigation-fallback.php | File | 9211 bytes | October 06 2023 13:06:22. | |
class-wp-network-query.php | File | 19857 bytes | June 21 2024 16:26:14. | |
class-wp-network.php | File | 12288 bytes | May 13 2024 12:34:12. | |
class-wp-object-cache.php | File | 17594 bytes | March 14 2023 15:55:20. | |
class-wp-oembed-controller.php | File | 6905 bytes | March 06 2024 05:05:12. | |
class-wp-oembed.php | File | 31475 bytes | June 07 2024 22:15:16. | |
class-wp-paused-extensions-storage.php | File | 5090 bytes | February 16 2024 21:47:12. | |
class-wp-plugin-dependencies.php | File | 25319 bytes | May 30 2024 14:15:10. | |
class-wp-post-type.php | File | 30350 bytes | May 27 2024 14:24:14. | |
class-wp-post.php | File | 6484 bytes | September 12 2022 14:47:14. | |
class-wp-query.php | File | 154081 bytes | May 20 2024 20:21:16. | |
class-wp-recovery-mode-cookie-service.php | File | 6877 bytes | October 04 2022 02:59:14. | |
class-wp-recovery-mode-email-service.php | File | 11183 bytes | May 02 2023 14:45:22. | |
class-wp-recovery-mode-key-service.php | File | 4601 bytes | December 24 2023 13:05:22. | |
class-wp-recovery-mode-link-service.php | File | 3463 bytes | September 12 2022 14:47:14. | |
class-wp-recovery-mode.php | File | 11435 bytes | May 02 2023 14:45:22. | |
class-wp-rewrite.php | File | 63430 bytes | September 09 2023 08:28:26. | |
class-wp-role.php | File | 2523 bytes | September 08 2023 08:32:24. | |
class-wp-roles.php | File | 8580 bytes | July 28 2023 10:37:26. | |
class-wp-script-modules.php | File | 13755 bytes | May 10 2024 08:09:18. | |
class-wp-scripts.php | File | 27906 bytes | February 05 2024 09:43:12. | |
class-wp-session-tokens.php | File | 7451 bytes | September 12 2022 14:47:14. | |
class-wp-simplepie-file.php | File | 3377 bytes | August 10 2023 00:06:22. | |
class-wp-simplepie-sanitize-kses.php | File | 1770 bytes | August 10 2023 00:06:22. | |
class-wp-site-query.php | File | 31545 bytes | June 21 2024 16:26:14. | |
class-wp-site.php | File | 7454 bytes | September 12 2022 14:47:14. | |
class-wp-styles.php | File | 10898 bytes | May 02 2023 14:45:22. | |
class-wp-tax-query.php | File | 19555 bytes | February 16 2024 21:47:12. | |
class-wp-taxonomy.php | File | 18567 bytes | April 27 2023 22:15:18. | |
class-wp-term-query.php | File | 41166 bytes | March 02 2024 13:38:08. | |
class-wp-term.php | File | 5298 bytes | September 12 2022 14:47:14. | |
class-wp-text-diff-renderer-inline.php | File | 979 bytes | February 14 2024 19:27:10. | |
class-wp-text-diff-renderer-table.php | File | 18807 bytes | October 15 2023 13:55:24. | |
class-wp-textdomain-registry.php | File | 10203 bytes | June 11 2024 13:27:18. | |
class-wp-theme-json-data.php | File | 1809 bytes | June 04 2024 10:55:14. | |
class-wp-theme-json-resolver.php | File | 34714 bytes | June 24 2024 09:33:16. | |
class-wp-theme-json-schema.php | File | 7367 bytes | June 06 2024 07:02:16. | |
class-wp-theme-json.php | File | 157322 bytes | September 04 2024 13:24:14. | |
class-wp-theme.php | File | 65299 bytes | April 19 2024 16:59:16. | |
class-wp-token-map.php | File | 28430 bytes | June 02 2024 14:16:14. | |
class-wp-user-meta-session-tokens.php | File | 2990 bytes | January 09 2019 05:04:50. | |
class-wp-user-query.php | File | 43654 bytes | May 19 2024 18:53:20. | |
class-wp-user-request.php | File | 2222 bytes | September 12 2022 14:47:14. | |
class-wp-user.php | File | 22827 bytes | February 16 2024 21:47:12. | |
class-wp-walker.php | File | 13322 bytes | August 07 2024 18:47:10. | |
class-wp-widget-factory.php | File | 3347 bytes | September 12 2022 14:47:14. | |
class-wp-widget.php | File | 18386 bytes | August 25 2023 00:28:16. | |
class-wp-xmlrpc-server.php | File | 214948 bytes | February 11 2024 19:14:20. | |
class-wp.php | File | 26119 bytes | August 13 2023 09:31:24. | |
class-wpdb.php | File | 118379 bytes | April 04 2024 14:13:14. | |
class.wp-dependencies.php | File | 373 bytes | September 20 2022 13:17:12. | |
class.wp-scripts.php | File | 343 bytes | September 20 2022 13:17:12. | |
class.wp-styles.php | File | 338 bytes | September 20 2022 13:17:12. | |
comment-template.php | File | 101738 bytes | July 18 2024 16:58:16. | |
comment.php | File | 129226 bytes | June 13 2024 12:05:14. | |
compat.php | File | 16467 bytes | July 18 2024 17:22:16. | |
cron.php | File | 41582 bytes | May 02 2024 12:19:14. | |
date.php | File | 400 bytes | June 17 2022 10:20:14. | |
default-constants.php | File | 11238 bytes | April 17 2024 08:46:20. | |
default-filters.php | File | 35490 bytes | June 11 2024 01:40:14. | |
default-widgets.php | File | 2222 bytes | May 25 2021 07:27:58. | |
deprecated.php | File | 186291 bytes | June 04 2024 06:39:10. | |
embed-template-trigger.php | File | 373 bytes | September 12 2022 14:47:14. | |
embed-template.php | File | 338 bytes | June 17 2022 10:20:14. | |
embed.php | File | 37908 bytes | June 02 2024 21:02:16. | |
error-protection.php | File | 4121 bytes | May 02 2023 14:45:22. | |
error_log | File | 795153 bytes | August 07 2025 03:15:23. | |
feed-atom-comments.php | File | 5504 bytes | March 04 2024 12:41:10. | |
feed-atom.php | File | 3048 bytes | November 29 2021 09:52:00. | |
feed-rdf.php | File | 2668 bytes | January 29 2020 00:45:18. | |
feed-rss.php | File | 1189 bytes | January 29 2020 00:45:18. | |
feed-rss2-comments.php | File | 4136 bytes | March 04 2024 12:41:10. | |
feed-rss2.php | File | 3799 bytes | January 29 2020 00:45:18. | |
feed.php | File | 23317 bytes | June 13 2024 19:50:14. | |
fonts.php | File | 9441 bytes | June 05 2024 22:19:18. | |
formatting.php | File | 335374 bytes | June 24 2024 13:42:10. | |
functions.php | File | 280644 bytes | July 18 2024 17:22:16. | |
functions.wp-scripts.php | File | 14558 bytes | May 26 2024 19:51:14. | |
functions.wp-styles.php | File | 8583 bytes | May 26 2024 19:51:14. | |
general-template.php | File | 169119 bytes | June 13 2024 13:48:06. | |
global-styles-and-settings.php | File | 21424 bytes | July 12 2024 19:01:16. | |
http.php | File | 25548 bytes | August 06 2025 04:48:37. | |
https-detection.php | File | 5661 bytes | September 22 2023 18:08:20. | |
https-migration.php | File | 4741 bytes | July 10 2023 21:38:26. | |
kses.php | File | 74389 bytes | June 17 2024 11:04:12. | |
l10n-object.php | File | 38 bytes | June 26 2025 11:42:43. | |
l10n.php | File | 66655 bytes | August 06 2025 04:48:37. | |
link-template.php | File | 156140 bytes | May 27 2024 15:29:16. | |
load.php | File | 55353 bytes | May 10 2024 10:48:16. | |
locale.php | File | 162 bytes | October 08 2019 16:19:04. | |
media-template.php | File | 62218 bytes | July 24 2024 16:32:16. | |
media.php | File | 210542 bytes | August 07 2024 18:43:12. | |
meta.php | File | 64078 bytes | September 26 2023 14:32:20. | |
ms-blogs.php | File | 25728 bytes | March 29 2024 10:42:14. | |
ms-default-constants.php | File | 4921 bytes | June 13 2024 19:50:14. | |
ms-default-filters.php | File | 6636 bytes | February 24 2023 01:23:20. | |
ms-deprecated.php | File | 21759 bytes | April 12 2024 16:47:14. | |
ms-files.php | File | 2711 bytes | August 23 2023 14:53:24. | |
ms-functions.php | File | 91243 bytes | November 13 2023 11:13:28. | |
ms-load.php | File | 19883 bytes | March 25 2024 16:19:18. | |
ms-network.php | File | 3782 bytes | May 02 2023 10:26:24. | |
ms-settings.php | File | 4124 bytes | June 22 2023 13:57:24. | |
ms-site.php | File | 40346 bytes | May 04 2024 18:25:10. | |
nav-menu-template.php | File | 25917 bytes | May 09 2024 14:16:14. | |
nav-menu.php | File | 44145 bytes | May 08 2024 17:37:14. | |
option.php | File | 100442 bytes | June 14 2024 14:21:10. | |
pluggable-deprecated.php | File | 6263 bytes | January 11 2020 18:32:06. | |
pluggable.php | File | 113181 bytes | April 13 2024 15:33:14. | |
plugin.php | File | 35465 bytes | June 08 2023 06:54:22. | |
post-formats.php | File | 7102 bytes | May 27 2024 15:29:16. | |
post-template.php | File | 66814 bytes | June 01 2024 16:37:18. | |
post-thumbnail-template.php | File | 10308 bytes | May 17 2023 17:31:24. | |
post.php | File | 284273 bytes | June 18 2024 13:46:10. | |
query.php | File | 37035 bytes | August 24 2023 08:01:16. | |
registration-functions.php | File | 200 bytes | November 12 2020 11:17:08. | |
registration.php | File | 200 bytes | November 12 2020 11:17:08. | |
rest-api.php | File | 98466 bytes | June 02 2024 21:02:16. | |
revision.php | File | 30906 bytes | May 06 2024 15:35:20. | |
rewrite.php | File | 19514 bytes | July 11 2023 10:15:28. | |
robots-template.php | File | 5185 bytes | April 06 2022 14:33:04. | |
rss-functions.php | File | 255 bytes | November 16 2020 22:52:06. | |
rss.php | File | 23107 bytes | June 13 2024 19:50:14. | |
script-loader.php | File | 130296 bytes | June 13 2024 14:06:08. | |
script-modules.php | File | 5978 bytes | May 26 2024 19:51:14. | |
session.php | File | 258 bytes | February 06 2020 06:33:12. | |
shortcodes.php | File | 24051 bytes | May 25 2024 02:04:12. | |
sitemaps.php | File | 3238 bytes | May 15 2021 16:38:06. | |
spl-autoload-compat.php | File | 441 bytes | November 12 2020 11:17:08. | |
style-engine.php | File | 7563 bytes | May 03 2024 03:47:12. | |
taxonomy.php | File | 175314 bytes | June 18 2024 03:12:12. | |
template-canvas.php | File | 544 bytes | September 30 2023 23:22:28. | |
template-loader.php | File | 3012 bytes | May 26 2020 08:37:10. | |
template.php | File | 24154 bytes | February 21 2024 19:26:08. | |
theme-i18n.json | File | 1245 bytes | June 24 2024 07:51:16. | |
theme-previews.php | File | 2832 bytes | December 08 2023 06:32:24. | |
theme-templates.php | File | 6223 bytes | October 13 2023 16:21:22. | |
theme.json | File | 8704 bytes | June 12 2024 05:11:14. | |
theme.php | File | 133979 bytes | June 13 2024 19:50:14. | |
update.php | File | 36884 bytes | June 13 2024 19:50:14. | |
user.php | File | 173735 bytes | June 05 2024 11:23:10. | |
vars.php | File | 6489 bytes | April 04 2024 12:40:06. | |
version.php | File | 961 bytes | August 06 2025 04:48:37. | |
widgets.php | File | 70682 bytes | May 26 2024 19:51:14. | |
wp-db.php | File | 445 bytes | July 21 2022 21:45:12. | |
wp-diff.php | File | 647 bytes | February 06 2020 06:33:12. |
<?php /** * WordPress Customize Setting classes * * @package WordPress * @subpackage Customize * @since 3.4.0 */ /** * Customize Setting class. * * Handles saving and sanitizing of settings. * * @since 3.4.0 * * @see WP_Customize_Manager * @link https://developer.wordpress.org/themes/customize-api */ #[AllowDynamicProperties] class WP_Customize_Setting { /** * Customizer bootstrap instance. * * @since 3.4.0 * @var WP_Customize_Manager */ public $manager; /** * Unique string identifier for the setting. * * @since 3.4.0 * @var string */ public $id; /** * Type of customize settings. * * @since 3.4.0 * @var string */ public $type = 'theme_mod'; /** * Capability required to edit this setting. * * @since 3.4.0 * @var string|array */ public $capability = 'edit_theme_options'; /** * Theme features required to support the setting. * * @since 3.4.0 * @var string|string[] */ public $theme_supports = ''; /** * The default value for the setting. * * @since 3.4.0 * @var string */ public $default = ''; /** * Options for rendering the live preview of changes in Customizer. * * Set this value to 'postMessage' to enable a custom JavaScript handler to render changes to this setting * as opposed to reloading the whole page. * * @since 3.4.0 * @var string */ public $transport = 'refresh'; /** * Server-side validation callback for the setting's value. * * @since 4.6.0 * @var callable */ public $validate_callback = ''; /** * Callback to filter a Customize setting value in un-slashed form. * * @since 3.4.0 * @var callable */ public $sanitize_callback = ''; /** * Callback to convert a Customize PHP setting value to a value that is JSON serializable. * * @since 3.4.0 * @var callable */ public $sanitize_js_callback = ''; /** * Whether or not the setting is initially dirty when created. * * This is used to ensure that a setting will be sent from the pane to the * preview when loading the Customizer. Normally a setting only is synced to * the preview if it has been changed. This allows the setting to be sent * from the start. * * @since 4.2.0 * @var bool */ public $dirty = false; /** * ID Data. * * @since 3.4.0 * @var array */ protected $id_data = array(); /** * Whether or not preview() was called. * * @since 4.4.0 * @var bool */ protected $is_previewed = false; /** * Cache of multidimensional values to improve performance. * * @since 4.4.0 * @var array */ protected static $aggregated_multidimensionals = array(); /** * Whether the multidimensional setting is aggregated. * * @since 4.4.0 * @var bool */ protected $is_multidimensional_aggregated = false; /** * Constructor. * * Any supplied $args override class property defaults. * * @since 3.4.0 * * @param WP_Customize_Manager $manager Customizer bootstrap instance. * @param string $id A specific ID of the setting. * Can be a theme mod or option name. * @param array $args { * Optional. Array of properties for the new Setting object. Default empty array. * * @type string $type Type of the setting. Default 'theme_mod'. * @type string $capability Capability required for the setting. Default 'edit_theme_options' * @type string|string[] $theme_supports Theme features required to support the panel. Default is none. * @type string $default Default value for the setting. Default is empty string. * @type string $transport Options for rendering the live preview of changes in Customizer. * Using 'refresh' makes the change visible by reloading the whole preview. * Using 'postMessage' allows a custom JavaScript to handle live changes. * Default is 'refresh'. * @type callable $validate_callback Server-side validation callback for the setting's value. * @type callable $sanitize_callback Callback to filter a Customize setting value in un-slashed form. * @type callable $sanitize_js_callback Callback to convert a Customize PHP setting value to a value that is * JSON serializable. * @type bool $dirty Whether or not the setting is initially dirty when created. * } */ public function __construct( $manager, $id, $args = array() ) { $keys = array_keys( get_object_vars( $this ) ); foreach ( $keys as $key ) { if ( isset( $args[ $key ] ) ) { $this->$key = $args[ $key ]; } } $this->manager = $manager; $this->id = $id; // Parse the ID for array keys. $this->id_data['keys'] = preg_split( '/\[/', str_replace( ']', '', $this->id ) ); $this->id_data['base'] = array_shift( $this->id_data['keys'] ); // Rebuild the ID. $this->id = $this->id_data['base']; if ( ! empty( $this->id_data['keys'] ) ) { $this->id .= '[' . implode( '][', $this->id_data['keys'] ) . ']'; } if ( $this->validate_callback ) { add_filter( "customize_validate_{$this->id}", $this->validate_callback, 10, 3 ); } if ( $this->sanitize_callback ) { add_filter( "customize_sanitize_{$this->id}", $this->sanitize_callback, 10, 2 ); } if ( $this->sanitize_js_callback ) { add_filter( "customize_sanitize_js_{$this->id}", $this->sanitize_js_callback, 10, 2 ); } if ( 'option' === $this->type || 'theme_mod' === $this->type ) { // Other setting types can opt-in to aggregate multidimensional explicitly. $this->aggregate_multidimensional(); // Allow option settings to indicate whether they should be autoloaded. if ( 'option' === $this->type && isset( $args['autoload'] ) ) { self::$aggregated_multidimensionals[ $this->type ][ $this->id_data['base'] ]['autoload'] = $args['autoload']; } } } /** * Get parsed ID data for multidimensional setting. * * @since 4.4.0 * * @return array { * ID data for multidimensional setting. * * @type string $base ID base * @type array $keys Keys for multidimensional array. * } */ final public function id_data() { return $this->id_data; } /** * Set up the setting for aggregated multidimensional values. * * When a multidimensional setting gets aggregated, all of its preview and update * calls get combined into one call, greatly improving performance. * * @since 4.4.0 */ protected function aggregate_multidimensional() { $id_base = $this->id_data['base']; if ( ! isset( self::$aggregated_multidimensionals[ $this->type ] ) ) { self::$aggregated_multidimensionals[ $this->type ] = array(); } if ( ! isset( self::$aggregated_multidimensionals[ $this->type ][ $id_base ] ) ) { self::$aggregated_multidimensionals[ $this->type ][ $id_base ] = array( 'previewed_instances' => array(), // Calling preview() will add the $setting to the array. 'preview_applied_instances' => array(), // Flags for which settings have had their values applied. 'root_value' => $this->get_root_value( array() ), // Root value for initial state, manipulated by preview and update calls. ); } if ( ! empty( $this->id_data['keys'] ) ) { // Note the preview-applied flag is cleared at priority 9 to ensure it is cleared before a deferred-preview runs. add_action( "customize_post_value_set_{$this->id}", array( $this, '_clear_aggregated_multidimensional_preview_applied_flag' ), 9 ); $this->is_multidimensional_aggregated = true; } } /** * Reset `$aggregated_multidimensionals` static variable. * * This is intended only for use by unit tests. * * @since 4.5.0 * @ignore */ public static function reset_aggregated_multidimensionals() { self::$aggregated_multidimensionals = array(); } /** * The ID for the current site when the preview() method was called. * * @since 4.2.0 * @var int */ protected $_previewed_blog_id; /** * Return true if the current site is not the same as the previewed site. * * @since 4.2.0 * * @return bool If preview() has been called. */ public function is_current_blog_previewed() { if ( ! isset( $this->_previewed_blog_id ) ) { return false; } return ( get_current_blog_id() === $this->_previewed_blog_id ); } /** * Original non-previewed value stored by the preview method. * * @see WP_Customize_Setting::preview() * @since 4.1.1 * @var mixed */ protected $_original_value; /** * Add filters to supply the setting's value when accessed. * * If the setting already has a pre-existing value and there is no incoming * post value for the setting, then this method will short-circuit since * there is no change to preview. * * @since 3.4.0 * @since 4.4.0 Added boolean return value. * * @return bool False when preview short-circuits due no change needing to be previewed. */ public function preview() { if ( ! isset( $this->_previewed_blog_id ) ) { $this->_previewed_blog_id = get_current_blog_id(); } // Prevent re-previewing an already-previewed setting. if ( $this->is_previewed ) { return true; } $id_base = $this->id_data['base']; $is_multidimensional = ! empty( $this->id_data['keys'] ); $multidimensional_filter = array( $this, '_multidimensional_preview_filter' ); /* * Check if the setting has a pre-existing value (an isset check), * and if doesn't have any incoming post value. If both checks are true, * then the preview short-circuits because there is nothing that needs * to be previewed. */ $undefined = new stdClass(); $needs_preview = ( $undefined !== $this->post_value( $undefined ) ); $value = null; // Since no post value was defined, check if we have an initial value set. if ( ! $needs_preview ) { if ( $this->is_multidimensional_aggregated ) { $root = self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['root_value']; $value = $this->multidimensional_get( $root, $this->id_data['keys'], $undefined ); } else { $default = $this->default; $this->default = $undefined; // Temporarily set default to undefined so we can detect if existing value is set. $value = $this->value(); $this->default = $default; } $needs_preview = ( $undefined === $value ); // Because the default needs to be supplied. } // If the setting does not need previewing now, defer to when it has a value to preview. if ( ! $needs_preview ) { if ( ! has_action( "customize_post_value_set_{$this->id}", array( $this, 'preview' ) ) ) { add_action( "customize_post_value_set_{$this->id}", array( $this, 'preview' ) ); } return false; } switch ( $this->type ) { case 'theme_mod': if ( ! $is_multidimensional ) { add_filter( "theme_mod_{$id_base}", array( $this, '_preview_filter' ) ); } else { if ( empty( self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'] ) ) { // Only add this filter once for this ID base. add_filter( "theme_mod_{$id_base}", $multidimensional_filter ); } self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'][ $this->id ] = $this; } break; case 'option': if ( ! $is_multidimensional ) { add_filter( "pre_option_{$id_base}", array( $this, '_preview_filter' ) ); } else { if ( empty( self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'] ) ) { // Only add these filters once for this ID base. add_filter( "option_{$id_base}", $multidimensional_filter ); add_filter( "default_option_{$id_base}", $multidimensional_filter ); } self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'][ $this->id ] = $this; } break; default: /** * Fires when the WP_Customize_Setting::preview() method is called for settings * not handled as theme_mods or options. * * The dynamic portion of the hook name, `$this->id`, refers to the setting ID. * * @since 3.4.0 * * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ do_action( "customize_preview_{$this->id}", $this ); /** * Fires when the WP_Customize_Setting::preview() method is called for settings * not handled as theme_mods or options. * * The dynamic portion of the hook name, `$this->type`, refers to the setting type. * * @since 4.1.0 * * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ do_action( "customize_preview_{$this->type}", $this ); } $this->is_previewed = true; return true; } /** * Clear out the previewed-applied flag for a multidimensional-aggregated value whenever its post value is updated. * * This ensures that the new value will get sanitized and used the next time * that `WP_Customize_Setting::_multidimensional_preview_filter()` * is called for this setting. * * @since 4.4.0 * * @see WP_Customize_Manager::set_post_value() * @see WP_Customize_Setting::_multidimensional_preview_filter() */ final public function _clear_aggregated_multidimensional_preview_applied_flag() { unset( self::$aggregated_multidimensionals[ $this->type ][ $this->id_data['base'] ]['preview_applied_instances'][ $this->id ] ); } /** * Callback function to filter non-multidimensional theme mods and options. * * If switch_to_blog() was called after the preview() method, and the current * site is now not the same site, then this method does a no-op and returns * the original value. * * @since 3.4.0 * * @param mixed $original Old value. * @return mixed New or old value. */ public function _preview_filter( $original ) { if ( ! $this->is_current_blog_previewed() ) { return $original; } $undefined = new stdClass(); // Symbol hack. $post_value = $this->post_value( $undefined ); if ( $undefined !== $post_value ) { $value = $post_value; } else { /* * Note that we don't use $original here because preview() will * not add the filter in the first place if it has an initial value * and there is no post value. */ $value = $this->default; } return $value; } /** * Callback function to filter multidimensional theme mods and options. * * For all multidimensional settings of a given type, the preview filter for * the first setting previewed will be used to apply the values for the others. * * @since 4.4.0 * * @see WP_Customize_Setting::$aggregated_multidimensionals * @param mixed $original Original root value. * @return mixed New or old value. */ final public function _multidimensional_preview_filter( $original ) { if ( ! $this->is_current_blog_previewed() ) { return $original; } $id_base = $this->id_data['base']; // If no settings have been previewed yet (which should not be the case, since $this is), just pass through the original value. if ( empty( self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'] ) ) { return $original; } foreach ( self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['previewed_instances'] as $previewed_setting ) { // Skip applying previewed value for any settings that have already been applied. if ( ! empty( self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['preview_applied_instances'][ $previewed_setting->id ] ) ) { continue; } // Do the replacements of the posted/default sub value into the root value. $value = $previewed_setting->post_value( $previewed_setting->default ); $root = self::$aggregated_multidimensionals[ $previewed_setting->type ][ $id_base ]['root_value']; $root = $previewed_setting->multidimensional_replace( $root, $previewed_setting->id_data['keys'], $value ); self::$aggregated_multidimensionals[ $previewed_setting->type ][ $id_base ]['root_value'] = $root; // Mark this setting having been applied so that it will be skipped when the filter is called again. self::$aggregated_multidimensionals[ $previewed_setting->type ][ $id_base ]['preview_applied_instances'][ $previewed_setting->id ] = true; } return self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['root_value']; } /** * Checks user capabilities and theme supports, and then saves * the value of the setting. * * @since 3.4.0 * * @return void|false Void on success, false if cap check fails * or value isn't set or is invalid. */ final public function save() { $value = $this->post_value(); if ( ! $this->check_capabilities() || ! isset( $value ) ) { return false; } $id_base = $this->id_data['base']; /** * Fires when the WP_Customize_Setting::save() method is called. * * The dynamic portion of the hook name, `$id_base` refers to * the base slug of the setting name. * * @since 3.4.0 * * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ do_action( "customize_save_{$id_base}", $this ); $this->update( $value ); } /** * Fetch and sanitize the $_POST value for the setting. * * During a save request prior to save, post_value() provides the new value while value() does not. * * @since 3.4.0 * * @param mixed $default_value A default value which is used as a fallback. Default null. * @return mixed The default value on failure, otherwise the sanitized and validated value. */ final public function post_value( $default_value = null ) { return $this->manager->post_value( $this, $default_value ); } /** * Sanitize an input. * * @since 3.4.0 * * @param string|array $value The value to sanitize. * @return string|array|null|WP_Error Sanitized value, or `null`/`WP_Error` if invalid. */ public function sanitize( $value ) { /** * Filters a Customize setting value in un-slashed form. * * @since 3.4.0 * * @param mixed $value Value of the setting. * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ return apply_filters( "customize_sanitize_{$this->id}", $value, $this ); } /** * Validates an input. * * @since 4.6.0 * * @see WP_REST_Request::has_valid_params() * * @param mixed $value Value to validate. * @return true|WP_Error True if the input was validated, otherwise WP_Error. */ public function validate( $value ) { if ( is_wp_error( $value ) ) { return $value; } if ( is_null( $value ) ) { return new WP_Error( 'invalid_value', __( 'Invalid value.' ) ); } $validity = new WP_Error(); /** * Validates a Customize setting value. * * Plugins should amend the `$validity` object via its `WP_Error::add()` method. * * The dynamic portion of the hook name, `$this->ID`, refers to the setting ID. * * @since 4.6.0 * * @param WP_Error $validity Filtered from `true` to `WP_Error` when invalid. * @param mixed $value Value of the setting. * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ $validity = apply_filters( "customize_validate_{$this->id}", $validity, $value, $this ); if ( is_wp_error( $validity ) && ! $validity->has_errors() ) { $validity = true; } return $validity; } /** * Get the root value for a setting, especially for multidimensional ones. * * @since 4.4.0 * * @param mixed $default_value Value to return if root does not exist. * @return mixed */ protected function get_root_value( $default_value = null ) { $id_base = $this->id_data['base']; if ( 'option' === $this->type ) { return get_option( $id_base, $default_value ); } elseif ( 'theme_mod' === $this->type ) { return get_theme_mod( $id_base, $default_value ); } else { /* * Any WP_Customize_Setting subclass implementing aggregate multidimensional * will need to override this method to obtain the data from the appropriate * location. */ return $default_value; } } /** * Set the root value for a setting, especially for multidimensional ones. * * @since 4.4.0 * * @param mixed $value Value to set as root of multidimensional setting. * @return bool Whether the multidimensional root was updated successfully. */ protected function set_root_value( $value ) { $id_base = $this->id_data['base']; if ( 'option' === $this->type ) { $autoload = true; if ( isset( self::$aggregated_multidimensionals[ $this->type ][ $this->id_data['base'] ]['autoload'] ) ) { $autoload = self::$aggregated_multidimensionals[ $this->type ][ $this->id_data['base'] ]['autoload']; } return update_option( $id_base, $value, $autoload ); } elseif ( 'theme_mod' === $this->type ) { set_theme_mod( $id_base, $value ); return true; } else { /* * Any WP_Customize_Setting subclass implementing aggregate multidimensional * will need to override this method to obtain the data from the appropriate * location. */ return false; } } /** * Save the value of the setting, using the related API. * * @since 3.4.0 * * @param mixed $value The value to update. * @return bool The result of saving the value. */ protected function update( $value ) { $id_base = $this->id_data['base']; if ( 'option' === $this->type || 'theme_mod' === $this->type ) { if ( ! $this->is_multidimensional_aggregated ) { return $this->set_root_value( $value ); } else { $root = self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['root_value']; $root = $this->multidimensional_replace( $root, $this->id_data['keys'], $value ); self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['root_value'] = $root; return $this->set_root_value( $root ); } } else { /** * Fires when the WP_Customize_Setting::update() method is called for settings * not handled as theme_mods or options. * * The dynamic portion of the hook name, `$this->type`, refers to the type of setting. * * @since 3.4.0 * * @param mixed $value Value of the setting. * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ do_action( "customize_update_{$this->type}", $value, $this ); return has_action( "customize_update_{$this->type}" ); } } /** * Deprecated method. * * @since 3.4.0 * @deprecated 4.4.0 Deprecated in favor of update() method. */ protected function _update_theme_mod() { _deprecated_function( __METHOD__, '4.4.0', __CLASS__ . '::update()' ); } /** * Deprecated method. * * @since 3.4.0 * @deprecated 4.4.0 Deprecated in favor of update() method. */ protected function _update_option() { _deprecated_function( __METHOD__, '4.4.0', __CLASS__ . '::update()' ); } /** * Fetch the value of the setting. * * @since 3.4.0 * * @return mixed The value. */ public function value() { $id_base = $this->id_data['base']; $is_core_type = ( 'option' === $this->type || 'theme_mod' === $this->type ); if ( ! $is_core_type && ! $this->is_multidimensional_aggregated ) { // Use post value if previewed and a post value is present. if ( $this->is_previewed ) { $value = $this->post_value( null ); if ( null !== $value ) { return $value; } } $value = $this->get_root_value( $this->default ); /** * Filters a Customize setting value not handled as a theme_mod or option. * * The dynamic portion of the hook name, `$id_base`, refers to * the base slug of the setting name, initialized from `$this->id_data['base']`. * * For settings handled as theme_mods or options, see those corresponding * functions for available hooks. * * @since 3.4.0 * @since 4.6.0 Added the `$this` setting instance as the second parameter. * * @param mixed $default_value The setting default value. Default empty. * @param WP_Customize_Setting $setting The setting instance. */ $value = apply_filters( "customize_value_{$id_base}", $value, $this ); } elseif ( $this->is_multidimensional_aggregated ) { $root_value = self::$aggregated_multidimensionals[ $this->type ][ $id_base ]['root_value']; $value = $this->multidimensional_get( $root_value, $this->id_data['keys'], $this->default ); // Ensure that the post value is used if the setting is previewed, since preview filters aren't applying on cached $root_value. if ( $this->is_previewed ) { $value = $this->post_value( $value ); } } else { $value = $this->get_root_value( $this->default ); } return $value; } /** * Sanitize the setting's value for use in JavaScript. * * @since 3.4.0 * * @return mixed The requested escaped value. */ public function js_value() { /** * Filters a Customize setting value for use in JavaScript. * * The dynamic portion of the hook name, `$this->id`, refers to the setting ID. * * @since 3.4.0 * * @param mixed $value The setting value. * @param WP_Customize_Setting $setting WP_Customize_Setting instance. */ $value = apply_filters( "customize_sanitize_js_{$this->id}", $this->value(), $this ); if ( is_string( $value ) ) { return html_entity_decode( $value, ENT_QUOTES, 'UTF-8' ); } return $value; } /** * Retrieves the data to export to the client via JSON. * * @since 4.6.0 * * @return array Array of parameters passed to JavaScript. */ public function json() { return array( 'value' => $this->js_value(), 'transport' => $this->transport, 'dirty' => $this->dirty, 'type' => $this->type, ); } /** * Validate user capabilities whether the theme supports the setting. * * @since 3.4.0 * * @return bool False if theme doesn't support the setting or user can't change setting, otherwise true. */ final public function check_capabilities() { if ( $this->capability && ! current_user_can( $this->capability ) ) { return false; } if ( $this->theme_supports && ! current_theme_supports( ...(array) $this->theme_supports ) ) { return false; } return true; } /** * Multidimensional helper function. * * @since 3.4.0 * * @param array $root * @param array $keys * @param bool $create Default false. * @return array|void Keys are 'root', 'node', and 'key'. */ final protected function multidimensional( &$root, $keys, $create = false ) { if ( $create && empty( $root ) ) { $root = array(); } if ( ! isset( $root ) || empty( $keys ) ) { return; } $last = array_pop( $keys ); $node = &$root; foreach ( $keys as $key ) { if ( $create && ! isset( $node[ $key ] ) ) { $node[ $key ] = array(); } if ( ! is_array( $node ) || ! isset( $node[ $key ] ) ) { return; } $node = &$node[ $key ]; } if ( $create ) { if ( ! is_array( $node ) ) { // Account for an array overriding a string or object value. $node = array(); } if ( ! isset( $node[ $last ] ) ) { $node[ $last ] = array(); } } if ( ! isset( $node[ $last ] ) ) { return; } return array( 'root' => &$root, 'node' => &$node, 'key' => $last, ); } /** * Will attempt to replace a specific value in a multidimensional array. * * @since 3.4.0 * * @param array $root * @param array $keys * @param mixed $value The value to update. * @return mixed */ final protected function multidimensional_replace( $root, $keys, $value ) { if ( ! isset( $value ) ) { return $root; } elseif ( empty( $keys ) ) { // If there are no keys, we're replacing the root. return $value; } $result = $this->multidimensional( $root, $keys, true ); if ( isset( $result ) ) { $result['node'][ $result['key'] ] = $value; } return $root; } /** * Will attempt to fetch a specific value from a multidimensional array. * * @since 3.4.0 * * @param array $root * @param array $keys * @param mixed $default_value A default value which is used as a fallback. Default null. * @return mixed The requested value or the default value. */ final protected function multidimensional_get( $root, $keys, $default_value = null ) { if ( empty( $keys ) ) { // If there are no keys, test the root. return isset( $root ) ? $root : $default_value; } $result = $this->multidimensional( $root, $keys ); return isset( $result ) ? $result['node'][ $result['key'] ] : $default_value; } /** * Will attempt to check if a specific value in a multidimensional array is set. * * @since 3.4.0 * * @param array $root * @param array $keys * @return bool True if value is set, false if not. */ final protected function multidimensional_isset( $root, $keys ) { $result = $this->multidimensional_get( $root, $keys ); return isset( $result ); } } /** * WP_Customize_Filter_Setting class. */ require_once ABSPATH . WPINC . '/customize/class-wp-customize-filter-setting.php'; /** * WP_Customize_Header_Image_Setting class. */ require_once ABSPATH . WPINC . '/customize/class-wp-customize-header-image-setting.php'; /** * WP_Customize_Background_Image_Setting class. */ require_once ABSPATH . WPINC . '/customize/class-wp-customize-background-image-setting.php'; /** * WP_Customize_Nav_Menu_Item_Setting class. */ require_once ABSPATH . WPINC . '/customize/class-wp-customize-nav-menu-item-setting.php'; /** * WP_Customize_Nav_Menu_Setting class. */ require_once ABSPATH . WPINC . '/customize/class-wp-customize-nav-menu-setting.php';
SILENT KILLER Tool