Current Path: > home > transcarter > public_html > > 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 /** * Core User Role & Capabilities API * * @package WordPress * @subpackage Users */ /** * Maps a capability to the primitive capabilities required of the given user to * satisfy the capability being checked. * * This function also accepts an ID of an object to map against if the capability is a meta capability. Meta * capabilities such as `edit_post` and `edit_user` are capabilities used by this function to map to primitive * capabilities that a user or role requires, such as `edit_posts` and `edit_others_posts`. * * Example usage: * * map_meta_cap( 'edit_posts', $user->ID ); * map_meta_cap( 'edit_post', $user->ID, $post->ID ); * map_meta_cap( 'edit_post_meta', $user->ID, $post->ID, $meta_key ); * * This function does not check whether the user has the required capabilities, * it just returns what the required capabilities are. * * @since 2.0.0 * @since 4.9.6 Added the `export_others_personal_data`, `erase_others_personal_data`, * and `manage_privacy_options` capabilities. * @since 5.1.0 Added the `update_php` capability. * @since 5.2.0 Added the `resume_plugin` and `resume_theme` capabilities. * @since 5.3.0 Formalized the existing and already documented `...$args` parameter * by adding it to the function signature. * @since 5.7.0 Added the `create_app_password`, `list_app_passwords`, `read_app_password`, * `edit_app_password`, `delete_app_passwords`, `delete_app_password`, * and `update_https` capabilities. * * @global array $post_type_meta_caps Used to get post type meta capabilities. * * @param string $cap Capability being checked. * @param int $user_id User ID. * @param mixed ...$args Optional further parameters, typically starting with an object ID. * @return string[] Primitive capabilities required of the user. */ function map_meta_cap( $cap, $user_id, ...$args ) { $caps = array(); switch ( $cap ) { case 'remove_user': // In multisite the user must be a super admin to remove themselves. if ( isset( $args[0] ) && $user_id == $args[0] && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'remove_users'; } break; case 'promote_user': case 'add_users': $caps[] = 'promote_users'; break; case 'edit_user': case 'edit_users': // Allow user to edit themselves. if ( 'edit_user' === $cap && isset( $args[0] ) && $user_id == $args[0] ) { break; } // In multisite the user must have manage_network_users caps. If editing a super admin, the user must be a super admin. if ( is_multisite() && ( ( ! is_super_admin( $user_id ) && 'edit_user' === $cap && is_super_admin( $args[0] ) ) || ! user_can( $user_id, 'manage_network_users' ) ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'edit_users'; // edit_user maps to edit_users. } break; case 'delete_post': case 'delete_page': if ( ! isset( $args[0] ) ) { if ( 'delete_post' === $cap ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific post.' ); } else { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific page.' ); } _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $post = get_post( $args[0] ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } if ( 'revision' === $post->post_type ) { $caps[] = 'do_not_allow'; break; } if ( ( get_option( 'page_for_posts' ) == $post->ID ) || ( get_option( 'page_on_front' ) == $post->ID ) ) { $caps[] = 'manage_options'; break; } $post_type = get_post_type_object( $post->post_type ); if ( ! $post_type ) { /* translators: 1: Post type, 2: Capability name. */ $message = __( 'The post type %1$s is not registered, so it may not be reliable to check the capability %2$s against a post of that type.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $post->post_type . '</code>', '<code>' . $cap . '</code>' ), '4.4.0' ); $caps[] = 'edit_others_posts'; break; } if ( ! $post_type->map_meta_cap ) { $caps[] = $post_type->cap->$cap; // Prior to 3.1 we would re-call map_meta_cap here. if ( 'delete_post' === $cap ) { $cap = $post_type->cap->$cap; } break; } // If the post author is set and the user is the author... if ( $post->post_author && $user_id == $post->post_author ) { // If the post is published or scheduled... if ( in_array( $post->post_status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->delete_published_posts; } elseif ( 'trash' === $post->post_status ) { $status = get_post_meta( $post->ID, '_wp_trash_meta_status', true ); if ( in_array( $status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->delete_published_posts; } else { $caps[] = $post_type->cap->delete_posts; } } else { // If the post is draft... $caps[] = $post_type->cap->delete_posts; } } else { // The user is trying to edit someone else's post. $caps[] = $post_type->cap->delete_others_posts; // The post is published or scheduled, extra cap required. if ( in_array( $post->post_status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->delete_published_posts; } elseif ( 'private' === $post->post_status ) { $caps[] = $post_type->cap->delete_private_posts; } } /* * Setting the privacy policy page requires `manage_privacy_options`, * so deleting it should require that too. */ if ( (int) get_option( 'wp_page_for_privacy_policy' ) === $post->ID ) { $caps = array_merge( $caps, map_meta_cap( 'manage_privacy_options', $user_id ) ); } break; /* * edit_post breaks down to edit_posts, edit_published_posts, or * edit_others_posts. */ case 'edit_post': case 'edit_page': if ( ! isset( $args[0] ) ) { if ( 'edit_post' === $cap ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific post.' ); } else { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific page.' ); } _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $post = get_post( $args[0] ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } if ( 'revision' === $post->post_type ) { $post = get_post( $post->post_parent ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } } $post_type = get_post_type_object( $post->post_type ); if ( ! $post_type ) { /* translators: 1: Post type, 2: Capability name. */ $message = __( 'The post type %1$s is not registered, so it may not be reliable to check the capability %2$s against a post of that type.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $post->post_type . '</code>', '<code>' . $cap . '</code>' ), '4.4.0' ); $caps[] = 'edit_others_posts'; break; } if ( ! $post_type->map_meta_cap ) { $caps[] = $post_type->cap->$cap; // Prior to 3.1 we would re-call map_meta_cap here. if ( 'edit_post' === $cap ) { $cap = $post_type->cap->$cap; } break; } // If the post author is set and the user is the author... if ( $post->post_author && $user_id == $post->post_author ) { // If the post is published or scheduled... if ( in_array( $post->post_status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->edit_published_posts; } elseif ( 'trash' === $post->post_status ) { $status = get_post_meta( $post->ID, '_wp_trash_meta_status', true ); if ( in_array( $status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->edit_published_posts; } else { $caps[] = $post_type->cap->edit_posts; } } else { // If the post is draft... $caps[] = $post_type->cap->edit_posts; } } else { // The user is trying to edit someone else's post. $caps[] = $post_type->cap->edit_others_posts; // The post is published or scheduled, extra cap required. if ( in_array( $post->post_status, array( 'publish', 'future' ), true ) ) { $caps[] = $post_type->cap->edit_published_posts; } elseif ( 'private' === $post->post_status ) { $caps[] = $post_type->cap->edit_private_posts; } } /* * Setting the privacy policy page requires `manage_privacy_options`, * so editing it should require that too. */ if ( (int) get_option( 'wp_page_for_privacy_policy' ) === $post->ID ) { $caps = array_merge( $caps, map_meta_cap( 'manage_privacy_options', $user_id ) ); } break; case 'read_post': case 'read_page': if ( ! isset( $args[0] ) ) { if ( 'read_post' === $cap ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific post.' ); } else { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific page.' ); } _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $post = get_post( $args[0] ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } if ( 'revision' === $post->post_type ) { $post = get_post( $post->post_parent ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } } $post_type = get_post_type_object( $post->post_type ); if ( ! $post_type ) { /* translators: 1: Post type, 2: Capability name. */ $message = __( 'The post type %1$s is not registered, so it may not be reliable to check the capability %2$s against a post of that type.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $post->post_type . '</code>', '<code>' . $cap . '</code>' ), '4.4.0' ); $caps[] = 'edit_others_posts'; break; } if ( ! $post_type->map_meta_cap ) { $caps[] = $post_type->cap->$cap; // Prior to 3.1 we would re-call map_meta_cap here. if ( 'read_post' === $cap ) { $cap = $post_type->cap->$cap; } break; } $status_obj = get_post_status_object( get_post_status( $post ) ); if ( ! $status_obj ) { /* translators: 1: Post status, 2: Capability name. */ $message = __( 'The post status %1$s is not registered, so it may not be reliable to check the capability %2$s against a post with that status.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . get_post_status( $post ) . '</code>', '<code>' . $cap . '</code>' ), '5.4.0' ); $caps[] = 'edit_others_posts'; break; } if ( $status_obj->public ) { $caps[] = $post_type->cap->read; break; } if ( $post->post_author && $user_id == $post->post_author ) { $caps[] = $post_type->cap->read; } elseif ( $status_obj->private ) { $caps[] = $post_type->cap->read_private_posts; } else { $caps = map_meta_cap( 'edit_post', $user_id, $post->ID ); } break; case 'publish_post': if ( ! isset( $args[0] ) ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific post.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $post = get_post( $args[0] ); if ( ! $post ) { $caps[] = 'do_not_allow'; break; } $post_type = get_post_type_object( $post->post_type ); if ( ! $post_type ) { /* translators: 1: Post type, 2: Capability name. */ $message = __( 'The post type %1$s is not registered, so it may not be reliable to check the capability %2$s against a post of that type.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $post->post_type . '</code>', '<code>' . $cap . '</code>' ), '4.4.0' ); $caps[] = 'edit_others_posts'; break; } $caps[] = $post_type->cap->publish_posts; break; case 'edit_post_meta': case 'delete_post_meta': case 'add_post_meta': case 'edit_comment_meta': case 'delete_comment_meta': case 'add_comment_meta': case 'edit_term_meta': case 'delete_term_meta': case 'add_term_meta': case 'edit_user_meta': case 'delete_user_meta': case 'add_user_meta': $object_type = explode( '_', $cap )[1]; if ( ! isset( $args[0] ) ) { if ( 'post' === $object_type ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific post.' ); } elseif ( 'comment' === $object_type ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific comment.' ); } elseif ( 'term' === $object_type ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific term.' ); } else { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific user.' ); } _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $object_id = (int) $args[0]; $object_subtype = get_object_subtype( $object_type, $object_id ); if ( empty( $object_subtype ) ) { $caps[] = 'do_not_allow'; break; } $caps = map_meta_cap( "edit_{$object_type}", $user_id, $object_id ); $meta_key = isset( $args[1] ) ? $args[1] : false; if ( $meta_key ) { $allowed = ! is_protected_meta( $meta_key, $object_type ); if ( ! empty( $object_subtype ) && has_filter( "auth_{$object_type}_meta_{$meta_key}_for_{$object_subtype}" ) ) { /** * Filters whether the user is allowed to edit a specific meta key of a specific object type and subtype. * * The dynamic portions of the hook name, `$object_type`, `$meta_key`, * and `$object_subtype`, refer to the metadata object type (comment, post, term or user), * the meta key value, and the object subtype respectively. * * @since 4.9.8 * * @param bool $allowed Whether the user can add the object meta. Default false. * @param string $meta_key The meta key. * @param int $object_id Object ID. * @param int $user_id User ID. * @param string $cap Capability name. * @param string[] $caps Array of the user's capabilities. */ $allowed = apply_filters( "auth_{$object_type}_meta_{$meta_key}_for_{$object_subtype}", $allowed, $meta_key, $object_id, $user_id, $cap, $caps ); } else { /** * Filters whether the user is allowed to edit a specific meta key of a specific object type. * * Return true to have the mapped meta caps from `edit_{$object_type}` apply. * * The dynamic portion of the hook name, `$object_type` refers to the object type being filtered. * The dynamic portion of the hook name, `$meta_key`, refers to the meta key passed to map_meta_cap(). * * @since 3.3.0 As `auth_post_meta_{$meta_key}`. * @since 4.6.0 * * @param bool $allowed Whether the user can add the object meta. Default false. * @param string $meta_key The meta key. * @param int $object_id Object ID. * @param int $user_id User ID. * @param string $cap Capability name. * @param string[] $caps Array of the user's capabilities. */ $allowed = apply_filters( "auth_{$object_type}_meta_{$meta_key}", $allowed, $meta_key, $object_id, $user_id, $cap, $caps ); } if ( ! empty( $object_subtype ) ) { /** * Filters whether the user is allowed to edit meta for specific object types/subtypes. * * Return true to have the mapped meta caps from `edit_{$object_type}` apply. * * The dynamic portion of the hook name, `$object_type` refers to the object type being filtered. * The dynamic portion of the hook name, `$object_subtype` refers to the object subtype being filtered. * The dynamic portion of the hook name, `$meta_key`, refers to the meta key passed to map_meta_cap(). * * @since 4.6.0 As `auth_post_{$post_type}_meta_{$meta_key}`. * @since 4.7.0 Renamed from `auth_post_{$post_type}_meta_{$meta_key}` to * `auth_{$object_type}_{$object_subtype}_meta_{$meta_key}`. * @deprecated 4.9.8 Use {@see 'auth_{$object_type}_meta_{$meta_key}_for_{$object_subtype}'} instead. * * @param bool $allowed Whether the user can add the object meta. Default false. * @param string $meta_key The meta key. * @param int $object_id Object ID. * @param int $user_id User ID. * @param string $cap Capability name. * @param string[] $caps Array of the user's capabilities. */ $allowed = apply_filters_deprecated( "auth_{$object_type}_{$object_subtype}_meta_{$meta_key}", array( $allowed, $meta_key, $object_id, $user_id, $cap, $caps ), '4.9.8', "auth_{$object_type}_meta_{$meta_key}_for_{$object_subtype}" ); } if ( ! $allowed ) { $caps[] = $cap; } } break; case 'edit_comment': if ( ! isset( $args[0] ) ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific comment.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $comment = get_comment( $args[0] ); if ( ! $comment ) { $caps[] = 'do_not_allow'; break; } $post = get_post( $comment->comment_post_ID ); /* * If the post doesn't exist, we have an orphaned comment. * Fall back to the edit_posts capability, instead. */ if ( $post ) { $caps = map_meta_cap( 'edit_post', $user_id, $post->ID ); } else { $caps = map_meta_cap( 'edit_posts', $user_id ); } break; case 'unfiltered_upload': if ( defined( 'ALLOW_UNFILTERED_UPLOADS' ) && ALLOW_UNFILTERED_UPLOADS && ( ! is_multisite() || is_super_admin( $user_id ) ) ) { $caps[] = $cap; } else { $caps[] = 'do_not_allow'; } break; case 'edit_css': case 'unfiltered_html': // Disallow unfiltered_html for all users, even admins and super admins. if ( defined( 'DISALLOW_UNFILTERED_HTML' ) && DISALLOW_UNFILTERED_HTML ) { $caps[] = 'do_not_allow'; } elseif ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'unfiltered_html'; } break; case 'edit_files': case 'edit_plugins': case 'edit_themes': // Disallow the file editors. if ( defined( 'DISALLOW_FILE_EDIT' ) && DISALLOW_FILE_EDIT ) { $caps[] = 'do_not_allow'; } elseif ( ! wp_is_file_mod_allowed( 'capability_edit_themes' ) ) { $caps[] = 'do_not_allow'; } elseif ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = $cap; } break; case 'update_plugins': case 'delete_plugins': case 'install_plugins': case 'upload_plugins': case 'update_themes': case 'delete_themes': case 'install_themes': case 'upload_themes': case 'update_core': /* * Disallow anything that creates, deletes, or updates core, plugin, or theme files. * Files in uploads are excepted. */ if ( ! wp_is_file_mod_allowed( 'capability_update_core' ) ) { $caps[] = 'do_not_allow'; } elseif ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } elseif ( 'upload_themes' === $cap ) { $caps[] = 'install_themes'; } elseif ( 'upload_plugins' === $cap ) { $caps[] = 'install_plugins'; } else { $caps[] = $cap; } break; case 'install_languages': case 'update_languages': if ( ! wp_is_file_mod_allowed( 'can_install_language_pack' ) ) { $caps[] = 'do_not_allow'; } elseif ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'install_languages'; } break; case 'activate_plugins': case 'deactivate_plugins': case 'activate_plugin': case 'deactivate_plugin': $caps[] = 'activate_plugins'; if ( is_multisite() ) { // update_, install_, and delete_ are handled above with is_super_admin(). $menu_perms = get_site_option( 'menu_items', array() ); if ( empty( $menu_perms['plugins'] ) ) { $caps[] = 'manage_network_plugins'; } } break; case 'resume_plugin': $caps[] = 'resume_plugins'; break; case 'resume_theme': $caps[] = 'resume_themes'; break; case 'delete_user': case 'delete_users': // If multisite only super admins can delete users. if ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'delete_users'; // delete_user maps to delete_users. } break; case 'create_users': if ( ! is_multisite() ) { $caps[] = $cap; } elseif ( is_super_admin( $user_id ) || get_site_option( 'add_new_users' ) ) { $caps[] = $cap; } else { $caps[] = 'do_not_allow'; } break; case 'manage_links': if ( get_option( 'link_manager_enabled' ) ) { $caps[] = $cap; } else { $caps[] = 'do_not_allow'; } break; case 'customize': $caps[] = 'edit_theme_options'; break; case 'delete_site': if ( is_multisite() ) { $caps[] = 'manage_options'; } else { $caps[] = 'do_not_allow'; } break; case 'edit_term': case 'delete_term': case 'assign_term': if ( ! isset( $args[0] ) ) { /* translators: %s: Capability name. */ $message = __( 'When checking for the %s capability, you must always check it against a specific term.' ); _doing_it_wrong( __FUNCTION__, sprintf( $message, '<code>' . $cap . '</code>' ), '6.1.0' ); $caps[] = 'do_not_allow'; break; } $term_id = (int) $args[0]; $term = get_term( $term_id ); if ( ! $term || is_wp_error( $term ) ) { $caps[] = 'do_not_allow'; break; } $tax = get_taxonomy( $term->taxonomy ); if ( ! $tax ) { $caps[] = 'do_not_allow'; break; } if ( 'delete_term' === $cap && ( get_option( 'default_' . $term->taxonomy ) == $term->term_id || get_option( 'default_term_' . $term->taxonomy ) == $term->term_id ) ) { $caps[] = 'do_not_allow'; break; } $taxo_cap = $cap . 's'; $caps = map_meta_cap( $tax->cap->$taxo_cap, $user_id, $term_id ); break; case 'manage_post_tags': case 'edit_categories': case 'edit_post_tags': case 'delete_categories': case 'delete_post_tags': $caps[] = 'manage_categories'; break; case 'assign_categories': case 'assign_post_tags': $caps[] = 'edit_posts'; break; case 'create_sites': case 'delete_sites': case 'manage_network': case 'manage_sites': case 'manage_network_users': case 'manage_network_plugins': case 'manage_network_themes': case 'manage_network_options': case 'upgrade_network': $caps[] = $cap; break; case 'setup_network': if ( is_multisite() ) { $caps[] = 'manage_network_options'; } else { $caps[] = 'manage_options'; } break; case 'update_php': if ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'update_core'; } break; case 'update_https': if ( is_multisite() && ! is_super_admin( $user_id ) ) { $caps[] = 'do_not_allow'; } else { $caps[] = 'manage_options'; $caps[] = 'update_core'; } break; case 'export_others_personal_data': case 'erase_others_personal_data': case 'manage_privacy_options': $caps[] = is_multisite() ? 'manage_network' : 'manage_options'; break; case 'create_app_password': case 'list_app_passwords': case 'read_app_password': case 'edit_app_password': case 'delete_app_passwords': case 'delete_app_password': $caps = map_meta_cap( 'edit_user', $user_id, $args[0] ); break; default: // Handle meta capabilities for custom post types. global $post_type_meta_caps; if ( isset( $post_type_meta_caps[ $cap ] ) ) { return map_meta_cap( $post_type_meta_caps[ $cap ], $user_id, ...$args ); } // Block capabilities map to their post equivalent. $block_caps = array( 'edit_blocks', 'edit_others_blocks', 'publish_blocks', 'read_private_blocks', 'delete_blocks', 'delete_private_blocks', 'delete_published_blocks', 'delete_others_blocks', 'edit_private_blocks', 'edit_published_blocks', ); if ( in_array( $cap, $block_caps, true ) ) { $cap = str_replace( '_blocks', '_posts', $cap ); } // If no meta caps match, return the original cap. $caps[] = $cap; } /** * Filters the primitive capabilities required of the given user to satisfy the * capability being checked. * * @since 2.8.0 * * @param string[] $caps Primitive capabilities required of the user. * @param string $cap Capability being checked. * @param int $user_id The user ID. * @param array $args Adds context to the capability check, typically * starting with an object ID. */ return apply_filters( 'map_meta_cap', $caps, $cap, $user_id, $args ); } /** * Returns whether the current user has the specified capability. * * This function also accepts an ID of an object to check against if the capability is a meta capability. Meta * capabilities such as `edit_post` and `edit_user` are capabilities used by the `map_meta_cap()` function to * map to primitive capabilities that a user or role has, such as `edit_posts` and `edit_others_posts`. * * Example usage: * * current_user_can( 'edit_posts' ); * current_user_can( 'edit_post', $post->ID ); * current_user_can( 'edit_post_meta', $post->ID, $meta_key ); * * While checking against particular roles in place of a capability is supported * in part, this practice is discouraged as it may produce unreliable results. * * Note: Will always return true if the current user is a super admin, unless specifically denied. * * @since 2.0.0 * @since 5.3.0 Formalized the existing and already documented `...$args` parameter * by adding it to the function signature. * @since 5.8.0 Converted to wrapper for the user_can() function. * * @see WP_User::has_cap() * @see map_meta_cap() * * @param string $capability Capability name. * @param mixed ...$args Optional further parameters, typically starting with an object ID. * @return bool Whether the current user has the given capability. If `$capability` is a meta cap and `$object_id` is * passed, whether the current user has the given meta capability for the given object. */ function current_user_can( $capability, ...$args ) { return user_can( wp_get_current_user(), $capability, ...$args ); } /** * Returns whether the current user has the specified capability for a given site. * * This function also accepts an ID of an object to check against if the capability is a meta capability. Meta * capabilities such as `edit_post` and `edit_user` are capabilities used by the `map_meta_cap()` function to * map to primitive capabilities that a user or role has, such as `edit_posts` and `edit_others_posts`. * * Example usage: * * current_user_can_for_blog( $blog_id, 'edit_posts' ); * current_user_can_for_blog( $blog_id, 'edit_post', $post->ID ); * current_user_can_for_blog( $blog_id, 'edit_post_meta', $post->ID, $meta_key ); * * @since 3.0.0 * @since 5.3.0 Formalized the existing and already documented `...$args` parameter * by adding it to the function signature. * @since 5.8.0 Wraps current_user_can() after switching to blog. * * @param int $blog_id Site ID. * @param string $capability Capability name. * @param mixed ...$args Optional further parameters, typically starting with an object ID. * @return bool Whether the user has the given capability. */ function current_user_can_for_blog( $blog_id, $capability, ...$args ) { $switched = is_multisite() ? switch_to_blog( $blog_id ) : false; $can = current_user_can( $capability, ...$args ); if ( $switched ) { restore_current_blog(); } return $can; } /** * Returns whether the author of the supplied post has the specified capability. * * This function also accepts an ID of an object to check against if the capability is a meta capability. Meta * capabilities such as `edit_post` and `edit_user` are capabilities used by the `map_meta_cap()` function to * map to primitive capabilities that a user or role has, such as `edit_posts` and `edit_others_posts`. * * Example usage: * * author_can( $post, 'edit_posts' ); * author_can( $post, 'edit_post', $post->ID ); * author_can( $post, 'edit_post_meta', $post->ID, $meta_key ); * * @since 2.9.0 * @since 5.3.0 Formalized the existing and already documented `...$args` parameter * by adding it to the function signature. * * @param int|WP_Post $post Post ID or post object. * @param string $capability Capability name. * @param mixed ...$args Optional further parameters, typically starting with an object ID. * @return bool Whether the post author has the given capability. */ function author_can( $post, $capability, ...$args ) { $post = get_post( $post ); if ( ! $post ) { return false; } $author = get_userdata( $post->post_author ); if ( ! $author ) { return false; } return $author->has_cap( $capability, ...$args ); } /** * Returns whether a particular user has the specified capability. * * This function also accepts an ID of an object to check against if the capability is a meta capability. Meta * capabilities such as `edit_post` and `edit_user` are capabilities used by the `map_meta_cap()` function to * map to primitive capabilities that a user or role has, such as `edit_posts` and `edit_others_posts`. * * Example usage: * * user_can( $user->ID, 'edit_posts' ); * user_can( $user->ID, 'edit_post', $post->ID ); * user_can( $user->ID, 'edit_post_meta', $post->ID, $meta_key ); * * @since 3.1.0 * @since 5.3.0 Formalized the existing and already documented `...$args` parameter * by adding it to the function signature. * * @param int|WP_User $user User ID or object. * @param string $capability Capability name. * @param mixed ...$args Optional further parameters, typically starting with an object ID. * @return bool Whether the user has the given capability. */ function user_can( $user, $capability, ...$args ) { if ( ! is_object( $user ) ) { $user = get_userdata( $user ); } if ( empty( $user ) ) { // User is logged out, create anonymous user object. $user = new WP_User( 0 ); $user->init( new stdClass() ); } return $user->has_cap( $capability, ...$args ); } /** * Retrieves the global WP_Roles instance and instantiates it if necessary. * * @since 4.3.0 * * @global WP_Roles $wp_roles WordPress role management object. * * @return WP_Roles WP_Roles global instance if not already instantiated. */ function wp_roles() { global $wp_roles; if ( ! isset( $wp_roles ) ) { $wp_roles = new WP_Roles(); } return $wp_roles; } /** * Retrieves role object. * * @since 2.0.0 * * @param string $role Role name. * @return WP_Role|null WP_Role object if found, null if the role does not exist. */ function get_role( $role ) { return wp_roles()->get_role( $role ); } /** * Adds a role, if it does not exist. * * @since 2.0.0 * * @param string $role Role name. * @param string $display_name Display name for role. * @param bool[] $capabilities List of capabilities keyed by the capability name, * e.g. array( 'edit_posts' => true, 'delete_posts' => false ). * @return WP_Role|void WP_Role object, if the role is added. */ function add_role( $role, $display_name, $capabilities = array() ) { if ( empty( $role ) ) { return; } return wp_roles()->add_role( $role, $display_name, $capabilities ); } /** * Removes a role, if it exists. * * @since 2.0.0 * * @param string $role Role name. */ function remove_role( $role ) { wp_roles()->remove_role( $role ); } /** * Retrieves a list of super admins. * * @since 3.0.0 * * @global array $super_admins * * @return string[] List of super admin logins. */ function get_super_admins() { global $super_admins; if ( isset( $super_admins ) ) { return $super_admins; } else { return get_site_option( 'site_admins', array( 'admin' ) ); } } /** * Determines whether user is a site admin. * * @since 3.0.0 * * @param int|false $user_id Optional. The ID of a user. Defaults to false, to check the current user. * @return bool Whether the user is a site admin. */ function is_super_admin( $user_id = false ) { if ( ! $user_id ) { $user = wp_get_current_user(); } else { $user = get_userdata( $user_id ); } if ( ! $user || ! $user->exists() ) { return false; } if ( is_multisite() ) { $super_admins = get_super_admins(); if ( is_array( $super_admins ) && in_array( $user->user_login, $super_admins, true ) ) { return true; } } elseif ( $user->has_cap( 'delete_users' ) ) { return true; } return false; } /** * Grants Super Admin privileges. * * @since 3.0.0 * * @global array $super_admins * * @param int $user_id ID of the user to be granted Super Admin privileges. * @return bool True on success, false on failure. This can fail when the user is * already a super admin or when the `$super_admins` global is defined. */ function grant_super_admin( $user_id ) { // If global super_admins override is defined, there is nothing to do here. if ( isset( $GLOBALS['super_admins'] ) || ! is_multisite() ) { return false; } /** * Fires before the user is granted Super Admin privileges. * * @since 3.0.0 * * @param int $user_id ID of the user that is about to be granted Super Admin privileges. */ do_action( 'grant_super_admin', $user_id ); // Directly fetch site_admins instead of using get_super_admins(). $super_admins = get_site_option( 'site_admins', array( 'admin' ) ); $user = get_userdata( $user_id ); if ( $user && ! in_array( $user->user_login, $super_admins, true ) ) { $super_admins[] = $user->user_login; update_site_option( 'site_admins', $super_admins ); /** * Fires after the user is granted Super Admin privileges. * * @since 3.0.0 * * @param int $user_id ID of the user that was granted Super Admin privileges. */ do_action( 'granted_super_admin', $user_id ); return true; } return false; } /** * Revokes Super Admin privileges. * * @since 3.0.0 * * @global array $super_admins * * @param int $user_id ID of the user Super Admin privileges to be revoked from. * @return bool True on success, false on failure. This can fail when the user's email * is the network admin email or when the `$super_admins` global is defined. */ function revoke_super_admin( $user_id ) { // If global super_admins override is defined, there is nothing to do here. if ( isset( $GLOBALS['super_admins'] ) || ! is_multisite() ) { return false; } /** * Fires before the user's Super Admin privileges are revoked. * * @since 3.0.0 * * @param int $user_id ID of the user Super Admin privileges are being revoked from. */ do_action( 'revoke_super_admin', $user_id ); // Directly fetch site_admins instead of using get_super_admins(). $super_admins = get_site_option( 'site_admins', array( 'admin' ) ); $user = get_userdata( $user_id ); if ( $user && 0 !== strcasecmp( $user->user_email, get_site_option( 'admin_email' ) ) ) { $key = array_search( $user->user_login, $super_admins, true ); if ( false !== $key ) { unset( $super_admins[ $key ] ); update_site_option( 'site_admins', $super_admins ); /** * Fires after the user's Super Admin privileges are revoked. * * @since 3.0.0 * * @param int $user_id ID of the user Super Admin privileges were revoked from. */ do_action( 'revoked_super_admin', $user_id ); return true; } } return false; } /** * Filters the user capabilities to grant the 'install_languages' capability as necessary. * * A user must have at least one out of the 'update_core', 'install_plugins', and * 'install_themes' capabilities to qualify for 'install_languages'. * * @since 4.9.0 * * @param bool[] $allcaps An array of all the user's capabilities. * @return bool[] Filtered array of the user's capabilities. */ function wp_maybe_grant_install_languages_cap( $allcaps ) { if ( ! empty( $allcaps['update_core'] ) || ! empty( $allcaps['install_plugins'] ) || ! empty( $allcaps['install_themes'] ) ) { $allcaps['install_languages'] = true; } return $allcaps; } /** * Filters the user capabilities to grant the 'resume_plugins' and 'resume_themes' capabilities as necessary. * * @since 5.2.0 * * @param bool[] $allcaps An array of all the user's capabilities. * @return bool[] Filtered array of the user's capabilities. */ function wp_maybe_grant_resume_extensions_caps( $allcaps ) { // Even in a multisite, regular administrators should be able to resume plugins. if ( ! empty( $allcaps['activate_plugins'] ) ) { $allcaps['resume_plugins'] = true; } // Even in a multisite, regular administrators should be able to resume themes. if ( ! empty( $allcaps['switch_themes'] ) ) { $allcaps['resume_themes'] = true; } return $allcaps; } /** * Filters the user capabilities to grant the 'view_site_health_checks' capabilities as necessary. * * @since 5.2.2 * * @param bool[] $allcaps An array of all the user's capabilities. * @param string[] $caps Required primitive capabilities for the requested capability. * @param array $args { * Arguments that accompany the requested capability check. * * @type string $0 Requested capability. * @type int $1 Concerned user ID. * @type mixed ...$2 Optional second and further parameters, typically object ID. * } * @param WP_User $user The user object. * @return bool[] Filtered array of the user's capabilities. */ function wp_maybe_grant_site_health_caps( $allcaps, $caps, $args, $user ) { if ( ! empty( $allcaps['install_plugins'] ) && ( ! is_multisite() || is_super_admin( $user->ID ) ) ) { $allcaps['view_site_health_checks'] = true; } return $allcaps; } return; // Dummy gettext calls to get strings in the catalog. /* translators: User role for administrators. */ _x( 'Administrator', 'User role' ); /* translators: User role for editors. */ _x( 'Editor', 'User role' ); /* translators: User role for authors. */ _x( 'Author', 'User role' ); /* translators: User role for contributors. */ _x( 'Contributor', 'User role' ); /* translators: User role for subscribers. */ _x( 'Subscriber', 'User role' );
SILENT KILLER Tool