Composer update drupal core and some modules, add fractal block
This commit is contained in:
parent
66fe03a785
commit
ed12973995
@ -29,6 +29,7 @@
|
|||||||
"drupal/entity_clone": "^1.0@beta",
|
"drupal/entity_clone": "^1.0@beta",
|
||||||
"drupal/eu_cookie_compliance": "^1.14",
|
"drupal/eu_cookie_compliance": "^1.14",
|
||||||
"drupal/facets": "^2.0",
|
"drupal/facets": "^2.0",
|
||||||
|
"drupal/facets_block": "^1.4",
|
||||||
"drupal/google_analytics": "^3.1",
|
"drupal/google_analytics": "^3.1",
|
||||||
"drupal/google_cse": "^3.4",
|
"drupal/google_cse": "^3.4",
|
||||||
"drupal/google_tag": "^1.4",
|
"drupal/google_tag": "^1.4",
|
||||||
|
208
frontend/drupal9/composer.lock
generated
208
frontend/drupal9/composer.lock
generated
@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "97bea759d444f1d827a8127bee107798",
|
"content-hash": "563dd71d4bd0fd9272be8b52ba16a604",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "asm89/stack-cors",
|
"name": "asm89/stack-cors",
|
||||||
@ -576,12 +576,8 @@
|
|||||||
"role": "Contributors"
|
"role": "Contributors"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "iamcarrico",
|
"name": "NickDickinsonWilde",
|
||||||
"homepage": "https://www.drupal.org/user/1300542"
|
"homepage": "https://www.drupal.org/user/3094661"
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "mikeytown2",
|
|
||||||
"homepage": "https://www.drupal.org/user/282446"
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "rupl",
|
"name": "rupl",
|
||||||
@ -590,6 +586,10 @@
|
|||||||
{
|
{
|
||||||
"name": "thalles",
|
"name": "thalles",
|
||||||
"homepage": "https://www.drupal.org/user/3589086"
|
"homepage": "https://www.drupal.org/user/3589086"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Wim Leers",
|
||||||
|
"homepage": "https://www.drupal.org/user/99777"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": "Improved aggregation of CSS/JS files to speed up page load times.",
|
"description": "Improved aggregation of CSS/JS files to speed up page load times.",
|
||||||
@ -814,16 +814,16 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/core",
|
"name": "drupal/core",
|
||||||
"version": "9.4.2",
|
"version": "9.4.3",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/drupal/core.git",
|
"url": "https://github.com/drupal/core.git",
|
||||||
"reference": "5a4d6acc99e279f70a914804ff3dd08111707de1"
|
"reference": "7b1a403c093c7abc89ef3df1a6b05bdb19b3ffad"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/drupal/core/zipball/5a4d6acc99e279f70a914804ff3dd08111707de1",
|
"url": "https://api.github.com/repos/drupal/core/zipball/7b1a403c093c7abc89ef3df1a6b05bdb19b3ffad",
|
||||||
"reference": "5a4d6acc99e279f70a914804ff3dd08111707de1",
|
"reference": "7b1a403c093c7abc89ef3df1a6b05bdb19b3ffad",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@ -1066,13 +1066,13 @@
|
|||||||
],
|
],
|
||||||
"description": "Drupal is an open source content management platform powering millions of websites and applications.",
|
"description": "Drupal is an open source content management platform powering millions of websites and applications.",
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/drupal/core/tree/9.4.2"
|
"source": "https://github.com/drupal/core/tree/9.4.3"
|
||||||
},
|
},
|
||||||
"time": "2022-07-07T01:18:39+00:00"
|
"time": "2022-07-20T15:11:38+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/core-composer-scaffold",
|
"name": "drupal/core-composer-scaffold",
|
||||||
"version": "9.4.2",
|
"version": "9.4.3",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/drupal/core-composer-scaffold.git",
|
"url": "https://github.com/drupal/core-composer-scaffold.git",
|
||||||
@ -1116,13 +1116,13 @@
|
|||||||
"drupal"
|
"drupal"
|
||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/drupal/core-composer-scaffold/tree/9.4.2"
|
"source": "https://github.com/drupal/core-composer-scaffold/tree/9.4.3"
|
||||||
},
|
},
|
||||||
"time": "2022-06-19T16:14:23+00:00"
|
"time": "2022-06-19T16:14:23+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/core-project-message",
|
"name": "drupal/core-project-message",
|
||||||
"version": "9.4.2",
|
"version": "9.4.3",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/drupal/core-project-message.git",
|
"url": "https://github.com/drupal/core-project-message.git",
|
||||||
@ -1157,22 +1157,22 @@
|
|||||||
"drupal"
|
"drupal"
|
||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/drupal/core-project-message/tree/9.4.2"
|
"source": "https://github.com/drupal/core-project-message/tree/9.4.3"
|
||||||
},
|
},
|
||||||
"time": "2022-02-24T17:40:53+00:00"
|
"time": "2022-02-24T17:40:53+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/core-recommended",
|
"name": "drupal/core-recommended",
|
||||||
"version": "9.4.2",
|
"version": "9.4.3",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/drupal/core-recommended.git",
|
"url": "https://github.com/drupal/core-recommended.git",
|
||||||
"reference": "c10da85434356b27e2bf0516a7b6f8103b473038"
|
"reference": "ff8662af0a5963a88ea856e9786e17a51f8e640c"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/drupal/core-recommended/zipball/c10da85434356b27e2bf0516a7b6f8103b473038",
|
"url": "https://api.github.com/repos/drupal/core-recommended/zipball/ff8662af0a5963a88ea856e9786e17a51f8e640c",
|
||||||
"reference": "c10da85434356b27e2bf0516a7b6f8103b473038",
|
"reference": "ff8662af0a5963a88ea856e9786e17a51f8e640c",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@ -1181,7 +1181,7 @@
|
|||||||
"doctrine/annotations": "~1.13.2",
|
"doctrine/annotations": "~1.13.2",
|
||||||
"doctrine/lexer": "~1.2.3",
|
"doctrine/lexer": "~1.2.3",
|
||||||
"doctrine/reflection": "~1.2.3",
|
"doctrine/reflection": "~1.2.3",
|
||||||
"drupal/core": "9.4.2",
|
"drupal/core": "9.4.3",
|
||||||
"egulias/email-validator": "~3.2",
|
"egulias/email-validator": "~3.2",
|
||||||
"guzzlehttp/guzzle": "~6.5.8",
|
"guzzlehttp/guzzle": "~6.5.8",
|
||||||
"guzzlehttp/promises": "~1.5.1",
|
"guzzlehttp/promises": "~1.5.1",
|
||||||
@ -1243,9 +1243,9 @@
|
|||||||
],
|
],
|
||||||
"description": "Core and its dependencies with known-compatible minor versions. Require this project INSTEAD OF drupal/core.",
|
"description": "Core and its dependencies with known-compatible minor versions. Require this project INSTEAD OF drupal/core.",
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://github.com/drupal/core-recommended/tree/9.4.2"
|
"source": "https://github.com/drupal/core-recommended/tree/9.4.3"
|
||||||
},
|
},
|
||||||
"time": "2022-07-07T01:18:39+00:00"
|
"time": "2022-07-20T15:11:38+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/ctools",
|
"name": "drupal/ctools",
|
||||||
@ -1602,20 +1602,20 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/facets",
|
"name": "drupal/facets",
|
||||||
"version": "2.0.2",
|
"version": "2.0.5",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.drupalcode.org/project/facets.git",
|
"url": "https://git.drupalcode.org/project/facets.git",
|
||||||
"reference": "2.0.2"
|
"reference": "2.0.5"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://ftp.drupal.org/files/projects/facets-2.0.2.zip",
|
"url": "https://ftp.drupal.org/files/projects/facets-2.0.5.zip",
|
||||||
"reference": "2.0.2",
|
"reference": "2.0.5",
|
||||||
"shasum": "17afc46d3f4e4300e8e69f23b3b01a4935b57104"
|
"shasum": "8be11b5bca088212270603cd3f3e69185022e379"
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"drupal/core": "^9.2 || ^10.0"
|
"drupal/core": "^9.3 || ^10.0"
|
||||||
},
|
},
|
||||||
"conflict": {
|
"conflict": {
|
||||||
"drupal/search_api": "<1.14"
|
"drupal/search_api": "<1.14"
|
||||||
@ -1623,7 +1623,7 @@
|
|||||||
"require-dev": {
|
"require-dev": {
|
||||||
"drupal/jquery_ui_slider": "~1.1",
|
"drupal/jquery_ui_slider": "~1.1",
|
||||||
"drupal/jquery_ui_touch_punch": "~1.0",
|
"drupal/jquery_ui_touch_punch": "~1.0",
|
||||||
"drupal/search_api": "~1.21"
|
"drupal/search_api": "^1.25||1.x-dev"
|
||||||
},
|
},
|
||||||
"suggest": {
|
"suggest": {
|
||||||
"drupal/jquery_ui_slider": "Required for the 'Facets Range Widget' module to work",
|
"drupal/jquery_ui_slider": "Required for the 'Facets Range Widget' module to work",
|
||||||
@ -1632,8 +1632,8 @@
|
|||||||
"type": "drupal-module",
|
"type": "drupal-module",
|
||||||
"extra": {
|
"extra": {
|
||||||
"drupal": {
|
"drupal": {
|
||||||
"version": "2.0.2",
|
"version": "2.0.5",
|
||||||
"datestamp": "1649151557",
|
"datestamp": "1658315614",
|
||||||
"security-coverage": {
|
"security-coverage": {
|
||||||
"status": "covered",
|
"status": "covered",
|
||||||
"message": "Covered by Drupal's security advisory policy"
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
@ -1649,14 +1649,6 @@
|
|||||||
"name": "See all contributors",
|
"name": "See all contributors",
|
||||||
"homepage": "https://www.drupal.org/node/2348769/committers"
|
"homepage": "https://www.drupal.org/node/2348769/committers"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "StryKaizer",
|
|
||||||
"homepage": "https://www.drupal.org/user/462700"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "borisson_",
|
|
||||||
"homepage": "https://www.drupal.org/user/2393360"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "drunken monkey",
|
"name": "drunken monkey",
|
||||||
"homepage": "https://www.drupal.org/user/205582"
|
"homepage": "https://www.drupal.org/user/205582"
|
||||||
@ -1664,6 +1656,14 @@
|
|||||||
{
|
{
|
||||||
"name": "mkalkbrenner",
|
"name": "mkalkbrenner",
|
||||||
"homepage": "https://www.drupal.org/user/124705"
|
"homepage": "https://www.drupal.org/user/124705"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Nick_vh",
|
||||||
|
"homepage": "https://www.drupal.org/user/122682"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "StryKaizer",
|
||||||
|
"homepage": "https://www.drupal.org/user/462700"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": "The Facet module allows site builders to easily create and manage faceted search interfaces.",
|
"description": "The Facet module allows site builders to easily create and manage faceted search interfaces.",
|
||||||
@ -1674,6 +1674,55 @@
|
|||||||
"irc": "irc://irc.freenode.org/drupal-search-api"
|
"irc": "irc://irc.freenode.org/drupal-search-api"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "drupal/facets_block",
|
||||||
|
"version": "1.4.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://git.drupalcode.org/project/facets_block.git",
|
||||||
|
"reference": "8.x-1.04"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://ftp.drupal.org/files/projects/facets_block-8.x-1.04.zip",
|
||||||
|
"reference": "8.x-1.04",
|
||||||
|
"shasum": "b20806b6174f941313182b4bd339ab7d5d1e6cf3"
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"drupal/core": "^8 || ^9",
|
||||||
|
"drupal/facets": "^1.0 || ^2.0"
|
||||||
|
},
|
||||||
|
"type": "drupal-module",
|
||||||
|
"extra": {
|
||||||
|
"drupal": {
|
||||||
|
"version": "8.x-1.04",
|
||||||
|
"datestamp": "1639331249",
|
||||||
|
"security-coverage": {
|
||||||
|
"status": "covered",
|
||||||
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packages.drupal.org/8/downloads",
|
||||||
|
"license": [
|
||||||
|
"GPL-2.0+"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Goran Nikolovski",
|
||||||
|
"homepage": "https://gorannikolovski.com",
|
||||||
|
"email": "goran@gorannikolovski.com",
|
||||||
|
"role": "Developer"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Render Facets in a single block.",
|
||||||
|
"homepage": "https://www.drupal.org/project/facets_block",
|
||||||
|
"support": {
|
||||||
|
"source": "https://git.drupalcode.org/project/facets_block",
|
||||||
|
"issues": "https://www.drupal.org/project/issues/facets_block",
|
||||||
|
"email": "goran@gorannikolovski.com"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/google_analytics",
|
"name": "drupal/google_analytics",
|
||||||
"version": "3.1.0",
|
"version": "3.1.0",
|
||||||
@ -2635,17 +2684,17 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/metatag",
|
"name": "drupal/metatag",
|
||||||
"version": "1.19.0",
|
"version": "1.21.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.drupalcode.org/project/metatag.git",
|
"url": "https://git.drupalcode.org/project/metatag.git",
|
||||||
"reference": "8.x-1.19"
|
"reference": "8.x-1.21"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://ftp.drupal.org/files/projects/metatag-8.x-1.19.zip",
|
"url": "https://ftp.drupal.org/files/projects/metatag-8.x-1.21.zip",
|
||||||
"reference": "8.x-1.19",
|
"reference": "8.x-1.21",
|
||||||
"shasum": "d70f59c034e971885ed4969a11bb392f6ab447ee"
|
"shasum": "677ff7384b557390d4d1a36f335452e8172f741d"
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"drupal/core": "^9",
|
"drupal/core": "^9",
|
||||||
@ -2664,8 +2713,8 @@
|
|||||||
"type": "drupal-module",
|
"type": "drupal-module",
|
||||||
"extra": {
|
"extra": {
|
||||||
"drupal": {
|
"drupal": {
|
||||||
"version": "8.x-1.19",
|
"version": "8.x-1.21",
|
||||||
"datestamp": "1641496014",
|
"datestamp": "1657971667",
|
||||||
"security-coverage": {
|
"security-coverage": {
|
||||||
"status": "covered",
|
"status": "covered",
|
||||||
"message": "Covered by Drupal's security advisory policy"
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
@ -3203,17 +3252,17 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/search_api",
|
"name": "drupal/search_api",
|
||||||
"version": "1.24.0",
|
"version": "1.25.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.drupalcode.org/project/search_api.git",
|
"url": "https://git.drupalcode.org/project/search_api.git",
|
||||||
"reference": "8.x-1.24"
|
"reference": "8.x-1.25"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://ftp.drupal.org/files/projects/search_api-8.x-1.24.zip",
|
"url": "https://ftp.drupal.org/files/projects/search_api-8.x-1.25.zip",
|
||||||
"reference": "8.x-1.24",
|
"reference": "8.x-1.25",
|
||||||
"shasum": "c4e93b8cc5bcdf7c7817bec06470af223f919f6c"
|
"shasum": "823bf5a6010cd08c7d1b287fcd855fbf81140e39"
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"drupal/core": "^9.2 || ^10.0"
|
"drupal/core": "^9.2 || ^10.0"
|
||||||
@ -3234,8 +3283,8 @@
|
|||||||
"type": "drupal-module",
|
"type": "drupal-module",
|
||||||
"extra": {
|
"extra": {
|
||||||
"drupal": {
|
"drupal": {
|
||||||
"version": "8.x-1.24",
|
"version": "8.x-1.25",
|
||||||
"datestamp": "1657180584",
|
"datestamp": "1658149514",
|
||||||
"security-coverage": {
|
"security-coverage": {
|
||||||
"status": "covered",
|
"status": "covered",
|
||||||
"message": "Covered by Drupal's security advisory policy"
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
@ -3275,7 +3324,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/search_api_db",
|
"name": "drupal/search_api_db",
|
||||||
"version": "1.24.0",
|
"version": "1.25.0",
|
||||||
"require": {
|
"require": {
|
||||||
"drupal/core": "^9.2 || ^10.0",
|
"drupal/core": "^9.2 || ^10.0",
|
||||||
"drupal/search_api": "*"
|
"drupal/search_api": "*"
|
||||||
@ -3283,8 +3332,8 @@
|
|||||||
"type": "metapackage",
|
"type": "metapackage",
|
||||||
"extra": {
|
"extra": {
|
||||||
"drupal": {
|
"drupal": {
|
||||||
"version": "8.x-1.24",
|
"version": "8.x-1.25",
|
||||||
"datestamp": "1657180584",
|
"datestamp": "1658149514",
|
||||||
"security-coverage": {
|
"security-coverage": {
|
||||||
"status": "covered",
|
"status": "covered",
|
||||||
"message": "Covered by Drupal's security advisory policy"
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
@ -3296,10 +3345,6 @@
|
|||||||
"GPL-2.0-or-later"
|
"GPL-2.0-or-later"
|
||||||
],
|
],
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
|
||||||
"name": "Nick_vh",
|
|
||||||
"homepage": "https://www.drupal.org/user/122682"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "borisson_",
|
"name": "borisson_",
|
||||||
"homepage": "https://www.drupal.org/user/2393360"
|
"homepage": "https://www.drupal.org/user/2393360"
|
||||||
@ -3307,6 +3352,10 @@
|
|||||||
{
|
{
|
||||||
"name": "drunken monkey",
|
"name": "drunken monkey",
|
||||||
"homepage": "https://www.drupal.org/user/205582"
|
"homepage": "https://www.drupal.org/user/205582"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Nick_vh",
|
||||||
|
"homepage": "https://www.drupal.org/user/122682"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": "Offers an implementation of the Search API that uses database tables for indexing content.",
|
"description": "Offers an implementation of the Search API that uses database tables for indexing content.",
|
||||||
@ -3856,23 +3905,24 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "drupal/xmlsitemap",
|
"name": "drupal/xmlsitemap",
|
||||||
"version": "1.2.0",
|
"version": "1.3.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.drupalcode.org/project/xmlsitemap.git",
|
"url": "https://git.drupalcode.org/project/xmlsitemap.git",
|
||||||
"reference": "8.x-1.2"
|
"reference": "8.x-1.3"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://ftp.drupal.org/files/projects/xmlsitemap-8.x-1.2.zip",
|
"url": "https://ftp.drupal.org/files/projects/xmlsitemap-8.x-1.3.zip",
|
||||||
"reference": "8.x-1.2",
|
"reference": "8.x-1.3",
|
||||||
"shasum": "528736c96ee5f19abbf798d1f8aefb211bf11b5d"
|
"shasum": "a2a20c5aab5682cc369d095cd2e21d67fc46df9b"
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"drupal/core": "^8.8 || ^9",
|
"drupal/core": "^9",
|
||||||
"ext-xmlwriter": "*"
|
"ext-xmlwriter": "*"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
|
"drupal/config_readonly": "^1.0",
|
||||||
"drupal/metatag": "^1.0",
|
"drupal/metatag": "^1.0",
|
||||||
"drupal/robotstxt": "^1.0"
|
"drupal/robotstxt": "^1.0"
|
||||||
},
|
},
|
||||||
@ -3882,8 +3932,8 @@
|
|||||||
"type": "drupal-module",
|
"type": "drupal-module",
|
||||||
"extra": {
|
"extra": {
|
||||||
"drupal": {
|
"drupal": {
|
||||||
"version": "8.x-1.2",
|
"version": "8.x-1.3",
|
||||||
"datestamp": "1638486168",
|
"datestamp": "1658327425",
|
||||||
"security-coverage": {
|
"security-coverage": {
|
||||||
"status": "covered",
|
"status": "covered",
|
||||||
"message": "Covered by Drupal's security advisory policy"
|
"message": "Covered by Drupal's security advisory policy"
|
||||||
@ -3900,14 +3950,6 @@
|
|||||||
"GPL-2.0-or-later"
|
"GPL-2.0-or-later"
|
||||||
],
|
],
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
|
||||||
"name": "Dave Reid",
|
|
||||||
"homepage": "https://www.drupal.org/user/53892"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "RenatoG",
|
|
||||||
"homepage": "https://www.drupal.org/user/3326031"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "amateescu",
|
"name": "amateescu",
|
||||||
"homepage": "https://www.drupal.org/user/729614"
|
"homepage": "https://www.drupal.org/user/729614"
|
||||||
@ -3916,6 +3958,10 @@
|
|||||||
"name": "andrei.dincu",
|
"name": "andrei.dincu",
|
||||||
"homepage": "https://www.drupal.org/user/2628879"
|
"homepage": "https://www.drupal.org/user/2628879"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Dave Reid",
|
||||||
|
"homepage": "https://www.drupal.org/user/53892"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "juampynr",
|
"name": "juampynr",
|
||||||
"homepage": "https://www.drupal.org/user/682736"
|
"homepage": "https://www.drupal.org/user/682736"
|
||||||
@ -3928,6 +3974,10 @@
|
|||||||
"name": "pifagor",
|
"name": "pifagor",
|
||||||
"homepage": "https://www.drupal.org/user/2375692"
|
"homepage": "https://www.drupal.org/user/2375692"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "RenatoG",
|
||||||
|
"homepage": "https://www.drupal.org/user/3326031"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "tadityar",
|
"name": "tadityar",
|
||||||
"homepage": "https://www.drupal.org/user/3094465"
|
"homepage": "https://www.drupal.org/user/3094465"
|
||||||
@ -3937,7 +3987,7 @@
|
|||||||
"homepage": "https://www.drupal.org/user/1835276"
|
"homepage": "https://www.drupal.org/user/1835276"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"description": "Creates XML sitemaps for the site",
|
"description": "Creates XML Sitemaps for the site",
|
||||||
"homepage": "https://www.drupal.org/project/xmlsitemap",
|
"homepage": "https://www.drupal.org/project/xmlsitemap",
|
||||||
"support": {
|
"support": {
|
||||||
"source": "https://git.drupalcode.org/project/xmlsitemap",
|
"source": "https://git.drupalcode.org/project/xmlsitemap",
|
||||||
|
@ -55,9 +55,14 @@ return array(
|
|||||||
'Drupal\\Composer\\Plugin\\Scaffold\\' => array($vendorDir . '/drupal/core-composer-scaffold'),
|
'Drupal\\Composer\\Plugin\\Scaffold\\' => array($vendorDir . '/drupal/core-composer-scaffold'),
|
||||||
'Drupal\\Composer\\Plugin\\ProjectMessage\\' => array($vendorDir . '/drupal/core-project-message'),
|
'Drupal\\Composer\\Plugin\\ProjectMessage\\' => array($vendorDir . '/drupal/core-project-message'),
|
||||||
'Drupal\\Component\\' => array($baseDir . '/web/core/lib/Drupal/Component'),
|
'Drupal\\Component\\' => array($baseDir . '/web/core/lib/Drupal/Component'),
|
||||||
|
'Doctrine\\Persistence\\' => array($vendorDir . '/doctrine/persistence/lib/Doctrine/Persistence'),
|
||||||
|
'Doctrine\\Inflector\\' => array($vendorDir . '/doctrine/inflector/lib/Doctrine/Inflector'),
|
||||||
'Doctrine\\Common\\Lexer\\' => array($vendorDir . '/doctrine/lexer/lib/Doctrine/Common/Lexer'),
|
'Doctrine\\Common\\Lexer\\' => array($vendorDir . '/doctrine/lexer/lib/Doctrine/Common/Lexer'),
|
||||||
|
'Doctrine\\Common\\Inflector\\' => array($vendorDir . '/doctrine/inflector/lib/Doctrine/Common/Inflector'),
|
||||||
|
'Doctrine\\Common\\Collections\\' => array($vendorDir . '/doctrine/collections/lib/Doctrine/Common/Collections'),
|
||||||
|
'Doctrine\\Common\\Cache\\' => array($vendorDir . '/doctrine/cache/lib/Doctrine/Common/Cache'),
|
||||||
'Doctrine\\Common\\Annotations\\' => array($vendorDir . '/doctrine/annotations/lib/Doctrine/Common/Annotations'),
|
'Doctrine\\Common\\Annotations\\' => array($vendorDir . '/doctrine/annotations/lib/Doctrine/Common/Annotations'),
|
||||||
'Doctrine\\Common\\' => array($vendorDir . '/doctrine/reflection/lib/Doctrine/Common'),
|
'Doctrine\\Common\\' => array($vendorDir . '/doctrine/common/lib/Doctrine/Common', $vendorDir . '/doctrine/event-manager/lib/Doctrine/Common', $vendorDir . '/doctrine/persistence/lib/Doctrine/Common', $vendorDir . '/doctrine/reflection/lib/Doctrine/Common'),
|
||||||
'Composer\\Semver\\' => array($vendorDir . '/composer/semver/src'),
|
'Composer\\Semver\\' => array($vendorDir . '/composer/semver/src'),
|
||||||
'Composer\\Installers\\' => array($vendorDir . '/composer/installers/src/Composer/Installers'),
|
'Composer\\Installers\\' => array($vendorDir . '/composer/installers/src/Composer/Installers'),
|
||||||
'Asm89\\Stack\\' => array($vendorDir . '/asm89/stack-cors/src/Asm89/Stack'),
|
'Asm89\\Stack\\' => array($vendorDir . '/asm89/stack-cors/src/Asm89/Stack'),
|
||||||
|
@ -114,7 +114,12 @@ class ComposerStaticInitd428c8960f3d72900807e718545d9f8d
|
|||||||
'Drupal\\Composer\\Plugin\\Scaffold\\' => 32,
|
'Drupal\\Composer\\Plugin\\Scaffold\\' => 32,
|
||||||
'Drupal\\Composer\\Plugin\\ProjectMessage\\' => 38,
|
'Drupal\\Composer\\Plugin\\ProjectMessage\\' => 38,
|
||||||
'Drupal\\Component\\' => 17,
|
'Drupal\\Component\\' => 17,
|
||||||
|
'Doctrine\\Persistence\\' => 21,
|
||||||
|
'Doctrine\\Inflector\\' => 19,
|
||||||
'Doctrine\\Common\\Lexer\\' => 22,
|
'Doctrine\\Common\\Lexer\\' => 22,
|
||||||
|
'Doctrine\\Common\\Inflector\\' => 26,
|
||||||
|
'Doctrine\\Common\\Collections\\' => 28,
|
||||||
|
'Doctrine\\Common\\Cache\\' => 22,
|
||||||
'Doctrine\\Common\\Annotations\\' => 28,
|
'Doctrine\\Common\\Annotations\\' => 28,
|
||||||
'Doctrine\\Common\\' => 16,
|
'Doctrine\\Common\\' => 16,
|
||||||
),
|
),
|
||||||
@ -327,17 +332,40 @@ class ComposerStaticInitd428c8960f3d72900807e718545d9f8d
|
|||||||
array (
|
array (
|
||||||
0 => __DIR__ . '/../..' . '/web/core/lib/Drupal/Component',
|
0 => __DIR__ . '/../..' . '/web/core/lib/Drupal/Component',
|
||||||
),
|
),
|
||||||
|
'Doctrine\\Persistence\\' =>
|
||||||
|
array (
|
||||||
|
0 => __DIR__ . '/..' . '/doctrine/persistence/lib/Doctrine/Persistence',
|
||||||
|
),
|
||||||
|
'Doctrine\\Inflector\\' =>
|
||||||
|
array (
|
||||||
|
0 => __DIR__ . '/..' . '/doctrine/inflector/lib/Doctrine/Inflector',
|
||||||
|
),
|
||||||
'Doctrine\\Common\\Lexer\\' =>
|
'Doctrine\\Common\\Lexer\\' =>
|
||||||
array (
|
array (
|
||||||
0 => __DIR__ . '/..' . '/doctrine/lexer/lib/Doctrine/Common/Lexer',
|
0 => __DIR__ . '/..' . '/doctrine/lexer/lib/Doctrine/Common/Lexer',
|
||||||
),
|
),
|
||||||
|
'Doctrine\\Common\\Inflector\\' =>
|
||||||
|
array (
|
||||||
|
0 => __DIR__ . '/..' . '/doctrine/inflector/lib/Doctrine/Common/Inflector',
|
||||||
|
),
|
||||||
|
'Doctrine\\Common\\Collections\\' =>
|
||||||
|
array (
|
||||||
|
0 => __DIR__ . '/..' . '/doctrine/collections/lib/Doctrine/Common/Collections',
|
||||||
|
),
|
||||||
|
'Doctrine\\Common\\Cache\\' =>
|
||||||
|
array (
|
||||||
|
0 => __DIR__ . '/..' . '/doctrine/cache/lib/Doctrine/Common/Cache',
|
||||||
|
),
|
||||||
'Doctrine\\Common\\Annotations\\' =>
|
'Doctrine\\Common\\Annotations\\' =>
|
||||||
array (
|
array (
|
||||||
0 => __DIR__ . '/..' . '/doctrine/annotations/lib/Doctrine/Common/Annotations',
|
0 => __DIR__ . '/..' . '/doctrine/annotations/lib/Doctrine/Common/Annotations',
|
||||||
),
|
),
|
||||||
'Doctrine\\Common\\' =>
|
'Doctrine\\Common\\' =>
|
||||||
array (
|
array (
|
||||||
0 => __DIR__ . '/..' . '/doctrine/reflection/lib/Doctrine/Common',
|
0 => __DIR__ . '/..' . '/doctrine/common/lib/Doctrine/Common',
|
||||||
|
1 => __DIR__ . '/..' . '/doctrine/event-manager/lib/Doctrine/Common',
|
||||||
|
2 => __DIR__ . '/..' . '/doctrine/persistence/lib/Doctrine/Common',
|
||||||
|
3 => __DIR__ . '/..' . '/doctrine/reflection/lib/Doctrine/Common',
|
||||||
),
|
),
|
||||||
'Composer\\Semver\\' =>
|
'Composer\\Semver\\' =>
|
||||||
array (
|
array (
|
||||||
|
931
frontend/drupal9/vendor/composer/installed.json
vendored
931
frontend/drupal9/vendor/composer/installed.json
vendored
File diff suppressed because it is too large
Load Diff
367
frontend/drupal9/vendor/composer/installed.php
vendored
367
frontend/drupal9/vendor/composer/installed.php
vendored
File diff suppressed because it is too large
Load Diff
19
frontend/drupal9/vendor/doctrine/cache/LICENSE
vendored
Normal file
19
frontend/drupal9/vendor/doctrine/cache/LICENSE
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
Copyright (c) 2006-2015 Doctrine Project
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is furnished to do
|
||||||
|
so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
13
frontend/drupal9/vendor/doctrine/cache/README.md
vendored
Normal file
13
frontend/drupal9/vendor/doctrine/cache/README.md
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# Doctrine Cache
|
||||||
|
|
||||||
|
[](https://github.com/doctrine/cache/actions)
|
||||||
|
[](https://codecov.io/gh/doctrine/cache/branch/1.10.x)
|
||||||
|
|
||||||
|
[](https://packagist.org/packages/doctrine/cache)
|
||||||
|
[](https://packagist.org/packages/doctrine/cache)
|
||||||
|
|
||||||
|
Cache component extracted from the Doctrine Common project. [Documentation](https://www.doctrine-project.org/projects/doctrine-cache/en/current/index.html)
|
||||||
|
|
||||||
|
This library is deprecated and will no longer receive bug fixes from the
|
||||||
|
Doctrine Project. Please use a different cache library, preferably PSR-6 or
|
||||||
|
PSR-16 instead.
|
15
frontend/drupal9/vendor/doctrine/cache/UPGRADE-1.11.md
vendored
Normal file
15
frontend/drupal9/vendor/doctrine/cache/UPGRADE-1.11.md
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
# Upgrade to 1.11
|
||||||
|
|
||||||
|
doctrine/cache will no longer be maintained and all cache implementations have
|
||||||
|
been marked as deprecated. These implementations will be removed in 2.0, which
|
||||||
|
will only contain interfaces to provide a lightweight package for backward
|
||||||
|
compatibility.
|
||||||
|
|
||||||
|
There are two new classes to use in the `Doctrine\Common\Cache\Psr6` namespace:
|
||||||
|
* The `CacheAdapter` class allows using any Doctrine Cache as PSR-6 cache. This
|
||||||
|
is useful to provide a forward compatibility layer in libraries that accept
|
||||||
|
Doctrine cache implementations and switch to PSR-6.
|
||||||
|
* The `DoctrineProvider` class allows using any PSR-6 cache as Doctrine cache.
|
||||||
|
This implementation is designed for libraries that leak the cache and want to
|
||||||
|
switch to allowing PSR-6 implementations. This class is design to be used
|
||||||
|
during the transition phase of sunsetting doctrine/cache support.
|
16
frontend/drupal9/vendor/doctrine/cache/UPGRADE-1.4.md
vendored
Normal file
16
frontend/drupal9/vendor/doctrine/cache/UPGRADE-1.4.md
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
# Upgrade to 1.4
|
||||||
|
|
||||||
|
## Minor BC Break: `Doctrine\Common\Cache\FileCache#$extension` is now `private`.
|
||||||
|
|
||||||
|
If you need to override the value of `Doctrine\Common\Cache\FileCache#$extension`, then use the
|
||||||
|
second parameter of `Doctrine\Common\Cache\FileCache#__construct()` instead of overriding
|
||||||
|
the property in your own implementation.
|
||||||
|
|
||||||
|
## Minor BC Break: file based caches paths changed
|
||||||
|
|
||||||
|
`Doctrine\Common\Cache\FileCache`, `Doctrine\Common\Cache\PhpFileCache` and
|
||||||
|
`Doctrine\Common\Cache\FilesystemCache` are using a different cache paths structure.
|
||||||
|
|
||||||
|
If you rely on warmed up caches for deployments, consider that caches generated
|
||||||
|
with `doctrine/cache` `<1.4` are not compatible with the new directory structure,
|
||||||
|
and will be ignored.
|
56
frontend/drupal9/vendor/doctrine/cache/composer.json
vendored
Normal file
56
frontend/drupal9/vendor/doctrine/cache/composer.json
vendored
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
{
|
||||||
|
"name": "doctrine/cache",
|
||||||
|
"type": "library",
|
||||||
|
"description": "PHP Doctrine Cache library is a popular cache implementation that supports many different drivers such as redis, memcache, apc, mongodb and others.",
|
||||||
|
"keywords": [
|
||||||
|
"php",
|
||||||
|
"cache",
|
||||||
|
"caching",
|
||||||
|
"abstraction",
|
||||||
|
"redis",
|
||||||
|
"memcached",
|
||||||
|
"couchdb",
|
||||||
|
"xcache",
|
||||||
|
"apcu"
|
||||||
|
],
|
||||||
|
"homepage": "https://www.doctrine-project.org/projects/cache.html",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"},
|
||||||
|
{"name": "Roman Borschel", "email": "roman@code-factory.org"},
|
||||||
|
{"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"},
|
||||||
|
{"name": "Jonathan Wage", "email": "jonwage@gmail.com"},
|
||||||
|
{"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": "~7.1 || ^8.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"alcaeus/mongo-php-adapter": "^1.1",
|
||||||
|
"mongodb/mongodb": "^1.1",
|
||||||
|
"phpunit/phpunit": "^7.5 || ^8.5 || ^9.5",
|
||||||
|
"predis/predis": "~1.0",
|
||||||
|
"doctrine/coding-standard": "^9",
|
||||||
|
"psr/cache": "^1.0 || ^2.0 || ^3.0",
|
||||||
|
"cache/integration-tests": "dev-master",
|
||||||
|
"symfony/cache": "^4.4 || ^5.4 || ^6",
|
||||||
|
"symfony/var-exporter": "^4.4 || ^5.4 || ^6"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"alcaeus/mongo-php-adapter": "Required to use legacy MongoDB driver"
|
||||||
|
},
|
||||||
|
"conflict": {
|
||||||
|
"doctrine/common": ">2.2,<2.4"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": { "Doctrine\\Common\\Cache\\": "lib/Doctrine/Common/Cache" }
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": { "Doctrine\\Tests\\": "tests/Doctrine/Tests" }
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"allow-plugins": {
|
||||||
|
"dealerdirect/phpcodesniffer-composer-installer": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcCache.php
vendored
Normal file
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcCache.php
vendored
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function apc_cache_info;
|
||||||
|
use function apc_clear_cache;
|
||||||
|
use function apc_delete;
|
||||||
|
use function apc_exists;
|
||||||
|
use function apc_fetch;
|
||||||
|
use function apc_sma_info;
|
||||||
|
use function apc_store;
|
||||||
|
|
||||||
|
use const PHP_VERSION_ID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* APC cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated since version 1.6, use ApcuCache instead
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class ApcCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return apc_fetch($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return apc_exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return apc_store($id, $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
// apc_delete returns false if the id does not exist
|
||||||
|
return apc_delete($id) || ! apc_exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return apc_clear_cache() && apc_clear_cache('user');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return apc_fetch($keys) ?: [];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$result = apc_store($keysAndValues, null, $lifetime);
|
||||||
|
|
||||||
|
return empty($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$info = apc_cache_info('', true);
|
||||||
|
$sma = apc_sma_info();
|
||||||
|
|
||||||
|
// @TODO - Temporary fix @see https://github.com/krakjoe/apcu/pull/42
|
||||||
|
if (PHP_VERSION_ID >= 50500) {
|
||||||
|
$info['num_hits'] = $info['num_hits'] ?? $info['nhits'];
|
||||||
|
$info['num_misses'] = $info['num_misses'] ?? $info['nmisses'];
|
||||||
|
$info['start_time'] = $info['start_time'] ?? $info['stime'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['num_hits'],
|
||||||
|
Cache::STATS_MISSES => $info['num_misses'],
|
||||||
|
Cache::STATS_UPTIME => $info['start_time'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $info['mem_size'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $sma['avail_mem'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
108
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcuCache.php
vendored
Normal file
108
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcuCache.php
vendored
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function apcu_cache_info;
|
||||||
|
use function apcu_clear_cache;
|
||||||
|
use function apcu_delete;
|
||||||
|
use function apcu_exists;
|
||||||
|
use function apcu_fetch;
|
||||||
|
use function apcu_sma_info;
|
||||||
|
use function apcu_store;
|
||||||
|
use function count;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* APCu cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class ApcuCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return apcu_fetch($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return apcu_exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return apcu_store($id, $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
// apcu_delete returns false if the id does not exist
|
||||||
|
return apcu_delete($id) || ! apcu_exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$result = apcu_delete($keys);
|
||||||
|
|
||||||
|
return $result !== false && count($result) !== count($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return apcu_clear_cache();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return apcu_fetch($keys) ?: [];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$result = apcu_store($keysAndValues, null, $lifetime);
|
||||||
|
|
||||||
|
return empty($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$info = apcu_cache_info(true);
|
||||||
|
$sma = apcu_sma_info();
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['num_hits'],
|
||||||
|
Cache::STATS_MISSES => $info['num_misses'],
|
||||||
|
Cache::STATS_UPTIME => $info['start_time'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $info['mem_size'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $sma['avail_mem'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
115
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ArrayCache.php
vendored
Normal file
115
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ArrayCache.php
vendored
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function time;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Array cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class ArrayCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @psalm-var array<string, array{mixed, int|bool}>> $data each element being a tuple of [$data, $expiration], where the expiration is int|bool */
|
||||||
|
private $data = [];
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $hitsCount = 0;
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $missesCount = 0;
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $upTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->upTime = time();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
if (! $this->doContains($id)) {
|
||||||
|
$this->missesCount += 1;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->hitsCount += 1;
|
||||||
|
|
||||||
|
return $this->data[$id][0];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
if (! isset($this->data[$id])) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$expiration = $this->data[$id][1];
|
||||||
|
|
||||||
|
if ($expiration && $expiration < time()) {
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$this->data[$id] = [$data, $lifeTime ? time() + $lifeTime : false];
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
unset($this->data[$id]);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$this->data = [];
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $this->hitsCount,
|
||||||
|
Cache::STATS_MISSES => $this->missesCount,
|
||||||
|
Cache::STATS_UPTIME => $this->upTime,
|
||||||
|
Cache::STATS_MEMORY_USAGE => null,
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => null,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
90
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Cache.php
vendored
Normal file
90
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Cache.php
vendored
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache drivers.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface Cache
|
||||||
|
{
|
||||||
|
public const STATS_HITS = 'hits';
|
||||||
|
public const STATS_MISSES = 'misses';
|
||||||
|
public const STATS_UPTIME = 'uptime';
|
||||||
|
public const STATS_MEMORY_USAGE = 'memory_usage';
|
||||||
|
public const STATS_MEMORY_AVAILABLE = 'memory_available';
|
||||||
|
/**
|
||||||
|
* Only for backward compatibility (may be removed in next major release)
|
||||||
|
*
|
||||||
|
* @deprecated
|
||||||
|
*/
|
||||||
|
public const STATS_MEMORY_AVAILIABLE = 'memory_available';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetches an entry from the cache.
|
||||||
|
*
|
||||||
|
* @param string $id The id of the cache entry to fetch.
|
||||||
|
*
|
||||||
|
* @return mixed The cached data or FALSE, if no cache entry exists for the given id.
|
||||||
|
*/
|
||||||
|
public function fetch($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests if an entry exists in the cache.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id of the entry to check for.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if a cache entry exists for the given cache id, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function contains($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Puts data into the cache.
|
||||||
|
*
|
||||||
|
* If a cache entry with the given id already exists, its data will be replaced.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id.
|
||||||
|
* @param mixed $data The cache entry/data.
|
||||||
|
* @param int $lifeTime The lifetime in number of seconds for this cache entry.
|
||||||
|
* If zero (the default), the entry never expires (although it may be deleted from the cache
|
||||||
|
* to make place for other entries).
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the entry was successfully stored in the cache, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function save($id, $data, $lifeTime = 0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes a cache entry.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the cache entry was successfully deleted, FALSE otherwise.
|
||||||
|
* Deleting a non-existing entry is considered successful.
|
||||||
|
*/
|
||||||
|
public function delete($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves cached information from the data store.
|
||||||
|
*
|
||||||
|
* The server's statistics array has the following values:
|
||||||
|
*
|
||||||
|
* - <b>hits</b>
|
||||||
|
* Number of keys that have been requested and found present.
|
||||||
|
*
|
||||||
|
* - <b>misses</b>
|
||||||
|
* Number of items that have been requested and not found.
|
||||||
|
*
|
||||||
|
* - <b>uptime</b>
|
||||||
|
* Time that the server is running.
|
||||||
|
*
|
||||||
|
* - <b>memory_usage</b>
|
||||||
|
* Memory used by this server to store items.
|
||||||
|
*
|
||||||
|
* - <b>memory_available</b>
|
||||||
|
* Memory allowed to use for storage.
|
||||||
|
*
|
||||||
|
* @return mixed[]|null An associative array with server's statistics if available, NULL otherwise.
|
||||||
|
*/
|
||||||
|
public function getStats();
|
||||||
|
}
|
325
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php
vendored
Normal file
325
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php
vendored
Normal file
@ -0,0 +1,325 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function array_combine;
|
||||||
|
use function array_key_exists;
|
||||||
|
use function array_map;
|
||||||
|
use function sprintf;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for cache provider implementations.
|
||||||
|
*/
|
||||||
|
abstract class CacheProvider implements Cache, FlushableCache, ClearableCache, MultiOperationCache
|
||||||
|
{
|
||||||
|
public const DOCTRINE_NAMESPACE_CACHEKEY = 'DoctrineNamespaceCacheKey[%s]';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The namespace to prefix all cache ids with.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $namespace = '';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The namespace version.
|
||||||
|
*
|
||||||
|
* @var int|null
|
||||||
|
*/
|
||||||
|
private $namespaceVersion;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the namespace to prefix all cache ids with.
|
||||||
|
*
|
||||||
|
* @param string $namespace
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setNamespace($namespace)
|
||||||
|
{
|
||||||
|
$this->namespace = (string) $namespace;
|
||||||
|
$this->namespaceVersion = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the namespace that prefixes all cache ids.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getNamespace()
|
||||||
|
{
|
||||||
|
return $this->namespace;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function fetch($id)
|
||||||
|
{
|
||||||
|
return $this->doFetch($this->getNamespacedId($id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function fetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
if (empty($keys)) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
// note: the array_combine() is in place to keep an association between our $keys and the $namespacedKeys
|
||||||
|
$namespacedKeys = array_combine($keys, array_map([$this, 'getNamespacedId'], $keys));
|
||||||
|
$items = $this->doFetchMultiple($namespacedKeys);
|
||||||
|
$foundItems = [];
|
||||||
|
|
||||||
|
// no internal array function supports this sort of mapping: needs to be iterative
|
||||||
|
// this filters and combines keys in one pass
|
||||||
|
foreach ($namespacedKeys as $requestedKey => $namespacedKey) {
|
||||||
|
if (! isset($items[$namespacedKey]) && ! array_key_exists($namespacedKey, $items)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$foundItems[$requestedKey] = $items[$namespacedKey];
|
||||||
|
}
|
||||||
|
|
||||||
|
return $foundItems;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function saveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$namespacedKeysAndValues = [];
|
||||||
|
foreach ($keysAndValues as $key => $value) {
|
||||||
|
$namespacedKeysAndValues[$this->getNamespacedId($key)] = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->doSaveMultiple($namespacedKeysAndValues, $lifetime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function contains($id)
|
||||||
|
{
|
||||||
|
return $this->doContains($this->getNamespacedId($id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function save($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return $this->doSave($this->getNamespacedId($id), $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function deleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return $this->doDeleteMultiple(array_map([$this, 'getNamespacedId'], $keys));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function delete($id)
|
||||||
|
{
|
||||||
|
return $this->doDelete($this->getNamespacedId($id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function getStats()
|
||||||
|
{
|
||||||
|
return $this->doGetStats();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function flushAll()
|
||||||
|
{
|
||||||
|
return $this->doFlush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function deleteAll()
|
||||||
|
{
|
||||||
|
$namespaceCacheKey = $this->getNamespaceCacheKey();
|
||||||
|
$namespaceVersion = $this->getNamespaceVersion() + 1;
|
||||||
|
|
||||||
|
if ($this->doSave($namespaceCacheKey, $namespaceVersion)) {
|
||||||
|
$this->namespaceVersion = $namespaceVersion;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prefixes the passed id with the configured namespace value.
|
||||||
|
*
|
||||||
|
* @param string $id The id to namespace.
|
||||||
|
*
|
||||||
|
* @return string The namespaced id.
|
||||||
|
*/
|
||||||
|
private function getNamespacedId(string $id): string
|
||||||
|
{
|
||||||
|
$namespaceVersion = $this->getNamespaceVersion();
|
||||||
|
|
||||||
|
return sprintf('%s[%s][%s]', $this->namespace, $id, $namespaceVersion);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the namespace cache key.
|
||||||
|
*/
|
||||||
|
private function getNamespaceCacheKey(): string
|
||||||
|
{
|
||||||
|
return sprintf(self::DOCTRINE_NAMESPACE_CACHEKEY, $this->namespace);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the namespace version.
|
||||||
|
*/
|
||||||
|
private function getNamespaceVersion(): int
|
||||||
|
{
|
||||||
|
if ($this->namespaceVersion !== null) {
|
||||||
|
return $this->namespaceVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
$namespaceCacheKey = $this->getNamespaceCacheKey();
|
||||||
|
$this->namespaceVersion = (int) $this->doFetch($namespaceCacheKey) ?: 1;
|
||||||
|
|
||||||
|
return $this->namespaceVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default implementation of doFetchMultiple. Each driver that supports multi-get should owerwrite it.
|
||||||
|
*
|
||||||
|
* @param string[] $keys Array of keys to retrieve from cache
|
||||||
|
*
|
||||||
|
* @return mixed[] Array of values retrieved for the given keys.
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$returnValues = [];
|
||||||
|
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
$item = $this->doFetch($key);
|
||||||
|
if ($item === false && ! $this->doContains($key)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$returnValues[$key] = $item;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $returnValues;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetches an entry from the cache.
|
||||||
|
*
|
||||||
|
* @param string $id The id of the cache entry to fetch.
|
||||||
|
*
|
||||||
|
* @return mixed|false The cached data or FALSE, if no cache entry exists for the given id.
|
||||||
|
*/
|
||||||
|
abstract protected function doFetch($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests if an entry exists in the cache.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id of the entry to check for.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if a cache entry exists for the given cache id, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
abstract protected function doContains($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default implementation of doSaveMultiple. Each driver that supports multi-put should override it.
|
||||||
|
*
|
||||||
|
* @param mixed[] $keysAndValues Array of keys and values to save in cache
|
||||||
|
* @param int $lifetime The lifetime. If != 0, sets a specific lifetime for these
|
||||||
|
* cache entries (0 => infinite lifeTime).
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the operation was successful, FALSE if it wasn't.
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$success = true;
|
||||||
|
|
||||||
|
foreach ($keysAndValues as $key => $value) {
|
||||||
|
if ($this->doSave($key, $value, $lifetime)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Puts data into the cache.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id.
|
||||||
|
* @param string $data The cache entry/data.
|
||||||
|
* @param int $lifeTime The lifetime. If != 0, sets a specific lifetime for this
|
||||||
|
* cache entry (0 => infinite lifeTime).
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the entry was successfully stored in the cache, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
abstract protected function doSave($id, $data, $lifeTime = 0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default implementation of doDeleteMultiple. Each driver that supports multi-delete should override it.
|
||||||
|
*
|
||||||
|
* @param string[] $keys Array of keys to delete from cache
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the operation was successful, FALSE if it wasn't
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$success = true;
|
||||||
|
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
if ($this->doDelete($key)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes a cache entry.
|
||||||
|
*
|
||||||
|
* @param string $id The cache id.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the cache entry was successfully deleted, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
abstract protected function doDelete($id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flushes all cache entries.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the cache entries were successfully flushed, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
abstract protected function doFlush();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves cached information from the data store.
|
||||||
|
*
|
||||||
|
* @return mixed[]|null An associative array with server's statistics if available, NULL otherwise.
|
||||||
|
*/
|
||||||
|
abstract protected function doGetStats();
|
||||||
|
}
|
198
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ChainCache.php
vendored
Normal file
198
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ChainCache.php
vendored
Normal file
@ -0,0 +1,198 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Traversable;
|
||||||
|
|
||||||
|
use function array_values;
|
||||||
|
use function count;
|
||||||
|
use function iterator_to_array;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cache provider that allows to easily chain multiple cache providers
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class ChainCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var CacheProvider[] */
|
||||||
|
private $cacheProviders = [];
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $defaultLifeTimeForDownstreamCacheProviders = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param CacheProvider[] $cacheProviders
|
||||||
|
*/
|
||||||
|
public function __construct($cacheProviders = [])
|
||||||
|
{
|
||||||
|
$this->cacheProviders = $cacheProviders instanceof Traversable
|
||||||
|
? iterator_to_array($cacheProviders, false)
|
||||||
|
: array_values($cacheProviders);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setDefaultLifeTimeForDownstreamCacheProviders(int $defaultLifeTimeForDownstreamCacheProviders): void
|
||||||
|
{
|
||||||
|
$this->defaultLifeTimeForDownstreamCacheProviders = $defaultLifeTimeForDownstreamCacheProviders;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function setNamespace($namespace)
|
||||||
|
{
|
||||||
|
parent::setNamespace($namespace);
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$cacheProvider->setNamespace($namespace);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
foreach ($this->cacheProviders as $key => $cacheProvider) {
|
||||||
|
if ($cacheProvider->doContains($id)) {
|
||||||
|
$value = $cacheProvider->doFetch($id);
|
||||||
|
|
||||||
|
// We populate all the previous cache layers (that are assumed to be faster)
|
||||||
|
for ($subKey = $key - 1; $subKey >= 0; $subKey--) {
|
||||||
|
$this->cacheProviders[$subKey]->doSave($id, $value, $this->defaultLifeTimeForDownstreamCacheProviders);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
/** @var CacheProvider[] $traversedProviders */
|
||||||
|
$traversedProviders = [];
|
||||||
|
$keysCount = count($keys);
|
||||||
|
$fetchedValues = [];
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $key => $cacheProvider) {
|
||||||
|
$fetchedValues = $cacheProvider->doFetchMultiple($keys);
|
||||||
|
|
||||||
|
// We populate all the previous cache layers (that are assumed to be faster)
|
||||||
|
if (count($fetchedValues) === $keysCount) {
|
||||||
|
foreach ($traversedProviders as $previousCacheProvider) {
|
||||||
|
$previousCacheProvider->doSaveMultiple($fetchedValues, $this->defaultLifeTimeForDownstreamCacheProviders);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $fetchedValues;
|
||||||
|
}
|
||||||
|
|
||||||
|
$traversedProviders[] = $cacheProvider;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $fetchedValues;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
if ($cacheProvider->doContains($id)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$stored = true;
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$stored = $cacheProvider->doSave($id, $data, $lifeTime) && $stored;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $stored;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$stored = true;
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$stored = $cacheProvider->doSaveMultiple($keysAndValues, $lifetime) && $stored;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $stored;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
$deleted = true;
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$deleted = $cacheProvider->doDelete($id) && $deleted;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $deleted;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$deleted = true;
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$deleted = $cacheProvider->doDeleteMultiple($keys) && $deleted;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $deleted;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$flushed = true;
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$flushed = $cacheProvider->doFlush() && $flushed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $flushed;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
// We return all the stats from all adapters
|
||||||
|
$stats = [];
|
||||||
|
|
||||||
|
foreach ($this->cacheProviders as $cacheProvider) {
|
||||||
|
$stats[] = $cacheProvider->doGetStats();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $stats;
|
||||||
|
}
|
||||||
|
}
|
21
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ClearableCache.php
vendored
Normal file
21
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ClearableCache.php
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache that can be flushed.
|
||||||
|
*
|
||||||
|
* Intended to be used for partial clearing of a cache namespace. For a more
|
||||||
|
* global "flushing", see {@see FlushableCache}.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface ClearableCache
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Deletes all cache entries in the current cache namespace.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the cache entries were successfully deleted, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function deleteAll();
|
||||||
|
}
|
200
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseBucketCache.php
vendored
Normal file
200
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseBucketCache.php
vendored
Normal file
@ -0,0 +1,200 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Couchbase\Bucket;
|
||||||
|
use Couchbase\Document;
|
||||||
|
use Couchbase\Exception;
|
||||||
|
use RuntimeException;
|
||||||
|
|
||||||
|
use function phpversion;
|
||||||
|
use function serialize;
|
||||||
|
use function sprintf;
|
||||||
|
use function substr;
|
||||||
|
use function time;
|
||||||
|
use function unserialize;
|
||||||
|
use function version_compare;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Couchbase ^2.3.0 cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
final class CouchbaseBucketCache extends CacheProvider
|
||||||
|
{
|
||||||
|
private const MINIMUM_VERSION = '2.3.0';
|
||||||
|
|
||||||
|
private const KEY_NOT_FOUND = 13;
|
||||||
|
|
||||||
|
private const MAX_KEY_LENGTH = 250;
|
||||||
|
|
||||||
|
private const THIRTY_DAYS_IN_SECONDS = 2592000;
|
||||||
|
|
||||||
|
/** @var Bucket */
|
||||||
|
private $bucket;
|
||||||
|
|
||||||
|
public function __construct(Bucket $bucket)
|
||||||
|
{
|
||||||
|
if (version_compare(phpversion('couchbase'), self::MINIMUM_VERSION) < 0) {
|
||||||
|
// Manager is required to flush cache and pull stats.
|
||||||
|
throw new RuntimeException(sprintf('ext-couchbase:^%s is required.', self::MINIMUM_VERSION));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->bucket = $bucket;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$id = $this->normalizeKey($id);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$document = $this->bucket->get($id);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($document instanceof Document && $document->value !== false) {
|
||||||
|
return unserialize($document->value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$id = $this->normalizeKey($id);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$document = $this->bucket->get($id);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($document instanceof Document) {
|
||||||
|
return ! $document->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$id = $this->normalizeKey($id);
|
||||||
|
|
||||||
|
$lifeTime = $this->normalizeExpiry($lifeTime);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$encoded = serialize($data);
|
||||||
|
|
||||||
|
$document = $this->bucket->upsert($id, $encoded, [
|
||||||
|
'expiry' => (int) $lifeTime,
|
||||||
|
]);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($document instanceof Document) {
|
||||||
|
return ! $document->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
$id = $this->normalizeKey($id);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$document = $this->bucket->remove($id);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return $e->getCode() === self::KEY_NOT_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($document instanceof Document) {
|
||||||
|
return ! $document->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$manager = $this->bucket->manager();
|
||||||
|
|
||||||
|
// Flush does not return with success or failure, and must be enabled per bucket on the server.
|
||||||
|
// Store a marker item so that we will know if it was successful.
|
||||||
|
$this->doSave(__METHOD__, true, 60);
|
||||||
|
|
||||||
|
$manager->flush();
|
||||||
|
|
||||||
|
if ($this->doContains(__METHOD__)) {
|
||||||
|
$this->doDelete(__METHOD__);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$manager = $this->bucket->manager();
|
||||||
|
$stats = $manager->info();
|
||||||
|
$nodes = $stats['nodes'];
|
||||||
|
$node = $nodes[0];
|
||||||
|
$interestingStats = $node['interestingStats'];
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $interestingStats['get_hits'],
|
||||||
|
Cache::STATS_MISSES => $interestingStats['cmd_get'] - $interestingStats['get_hits'],
|
||||||
|
Cache::STATS_UPTIME => $node['uptime'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $interestingStats['mem_used'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $node['memoryFree'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
private function normalizeKey(string $id): string
|
||||||
|
{
|
||||||
|
$normalized = substr($id, 0, self::MAX_KEY_LENGTH);
|
||||||
|
|
||||||
|
if ($normalized === false) {
|
||||||
|
return $id;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $normalized;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expiry treated as a unix timestamp instead of an offset if expiry is greater than 30 days.
|
||||||
|
*
|
||||||
|
* @src https://developer.couchbase.com/documentation/server/4.1/developer-guide/expiry.html
|
||||||
|
*/
|
||||||
|
private function normalizeExpiry(int $expiry): int
|
||||||
|
{
|
||||||
|
if ($expiry > self::THIRTY_DAYS_IN_SECONDS) {
|
||||||
|
return time() + $expiry;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $expiry;
|
||||||
|
}
|
||||||
|
}
|
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseCache.php
vendored
Normal file
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseCache.php
vendored
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Couchbase;
|
||||||
|
|
||||||
|
use function explode;
|
||||||
|
use function time;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Couchbase cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Couchbase SDK 1.x is now deprecated. Use \Doctrine\Common\Cache\CouchbaseBucketCache instead.
|
||||||
|
* https://developer.couchbase.com/documentation/server/current/sdk/php/compatibility-versions-features.html
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class CouchbaseCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var Couchbase|null */
|
||||||
|
private $couchbase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the Couchbase instance to use.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setCouchbase(Couchbase $couchbase)
|
||||||
|
{
|
||||||
|
$this->couchbase = $couchbase;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the Couchbase instance used by the cache.
|
||||||
|
*
|
||||||
|
* @return Couchbase|null
|
||||||
|
*/
|
||||||
|
public function getCouchbase()
|
||||||
|
{
|
||||||
|
return $this->couchbase;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->couchbase->get($id) ?: false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return $this->couchbase->get($id) !== null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
if ($lifeTime > 30 * 24 * 3600) {
|
||||||
|
$lifeTime = time() + $lifeTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->couchbase->set($id, $data, (int) $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->couchbase->delete($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->couchbase->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$stats = $this->couchbase->getStats();
|
||||||
|
$servers = $this->couchbase->getServers();
|
||||||
|
$server = explode(':', $servers[0]);
|
||||||
|
$key = $server[0] . ':11210';
|
||||||
|
$stats = $stats[$key];
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $stats['get_hits'],
|
||||||
|
Cache::STATS_MISSES => $stats['get_misses'],
|
||||||
|
Cache::STATS_UPTIME => $stats['uptime'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $stats['bytes'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
199
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ExtMongoDBCache.php
vendored
Normal file
199
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ExtMongoDBCache.php
vendored
Normal file
@ -0,0 +1,199 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use DateTime;
|
||||||
|
use MongoDB\BSON\Binary;
|
||||||
|
use MongoDB\BSON\UTCDateTime;
|
||||||
|
use MongoDB\Collection;
|
||||||
|
use MongoDB\Database;
|
||||||
|
use MongoDB\Driver\Exception\Exception;
|
||||||
|
use MongoDB\Model\BSONDocument;
|
||||||
|
|
||||||
|
use function serialize;
|
||||||
|
use function time;
|
||||||
|
use function unserialize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MongoDB cache provider for ext-mongodb
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class ExtMongoDBCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var Database */
|
||||||
|
private $database;
|
||||||
|
|
||||||
|
/** @var Collection */
|
||||||
|
private $collection;
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
|
private $expirationIndexCreated = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This provider will default to the write concern and read preference
|
||||||
|
* options set on the Database instance (or inherited from MongoDB or
|
||||||
|
* Client). Using an unacknowledged write concern (< 1) may make the return
|
||||||
|
* values of delete() and save() unreliable. Reading from secondaries may
|
||||||
|
* make contain() and fetch() unreliable.
|
||||||
|
*
|
||||||
|
* @see http://www.php.net/manual/en/mongo.readpreferences.php
|
||||||
|
* @see http://www.php.net/manual/en/mongo.writeconcerns.php
|
||||||
|
*/
|
||||||
|
public function __construct(Collection $collection)
|
||||||
|
{
|
||||||
|
// Ensure there is no typemap set - we want to use our own
|
||||||
|
$this->collection = $collection->withOptions(['typeMap' => null]);
|
||||||
|
$this->database = new Database($collection->getManager(), $collection->getDatabaseName());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$document = $this->collection->findOne(['_id' => $id], [MongoDBCache::DATA_FIELD, MongoDBCache::EXPIRATION_FIELD]);
|
||||||
|
|
||||||
|
if ($document === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->isExpired($document)) {
|
||||||
|
$this->createExpirationIndex();
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return unserialize($document[MongoDBCache::DATA_FIELD]->getData());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$document = $this->collection->findOne(['_id' => $id], [MongoDBCache::EXPIRATION_FIELD]);
|
||||||
|
|
||||||
|
if ($document === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->isExpired($document)) {
|
||||||
|
$this->createExpirationIndex();
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this->collection->updateOne(
|
||||||
|
['_id' => $id],
|
||||||
|
[
|
||||||
|
'$set' => [
|
||||||
|
MongoDBCache::EXPIRATION_FIELD => ($lifeTime > 0 ? new UTCDateTime((time() + $lifeTime) * 1000) : null),
|
||||||
|
MongoDBCache::DATA_FIELD => new Binary(serialize($data), Binary::TYPE_GENERIC),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
['upsert' => true]
|
||||||
|
);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$this->collection->deleteOne(['_id' => $id]);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// Use remove() in lieu of drop() to maintain any collection indexes
|
||||||
|
$this->collection->deleteMany([]);
|
||||||
|
} catch (Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$uptime = null;
|
||||||
|
$memoryUsage = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
$serverStatus = $this->database->command([
|
||||||
|
'serverStatus' => 1,
|
||||||
|
'locks' => 0,
|
||||||
|
'metrics' => 0,
|
||||||
|
'recordStats' => 0,
|
||||||
|
'repl' => 0,
|
||||||
|
])->toArray()[0];
|
||||||
|
$uptime = $serverStatus['uptime'] ?? null;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$collStats = $this->database->command(['collStats' => $this->collection->getCollectionName()])->toArray()[0];
|
||||||
|
$memoryUsage = $collStats['size'] ?? null;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => null,
|
||||||
|
Cache::STATS_MISSES => null,
|
||||||
|
Cache::STATS_UPTIME => $uptime,
|
||||||
|
Cache::STATS_MEMORY_USAGE => $memoryUsage,
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => null,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the document is expired.
|
||||||
|
*/
|
||||||
|
private function isExpired(BSONDocument $document): bool
|
||||||
|
{
|
||||||
|
return isset($document[MongoDBCache::EXPIRATION_FIELD]) &&
|
||||||
|
$document[MongoDBCache::EXPIRATION_FIELD] instanceof UTCDateTime &&
|
||||||
|
$document[MongoDBCache::EXPIRATION_FIELD]->toDateTime() < new DateTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createExpirationIndex(): void
|
||||||
|
{
|
||||||
|
if ($this->expirationIndexCreated) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->collection->createIndex([MongoDBCache::EXPIRATION_FIELD => 1], ['background' => true, 'expireAfterSeconds' => 0]);
|
||||||
|
}
|
||||||
|
}
|
292
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FileCache.php
vendored
Normal file
292
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FileCache.php
vendored
Normal file
@ -0,0 +1,292 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use FilesystemIterator;
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use Iterator;
|
||||||
|
use RecursiveDirectoryIterator;
|
||||||
|
use RecursiveIteratorIterator;
|
||||||
|
use SplFileInfo;
|
||||||
|
|
||||||
|
use function bin2hex;
|
||||||
|
use function chmod;
|
||||||
|
use function defined;
|
||||||
|
use function disk_free_space;
|
||||||
|
use function file_exists;
|
||||||
|
use function file_put_contents;
|
||||||
|
use function gettype;
|
||||||
|
use function hash;
|
||||||
|
use function is_dir;
|
||||||
|
use function is_int;
|
||||||
|
use function is_writable;
|
||||||
|
use function mkdir;
|
||||||
|
use function pathinfo;
|
||||||
|
use function realpath;
|
||||||
|
use function rename;
|
||||||
|
use function rmdir;
|
||||||
|
use function sprintf;
|
||||||
|
use function strlen;
|
||||||
|
use function strrpos;
|
||||||
|
use function substr;
|
||||||
|
use function tempnam;
|
||||||
|
use function unlink;
|
||||||
|
|
||||||
|
use const DIRECTORY_SEPARATOR;
|
||||||
|
use const PATHINFO_DIRNAME;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base file cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
abstract class FileCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The cache directory.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $directory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The cache file extension.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $extension;
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $umask;
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $directoryStringLength;
|
||||||
|
|
||||||
|
/** @var int */
|
||||||
|
private $extensionStringLength;
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
|
private $isRunningOnWindows;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $directory The cache directory.
|
||||||
|
* @param string $extension The cache file extension.
|
||||||
|
* @param int $umask
|
||||||
|
*
|
||||||
|
* @throws InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public function __construct($directory, $extension = '', $umask = 0002)
|
||||||
|
{
|
||||||
|
// YES, this needs to be *before* createPathIfNeeded()
|
||||||
|
if (! is_int($umask)) {
|
||||||
|
throw new InvalidArgumentException(sprintf(
|
||||||
|
'The umask parameter is required to be integer, was: %s',
|
||||||
|
gettype($umask)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->umask = $umask;
|
||||||
|
|
||||||
|
if (! $this->createPathIfNeeded($directory)) {
|
||||||
|
throw new InvalidArgumentException(sprintf(
|
||||||
|
'The directory "%s" does not exist and could not be created.',
|
||||||
|
$directory
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! is_writable($directory)) {
|
||||||
|
throw new InvalidArgumentException(sprintf(
|
||||||
|
'The directory "%s" is not writable.',
|
||||||
|
$directory
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
// YES, this needs to be *after* createPathIfNeeded()
|
||||||
|
$this->directory = realpath($directory);
|
||||||
|
$this->extension = (string) $extension;
|
||||||
|
|
||||||
|
$this->directoryStringLength = strlen($this->directory);
|
||||||
|
$this->extensionStringLength = strlen($this->extension);
|
||||||
|
$this->isRunningOnWindows = defined('PHP_WINDOWS_VERSION_BUILD');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the cache directory.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getDirectory()
|
||||||
|
{
|
||||||
|
return $this->directory;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the cache file extension.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getExtension()
|
||||||
|
{
|
||||||
|
return $this->extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $id
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getFilename($id)
|
||||||
|
{
|
||||||
|
$hash = hash('sha256', $id);
|
||||||
|
|
||||||
|
// This ensures that the filename is unique and that there are no invalid chars in it.
|
||||||
|
if (
|
||||||
|
$id === ''
|
||||||
|
|| ((strlen($id) * 2 + $this->extensionStringLength) > 255)
|
||||||
|
|| ($this->isRunningOnWindows && ($this->directoryStringLength + 4 + strlen($id) * 2 + $this->extensionStringLength) > 258)
|
||||||
|
) {
|
||||||
|
// Most filesystems have a limit of 255 chars for each path component. On Windows the the whole path is limited
|
||||||
|
// to 260 chars (including terminating null char). Using long UNC ("\\?\" prefix) does not work with the PHP API.
|
||||||
|
// And there is a bug in PHP (https://bugs.php.net/bug.php?id=70943) with path lengths of 259.
|
||||||
|
// So if the id in hex representation would surpass the limit, we use the hash instead. The prefix prevents
|
||||||
|
// collisions between the hash and bin2hex.
|
||||||
|
$filename = '_' . $hash;
|
||||||
|
} else {
|
||||||
|
$filename = bin2hex($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->directory
|
||||||
|
. DIRECTORY_SEPARATOR
|
||||||
|
. substr($hash, 0, 2)
|
||||||
|
. DIRECTORY_SEPARATOR
|
||||||
|
. $filename
|
||||||
|
. $this->extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
$filename = $this->getFilename($id);
|
||||||
|
|
||||||
|
return @unlink($filename) || ! file_exists($filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
foreach ($this->getIterator() as $name => $file) {
|
||||||
|
if ($file->isDir()) {
|
||||||
|
// Remove the intermediate directories which have been created to balance the tree. It only takes effect
|
||||||
|
// if the directory is empty. If several caches share the same directory but with different file extensions,
|
||||||
|
// the other ones are not removed.
|
||||||
|
@rmdir($name);
|
||||||
|
} elseif ($this->isFilenameEndingWithExtension($name)) {
|
||||||
|
// If an extension is set, only remove files which end with the given extension.
|
||||||
|
// If no extension is set, we have no other choice than removing everything.
|
||||||
|
@unlink($name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$usage = 0;
|
||||||
|
foreach ($this->getIterator() as $name => $file) {
|
||||||
|
if ($file->isDir() || ! $this->isFilenameEndingWithExtension($name)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$usage += $file->getSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
$free = disk_free_space($this->directory);
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => null,
|
||||||
|
Cache::STATS_MISSES => null,
|
||||||
|
Cache::STATS_UPTIME => null,
|
||||||
|
Cache::STATS_MEMORY_USAGE => $usage,
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $free,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create path if needed.
|
||||||
|
*
|
||||||
|
* @return bool TRUE on success or if path already exists, FALSE if path cannot be created.
|
||||||
|
*/
|
||||||
|
private function createPathIfNeeded(string $path): bool
|
||||||
|
{
|
||||||
|
if (! is_dir($path)) {
|
||||||
|
if (@mkdir($path, 0777 & (~$this->umask), true) === false && ! is_dir($path)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a string content to file in an atomic way.
|
||||||
|
*
|
||||||
|
* @param string $filename Path to the file where to write the data.
|
||||||
|
* @param string $content The content to write
|
||||||
|
*
|
||||||
|
* @return bool TRUE on success, FALSE if path cannot be created, if path is not writable or an any other error.
|
||||||
|
*/
|
||||||
|
protected function writeFile(string $filename, string $content): bool
|
||||||
|
{
|
||||||
|
$filepath = pathinfo($filename, PATHINFO_DIRNAME);
|
||||||
|
|
||||||
|
if (! $this->createPathIfNeeded($filepath)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! is_writable($filepath)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$tmpFile = tempnam($filepath, 'swap');
|
||||||
|
@chmod($tmpFile, 0666 & (~$this->umask));
|
||||||
|
|
||||||
|
if (file_put_contents($tmpFile, $content) !== false) {
|
||||||
|
@chmod($tmpFile, 0666 & (~$this->umask));
|
||||||
|
if (@rename($tmpFile, $filename)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@unlink($tmpFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Iterator<string, SplFileInfo>
|
||||||
|
*/
|
||||||
|
private function getIterator(): Iterator
|
||||||
|
{
|
||||||
|
return new RecursiveIteratorIterator(
|
||||||
|
new RecursiveDirectoryIterator($this->directory, FilesystemIterator::SKIP_DOTS),
|
||||||
|
RecursiveIteratorIterator::CHILD_FIRST
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $name The filename
|
||||||
|
*/
|
||||||
|
private function isFilenameEndingWithExtension(string $name): bool
|
||||||
|
{
|
||||||
|
return $this->extension === ''
|
||||||
|
|| strrpos($name, $this->extension) === strlen($name) - $this->extensionStringLength;
|
||||||
|
}
|
||||||
|
}
|
105
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FilesystemCache.php
vendored
Normal file
105
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FilesystemCache.php
vendored
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function fclose;
|
||||||
|
use function fgets;
|
||||||
|
use function fopen;
|
||||||
|
use function is_file;
|
||||||
|
use function serialize;
|
||||||
|
use function time;
|
||||||
|
use function unserialize;
|
||||||
|
|
||||||
|
use const PHP_EOL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filesystem cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class FilesystemCache extends FileCache
|
||||||
|
{
|
||||||
|
public const EXTENSION = '.doctrinecache.data';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function __construct($directory, $extension = self::EXTENSION, $umask = 0002)
|
||||||
|
{
|
||||||
|
parent::__construct($directory, $extension, $umask);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$data = '';
|
||||||
|
$lifetime = -1;
|
||||||
|
$filename = $this->getFilename($id);
|
||||||
|
|
||||||
|
if (! is_file($filename)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$resource = fopen($filename, 'r');
|
||||||
|
$line = fgets($resource);
|
||||||
|
|
||||||
|
if ($line !== false) {
|
||||||
|
$lifetime = (int) $line;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($lifetime !== 0 && $lifetime < time()) {
|
||||||
|
fclose($resource);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (($line = fgets($resource)) !== false) {
|
||||||
|
$data .= $line;
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose($resource);
|
||||||
|
|
||||||
|
return unserialize($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$lifetime = -1;
|
||||||
|
$filename = $this->getFilename($id);
|
||||||
|
|
||||||
|
if (! is_file($filename)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$resource = fopen($filename, 'r');
|
||||||
|
$line = fgets($resource);
|
||||||
|
|
||||||
|
if ($line !== false) {
|
||||||
|
$lifetime = (int) $line;
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose($resource);
|
||||||
|
|
||||||
|
return $lifetime === 0 || $lifetime > time();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
if ($lifeTime > 0) {
|
||||||
|
$lifeTime = time() + $lifeTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = serialize($data);
|
||||||
|
$filename = $this->getFilename($id);
|
||||||
|
|
||||||
|
return $this->writeFile($filename, $lifeTime . PHP_EOL . $data);
|
||||||
|
}
|
||||||
|
}
|
18
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FlushableCache.php
vendored
Normal file
18
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/FlushableCache.php
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache that can be flushed.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface FlushableCache
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Flushes all cache entries, globally.
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the cache entries were successfully flushed, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function flushAll();
|
||||||
|
}
|
38
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/InvalidCacheId.php
vendored
Normal file
38
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/InvalidCacheId.php
vendored
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
<?php
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
|
||||||
|
use function sprintf;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
final class InvalidCacheId extends InvalidArgumentException
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param mixed $id
|
||||||
|
*/
|
||||||
|
public static function exceedsMaxLength($id, int $maxLength): self
|
||||||
|
{
|
||||||
|
return new self(sprintf('Cache id "%s" exceeds maximum length %d', $id, $maxLength));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $id
|
||||||
|
*/
|
||||||
|
public static function containsUnauthorizedCharacter($id, string $character): self
|
||||||
|
{
|
||||||
|
return new self(sprintf('Cache id "%s" contains unauthorized character "%s"', $id, $character));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $id
|
||||||
|
*/
|
||||||
|
public static function containsControlCharacter($id): self
|
||||||
|
{
|
||||||
|
return new self(sprintf('Cache id "%s" contains at least one control character', $id));
|
||||||
|
}
|
||||||
|
}
|
177
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/LegacyMongoDBCache.php
vendored
Normal file
177
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/LegacyMongoDBCache.php
vendored
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use MongoBinData;
|
||||||
|
use MongoCollection;
|
||||||
|
use MongoCursorException;
|
||||||
|
use MongoDate;
|
||||||
|
|
||||||
|
use function serialize;
|
||||||
|
use function time;
|
||||||
|
use function trigger_error;
|
||||||
|
use function unserialize;
|
||||||
|
|
||||||
|
use const E_USER_DEPRECATED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MongoDB cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class LegacyMongoDBCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var MongoCollection */
|
||||||
|
private $collection;
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
|
private $expirationIndexCreated = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This provider will default to the write concern and read preference
|
||||||
|
* options set on the MongoCollection instance (or inherited from MongoDB or
|
||||||
|
* MongoClient). Using an unacknowledged write concern (< 1) may make the
|
||||||
|
* return values of delete() and save() unreliable. Reading from secondaries
|
||||||
|
* may make contain() and fetch() unreliable.
|
||||||
|
*
|
||||||
|
* @see http://www.php.net/manual/en/mongo.readpreferences.php
|
||||||
|
* @see http://www.php.net/manual/en/mongo.writeconcerns.php
|
||||||
|
*/
|
||||||
|
public function __construct(MongoCollection $collection)
|
||||||
|
{
|
||||||
|
@trigger_error('Using the legacy MongoDB cache provider is deprecated and will be removed in 2.0', E_USER_DEPRECATED);
|
||||||
|
$this->collection = $collection;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$document = $this->collection->findOne(['_id' => $id], [MongoDBCache::DATA_FIELD, MongoDBCache::EXPIRATION_FIELD]);
|
||||||
|
|
||||||
|
if ($document === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->isExpired($document)) {
|
||||||
|
$this->createExpirationIndex();
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return unserialize($document[MongoDBCache::DATA_FIELD]->bin);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$document = $this->collection->findOne(['_id' => $id], [MongoDBCache::EXPIRATION_FIELD]);
|
||||||
|
|
||||||
|
if ($document === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->isExpired($document)) {
|
||||||
|
$this->createExpirationIndex();
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$result = $this->collection->update(
|
||||||
|
['_id' => $id],
|
||||||
|
[
|
||||||
|
'$set' => [
|
||||||
|
MongoDBCache::EXPIRATION_FIELD => ($lifeTime > 0 ? new MongoDate(time() + $lifeTime) : null),
|
||||||
|
MongoDBCache::DATA_FIELD => new MongoBinData(serialize($data), MongoBinData::BYTE_ARRAY),
|
||||||
|
],
|
||||||
|
],
|
||||||
|
['upsert' => true, 'multiple' => false]
|
||||||
|
);
|
||||||
|
} catch (MongoCursorException $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ($result['ok'] ?? 1) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
$result = $this->collection->remove(['_id' => $id]);
|
||||||
|
|
||||||
|
return ($result['ok'] ?? 1) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
// Use remove() in lieu of drop() to maintain any collection indexes
|
||||||
|
$result = $this->collection->remove();
|
||||||
|
|
||||||
|
return ($result['ok'] ?? 1) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$serverStatus = $this->collection->db->command([
|
||||||
|
'serverStatus' => 1,
|
||||||
|
'locks' => 0,
|
||||||
|
'metrics' => 0,
|
||||||
|
'recordStats' => 0,
|
||||||
|
'repl' => 0,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$collStats = $this->collection->db->command(['collStats' => 1]);
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => null,
|
||||||
|
Cache::STATS_MISSES => null,
|
||||||
|
Cache::STATS_UPTIME => $serverStatus['uptime'] ?? null,
|
||||||
|
Cache::STATS_MEMORY_USAGE => $collStats['size'] ?? null,
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => null,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the document is expired.
|
||||||
|
*
|
||||||
|
* @param mixed[] $document
|
||||||
|
*/
|
||||||
|
private function isExpired(array $document): bool
|
||||||
|
{
|
||||||
|
return isset($document[MongoDBCache::EXPIRATION_FIELD]) &&
|
||||||
|
$document[MongoDBCache::EXPIRATION_FIELD] instanceof MongoDate &&
|
||||||
|
$document[MongoDBCache::EXPIRATION_FIELD]->sec < time();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function createExpirationIndex(): void
|
||||||
|
{
|
||||||
|
if ($this->expirationIndexCreated) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->expirationIndexCreated = true;
|
||||||
|
$this->collection->createIndex([MongoDBCache::EXPIRATION_FIELD => 1], ['background' => true, 'expireAfterSeconds' => 0]);
|
||||||
|
}
|
||||||
|
}
|
105
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcacheCache.php
vendored
Normal file
105
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcacheCache.php
vendored
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Memcache;
|
||||||
|
|
||||||
|
use function time;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Memcache cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class MemcacheCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var Memcache|null */
|
||||||
|
private $memcache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the memcache instance to use.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setMemcache(Memcache $memcache)
|
||||||
|
{
|
||||||
|
$this->memcache = $memcache;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the memcache instance used by the cache.
|
||||||
|
*
|
||||||
|
* @return Memcache|null
|
||||||
|
*/
|
||||||
|
public function getMemcache()
|
||||||
|
{
|
||||||
|
return $this->memcache;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->memcache->get($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$flags = null;
|
||||||
|
$this->memcache->get($id, $flags);
|
||||||
|
|
||||||
|
//if memcache has changed the value of "flags", it means the value exists
|
||||||
|
return $flags !== null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
if ($lifeTime > 30 * 24 * 3600) {
|
||||||
|
$lifeTime = time() + $lifeTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->memcache->set($id, $data, 0, (int) $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
// Memcache::delete() returns false if entry does not exist
|
||||||
|
return $this->memcache->delete($id) || ! $this->doContains($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->memcache->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$stats = $this->memcache->getStats();
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $stats['get_hits'],
|
||||||
|
Cache::STATS_MISSES => $stats['get_misses'],
|
||||||
|
Cache::STATS_UPTIME => $stats['uptime'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $stats['bytes'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
173
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcachedCache.php
vendored
Normal file
173
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcachedCache.php
vendored
Normal file
@ -0,0 +1,173 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Memcached;
|
||||||
|
|
||||||
|
use function array_keys;
|
||||||
|
use function preg_match;
|
||||||
|
use function strlen;
|
||||||
|
use function strpos;
|
||||||
|
use function time;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Memcached cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class MemcachedCache extends CacheProvider
|
||||||
|
{
|
||||||
|
public const CACHE_ID_MAX_LENGTH = 250;
|
||||||
|
|
||||||
|
/** @var Memcached|null */
|
||||||
|
private $memcached;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the memcache instance to use.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setMemcached(Memcached $memcached)
|
||||||
|
{
|
||||||
|
$this->memcached = $memcached;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the memcached instance used by the cache.
|
||||||
|
*
|
||||||
|
* @return Memcached|null
|
||||||
|
*/
|
||||||
|
public function getMemcached()
|
||||||
|
{
|
||||||
|
return $this->memcached;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->memcached->get($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return $this->memcached->getMulti($keys) ?: [];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
foreach (array_keys($keysAndValues) as $id) {
|
||||||
|
$this->validateCacheId($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($lifetime > 30 * 24 * 3600) {
|
||||||
|
$lifetime = time() + $lifetime;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->memcached->setMulti($keysAndValues, $lifetime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$this->memcached->get($id);
|
||||||
|
|
||||||
|
return $this->memcached->getResultCode() === Memcached::RES_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$this->validateCacheId($id);
|
||||||
|
|
||||||
|
if ($lifeTime > 30 * 24 * 3600) {
|
||||||
|
$lifeTime = time() + $lifeTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->memcached->set($id, $data, (int) $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return $this->memcached->deleteMulti($keys)
|
||||||
|
|| $this->memcached->getResultCode() === Memcached::RES_NOTFOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->memcached->delete($id)
|
||||||
|
|| $this->memcached->getResultCode() === Memcached::RES_NOTFOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->memcached->flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$stats = $this->memcached->getStats();
|
||||||
|
$servers = $this->memcached->getServerList();
|
||||||
|
$key = $servers[0]['host'] . ':' . $servers[0]['port'];
|
||||||
|
$stats = $stats[$key];
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $stats['get_hits'],
|
||||||
|
Cache::STATS_MISSES => $stats['get_misses'],
|
||||||
|
Cache::STATS_UPTIME => $stats['uptime'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $stats['bytes'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate the cache id
|
||||||
|
*
|
||||||
|
* @see https://github.com/memcached/memcached/blob/1.5.12/doc/protocol.txt#L41-L49
|
||||||
|
*
|
||||||
|
* @param string $id
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*
|
||||||
|
* @throws InvalidCacheId
|
||||||
|
*/
|
||||||
|
private function validateCacheId($id)
|
||||||
|
{
|
||||||
|
if (strlen($id) > self::CACHE_ID_MAX_LENGTH) {
|
||||||
|
throw InvalidCacheId::exceedsMaxLength($id, self::CACHE_ID_MAX_LENGTH);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strpos($id, ' ') !== false) {
|
||||||
|
throw InvalidCacheId::containsUnauthorizedCharacter($id, ' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (preg_match('/[\t\r\n]/', $id) === 1) {
|
||||||
|
throw InvalidCacheId::containsControlCharacter($id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
116
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MongoDBCache.php
vendored
Normal file
116
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MongoDBCache.php
vendored
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use MongoCollection;
|
||||||
|
use MongoDB\Collection;
|
||||||
|
|
||||||
|
use function trigger_error;
|
||||||
|
|
||||||
|
use const E_USER_DEPRECATED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MongoDB cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class MongoDBCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The data field will store the serialized PHP value.
|
||||||
|
*/
|
||||||
|
public const DATA_FIELD = 'd';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The expiration field will store a MongoDate value indicating when the
|
||||||
|
* cache entry should expire.
|
||||||
|
*
|
||||||
|
* With MongoDB 2.2+, entries can be automatically deleted by MongoDB by
|
||||||
|
* indexing this field with the "expireAfterSeconds" option equal to zero.
|
||||||
|
* This will direct MongoDB to regularly query for and delete any entries
|
||||||
|
* whose date is older than the current time. Entries without a date value
|
||||||
|
* in this field will be ignored.
|
||||||
|
*
|
||||||
|
* The cache provider will also check dates on its own, in case expired
|
||||||
|
* entries are fetched before MongoDB's TTLMonitor pass can expire them.
|
||||||
|
*
|
||||||
|
* @see http://docs.mongodb.org/manual/tutorial/expire-data/
|
||||||
|
*/
|
||||||
|
public const EXPIRATION_FIELD = 'e';
|
||||||
|
|
||||||
|
/** @var CacheProvider */
|
||||||
|
private $provider;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This provider will default to the write concern and read preference
|
||||||
|
* options set on the collection instance (or inherited from MongoDB or
|
||||||
|
* MongoClient). Using an unacknowledged write concern (< 1) may make the
|
||||||
|
* return values of delete() and save() unreliable. Reading from secondaries
|
||||||
|
* may make contain() and fetch() unreliable.
|
||||||
|
*
|
||||||
|
* @see http://www.php.net/manual/en/mongo.readpreferences.php
|
||||||
|
* @see http://www.php.net/manual/en/mongo.writeconcerns.php
|
||||||
|
*
|
||||||
|
* @param MongoCollection|Collection $collection
|
||||||
|
*/
|
||||||
|
public function __construct($collection)
|
||||||
|
{
|
||||||
|
if ($collection instanceof MongoCollection) {
|
||||||
|
@trigger_error('Using a MongoCollection instance for creating a cache adapter is deprecated and will be removed in 2.0', E_USER_DEPRECATED);
|
||||||
|
$this->provider = new LegacyMongoDBCache($collection);
|
||||||
|
} elseif ($collection instanceof Collection) {
|
||||||
|
$this->provider = new ExtMongoDBCache($collection);
|
||||||
|
} else {
|
||||||
|
throw new InvalidArgumentException('Invalid collection given - expected a MongoCollection or MongoDB\Collection instance');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->provider->doFetch($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return $this->provider->doContains($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return $this->provider->doSave($id, $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->provider->doDelete($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->provider->doFlush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
return $this->provider->doGetStats();
|
||||||
|
}
|
||||||
|
}
|
22
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiDeleteCache.php
vendored
Normal file
22
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiDeleteCache.php
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache drivers that allows to put many items at once.
|
||||||
|
*
|
||||||
|
* @deprecated
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface MultiDeleteCache
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Deletes several cache entries.
|
||||||
|
*
|
||||||
|
* @param string[] $keys Array of keys to delete from cache
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the operation was successful, FALSE if it wasn't.
|
||||||
|
*/
|
||||||
|
public function deleteMultiple(array $keys);
|
||||||
|
}
|
23
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiGetCache.php
vendored
Normal file
23
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiGetCache.php
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache drivers that allows to get many items at once.
|
||||||
|
*
|
||||||
|
* @deprecated
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface MultiGetCache
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Returns an associative array of values for keys is found in cache.
|
||||||
|
*
|
||||||
|
* @param string[] $keys Array of keys to retrieve from cache
|
||||||
|
*
|
||||||
|
* @return mixed[] Array of retrieved values, indexed by the specified keys.
|
||||||
|
* Values that couldn't be retrieved are not contained in this array.
|
||||||
|
*/
|
||||||
|
public function fetchMultiple(array $keys);
|
||||||
|
}
|
12
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiOperationCache.php
vendored
Normal file
12
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiOperationCache.php
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache drivers that supports multiple items manipulation.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface MultiOperationCache extends MultiGetCache, MultiDeleteCache, MultiPutCache
|
||||||
|
{
|
||||||
|
}
|
24
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiPutCache.php
vendored
Normal file
24
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/MultiPutCache.php
vendored
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for cache drivers that allows to put many items at once.
|
||||||
|
*
|
||||||
|
* @deprecated
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
interface MultiPutCache
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Returns a boolean value indicating if the operation succeeded.
|
||||||
|
*
|
||||||
|
* @param mixed[] $keysAndValues Array of keys and values to save in cache
|
||||||
|
* @param int $lifetime The lifetime. If != 0, sets a specific lifetime for these
|
||||||
|
* cache entries (0 => infinite lifeTime).
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the operation was successful, FALSE if it wasn't.
|
||||||
|
*/
|
||||||
|
public function saveMultiple(array $keysAndValues, $lifetime = 0);
|
||||||
|
}
|
120
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PhpFileCache.php
vendored
Normal file
120
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PhpFileCache.php
vendored
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function is_object;
|
||||||
|
use function method_exists;
|
||||||
|
use function restore_error_handler;
|
||||||
|
use function serialize;
|
||||||
|
use function set_error_handler;
|
||||||
|
use function sprintf;
|
||||||
|
use function time;
|
||||||
|
use function var_export;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Php file cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class PhpFileCache extends FileCache
|
||||||
|
{
|
||||||
|
public const EXTENSION = '.doctrinecache.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var callable
|
||||||
|
*
|
||||||
|
* This is cached in a local static variable to avoid instantiating a closure each time we need an empty handler
|
||||||
|
*/
|
||||||
|
private static $emptyErrorHandler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function __construct($directory, $extension = self::EXTENSION, $umask = 0002)
|
||||||
|
{
|
||||||
|
parent::__construct($directory, $extension, $umask);
|
||||||
|
|
||||||
|
self::$emptyErrorHandler = static function () {
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$value = $this->includeFileForId($id);
|
||||||
|
|
||||||
|
if ($value === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($value['lifetime'] !== 0 && $value['lifetime'] < time()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value['data'];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$value = $this->includeFileForId($id);
|
||||||
|
|
||||||
|
if ($value === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value['lifetime'] === 0 || $value['lifetime'] > time();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
if ($lifeTime > 0) {
|
||||||
|
$lifeTime = time() + $lifeTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
$filename = $this->getFilename($id);
|
||||||
|
|
||||||
|
$value = [
|
||||||
|
'lifetime' => $lifeTime,
|
||||||
|
'data' => $data,
|
||||||
|
];
|
||||||
|
|
||||||
|
if (is_object($data) && method_exists($data, '__set_state')) {
|
||||||
|
$value = var_export($value, true);
|
||||||
|
$code = sprintf('<?php return %s;', $value);
|
||||||
|
} else {
|
||||||
|
$value = var_export(serialize($value), true);
|
||||||
|
$code = sprintf('<?php return unserialize(%s);', $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->writeFile($filename, $code);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return mixed[]|null
|
||||||
|
*/
|
||||||
|
private function includeFileForId(string $id): ?array
|
||||||
|
{
|
||||||
|
$fileName = $this->getFilename($id);
|
||||||
|
|
||||||
|
// note: error suppression is still faster than `file_exists`, `is_file` and `is_readable`
|
||||||
|
set_error_handler(self::$emptyErrorHandler);
|
||||||
|
|
||||||
|
$value = include $fileName;
|
||||||
|
|
||||||
|
restore_error_handler();
|
||||||
|
|
||||||
|
if (! isset($value['lifetime'])) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
}
|
147
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PredisCache.php
vendored
Normal file
147
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/PredisCache.php
vendored
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Predis\ClientInterface;
|
||||||
|
|
||||||
|
use function array_combine;
|
||||||
|
use function array_filter;
|
||||||
|
use function array_map;
|
||||||
|
use function array_values;
|
||||||
|
use function call_user_func_array;
|
||||||
|
use function serialize;
|
||||||
|
use function unserialize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Predis cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class PredisCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var ClientInterface */
|
||||||
|
private $client;
|
||||||
|
|
||||||
|
public function __construct(ClientInterface $client)
|
||||||
|
{
|
||||||
|
$this->client = $client;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$result = $this->client->get($id);
|
||||||
|
if ($result === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return unserialize($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$fetchedItems = call_user_func_array([$this->client, 'mget'], array_values($keys));
|
||||||
|
|
||||||
|
return array_map('unserialize', array_filter(array_combine($keys, $fetchedItems)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
if ($lifetime) {
|
||||||
|
$success = true;
|
||||||
|
|
||||||
|
// Keys have lifetime, use SETEX for each of them
|
||||||
|
foreach ($keysAndValues as $key => $value) {
|
||||||
|
$response = (string) $this->client->setex($key, $lifetime, serialize($value));
|
||||||
|
|
||||||
|
if ($response == 'OK') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
// No lifetime, use MSET
|
||||||
|
$response = $this->client->mset(array_map(static function ($value) {
|
||||||
|
return serialize($value);
|
||||||
|
}, $keysAndValues));
|
||||||
|
|
||||||
|
return (string) $response == 'OK';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return (bool) $this->client->exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$data = serialize($data);
|
||||||
|
if ($lifeTime > 0) {
|
||||||
|
$response = $this->client->setex($id, $lifeTime, $data);
|
||||||
|
} else {
|
||||||
|
$response = $this->client->set($id, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $response === true || $response == 'OK';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->client->del($id) >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return $this->client->del($keys) >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$response = $this->client->flushdb();
|
||||||
|
|
||||||
|
return $response === true || $response == 'OK';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$info = $this->client->info();
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['Stats']['keyspace_hits'],
|
||||||
|
Cache::STATS_MISSES => $info['Stats']['keyspace_misses'],
|
||||||
|
Cache::STATS_UPTIME => $info['Server']['uptime_in_seconds'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $info['Memory']['used_memory'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => false,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
340
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/CacheAdapter.php
vendored
Normal file
340
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/CacheAdapter.php
vendored
Normal file
@ -0,0 +1,340 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache\Psr6;
|
||||||
|
|
||||||
|
use Doctrine\Common\Cache\Cache;
|
||||||
|
use Doctrine\Common\Cache\ClearableCache;
|
||||||
|
use Doctrine\Common\Cache\MultiDeleteCache;
|
||||||
|
use Doctrine\Common\Cache\MultiGetCache;
|
||||||
|
use Doctrine\Common\Cache\MultiPutCache;
|
||||||
|
use Psr\Cache\CacheItemInterface;
|
||||||
|
use Psr\Cache\CacheItemPoolInterface;
|
||||||
|
use Symfony\Component\Cache\DoctrineProvider as SymfonyDoctrineProvider;
|
||||||
|
|
||||||
|
use function array_key_exists;
|
||||||
|
use function assert;
|
||||||
|
use function count;
|
||||||
|
use function current;
|
||||||
|
use function get_class;
|
||||||
|
use function gettype;
|
||||||
|
use function is_object;
|
||||||
|
use function is_string;
|
||||||
|
use function microtime;
|
||||||
|
use function sprintf;
|
||||||
|
use function strpbrk;
|
||||||
|
|
||||||
|
use const PHP_VERSION_ID;
|
||||||
|
|
||||||
|
final class CacheAdapter implements CacheItemPoolInterface
|
||||||
|
{
|
||||||
|
private const RESERVED_CHARACTERS = '{}()/\@:';
|
||||||
|
|
||||||
|
/** @var Cache */
|
||||||
|
private $cache;
|
||||||
|
|
||||||
|
/** @var array<CacheItem|TypedCacheItem> */
|
||||||
|
private $deferredItems = [];
|
||||||
|
|
||||||
|
public static function wrap(Cache $cache): CacheItemPoolInterface
|
||||||
|
{
|
||||||
|
if ($cache instanceof DoctrineProvider && ! $cache->getNamespace()) {
|
||||||
|
return $cache->getPool();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($cache instanceof SymfonyDoctrineProvider && ! $cache->getNamespace()) {
|
||||||
|
$getPool = function () {
|
||||||
|
// phpcs:ignore Squiz.Scope.StaticThisUsage.Found
|
||||||
|
return $this->pool;
|
||||||
|
};
|
||||||
|
|
||||||
|
return $getPool->bindTo($cache, SymfonyDoctrineProvider::class)();
|
||||||
|
}
|
||||||
|
|
||||||
|
return new self($cache);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function __construct(Cache $cache)
|
||||||
|
{
|
||||||
|
$this->cache = $cache;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @internal */
|
||||||
|
public function getCache(): Cache
|
||||||
|
{
|
||||||
|
return $this->cache;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getItem($key): CacheItemInterface
|
||||||
|
{
|
||||||
|
assert(self::validKey($key));
|
||||||
|
|
||||||
|
if (isset($this->deferredItems[$key])) {
|
||||||
|
$this->commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = $this->cache->fetch($key);
|
||||||
|
|
||||||
|
if (PHP_VERSION_ID >= 80000) {
|
||||||
|
if ($value !== false) {
|
||||||
|
return new TypedCacheItem($key, $value, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new TypedCacheItem($key, null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($value !== false) {
|
||||||
|
return new CacheItem($key, $value, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new CacheItem($key, null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getItems(array $keys = []): array
|
||||||
|
{
|
||||||
|
if ($this->deferredItems) {
|
||||||
|
$this->commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(self::validKeys($keys));
|
||||||
|
|
||||||
|
$values = $this->doFetchMultiple($keys);
|
||||||
|
$items = [];
|
||||||
|
|
||||||
|
if (PHP_VERSION_ID >= 80000) {
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
if (array_key_exists($key, $values)) {
|
||||||
|
$items[$key] = new TypedCacheItem($key, $values[$key], true);
|
||||||
|
} else {
|
||||||
|
$items[$key] = new TypedCacheItem($key, null, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $items;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
if (array_key_exists($key, $values)) {
|
||||||
|
$items[$key] = new CacheItem($key, $values[$key], true);
|
||||||
|
} else {
|
||||||
|
$items[$key] = new CacheItem($key, null, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $items;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function hasItem($key): bool
|
||||||
|
{
|
||||||
|
assert(self::validKey($key));
|
||||||
|
|
||||||
|
if (isset($this->deferredItems[$key])) {
|
||||||
|
$this->commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->cache->contains($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function clear(): bool
|
||||||
|
{
|
||||||
|
$this->deferredItems = [];
|
||||||
|
|
||||||
|
if (! $this->cache instanceof ClearableCache) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->cache->deleteAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function deleteItem($key): bool
|
||||||
|
{
|
||||||
|
assert(self::validKey($key));
|
||||||
|
unset($this->deferredItems[$key]);
|
||||||
|
|
||||||
|
return $this->cache->delete($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function deleteItems(array $keys): bool
|
||||||
|
{
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
assert(self::validKey($key));
|
||||||
|
unset($this->deferredItems[$key]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->doDeleteMultiple($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function save(CacheItemInterface $item): bool
|
||||||
|
{
|
||||||
|
return $this->saveDeferred($item) && $this->commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function saveDeferred(CacheItemInterface $item): bool
|
||||||
|
{
|
||||||
|
if (! $item instanceof CacheItem && ! $item instanceof TypedCacheItem) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->deferredItems[$item->getKey()] = $item;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function commit(): bool
|
||||||
|
{
|
||||||
|
if (! $this->deferredItems) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
$now = microtime(true);
|
||||||
|
$itemsCount = 0;
|
||||||
|
$byLifetime = [];
|
||||||
|
$expiredKeys = [];
|
||||||
|
|
||||||
|
foreach ($this->deferredItems as $key => $item) {
|
||||||
|
$lifetime = ($item->getExpiry() ?? $now) - $now;
|
||||||
|
|
||||||
|
if ($lifetime < 0) {
|
||||||
|
$expiredKeys[] = $key;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
++$itemsCount;
|
||||||
|
$byLifetime[(int) $lifetime][$key] = $item->get();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->deferredItems = [];
|
||||||
|
|
||||||
|
switch (count($expiredKeys)) {
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
$this->cache->delete(current($expiredKeys));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$this->doDeleteMultiple($expiredKeys);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($itemsCount === 1) {
|
||||||
|
return $this->cache->save($key, $item->get(), (int) $lifetime);
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = true;
|
||||||
|
foreach ($byLifetime as $lifetime => $values) {
|
||||||
|
$success = $this->doSaveMultiple($values, $lifetime) && $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __destruct()
|
||||||
|
{
|
||||||
|
$this->commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $key
|
||||||
|
*/
|
||||||
|
private static function validKey($key): bool
|
||||||
|
{
|
||||||
|
if (! is_string($key)) {
|
||||||
|
throw new InvalidArgument(sprintf('Cache key must be string, "%s" given.', is_object($key) ? get_class($key) : gettype($key)));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($key === '') {
|
||||||
|
throw new InvalidArgument('Cache key length must be greater than zero.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strpbrk($key, self::RESERVED_CHARACTERS) !== false) {
|
||||||
|
throw new InvalidArgument(sprintf('Cache key "%s" contains reserved characters "%s".', $key, self::RESERVED_CHARACTERS));
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed[] $keys
|
||||||
|
*/
|
||||||
|
private static function validKeys(array $keys): bool
|
||||||
|
{
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
self::validKey($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed[] $keys
|
||||||
|
*/
|
||||||
|
private function doDeleteMultiple(array $keys): bool
|
||||||
|
{
|
||||||
|
if ($this->cache instanceof MultiDeleteCache) {
|
||||||
|
return $this->cache->deleteMultiple($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = true;
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
$success = $this->cache->delete($key) && $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed[] $keys
|
||||||
|
*
|
||||||
|
* @return mixed[]
|
||||||
|
*/
|
||||||
|
private function doFetchMultiple(array $keys): array
|
||||||
|
{
|
||||||
|
if ($this->cache instanceof MultiGetCache) {
|
||||||
|
return $this->cache->fetchMultiple($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
$values = [];
|
||||||
|
foreach ($keys as $key) {
|
||||||
|
$value = $this->cache->fetch($key);
|
||||||
|
if (! $value) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$values[$key] = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $values;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed[] $keysAndValues
|
||||||
|
*/
|
||||||
|
private function doSaveMultiple(array $keysAndValues, int $lifetime = 0): bool
|
||||||
|
{
|
||||||
|
if ($this->cache instanceof MultiPutCache) {
|
||||||
|
return $this->cache->saveMultiple($keysAndValues, $lifetime);
|
||||||
|
}
|
||||||
|
|
||||||
|
$success = true;
|
||||||
|
foreach ($keysAndValues as $key => $value) {
|
||||||
|
$success = $this->cache->save($key, $value, $lifetime) && $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
}
|
118
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/CacheItem.php
vendored
Normal file
118
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/CacheItem.php
vendored
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache\Psr6;
|
||||||
|
|
||||||
|
use DateInterval;
|
||||||
|
use DateTime;
|
||||||
|
use DateTimeInterface;
|
||||||
|
use Psr\Cache\CacheItemInterface;
|
||||||
|
use TypeError;
|
||||||
|
|
||||||
|
use function get_class;
|
||||||
|
use function gettype;
|
||||||
|
use function is_int;
|
||||||
|
use function is_object;
|
||||||
|
use function microtime;
|
||||||
|
use function sprintf;
|
||||||
|
|
||||||
|
final class CacheItem implements CacheItemInterface
|
||||||
|
{
|
||||||
|
/** @var string */
|
||||||
|
private $key;
|
||||||
|
/** @var mixed */
|
||||||
|
private $value;
|
||||||
|
/** @var bool */
|
||||||
|
private $isHit;
|
||||||
|
/** @var float|null */
|
||||||
|
private $expiry;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*
|
||||||
|
* @param mixed $data
|
||||||
|
*/
|
||||||
|
public function __construct(string $key, $data, bool $isHit)
|
||||||
|
{
|
||||||
|
$this->key = $key;
|
||||||
|
$this->value = $data;
|
||||||
|
$this->isHit = $isHit;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getKey(): string
|
||||||
|
{
|
||||||
|
return $this->key;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function get()
|
||||||
|
{
|
||||||
|
return $this->value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function isHit(): bool
|
||||||
|
{
|
||||||
|
return $this->isHit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function set($value): self
|
||||||
|
{
|
||||||
|
$this->value = $value;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function expiresAt($expiration): self
|
||||||
|
{
|
||||||
|
if ($expiration === null) {
|
||||||
|
$this->expiry = null;
|
||||||
|
} elseif ($expiration instanceof DateTimeInterface) {
|
||||||
|
$this->expiry = (float) $expiration->format('U.u');
|
||||||
|
} else {
|
||||||
|
throw new TypeError(sprintf(
|
||||||
|
'Expected $expiration to be an instance of DateTimeInterface or null, got %s',
|
||||||
|
is_object($expiration) ? get_class($expiration) : gettype($expiration)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function expiresAfter($time): self
|
||||||
|
{
|
||||||
|
if ($time === null) {
|
||||||
|
$this->expiry = null;
|
||||||
|
} elseif ($time instanceof DateInterval) {
|
||||||
|
$this->expiry = microtime(true) + DateTime::createFromFormat('U', 0)->add($time)->format('U.u');
|
||||||
|
} elseif (is_int($time)) {
|
||||||
|
$this->expiry = $time + microtime(true);
|
||||||
|
} else {
|
||||||
|
throw new TypeError(sprintf(
|
||||||
|
'Expected $time to be either an integer, an instance of DateInterval or null, got %s',
|
||||||
|
is_object($time) ? get_class($time) : gettype($time)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
public function getExpiry(): ?float
|
||||||
|
{
|
||||||
|
return $this->expiry;
|
||||||
|
}
|
||||||
|
}
|
135
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/DoctrineProvider.php
vendored
Normal file
135
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/DoctrineProvider.php
vendored
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of the Symfony package.
|
||||||
|
*
|
||||||
|
* (c) Fabien Potencier <fabien@symfony.com>
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache\Psr6;
|
||||||
|
|
||||||
|
use Doctrine\Common\Cache\Cache;
|
||||||
|
use Doctrine\Common\Cache\CacheProvider;
|
||||||
|
use Psr\Cache\CacheItemPoolInterface;
|
||||||
|
use Symfony\Component\Cache\Adapter\DoctrineAdapter as SymfonyDoctrineAdapter;
|
||||||
|
use Symfony\Contracts\Service\ResetInterface;
|
||||||
|
|
||||||
|
use function rawurlencode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class was copied from the Symfony Framework, see the original copyright
|
||||||
|
* notice above. The code is distributed subject to the license terms in
|
||||||
|
* https://github.com/symfony/symfony/blob/ff0cf61278982539c49e467db9ab13cbd342f76d/LICENSE
|
||||||
|
*/
|
||||||
|
final class DoctrineProvider extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var CacheItemPoolInterface */
|
||||||
|
private $pool;
|
||||||
|
|
||||||
|
public static function wrap(CacheItemPoolInterface $pool): Cache
|
||||||
|
{
|
||||||
|
if ($pool instanceof CacheAdapter) {
|
||||||
|
return $pool->getCache();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($pool instanceof SymfonyDoctrineAdapter) {
|
||||||
|
$getCache = function () {
|
||||||
|
// phpcs:ignore Squiz.Scope.StaticThisUsage.Found
|
||||||
|
return $this->provider;
|
||||||
|
};
|
||||||
|
|
||||||
|
return $getCache->bindTo($pool, SymfonyDoctrineAdapter::class)();
|
||||||
|
}
|
||||||
|
|
||||||
|
return new self($pool);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function __construct(CacheItemPoolInterface $pool)
|
||||||
|
{
|
||||||
|
$this->pool = $pool;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @internal */
|
||||||
|
public function getPool(): CacheItemPoolInterface
|
||||||
|
{
|
||||||
|
return $this->pool;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function reset(): void
|
||||||
|
{
|
||||||
|
if ($this->pool instanceof ResetInterface) {
|
||||||
|
$this->pool->reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->setNamespace($this->getNamespace());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$item = $this->pool->getItem(rawurlencode($id));
|
||||||
|
|
||||||
|
return $item->isHit() ? $item->get() : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return $this->pool->hasItem(rawurlencode($id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$item = $this->pool->getItem(rawurlencode($id));
|
||||||
|
|
||||||
|
if (0 < $lifeTime) {
|
||||||
|
$item->expiresAfter($lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->pool->save($item->set($data));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->pool->deleteItem(rawurlencode($id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->pool->clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @return array|null
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
13
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/InvalidArgument.php
vendored
Normal file
13
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/InvalidArgument.php
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache\Psr6;
|
||||||
|
|
||||||
|
use InvalidArgumentException;
|
||||||
|
use Psr\Cache\InvalidArgumentException as PsrInvalidArgumentException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
final class InvalidArgument extends InvalidArgumentException implements PsrInvalidArgumentException
|
||||||
|
{
|
||||||
|
}
|
99
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/TypedCacheItem.php
vendored
Normal file
99
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Psr6/TypedCacheItem.php
vendored
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache\Psr6;
|
||||||
|
|
||||||
|
use DateInterval;
|
||||||
|
use DateTime;
|
||||||
|
use DateTimeInterface;
|
||||||
|
use Psr\Cache\CacheItemInterface;
|
||||||
|
use TypeError;
|
||||||
|
|
||||||
|
use function get_debug_type;
|
||||||
|
use function is_int;
|
||||||
|
use function microtime;
|
||||||
|
use function sprintf;
|
||||||
|
|
||||||
|
final class TypedCacheItem implements CacheItemInterface
|
||||||
|
{
|
||||||
|
private ?float $expiry = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
public function __construct(
|
||||||
|
private string $key,
|
||||||
|
private mixed $value,
|
||||||
|
private bool $isHit,
|
||||||
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getKey(): string
|
||||||
|
{
|
||||||
|
return $this->key;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function get(): mixed
|
||||||
|
{
|
||||||
|
return $this->value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function isHit(): bool
|
||||||
|
{
|
||||||
|
return $this->isHit;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function set(mixed $value): static
|
||||||
|
{
|
||||||
|
$this->value = $value;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function expiresAt($expiration): static
|
||||||
|
{
|
||||||
|
if ($expiration === null) {
|
||||||
|
$this->expiry = null;
|
||||||
|
} elseif ($expiration instanceof DateTimeInterface) {
|
||||||
|
$this->expiry = (float) $expiration->format('U.u');
|
||||||
|
} else {
|
||||||
|
throw new TypeError(sprintf(
|
||||||
|
'Expected $expiration to be an instance of DateTimeInterface or null, got %s',
|
||||||
|
get_debug_type($expiration)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function expiresAfter($time): static
|
||||||
|
{
|
||||||
|
if ($time === null) {
|
||||||
|
$this->expiry = null;
|
||||||
|
} elseif ($time instanceof DateInterval) {
|
||||||
|
$this->expiry = microtime(true) + DateTime::createFromFormat('U', 0)->add($time)->format('U.u');
|
||||||
|
} elseif (is_int($time)) {
|
||||||
|
$this->expiry = $time + microtime(true);
|
||||||
|
} else {
|
||||||
|
throw new TypeError(sprintf(
|
||||||
|
'Expected $time to be either an integer, an instance of DateInterval or null, got %s',
|
||||||
|
get_debug_type($time)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
public function getExpiry(): ?float
|
||||||
|
{
|
||||||
|
return $this->expiry;
|
||||||
|
}
|
||||||
|
}
|
186
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php
vendored
Normal file
186
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php
vendored
Normal file
@ -0,0 +1,186 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use Redis;
|
||||||
|
|
||||||
|
use function array_combine;
|
||||||
|
use function array_diff_key;
|
||||||
|
use function array_fill_keys;
|
||||||
|
use function array_filter;
|
||||||
|
use function array_keys;
|
||||||
|
use function count;
|
||||||
|
use function defined;
|
||||||
|
use function extension_loaded;
|
||||||
|
use function is_bool;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Redis cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class RedisCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/** @var Redis|null */
|
||||||
|
private $redis;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the redis instance to use.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setRedis(Redis $redis)
|
||||||
|
{
|
||||||
|
$redis->setOption(Redis::OPT_SERIALIZER, $this->getSerializerValue());
|
||||||
|
$this->redis = $redis;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the redis instance used by the cache.
|
||||||
|
*
|
||||||
|
* @return Redis|null
|
||||||
|
*/
|
||||||
|
public function getRedis()
|
||||||
|
{
|
||||||
|
return $this->redis;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->redis->get($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$fetchedItems = array_combine($keys, $this->redis->mget($keys));
|
||||||
|
|
||||||
|
// Redis mget returns false for keys that do not exist. So we need to filter those out unless it's the real data.
|
||||||
|
$keysToFilter = array_keys(array_filter($fetchedItems, static function ($item): bool {
|
||||||
|
return $item === false;
|
||||||
|
}));
|
||||||
|
|
||||||
|
if ($keysToFilter) {
|
||||||
|
$multi = $this->redis->multi(Redis::PIPELINE);
|
||||||
|
foreach ($keysToFilter as $key) {
|
||||||
|
$multi->exists($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
$existItems = array_filter($multi->exec());
|
||||||
|
$missedItemKeys = array_diff_key($keysToFilter, $existItems);
|
||||||
|
$fetchedItems = array_diff_key($fetchedItems, array_fill_keys($missedItemKeys, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $fetchedItems;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
if ($lifetime) {
|
||||||
|
// Keys have lifetime, use SETEX for each of them
|
||||||
|
$multi = $this->redis->multi(Redis::PIPELINE);
|
||||||
|
foreach ($keysAndValues as $key => $value) {
|
||||||
|
$multi->setex($key, $lifetime, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
$succeeded = array_filter($multi->exec());
|
||||||
|
|
||||||
|
return count($succeeded) == count($keysAndValues);
|
||||||
|
}
|
||||||
|
|
||||||
|
// No lifetime, use MSET
|
||||||
|
return (bool) $this->redis->mset($keysAndValues);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
$exists = $this->redis->exists($id);
|
||||||
|
|
||||||
|
if (is_bool($exists)) {
|
||||||
|
return $exists;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $exists > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
if ($lifeTime > 0) {
|
||||||
|
return $this->redis->setex($id, $lifeTime, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->redis->set($id, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return $this->redis->del($id) >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return $this->redis->del($keys) >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->redis->flushDB();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$info = $this->redis->info();
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['keyspace_hits'],
|
||||||
|
Cache::STATS_MISSES => $info['keyspace_misses'],
|
||||||
|
Cache::STATS_UPTIME => $info['uptime_in_seconds'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $info['used_memory'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => false,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the serializer constant to use. If Redis is compiled with
|
||||||
|
* igbinary support, that is used. Otherwise the default PHP serializer is
|
||||||
|
* used.
|
||||||
|
*
|
||||||
|
* @return int One of the Redis::SERIALIZER_* constants
|
||||||
|
*/
|
||||||
|
protected function getSerializerValue()
|
||||||
|
{
|
||||||
|
if (defined('Redis::SERIALIZER_IGBINARY') && extension_loaded('igbinary')) {
|
||||||
|
return Redis::SERIALIZER_IGBINARY;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Redis::SERIALIZER_PHP;
|
||||||
|
}
|
||||||
|
}
|
210
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/SQLite3Cache.php
vendored
Normal file
210
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/SQLite3Cache.php
vendored
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use SQLite3;
|
||||||
|
use SQLite3Result;
|
||||||
|
|
||||||
|
use function array_search;
|
||||||
|
use function implode;
|
||||||
|
use function serialize;
|
||||||
|
use function sprintf;
|
||||||
|
use function time;
|
||||||
|
use function unserialize;
|
||||||
|
|
||||||
|
use const SQLITE3_ASSOC;
|
||||||
|
use const SQLITE3_BLOB;
|
||||||
|
use const SQLITE3_TEXT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SQLite3 cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class SQLite3Cache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The ID field will store the cache key.
|
||||||
|
*/
|
||||||
|
public const ID_FIELD = 'k';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The data field will store the serialized PHP value.
|
||||||
|
*/
|
||||||
|
public const DATA_FIELD = 'd';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The expiration field will store a date value indicating when the
|
||||||
|
* cache entry should expire.
|
||||||
|
*/
|
||||||
|
public const EXPIRATION_FIELD = 'e';
|
||||||
|
|
||||||
|
/** @var SQLite3 */
|
||||||
|
private $sqlite;
|
||||||
|
|
||||||
|
/** @var string */
|
||||||
|
private $table;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calling the constructor will ensure that the database file and table
|
||||||
|
* exist and will create both if they don't.
|
||||||
|
*
|
||||||
|
* @param string $table
|
||||||
|
*/
|
||||||
|
public function __construct(SQLite3 $sqlite, $table)
|
||||||
|
{
|
||||||
|
$this->sqlite = $sqlite;
|
||||||
|
$this->table = (string) $table;
|
||||||
|
|
||||||
|
$this->ensureTableExists();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function ensureTableExists(): void
|
||||||
|
{
|
||||||
|
$this->sqlite->exec(
|
||||||
|
sprintf(
|
||||||
|
'CREATE TABLE IF NOT EXISTS %s(%s TEXT PRIMARY KEY NOT NULL, %s BLOB, %s INTEGER)',
|
||||||
|
$this->table,
|
||||||
|
static::ID_FIELD,
|
||||||
|
static::DATA_FIELD,
|
||||||
|
static::EXPIRATION_FIELD
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
$item = $this->findById($id);
|
||||||
|
|
||||||
|
if (! $item) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return unserialize($item[self::DATA_FIELD]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return $this->findById($id, false) !== null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
$statement = $this->sqlite->prepare(sprintf(
|
||||||
|
'INSERT OR REPLACE INTO %s (%s) VALUES (:id, :data, :expire)',
|
||||||
|
$this->table,
|
||||||
|
implode(',', $this->getFields())
|
||||||
|
));
|
||||||
|
|
||||||
|
$statement->bindValue(':id', $id);
|
||||||
|
$statement->bindValue(':data', serialize($data), SQLITE3_BLOB);
|
||||||
|
$statement->bindValue(':expire', $lifeTime > 0 ? time() + $lifeTime : null);
|
||||||
|
|
||||||
|
return $statement->execute() instanceof SQLite3Result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
[$idField] = $this->getFields();
|
||||||
|
|
||||||
|
$statement = $this->sqlite->prepare(sprintf(
|
||||||
|
'DELETE FROM %s WHERE %s = :id',
|
||||||
|
$this->table,
|
||||||
|
$idField
|
||||||
|
));
|
||||||
|
|
||||||
|
$statement->bindValue(':id', $id);
|
||||||
|
|
||||||
|
return $statement->execute() instanceof SQLite3Result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return $this->sqlite->exec(sprintf('DELETE FROM %s', $this->table));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
// no-op.
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find a single row by ID.
|
||||||
|
*
|
||||||
|
* @param mixed $id
|
||||||
|
*
|
||||||
|
* @return mixed[]|null
|
||||||
|
*/
|
||||||
|
private function findById($id, bool $includeData = true): ?array
|
||||||
|
{
|
||||||
|
[$idField] = $fields = $this->getFields();
|
||||||
|
|
||||||
|
if (! $includeData) {
|
||||||
|
$key = array_search(static::DATA_FIELD, $fields);
|
||||||
|
unset($fields[$key]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$statement = $this->sqlite->prepare(sprintf(
|
||||||
|
'SELECT %s FROM %s WHERE %s = :id LIMIT 1',
|
||||||
|
implode(',', $fields),
|
||||||
|
$this->table,
|
||||||
|
$idField
|
||||||
|
));
|
||||||
|
|
||||||
|
$statement->bindValue(':id', $id, SQLITE3_TEXT);
|
||||||
|
|
||||||
|
$item = $statement->execute()->fetchArray(SQLITE3_ASSOC);
|
||||||
|
|
||||||
|
if ($item === false) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->isExpired($item)) {
|
||||||
|
$this->doDelete($id);
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $item;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets an array of the fields in our table.
|
||||||
|
*
|
||||||
|
* @psalm-return array{string, string, string}
|
||||||
|
*/
|
||||||
|
private function getFields(): array
|
||||||
|
{
|
||||||
|
return [static::ID_FIELD, static::DATA_FIELD, static::EXPIRATION_FIELD];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the item is expired.
|
||||||
|
*
|
||||||
|
* @param mixed[] $item
|
||||||
|
*/
|
||||||
|
private function isExpired(array $item): bool
|
||||||
|
{
|
||||||
|
return isset($item[static::EXPIRATION_FIELD]) &&
|
||||||
|
$item[self::EXPIRATION_FIELD] !== null &&
|
||||||
|
$item[self::EXPIRATION_FIELD] < time();
|
||||||
|
}
|
||||||
|
}
|
11
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Version.php
vendored
Normal file
11
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/Version.php
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*/
|
||||||
|
class Version
|
||||||
|
{
|
||||||
|
public const VERSION = '1.9.0-DEV';
|
||||||
|
}
|
61
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/VoidCache.php
vendored
Normal file
61
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/VoidCache.php
vendored
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Void cache driver. The cache could be of use in tests where you don`t need to cache anything.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class VoidCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
108
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/WinCacheCache.php
vendored
Normal file
108
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/WinCacheCache.php
vendored
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function count;
|
||||||
|
use function is_array;
|
||||||
|
use function wincache_ucache_clear;
|
||||||
|
use function wincache_ucache_delete;
|
||||||
|
use function wincache_ucache_exists;
|
||||||
|
use function wincache_ucache_get;
|
||||||
|
use function wincache_ucache_info;
|
||||||
|
use function wincache_ucache_meminfo;
|
||||||
|
use function wincache_ucache_set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WinCache cache provider.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class WinCacheCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return wincache_ucache_get($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return wincache_ucache_exists($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return wincache_ucache_set($id, $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return wincache_ucache_delete($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
return wincache_ucache_clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetchMultiple(array $keys)
|
||||||
|
{
|
||||||
|
return wincache_ucache_get($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSaveMultiple(array $keysAndValues, $lifetime = 0)
|
||||||
|
{
|
||||||
|
$result = wincache_ucache_set($keysAndValues, null, $lifetime);
|
||||||
|
|
||||||
|
return empty($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDeleteMultiple(array $keys)
|
||||||
|
{
|
||||||
|
$result = wincache_ucache_delete($keys);
|
||||||
|
|
||||||
|
return is_array($result) && count($result) !== count($keys);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$info = wincache_ucache_info();
|
||||||
|
$meminfo = wincache_ucache_meminfo();
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['total_hit_count'],
|
||||||
|
Cache::STATS_MISSES => $info['total_miss_count'],
|
||||||
|
Cache::STATS_UPTIME => $info['total_cache_uptime'],
|
||||||
|
Cache::STATS_MEMORY_USAGE => $meminfo['memory_total'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $meminfo['memory_free'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/XcacheCache.php
vendored
Normal file
106
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/XcacheCache.php
vendored
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use BadMethodCallException;
|
||||||
|
|
||||||
|
use function ini_get;
|
||||||
|
use function serialize;
|
||||||
|
use function unserialize;
|
||||||
|
use function xcache_clear_cache;
|
||||||
|
use function xcache_get;
|
||||||
|
use function xcache_info;
|
||||||
|
use function xcache_isset;
|
||||||
|
use function xcache_set;
|
||||||
|
use function xcache_unset;
|
||||||
|
|
||||||
|
use const XC_TYPE_VAR;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Xcache cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class XcacheCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return $this->doContains($id) ? unserialize(xcache_get($id)) : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return xcache_isset($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return xcache_set($id, serialize($data), (int) $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return xcache_unset($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$this->checkAuthorization();
|
||||||
|
|
||||||
|
xcache_clear_cache(XC_TYPE_VAR);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks that xcache.admin.enable_auth is Off.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*
|
||||||
|
* @throws BadMethodCallException When xcache.admin.enable_auth is On.
|
||||||
|
*/
|
||||||
|
protected function checkAuthorization()
|
||||||
|
{
|
||||||
|
if (ini_get('xcache.admin.enable_auth')) {
|
||||||
|
throw new BadMethodCallException(
|
||||||
|
'To use all features of \Doctrine\Common\Cache\XcacheCache, '
|
||||||
|
. 'you must set "xcache.admin.enable_auth" to "Off" in your php.ini.'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
$this->checkAuthorization();
|
||||||
|
|
||||||
|
$info = xcache_info(XC_TYPE_VAR, 0);
|
||||||
|
|
||||||
|
return [
|
||||||
|
Cache::STATS_HITS => $info['hits'],
|
||||||
|
Cache::STATS_MISSES => $info['misses'],
|
||||||
|
Cache::STATS_UPTIME => null,
|
||||||
|
Cache::STATS_MEMORY_USAGE => $info['size'],
|
||||||
|
Cache::STATS_MEMORY_AVAILABLE => $info['avail'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
71
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ZendDataCache.php
vendored
Normal file
71
frontend/drupal9/vendor/doctrine/cache/lib/Doctrine/Common/Cache/ZendDataCache.php
vendored
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Cache;
|
||||||
|
|
||||||
|
use function zend_shm_cache_clear;
|
||||||
|
use function zend_shm_cache_delete;
|
||||||
|
use function zend_shm_cache_fetch;
|
||||||
|
use function zend_shm_cache_store;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Zend Data Cache cache driver.
|
||||||
|
*
|
||||||
|
* @deprecated Deprecated without replacement in doctrine/cache 1.11. This class will be dropped in 2.0
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
*/
|
||||||
|
class ZendDataCache extends CacheProvider
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFetch($id)
|
||||||
|
{
|
||||||
|
return zend_shm_cache_fetch($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doContains($id)
|
||||||
|
{
|
||||||
|
return zend_shm_cache_fetch($id) !== false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doSave($id, $data, $lifeTime = 0)
|
||||||
|
{
|
||||||
|
return zend_shm_cache_store($id, $data, $lifeTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doDelete($id)
|
||||||
|
{
|
||||||
|
return zend_shm_cache_delete($id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doFlush()
|
||||||
|
{
|
||||||
|
$namespace = $this->getNamespace();
|
||||||
|
if (empty($namespace)) {
|
||||||
|
return zend_shm_cache_clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
return zend_shm_cache_clear($namespace);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function doGetStats()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
26
frontend/drupal9/vendor/doctrine/collections/.doctrine-project.json
vendored
Normal file
26
frontend/drupal9/vendor/doctrine/collections/.doctrine-project.json
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
"active": true,
|
||||||
|
"name": "Collections",
|
||||||
|
"slug": "collections",
|
||||||
|
"docsSlug": "doctrine-collections",
|
||||||
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "2.0",
|
||||||
|
"branchName": "2.0.x",
|
||||||
|
"slug": "latest",
|
||||||
|
"upcoming": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "1.7",
|
||||||
|
"branchName": "1.7.x",
|
||||||
|
"slug": "1.7",
|
||||||
|
"upcoming": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "1.6",
|
||||||
|
"branchName": "1.6.x",
|
||||||
|
"slug": "1.6",
|
||||||
|
"current": true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
54
frontend/drupal9/vendor/doctrine/collections/CONTRIBUTING.md
vendored
Normal file
54
frontend/drupal9/vendor/doctrine/collections/CONTRIBUTING.md
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
# Contribute to Doctrine
|
||||||
|
|
||||||
|
Thank you for contributing to Doctrine!
|
||||||
|
|
||||||
|
Before we can merge your Pull-Request here are some guidelines that you need to follow.
|
||||||
|
These guidelines exist not to annoy you, but to keep the code base clean,
|
||||||
|
unified and future proof.
|
||||||
|
|
||||||
|
## We only accept PRs to "master"
|
||||||
|
|
||||||
|
Our branching strategy is "everything to master first", even
|
||||||
|
bugfixes and we then merge them into the stable branches. You should only
|
||||||
|
open pull requests against the master branch. Otherwise we cannot accept the PR.
|
||||||
|
|
||||||
|
There is one exception to the rule, when we merged a bug into some stable branches
|
||||||
|
we do occasionally accept pull requests that merge the same bug fix into earlier
|
||||||
|
branches.
|
||||||
|
|
||||||
|
## Coding Standard
|
||||||
|
|
||||||
|
We use the [Doctrine Coding Standard](https://github.com/doctrine/coding-standard).
|
||||||
|
|
||||||
|
## Unit-Tests
|
||||||
|
|
||||||
|
Please try to add a test for your pull-request.
|
||||||
|
|
||||||
|
* If you want to contribute new functionality add unit- or functional tests
|
||||||
|
depending on the scope of the feature.
|
||||||
|
|
||||||
|
You can run the unit-tests by calling ``vendor/bin/phpunit`` from the root of the project.
|
||||||
|
It will run all the project tests.
|
||||||
|
|
||||||
|
In order to do that, you will need a fresh copy of doctrine/collections, and you
|
||||||
|
will have to run a composer installation in the project:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git clone git@github.com:doctrine/collections.git
|
||||||
|
cd collections
|
||||||
|
curl -sS https://getcomposer.org/installer | php --
|
||||||
|
./composer.phar install
|
||||||
|
```
|
||||||
|
|
||||||
|
## Github Actions
|
||||||
|
|
||||||
|
We automatically run your pull request through Github Actions against supported
|
||||||
|
PHP versions. If you break the tests, we cannot merge your code, so please make
|
||||||
|
sure that your code is working before opening up a Pull-Request.
|
||||||
|
|
||||||
|
## Getting merged
|
||||||
|
|
||||||
|
Please allow us time to review your pull requests. We will give our best to review
|
||||||
|
everything as fast as possible, but cannot always live up to our own expectations.
|
||||||
|
|
||||||
|
Thank you very much again for your contribution!
|
19
frontend/drupal9/vendor/doctrine/collections/LICENSE
vendored
Normal file
19
frontend/drupal9/vendor/doctrine/collections/LICENSE
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
Copyright (c) 2006-2013 Doctrine Project
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is furnished to do
|
||||||
|
so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
92
frontend/drupal9/vendor/doctrine/collections/README.md
vendored
Normal file
92
frontend/drupal9/vendor/doctrine/collections/README.md
vendored
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
# Doctrine Collections
|
||||||
|
|
||||||
|
[](https://github.com/doctrine/collections/actions)
|
||||||
|
[](https://codecov.io/gh/doctrine/collections/branch/master)
|
||||||
|
|
||||||
|
Collections Abstraction library
|
||||||
|
|
||||||
|
## Changelog
|
||||||
|
|
||||||
|
### v1.6.1
|
||||||
|
|
||||||
|
This release, combined with the release of [`doctrine/collections` `v1.6.1`](https://github.com/doctrine/collections/releases/tag/v1.6.1),
|
||||||
|
fixes an issue where parsing annotations was not possible
|
||||||
|
for classes within `doctrine/collections`.
|
||||||
|
|
||||||
|
Specifically, `v1.6.0` introduced Psalm-specific annotations
|
||||||
|
such as (for example) `@template` and `@template-implements`,
|
||||||
|
which were both incorrectly recognized as `@template`.
|
||||||
|
|
||||||
|
`@template` has therefore been removed, and instead we use
|
||||||
|
the prefixed `@psalm-template`, which is no longer parsed
|
||||||
|
by `doctrine/collections` `v1.6.1`
|
||||||
|
|
||||||
|
Total issues resolved: **1**
|
||||||
|
|
||||||
|
- [186: Use `@psalm-template` annotation to avoid clashes](https://github.com/doctrine/collections/pull/186) thanks to @muglug
|
||||||
|
|
||||||
|
### v1.6.0
|
||||||
|
|
||||||
|
This release bumps the minimum required PHP version to 7.1.3.
|
||||||
|
|
||||||
|
Following improvements were introduced:
|
||||||
|
|
||||||
|
* `ArrayCollection#filter()` now allows filtering by key, value or both.
|
||||||
|
* When using the `ClosureExpressionVisitor` over objects with a defined
|
||||||
|
accessor and property, the accessor is prioritised.
|
||||||
|
* Updated testing tools and coding standards, autoloading, which also
|
||||||
|
led to marginal performance improvements
|
||||||
|
* Introduced generic type docblock declarations from [psalm](https://github.com/vimeo/psalm),
|
||||||
|
which should allow users to declare `/** @var Collection<KeyType, ValueType> */`
|
||||||
|
in their code, and leverage the type propagation deriving from that.
|
||||||
|
|
||||||
|
Total issues resolved: **16**
|
||||||
|
|
||||||
|
- [127: Use PSR-4](https://github.com/doctrine/collections/pull/127) thanks to @Nyholm
|
||||||
|
- [129: Remove space in method declaration](https://github.com/doctrine/collections/pull/129) thanks to @bounoable
|
||||||
|
- [130: Update build to add PHPCS and PHPStan](https://github.com/doctrine/collections/pull/130) thanks to @lcobucci
|
||||||
|
- [131: ClosureExpressionVisitor > Don't duplicate the accessor when the field already starts with it](https://github.com/doctrine/collections/pull/131) thanks to @ruudk
|
||||||
|
- [139: Apply Doctrine CS 2.1](https://github.com/doctrine/collections/pull/139) thanks to @Majkl578
|
||||||
|
- [142: CS 4.0, version composer.lock, merge stages](https://github.com/doctrine/collections/pull/142) thanks to @Majkl578
|
||||||
|
- [144: Update to PHPUnit 7](https://github.com/doctrine/collections/pull/144) thanks to @carusogabriel
|
||||||
|
- [146: Update changelog for v1.4.0 and v1.5.0](https://github.com/doctrine/collections/pull/146) thanks to @GromNaN
|
||||||
|
- [154: Update index.rst](https://github.com/doctrine/collections/pull/154) thanks to @chraiet
|
||||||
|
- [158: Extract Selectable method into own documentation section](https://github.com/doctrine/collections/pull/158) thanks to @SenseException
|
||||||
|
- [160: Update homepage](https://github.com/doctrine/collections/pull/160) thanks to @Majkl578
|
||||||
|
- [165: Allow `ArrayCollection#filter()` to filter by key, value or both](https://github.com/doctrine/collections/issues/165) thanks to @0x13a
|
||||||
|
- [167: Allow `ArrayCollection#filter()` to filter by key and also value](https://github.com/doctrine/collections/pull/167) thanks to @0x13a
|
||||||
|
- [175: CI: Test against PHP 7.4snapshot instead of nightly (8.0)](https://github.com/doctrine/collections/pull/175) thanks to @Majkl578
|
||||||
|
- [177: Generify collections using Psalm](https://github.com/doctrine/collections/pull/177) thanks to @nschoellhorn
|
||||||
|
- [178: Updated doctrine/coding-standard to 6.0](https://github.com/doctrine/collections/pull/178) thanks to @patrickjahns
|
||||||
|
|
||||||
|
### v1.5.0
|
||||||
|
|
||||||
|
* [Require PHP 7.1+](https://github.com/doctrine/collections/pull/105)
|
||||||
|
* [Drop HHVM support](https://github.com/doctrine/collections/pull/118)
|
||||||
|
|
||||||
|
### v1.4.0
|
||||||
|
|
||||||
|
* [Require PHP 5.6+](https://github.com/doctrine/collections/pull/105)
|
||||||
|
* [Add `ArrayCollection::createFrom()`](https://github.com/doctrine/collections/pull/91)
|
||||||
|
* [Support non-camel-case naming](https://github.com/doctrine/collections/pull/57)
|
||||||
|
* [Comparison `START_WITH`, `END_WITH`](https://github.com/doctrine/collections/pull/78)
|
||||||
|
* [Comparison `MEMBER_OF`](https://github.com/doctrine/collections/pull/66)
|
||||||
|
* [Add Contributing guide](https://github.com/doctrine/collections/pull/103)
|
||||||
|
|
||||||
|
### v1.3.0
|
||||||
|
|
||||||
|
* [Explicit casting of first and max results in criteria API](https://github.com/doctrine/collections/pull/26)
|
||||||
|
* [Keep keys when using `ArrayCollection#matching()` with sorting](https://github.com/doctrine/collections/pull/49)
|
||||||
|
* [Made `AbstractLazyCollection#$initialized` protected for extensibility](https://github.com/doctrine/collections/pull/52)
|
||||||
|
|
||||||
|
### v1.2.0
|
||||||
|
|
||||||
|
* Add a new ``AbstractLazyCollection``
|
||||||
|
|
||||||
|
### v1.1.0
|
||||||
|
|
||||||
|
* Deprecated ``Comparison::IS``, because it's only there for SQL semantics.
|
||||||
|
These are fixed in the ORM instead.
|
||||||
|
* Add ``Comparison::CONTAINS`` to perform partial string matches:
|
||||||
|
|
||||||
|
$criteria->andWhere($criteria->expr()->contains('property', 'Foo'));
|
37
frontend/drupal9/vendor/doctrine/collections/composer.json
vendored
Normal file
37
frontend/drupal9/vendor/doctrine/collections/composer.json
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
{
|
||||||
|
"name": "doctrine/collections",
|
||||||
|
"type": "library",
|
||||||
|
"description": "PHP Doctrine Collections library that adds additional functionality on top of PHP arrays.",
|
||||||
|
"keywords": [
|
||||||
|
"php",
|
||||||
|
"collections",
|
||||||
|
"array",
|
||||||
|
"iterators"
|
||||||
|
],
|
||||||
|
"homepage": "https://www.doctrine-project.org/projects/collections.html",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"},
|
||||||
|
{"name": "Roman Borschel", "email": "roman@code-factory.org"},
|
||||||
|
{"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"},
|
||||||
|
{"name": "Jonathan Wage", "email": "jonwage@gmail.com"},
|
||||||
|
{"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": "^7.1.3 || ^8.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "^7.5 || ^8.5 || ^9.1.5",
|
||||||
|
"doctrine/coding-standard": "^9.0",
|
||||||
|
"phpstan/phpstan": "^0.12",
|
||||||
|
"vimeo/psalm": "^4.2.1"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": { "Doctrine\\Common\\Collections\\": "lib/Doctrine/Common/Collections" }
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"Doctrine\\Tests\\": "tests/Doctrine/Tests"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
26
frontend/drupal9/vendor/doctrine/collections/docs/en/derived-collections.rst
vendored
Normal file
26
frontend/drupal9/vendor/doctrine/collections/docs/en/derived-collections.rst
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
Derived Collections
|
||||||
|
===================
|
||||||
|
|
||||||
|
You can create custom collection classes by extending the
|
||||||
|
``Doctrine\Common\Collections\ArrayCollection`` class. If the
|
||||||
|
``__construct`` semantics are different from the default ``ArrayCollection``
|
||||||
|
you can override the ``createFrom`` method:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
final class DerivedArrayCollection extends ArrayCollection
|
||||||
|
{
|
||||||
|
/** @var \stdClass */
|
||||||
|
private $foo;
|
||||||
|
|
||||||
|
public function __construct(\stdClass $foo, array $elements = [])
|
||||||
|
{
|
||||||
|
$this->foo = $foo;
|
||||||
|
|
||||||
|
parent::__construct($elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function createFrom(array $elements) : self
|
||||||
|
{
|
||||||
|
return new static($this->foo, $elements);
|
||||||
|
}
|
||||||
|
}
|
173
frontend/drupal9/vendor/doctrine/collections/docs/en/expression-builder.rst
vendored
Normal file
173
frontend/drupal9/vendor/doctrine/collections/docs/en/expression-builder.rst
vendored
Normal file
@ -0,0 +1,173 @@
|
|||||||
|
Expression Builder
|
||||||
|
==================
|
||||||
|
|
||||||
|
The Expression Builder is a convenient fluent interface for
|
||||||
|
building expressions to be used with the ``Doctrine\Common\Collections\Criteria``
|
||||||
|
class:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$criteria = new Criteria();
|
||||||
|
$criteria->where($expressionBuilder->eq('name', 'jwage'));
|
||||||
|
$criteria->orWhere($expressionBuilder->eq('name', 'romanb'));
|
||||||
|
|
||||||
|
$collection->matching($criteria);
|
||||||
|
|
||||||
|
The ``ExpressionBuilder`` has the following API:
|
||||||
|
|
||||||
|
andX
|
||||||
|
----
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->andX(
|
||||||
|
$expressionBuilder->eq('foo', 1),
|
||||||
|
$expressionBuilder->eq('bar', 1)
|
||||||
|
);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
orX
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->orX(
|
||||||
|
$expressionBuilder->eq('foo', 1),
|
||||||
|
$expressionBuilder->eq('bar', 1)
|
||||||
|
);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
eq
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->eq('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
gt
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->gt('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
lt
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->lt('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
gte
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->gte('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
lte
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->lte('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
neq
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->neq('foo', 1);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
isNull
|
||||||
|
------
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->isNull('foo');
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
in
|
||||||
|
---
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->in('foo', ['value1', 'value2']);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
notIn
|
||||||
|
-----
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->notIn('foo', ['value1', 'value2']);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
contains
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->contains('foo', 'value1');
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
memberOf
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->memberOf('foo', ['value1', 'value2']);
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
startsWith
|
||||||
|
----------
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->startsWith('foo', 'hello');
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
||||||
|
|
||||||
|
endsWith
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expressionBuilder = Criteria::expr();
|
||||||
|
|
||||||
|
$expression = $expressionBuilder->endsWith('foo', 'world');
|
||||||
|
|
||||||
|
$collection->matching(new Criteria($expression));
|
102
frontend/drupal9/vendor/doctrine/collections/docs/en/expressions.rst
vendored
Normal file
102
frontend/drupal9/vendor/doctrine/collections/docs/en/expressions.rst
vendored
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
Expressions
|
||||||
|
===========
|
||||||
|
|
||||||
|
The ``Doctrine\Common\Collections\Expr\Comparison`` class
|
||||||
|
can be used to create expressions to be used with the
|
||||||
|
``Doctrine\Common\Collections\Criteria`` class. It has the
|
||||||
|
following operator constants:
|
||||||
|
|
||||||
|
- ``Comparison::EQ``
|
||||||
|
- ``Comparison::NEQ``
|
||||||
|
- ``Comparison::LT``
|
||||||
|
- ``Comparison::LTE``
|
||||||
|
- ``Comparison::GT``
|
||||||
|
- ``Comparison::GTE``
|
||||||
|
- ``Comparison::IS``
|
||||||
|
- ``Comparison::IN``
|
||||||
|
- ``Comparison::NIN``
|
||||||
|
- ``Comparison::CONTAINS``
|
||||||
|
- ``Comparison::MEMBER_OF``
|
||||||
|
- ``Comparison::STARTS_WITH``
|
||||||
|
- ``Comparison::ENDS_WITH``
|
||||||
|
|
||||||
|
The ``Doctrine\Common\Collections\Criteria`` class has the following
|
||||||
|
API to be used with expressions:
|
||||||
|
|
||||||
|
where
|
||||||
|
-----
|
||||||
|
|
||||||
|
Sets the where expression to evaluate when this Criteria is searched for.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expr = new Comparison('key', Comparison::EQ, 'value');
|
||||||
|
|
||||||
|
$criteria->where($expr);
|
||||||
|
|
||||||
|
andWhere
|
||||||
|
--------
|
||||||
|
|
||||||
|
Appends the where expression to evaluate when this Criteria is searched for
|
||||||
|
using an AND with previous expression.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expr = new Comparison('key', Comparison::EQ, 'value');
|
||||||
|
|
||||||
|
$criteria->andWhere($expr);
|
||||||
|
|
||||||
|
orWhere
|
||||||
|
-------
|
||||||
|
|
||||||
|
Appends the where expression to evaluate when this Criteria is searched for
|
||||||
|
using an OR with previous expression.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$expr1 = new Comparison('key', Comparison::EQ, 'value1');
|
||||||
|
$expr2 = new Comparison('key', Comparison::EQ, 'value2');
|
||||||
|
|
||||||
|
$criteria->where($expr1);
|
||||||
|
$criteria->orWhere($expr2);
|
||||||
|
|
||||||
|
orderBy
|
||||||
|
-------
|
||||||
|
|
||||||
|
Sets the ordering of the result of this Criteria.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$criteria->orderBy(['name' => Criteria::ASC]);
|
||||||
|
|
||||||
|
setFirstResult
|
||||||
|
--------------
|
||||||
|
|
||||||
|
Set the number of first result that this Criteria should return.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$criteria->setFirstResult(0);
|
||||||
|
|
||||||
|
getFirstResult
|
||||||
|
--------------
|
||||||
|
|
||||||
|
Gets the current first result option of this Criteria.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$criteria->setFirstResult(10);
|
||||||
|
|
||||||
|
echo $criteria->getFirstResult(); // 10
|
||||||
|
|
||||||
|
setMaxResults
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Sets the max results that this Criteria should return.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$criteria->setMaxResults(20);
|
||||||
|
|
||||||
|
getMaxResults
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Gets the current max results option of this Criteria.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$criteria->setMaxResults(20);
|
||||||
|
|
||||||
|
echo $criteria->getMaxResults(); // 20
|
328
frontend/drupal9/vendor/doctrine/collections/docs/en/index.rst
vendored
Normal file
328
frontend/drupal9/vendor/doctrine/collections/docs/en/index.rst
vendored
Normal file
@ -0,0 +1,328 @@
|
|||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
|
Doctrine Collections is a library that contains classes for working with
|
||||||
|
arrays of data. Here is an example using the simple
|
||||||
|
``Doctrine\Common\Collections\ArrayCollection`` class:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Doctrine\Common\Collections\ArrayCollection;
|
||||||
|
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$filteredCollection = $collection->filter(function($element) {
|
||||||
|
return $element > 1;
|
||||||
|
}); // [2, 3]
|
||||||
|
|
||||||
|
Collection Methods
|
||||||
|
==================
|
||||||
|
|
||||||
|
Doctrine Collections provides an interface named ``Doctrine\Common\Collections\Collection``
|
||||||
|
that resembles the nature of a regular PHP array. That is,
|
||||||
|
it is essentially an **ordered map** that can also be used
|
||||||
|
like a list.
|
||||||
|
|
||||||
|
A Collection has an internal iterator just like a PHP array. In addition,
|
||||||
|
a Collection can be iterated with external iterators, which is preferable.
|
||||||
|
To use an external iterator simply use the foreach language construct to
|
||||||
|
iterate over the collection, which calls ``getIterator()`` internally, or
|
||||||
|
explicitly retrieve an iterator though ``getIterator()`` which can then be
|
||||||
|
used to iterate over the collection. You can not rely on the internal iterator
|
||||||
|
of the collection being at a certain position unless you explicitly positioned it before.
|
||||||
|
|
||||||
|
The methods available on the interface are:
|
||||||
|
|
||||||
|
add
|
||||||
|
---
|
||||||
|
|
||||||
|
Adds an element at the end of the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection->add('test');
|
||||||
|
|
||||||
|
clear
|
||||||
|
-----
|
||||||
|
|
||||||
|
Clears the collection, removing all elements.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection->clear();
|
||||||
|
|
||||||
|
contains
|
||||||
|
--------
|
||||||
|
|
||||||
|
Checks whether an element is contained in the collection. This is an O(n) operation, where n is the size of the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['test']);
|
||||||
|
|
||||||
|
$contains = $collection->contains('test'); // true
|
||||||
|
|
||||||
|
containsKey
|
||||||
|
-----------
|
||||||
|
|
||||||
|
Checks whether the collection contains an element with the specified key/index.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['test' => true]);
|
||||||
|
|
||||||
|
$contains = $collection->containsKey('test'); // true
|
||||||
|
|
||||||
|
current
|
||||||
|
-------
|
||||||
|
|
||||||
|
Gets the element of the collection at the current iterator position.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['first', 'second', 'third']);
|
||||||
|
|
||||||
|
$current = $collection->current(); // first
|
||||||
|
|
||||||
|
get
|
||||||
|
---
|
||||||
|
|
||||||
|
Gets the element at the specified key/index.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection([
|
||||||
|
'key' => 'value',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$value = $collection->get('key'); // value
|
||||||
|
|
||||||
|
getKeys
|
||||||
|
-------
|
||||||
|
|
||||||
|
Gets all keys/indices of the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['a', 'b', 'c']);
|
||||||
|
|
||||||
|
$keys = $collection->getKeys(); // [0, 1, 2]
|
||||||
|
|
||||||
|
getValues
|
||||||
|
---------
|
||||||
|
|
||||||
|
Gets all values of the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection([
|
||||||
|
'key1' => 'value1',
|
||||||
|
'key2' => 'value2',
|
||||||
|
'key3' => 'value3',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$values = $collection->getValues(); // ['value1', 'value2', 'value3']
|
||||||
|
|
||||||
|
isEmpty
|
||||||
|
-------
|
||||||
|
|
||||||
|
Checks whether the collection is empty (contains no elements).
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['a', 'b', 'c']);
|
||||||
|
|
||||||
|
$isEmpty = $collection->isEmpty(); // false
|
||||||
|
|
||||||
|
first
|
||||||
|
-----
|
||||||
|
|
||||||
|
Sets the internal iterator to the first element in the collection and returns this element.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['first', 'second', 'third']);
|
||||||
|
|
||||||
|
$first = $collection->first(); // first
|
||||||
|
|
||||||
|
exists
|
||||||
|
------
|
||||||
|
|
||||||
|
Tests for the existence of an element that satisfies the given predicate.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new Collection(['first', 'second', 'third']);
|
||||||
|
|
||||||
|
$exists = $collection->exists(function($key, $value) {
|
||||||
|
return $value === 'first';
|
||||||
|
}); // true
|
||||||
|
|
||||||
|
filter
|
||||||
|
------
|
||||||
|
|
||||||
|
Returns all the elements of this collection for which your callback function returns `true`.
|
||||||
|
The order and keys of the elements are preserved.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$filteredCollection = $collection->filter(function($element) {
|
||||||
|
return $element > 1;
|
||||||
|
}); // [2, 3]
|
||||||
|
|
||||||
|
forAll
|
||||||
|
------
|
||||||
|
|
||||||
|
Tests whether the given predicate holds for all elements of this collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$forAll = $collection->forAll(function($key, $value) {
|
||||||
|
return $value > 1;
|
||||||
|
}); // false
|
||||||
|
|
||||||
|
indexOf
|
||||||
|
-------
|
||||||
|
|
||||||
|
Gets the index/key of a given element. The comparison of two elements is strict, that means not only the value but also the type must match. For objects this means reference equality.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$indexOf = $collection->indexOf(3); // 2
|
||||||
|
|
||||||
|
key
|
||||||
|
---
|
||||||
|
|
||||||
|
Gets the key/index of the element at the current iterator position.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$collection->next();
|
||||||
|
|
||||||
|
$key = $collection->key(); // 1
|
||||||
|
|
||||||
|
last
|
||||||
|
----
|
||||||
|
|
||||||
|
Sets the internal iterator to the last element in the collection and returns this element.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$last = $collection->last(); // 3
|
||||||
|
|
||||||
|
map
|
||||||
|
---
|
||||||
|
|
||||||
|
Applies the given function to each element in the collection and returns a new collection with the elements returned by the function.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$mappedCollection = $collection->map(function($value) {
|
||||||
|
return $value + 1;
|
||||||
|
}); // [2, 3, 4]
|
||||||
|
|
||||||
|
next
|
||||||
|
----
|
||||||
|
|
||||||
|
Moves the internal iterator position to the next element and returns this element.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$next = $collection->next(); // 2
|
||||||
|
|
||||||
|
partition
|
||||||
|
---------
|
||||||
|
|
||||||
|
Partitions this collection in two collections according to a predicate. Keys are preserved in the resulting collections.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$mappedCollection = $collection->partition(function($key, $value) {
|
||||||
|
return $value > 1
|
||||||
|
}); // [[2, 3], [1]]
|
||||||
|
|
||||||
|
remove
|
||||||
|
------
|
||||||
|
|
||||||
|
Removes the element at the specified index from the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$collection->remove(0); // [2, 3]
|
||||||
|
|
||||||
|
removeElement
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Removes the specified element from the collection, if it is found.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([1, 2, 3]);
|
||||||
|
|
||||||
|
$collection->removeElement(3); // [1, 2]
|
||||||
|
|
||||||
|
set
|
||||||
|
---
|
||||||
|
|
||||||
|
Sets an element in the collection at the specified key/index.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection();
|
||||||
|
|
||||||
|
$collection->set('name', 'jwage');
|
||||||
|
|
||||||
|
slice
|
||||||
|
-----
|
||||||
|
|
||||||
|
Extracts a slice of $length elements starting at position $offset from the Collection. If $length is null it returns all elements from $offset to the end of the Collection. Keys have to be preserved by this method. Calling this method will only return the selected slice and NOT change the elements contained in the collection slice is called on.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([0, 1, 2, 3, 4, 5]);
|
||||||
|
|
||||||
|
$slice = $collection->slice(1, 2); // [1, 2]
|
||||||
|
|
||||||
|
toArray
|
||||||
|
-------
|
||||||
|
|
||||||
|
Gets a native PHP array representation of the collection.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
$collection = new ArrayCollection([0, 1, 2, 3, 4, 5]);
|
||||||
|
|
||||||
|
$array = $collection->toArray(); // [0, 1, 2, 3, 4, 5]
|
||||||
|
|
||||||
|
Selectable Methods
|
||||||
|
==================
|
||||||
|
|
||||||
|
Some Doctrine Collections, like ``Doctrine\Common\Collections\ArrayCollection``,
|
||||||
|
implement an interface named ``Doctrine\Common\Collections\Selectable``
|
||||||
|
that offers the usage of a powerful expressions API, where conditions
|
||||||
|
can be applied to a collection to get a result with matching elements
|
||||||
|
only.
|
||||||
|
|
||||||
|
matching
|
||||||
|
--------
|
||||||
|
|
||||||
|
Selects all elements from a selectable that match the expression and
|
||||||
|
returns a new collection containing these elements.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
use Doctrine\Common\Collections\Criteria;
|
||||||
|
use Doctrine\Common\Collections\Expr\Comparison;
|
||||||
|
|
||||||
|
$collection = new ArrayCollection([
|
||||||
|
[
|
||||||
|
'name' => 'jwage',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'name' => 'romanb',
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$expr = new Comparison('name', '=', 'jwage');
|
||||||
|
|
||||||
|
$criteria = new Criteria();
|
||||||
|
|
||||||
|
$criteria->where($expr);
|
||||||
|
|
||||||
|
$matched = $collection->matching($criteria); // ['jwage']
|
||||||
|
|
||||||
|
You can read more about expressions :ref:`here <expressions>`.
|
26
frontend/drupal9/vendor/doctrine/collections/docs/en/lazy-collections.rst
vendored
Normal file
26
frontend/drupal9/vendor/doctrine/collections/docs/en/lazy-collections.rst
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
Lazy Collections
|
||||||
|
================
|
||||||
|
|
||||||
|
To create a lazy collection you can extend the
|
||||||
|
``Doctrine\Common\Collections\AbstractLazyCollection`` class
|
||||||
|
and define the ``doInitialize`` method. Here is an example where
|
||||||
|
we lazily query the database for a collection of user records:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
use Doctrine\DBAL\Connection;
|
||||||
|
|
||||||
|
class UsersLazyCollection extends AbstractLazyCollection
|
||||||
|
{
|
||||||
|
/** @var Connection */
|
||||||
|
private $connection;
|
||||||
|
|
||||||
|
public function __construct(Connection $connection)
|
||||||
|
{
|
||||||
|
$this->connection = $connection;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function doInitialize() : void
|
||||||
|
{
|
||||||
|
$this->collection = $this->connection->fetchAll('SELECT * FROM users');
|
||||||
|
}
|
||||||
|
}
|
8
frontend/drupal9/vendor/doctrine/collections/docs/en/sidebar.rst
vendored
Normal file
8
frontend/drupal9/vendor/doctrine/collections/docs/en/sidebar.rst
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
.. toctree::
|
||||||
|
:depth: 3
|
||||||
|
|
||||||
|
index
|
||||||
|
expressions
|
||||||
|
expression-builder
|
||||||
|
derived-collections
|
||||||
|
lazy-collections
|
@ -0,0 +1,385 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use ReturnTypeWillChange;
|
||||||
|
use Traversable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lazy collection that is backed by a concrete collection
|
||||||
|
*
|
||||||
|
* @psalm-template TKey of array-key
|
||||||
|
* @psalm-template T
|
||||||
|
* @template-implements Collection<TKey,T>
|
||||||
|
*/
|
||||||
|
abstract class AbstractLazyCollection implements Collection
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The backed collection to use
|
||||||
|
*
|
||||||
|
* @psalm-var Collection<TKey,T>
|
||||||
|
* @var Collection<mixed>
|
||||||
|
*/
|
||||||
|
protected $collection;
|
||||||
|
|
||||||
|
/** @var bool */
|
||||||
|
protected $initialized = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function count()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->count();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function add($element)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->add($element);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function clear()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
$this->collection->clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function contains($element)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->contains($element);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function isEmpty()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function remove($key)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->remove($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function removeElement($element)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->removeElement($element);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function containsKey($key)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->containsKey($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function get($key)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->get($key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getKeys()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->getKeys();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getValues()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->getValues();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function set($key, $value)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
$this->collection->set($key, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function toArray()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function first()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->first();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function last()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->last();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function key()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->key();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function current()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->current();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function next()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->next();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function exists(Closure $p)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->exists($p);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function filter(Closure $p)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->filter($p);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function forAll(Closure $p)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->forAll($p);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function map(Closure $func)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->map($func);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function partition(Closure $p)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->partition($p);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function indexOf($element)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->indexOf($element);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function slice($offset, $length = null)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->slice($offset, $length);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return Traversable<int|string, mixed>
|
||||||
|
* @psalm-return Traversable<TKey,T>
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function getIterator()
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->getIterator();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetExists($offset)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->offsetExists($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @param int|string $offset
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetGet($offset)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
|
||||||
|
return $this->collection->offsetGet($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @param mixed $value
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetSet($offset, $value)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
$this->collection->offsetSet($offset, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetUnset($offset)
|
||||||
|
{
|
||||||
|
$this->initialize();
|
||||||
|
$this->collection->offsetUnset($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is the lazy collection already initialized?
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function isInitialized()
|
||||||
|
{
|
||||||
|
return $this->initialized;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the collection
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
protected function initialize()
|
||||||
|
{
|
||||||
|
if ($this->initialized) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->doInitialize();
|
||||||
|
$this->initialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Do the initialization logic
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
abstract protected function doInitialize();
|
||||||
|
}
|
463
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/ArrayCollection.php
vendored
Normal file
463
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/ArrayCollection.php
vendored
Normal file
@ -0,0 +1,463 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
use ArrayIterator;
|
||||||
|
use Closure;
|
||||||
|
use Doctrine\Common\Collections\Expr\ClosureExpressionVisitor;
|
||||||
|
use ReturnTypeWillChange;
|
||||||
|
use Traversable;
|
||||||
|
|
||||||
|
use function array_filter;
|
||||||
|
use function array_key_exists;
|
||||||
|
use function array_keys;
|
||||||
|
use function array_map;
|
||||||
|
use function array_reverse;
|
||||||
|
use function array_search;
|
||||||
|
use function array_slice;
|
||||||
|
use function array_values;
|
||||||
|
use function count;
|
||||||
|
use function current;
|
||||||
|
use function end;
|
||||||
|
use function in_array;
|
||||||
|
use function key;
|
||||||
|
use function next;
|
||||||
|
use function reset;
|
||||||
|
use function spl_object_hash;
|
||||||
|
use function uasort;
|
||||||
|
|
||||||
|
use const ARRAY_FILTER_USE_BOTH;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An ArrayCollection is a Collection implementation that wraps a regular PHP array.
|
||||||
|
*
|
||||||
|
* Warning: Using (un-)serialize() on a collection is not a supported use-case
|
||||||
|
* and may break when we change the internals in the future. If you need to
|
||||||
|
* serialize a collection use {@link toArray()} and reconstruct the collection
|
||||||
|
* manually.
|
||||||
|
*
|
||||||
|
* @psalm-template TKey of array-key
|
||||||
|
* @psalm-template T
|
||||||
|
* @template-implements Collection<TKey,T>
|
||||||
|
* @template-implements Selectable<TKey,T>
|
||||||
|
* @psalm-consistent-constructor
|
||||||
|
*/
|
||||||
|
class ArrayCollection implements Collection, Selectable
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* An array containing the entries of this collection.
|
||||||
|
*
|
||||||
|
* @psalm-var array<TKey,T>
|
||||||
|
* @var mixed[]
|
||||||
|
*/
|
||||||
|
private $elements;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes a new ArrayCollection.
|
||||||
|
*
|
||||||
|
* @param array $elements
|
||||||
|
* @psalm-param array<TKey,T> $elements
|
||||||
|
*/
|
||||||
|
public function __construct(array $elements = [])
|
||||||
|
{
|
||||||
|
$this->elements = $elements;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function toArray()
|
||||||
|
{
|
||||||
|
return $this->elements;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function first()
|
||||||
|
{
|
||||||
|
return reset($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new instance from the specified elements.
|
||||||
|
*
|
||||||
|
* This method is provided for derived classes to specify how a new
|
||||||
|
* instance should be created when constructor semantics have changed.
|
||||||
|
*
|
||||||
|
* @param array $elements Elements.
|
||||||
|
* @psalm-param array<K,V> $elements
|
||||||
|
*
|
||||||
|
* @return static
|
||||||
|
* @psalm-return static<K,V>
|
||||||
|
*
|
||||||
|
* @psalm-template K of array-key
|
||||||
|
* @psalm-template V
|
||||||
|
*/
|
||||||
|
protected function createFrom(array $elements)
|
||||||
|
{
|
||||||
|
return new static($elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function last()
|
||||||
|
{
|
||||||
|
return end($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function key()
|
||||||
|
{
|
||||||
|
return key($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function next()
|
||||||
|
{
|
||||||
|
return next($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function current()
|
||||||
|
{
|
||||||
|
return current($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function remove($key)
|
||||||
|
{
|
||||||
|
if (! isset($this->elements[$key]) && ! array_key_exists($key, $this->elements)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$removed = $this->elements[$key];
|
||||||
|
unset($this->elements[$key]);
|
||||||
|
|
||||||
|
return $removed;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function removeElement($element)
|
||||||
|
{
|
||||||
|
$key = array_search($element, $this->elements, true);
|
||||||
|
|
||||||
|
if ($key === false) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($this->elements[$key]);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Required by interface ArrayAccess.
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetExists($offset)
|
||||||
|
{
|
||||||
|
return $this->containsKey($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Required by interface ArrayAccess.
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetGet($offset)
|
||||||
|
{
|
||||||
|
return $this->get($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Required by interface ArrayAccess.
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetSet($offset, $value)
|
||||||
|
{
|
||||||
|
if (! isset($offset)) {
|
||||||
|
$this->add($value);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->set($offset, $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Required by interface ArrayAccess.
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param TKey $offset
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function offsetUnset($offset)
|
||||||
|
{
|
||||||
|
$this->remove($offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function containsKey($key)
|
||||||
|
{
|
||||||
|
return isset($this->elements[$key]) || array_key_exists($key, $this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function contains($element)
|
||||||
|
{
|
||||||
|
return in_array($element, $this->elements, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function exists(Closure $p)
|
||||||
|
{
|
||||||
|
foreach ($this->elements as $key => $element) {
|
||||||
|
if ($p($key, $element)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function indexOf($element)
|
||||||
|
{
|
||||||
|
return array_search($element, $this->elements, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function get($key)
|
||||||
|
{
|
||||||
|
return $this->elements[$key] ?? null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getKeys()
|
||||||
|
{
|
||||||
|
return array_keys($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function getValues()
|
||||||
|
{
|
||||||
|
return array_values($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function count()
|
||||||
|
{
|
||||||
|
return count($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function set($key, $value)
|
||||||
|
{
|
||||||
|
$this->elements[$key] = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-suppress InvalidPropertyAssignmentValue
|
||||||
|
*
|
||||||
|
* This breaks assumptions about the template type, but it would
|
||||||
|
* be a backwards-incompatible change to remove this method
|
||||||
|
*/
|
||||||
|
public function add($element)
|
||||||
|
{
|
||||||
|
$this->elements[] = $element;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function isEmpty()
|
||||||
|
{
|
||||||
|
return empty($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return Traversable<int|string, mixed>
|
||||||
|
* @psalm-return Traversable<TKey,T>
|
||||||
|
*/
|
||||||
|
#[ReturnTypeWillChange]
|
||||||
|
public function getIterator()
|
||||||
|
{
|
||||||
|
return new ArrayIterator($this->elements);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @psalm-param Closure(T=):U $func
|
||||||
|
*
|
||||||
|
* @return static
|
||||||
|
* @psalm-return static<TKey, U>
|
||||||
|
*
|
||||||
|
* @psalm-template U
|
||||||
|
*/
|
||||||
|
public function map(Closure $func)
|
||||||
|
{
|
||||||
|
return $this->createFrom(array_map($func, $this->elements));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*
|
||||||
|
* @return static
|
||||||
|
* @psalm-return static<TKey,T>
|
||||||
|
*/
|
||||||
|
public function filter(Closure $p)
|
||||||
|
{
|
||||||
|
return $this->createFrom(array_filter($this->elements, $p, ARRAY_FILTER_USE_BOTH));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function forAll(Closure $p)
|
||||||
|
{
|
||||||
|
foreach ($this->elements as $key => $element) {
|
||||||
|
if (! $p($key, $element)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function partition(Closure $p)
|
||||||
|
{
|
||||||
|
$matches = $noMatches = [];
|
||||||
|
|
||||||
|
foreach ($this->elements as $key => $element) {
|
||||||
|
if ($p($key, $element)) {
|
||||||
|
$matches[$key] = $element;
|
||||||
|
} else {
|
||||||
|
$noMatches[$key] = $element;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return [$this->createFrom($matches), $this->createFrom($noMatches)];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a string representation of this object.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function __toString()
|
||||||
|
{
|
||||||
|
return self::class . '@' . spl_object_hash($this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function clear()
|
||||||
|
{
|
||||||
|
$this->elements = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function slice($offset, $length = null)
|
||||||
|
{
|
||||||
|
return array_slice($this->elements, $offset, $length, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function matching(Criteria $criteria)
|
||||||
|
{
|
||||||
|
$expr = $criteria->getWhereExpression();
|
||||||
|
$filtered = $this->elements;
|
||||||
|
|
||||||
|
if ($expr) {
|
||||||
|
$visitor = new ClosureExpressionVisitor();
|
||||||
|
$filter = $visitor->dispatch($expr);
|
||||||
|
$filtered = array_filter($filtered, $filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
$orderings = $criteria->getOrderings();
|
||||||
|
|
||||||
|
if ($orderings) {
|
||||||
|
$next = null;
|
||||||
|
foreach (array_reverse($orderings) as $field => $ordering) {
|
||||||
|
$next = ClosureExpressionVisitor::sortByField($field, $ordering === Criteria::DESC ? -1 : 1, $next);
|
||||||
|
}
|
||||||
|
|
||||||
|
uasort($filtered, $next);
|
||||||
|
}
|
||||||
|
|
||||||
|
$offset = $criteria->getFirstResult();
|
||||||
|
$length = $criteria->getMaxResults();
|
||||||
|
|
||||||
|
if ($offset || $length) {
|
||||||
|
$filtered = array_slice($filtered, (int) $offset, $length);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->createFrom($filtered);
|
||||||
|
}
|
||||||
|
}
|
276
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Collection.php
vendored
Normal file
276
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Collection.php
vendored
Normal file
@ -0,0 +1,276 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
use ArrayAccess;
|
||||||
|
use Closure;
|
||||||
|
use Countable;
|
||||||
|
use IteratorAggregate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The missing (SPL) Collection/Array/OrderedMap interface.
|
||||||
|
*
|
||||||
|
* A Collection resembles the nature of a regular PHP array. That is,
|
||||||
|
* it is essentially an <b>ordered map</b> that can also be used
|
||||||
|
* like a list.
|
||||||
|
*
|
||||||
|
* A Collection has an internal iterator just like a PHP array. In addition,
|
||||||
|
* a Collection can be iterated with external iterators, which is preferable.
|
||||||
|
* To use an external iterator simply use the foreach language construct to
|
||||||
|
* iterate over the collection (which calls {@link getIterator()} internally) or
|
||||||
|
* explicitly retrieve an iterator though {@link getIterator()} which can then be
|
||||||
|
* used to iterate over the collection.
|
||||||
|
* You can not rely on the internal iterator of the collection being at a certain
|
||||||
|
* position unless you explicitly positioned it before. Prefer iteration with
|
||||||
|
* external iterators.
|
||||||
|
*
|
||||||
|
* @psalm-template TKey of array-key
|
||||||
|
* @psalm-template T
|
||||||
|
* @template-extends IteratorAggregate<TKey, T>
|
||||||
|
* @template-extends ArrayAccess<TKey|null, T>
|
||||||
|
*/
|
||||||
|
interface Collection extends Countable, IteratorAggregate, ArrayAccess
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Adds an element at the end of the collection.
|
||||||
|
*
|
||||||
|
* @param mixed $element The element to add.
|
||||||
|
* @psalm-param T $element
|
||||||
|
*
|
||||||
|
* @return true Always TRUE.
|
||||||
|
*/
|
||||||
|
public function add($element);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clears the collection, removing all elements.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function clear();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether an element is contained in the collection.
|
||||||
|
* This is an O(n) operation, where n is the size of the collection.
|
||||||
|
*
|
||||||
|
* @param mixed $element The element to search for.
|
||||||
|
* @psalm-param T $element
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the collection contains the element, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function contains($element);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether the collection is empty (contains no elements).
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the collection is empty, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function isEmpty();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the element at the specified index from the collection.
|
||||||
|
*
|
||||||
|
* @param string|int $key The key/index of the element to remove.
|
||||||
|
* @psalm-param TKey $key
|
||||||
|
*
|
||||||
|
* @return mixed The removed element or NULL, if the collection did not contain the element.
|
||||||
|
* @psalm-return T|null
|
||||||
|
*/
|
||||||
|
public function remove($key);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the specified element from the collection, if it is found.
|
||||||
|
*
|
||||||
|
* @param mixed $element The element to remove.
|
||||||
|
* @psalm-param T $element
|
||||||
|
*
|
||||||
|
* @return bool TRUE if this collection contained the specified element, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function removeElement($element);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether the collection contains an element with the specified key/index.
|
||||||
|
*
|
||||||
|
* @param string|int $key The key/index to check for.
|
||||||
|
* @psalm-param TKey $key
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the collection contains an element with the specified key/index,
|
||||||
|
* FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function containsKey($key);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the element at the specified key/index.
|
||||||
|
*
|
||||||
|
* @param string|int $key The key/index of the element to retrieve.
|
||||||
|
* @psalm-param TKey $key
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
* @psalm-return T|null
|
||||||
|
*/
|
||||||
|
public function get($key);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets all keys/indices of the collection.
|
||||||
|
*
|
||||||
|
* @return int[]|string[] The keys/indices of the collection, in the order of the corresponding
|
||||||
|
* elements in the collection.
|
||||||
|
* @psalm-return TKey[]
|
||||||
|
*/
|
||||||
|
public function getKeys();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets all values of the collection.
|
||||||
|
*
|
||||||
|
* @return mixed[] The values of all elements in the collection, in the
|
||||||
|
* order they appear in the collection.
|
||||||
|
* @psalm-return T[]
|
||||||
|
*/
|
||||||
|
public function getValues();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets an element in the collection at the specified key/index.
|
||||||
|
*
|
||||||
|
* @param string|int $key The key/index of the element to set.
|
||||||
|
* @param mixed $value The element to set.
|
||||||
|
* @psalm-param TKey $key
|
||||||
|
* @psalm-param T $value
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function set($key, $value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a native PHP array representation of the collection.
|
||||||
|
*
|
||||||
|
* @return mixed[]
|
||||||
|
* @psalm-return array<TKey,T>
|
||||||
|
*/
|
||||||
|
public function toArray();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the internal iterator to the first element in the collection and returns this element.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
* @psalm-return T|false
|
||||||
|
*/
|
||||||
|
public function first();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the internal iterator to the last element in the collection and returns this element.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
* @psalm-return T|false
|
||||||
|
*/
|
||||||
|
public function last();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the key/index of the element at the current iterator position.
|
||||||
|
*
|
||||||
|
* @return int|string|null
|
||||||
|
* @psalm-return TKey|null
|
||||||
|
*/
|
||||||
|
public function key();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the element of the collection at the current iterator position.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
* @psalm-return T|false
|
||||||
|
*/
|
||||||
|
public function current();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Moves the internal iterator position to the next element and returns this element.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
* @psalm-return T|false
|
||||||
|
*/
|
||||||
|
public function next();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for the existence of an element that satisfies the given predicate.
|
||||||
|
*
|
||||||
|
* @param Closure $p The predicate.
|
||||||
|
* @psalm-param Closure(TKey=, T=):bool $p
|
||||||
|
*
|
||||||
|
* @return bool TRUE if the predicate is TRUE for at least one element, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function exists(Closure $p);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns all the elements of this collection that satisfy the predicate p.
|
||||||
|
* The order of the elements is preserved.
|
||||||
|
*
|
||||||
|
* @param Closure $p The predicate used for filtering.
|
||||||
|
* @psalm-param Closure(T=):bool $p
|
||||||
|
*
|
||||||
|
* @return Collection<mixed> A collection with the results of the filter operation.
|
||||||
|
* @psalm-return Collection<TKey, T>
|
||||||
|
*/
|
||||||
|
public function filter(Closure $p);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests whether the given predicate p holds for all elements of this collection.
|
||||||
|
*
|
||||||
|
* @param Closure $p The predicate.
|
||||||
|
* @psalm-param Closure(TKey=, T=):bool $p
|
||||||
|
*
|
||||||
|
* @return bool TRUE, if the predicate yields TRUE for all elements, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function forAll(Closure $p);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Applies the given function to each element in the collection and returns
|
||||||
|
* a new collection with the elements returned by the function.
|
||||||
|
*
|
||||||
|
* @psalm-param Closure(T=):U $func
|
||||||
|
*
|
||||||
|
* @return Collection<mixed>
|
||||||
|
* @psalm-return Collection<TKey, U>
|
||||||
|
*
|
||||||
|
* @psalm-template U
|
||||||
|
*/
|
||||||
|
public function map(Closure $func);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Partitions this collection in two collections according to a predicate.
|
||||||
|
* Keys are preserved in the resulting collections.
|
||||||
|
*
|
||||||
|
* @param Closure $p The predicate on which to partition.
|
||||||
|
* @psalm-param Closure(TKey=, T=):bool $p
|
||||||
|
*
|
||||||
|
* @return Collection<mixed> An array with two elements. The first element contains the collection
|
||||||
|
* of elements where the predicate returned TRUE, the second element
|
||||||
|
* contains the collection of elements where the predicate returned FALSE.
|
||||||
|
* @psalm-return array{0: Collection<TKey, T>, 1: Collection<TKey, T>}
|
||||||
|
*/
|
||||||
|
public function partition(Closure $p);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the index/key of a given element. The comparison of two elements is strict,
|
||||||
|
* that means not only the value but also the type must match.
|
||||||
|
* For objects this means reference equality.
|
||||||
|
*
|
||||||
|
* @param mixed $element The element to search for.
|
||||||
|
* @psalm-param T $element
|
||||||
|
*
|
||||||
|
* @return int|string|bool The key/index of the element or FALSE if the element was not found.
|
||||||
|
* @psalm-return TKey|false
|
||||||
|
*/
|
||||||
|
public function indexOf($element);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extracts a slice of $length elements starting at position $offset from the Collection.
|
||||||
|
*
|
||||||
|
* If $length is null it returns all elements from $offset to the end of the Collection.
|
||||||
|
* Keys have to be preserved by this method. Calling this method will only return the
|
||||||
|
* selected slice and NOT change the elements contained in the collection slice is called on.
|
||||||
|
*
|
||||||
|
* @param int $offset The offset to start from.
|
||||||
|
* @param int|null $length The maximum number of elements to return, or null for no limit.
|
||||||
|
*
|
||||||
|
* @return mixed[]
|
||||||
|
* @psalm-return array<TKey,T>
|
||||||
|
*/
|
||||||
|
public function slice($offset, $length = null);
|
||||||
|
}
|
225
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Criteria.php
vendored
Normal file
225
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Criteria.php
vendored
Normal file
@ -0,0 +1,225 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
use Doctrine\Common\Collections\Expr\CompositeExpression;
|
||||||
|
use Doctrine\Common\Collections\Expr\Expression;
|
||||||
|
|
||||||
|
use function array_map;
|
||||||
|
use function strtoupper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Criteria for filtering Selectable collections.
|
||||||
|
*
|
||||||
|
* @psalm-consistent-constructor
|
||||||
|
*/
|
||||||
|
class Criteria
|
||||||
|
{
|
||||||
|
public const ASC = 'ASC';
|
||||||
|
|
||||||
|
public const DESC = 'DESC';
|
||||||
|
|
||||||
|
/** @var ExpressionBuilder|null */
|
||||||
|
private static $expressionBuilder;
|
||||||
|
|
||||||
|
/** @var Expression|null */
|
||||||
|
private $expression;
|
||||||
|
|
||||||
|
/** @var string[] */
|
||||||
|
private $orderings = [];
|
||||||
|
|
||||||
|
/** @var int|null */
|
||||||
|
private $firstResult;
|
||||||
|
|
||||||
|
/** @var int|null */
|
||||||
|
private $maxResults;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance of the class.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public static function create()
|
||||||
|
{
|
||||||
|
return new static();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the expression builder.
|
||||||
|
*
|
||||||
|
* @return ExpressionBuilder
|
||||||
|
*/
|
||||||
|
public static function expr()
|
||||||
|
{
|
||||||
|
if (self::$expressionBuilder === null) {
|
||||||
|
self::$expressionBuilder = new ExpressionBuilder();
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::$expressionBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a new Criteria.
|
||||||
|
*
|
||||||
|
* @param string[]|null $orderings
|
||||||
|
* @param int|null $firstResult
|
||||||
|
* @param int|null $maxResults
|
||||||
|
*/
|
||||||
|
public function __construct(?Expression $expression = null, ?array $orderings = null, $firstResult = null, $maxResults = null)
|
||||||
|
{
|
||||||
|
$this->expression = $expression;
|
||||||
|
|
||||||
|
$this->setFirstResult($firstResult);
|
||||||
|
$this->setMaxResults($maxResults);
|
||||||
|
|
||||||
|
if ($orderings === null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->orderBy($orderings);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the where expression to evaluate when this Criteria is searched for.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function where(Expression $expression)
|
||||||
|
{
|
||||||
|
$this->expression = $expression;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Appends the where expression to evaluate when this Criteria is searched for
|
||||||
|
* using an AND with previous expression.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function andWhere(Expression $expression)
|
||||||
|
{
|
||||||
|
if ($this->expression === null) {
|
||||||
|
return $this->where($expression);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->expression = new CompositeExpression(
|
||||||
|
CompositeExpression::TYPE_AND,
|
||||||
|
[$this->expression, $expression]
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Appends the where expression to evaluate when this Criteria is searched for
|
||||||
|
* using an OR with previous expression.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function orWhere(Expression $expression)
|
||||||
|
{
|
||||||
|
if ($this->expression === null) {
|
||||||
|
return $this->where($expression);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->expression = new CompositeExpression(
|
||||||
|
CompositeExpression::TYPE_OR,
|
||||||
|
[$this->expression, $expression]
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the expression attached to this Criteria.
|
||||||
|
*
|
||||||
|
* @return Expression|null
|
||||||
|
*/
|
||||||
|
public function getWhereExpression()
|
||||||
|
{
|
||||||
|
return $this->expression;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the current orderings of this Criteria.
|
||||||
|
*
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
public function getOrderings()
|
||||||
|
{
|
||||||
|
return $this->orderings;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the ordering of the result of this Criteria.
|
||||||
|
*
|
||||||
|
* Keys are field and values are the order, being either ASC or DESC.
|
||||||
|
*
|
||||||
|
* @see Criteria::ASC
|
||||||
|
* @see Criteria::DESC
|
||||||
|
*
|
||||||
|
* @param string[] $orderings
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function orderBy(array $orderings)
|
||||||
|
{
|
||||||
|
$this->orderings = array_map(
|
||||||
|
static function (string $ordering): string {
|
||||||
|
return strtoupper($ordering) === Criteria::ASC ? Criteria::ASC : Criteria::DESC;
|
||||||
|
},
|
||||||
|
$orderings
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the current first result option of this Criteria.
|
||||||
|
*
|
||||||
|
* @return int|null
|
||||||
|
*/
|
||||||
|
public function getFirstResult()
|
||||||
|
{
|
||||||
|
return $this->firstResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the number of first result that this Criteria should return.
|
||||||
|
*
|
||||||
|
* @param int|null $firstResult The value to set.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function setFirstResult($firstResult)
|
||||||
|
{
|
||||||
|
$this->firstResult = $firstResult;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets maxResults.
|
||||||
|
*
|
||||||
|
* @return int|null
|
||||||
|
*/
|
||||||
|
public function getMaxResults()
|
||||||
|
{
|
||||||
|
return $this->maxResults;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets maxResults.
|
||||||
|
*
|
||||||
|
* @param int|null $maxResults The value to set.
|
||||||
|
*
|
||||||
|
* @return Criteria
|
||||||
|
*/
|
||||||
|
public function setMaxResults($maxResults)
|
||||||
|
{
|
||||||
|
$this->maxResults = $maxResults;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,265 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
use ArrayAccess;
|
||||||
|
use Closure;
|
||||||
|
use RuntimeException;
|
||||||
|
|
||||||
|
use function in_array;
|
||||||
|
use function is_array;
|
||||||
|
use function is_scalar;
|
||||||
|
use function iterator_to_array;
|
||||||
|
use function method_exists;
|
||||||
|
use function preg_match;
|
||||||
|
use function preg_replace_callback;
|
||||||
|
use function strlen;
|
||||||
|
use function strpos;
|
||||||
|
use function strtoupper;
|
||||||
|
use function substr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Walks an expression graph and turns it into a PHP closure.
|
||||||
|
*
|
||||||
|
* This closure can be used with {@Collection#filter()} and is used internally
|
||||||
|
* by {@ArrayCollection#select()}.
|
||||||
|
*/
|
||||||
|
class ClosureExpressionVisitor extends ExpressionVisitor
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Accesses the field of a given object. This field has to be public
|
||||||
|
* directly or indirectly (through an accessor get*, is*, or a magic
|
||||||
|
* method, __get, __call).
|
||||||
|
*
|
||||||
|
* @param object|mixed[] $object
|
||||||
|
* @param string $field
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public static function getObjectFieldValue($object, $field)
|
||||||
|
{
|
||||||
|
if (is_array($object)) {
|
||||||
|
return $object[$field];
|
||||||
|
}
|
||||||
|
|
||||||
|
$accessors = ['get', 'is'];
|
||||||
|
|
||||||
|
foreach ($accessors as $accessor) {
|
||||||
|
$accessor .= $field;
|
||||||
|
|
||||||
|
if (method_exists($object, $accessor)) {
|
||||||
|
return $object->$accessor();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (preg_match('/^is[A-Z]+/', $field) === 1 && method_exists($object, $field)) {
|
||||||
|
return $object->$field();
|
||||||
|
}
|
||||||
|
|
||||||
|
// __call should be triggered for get.
|
||||||
|
$accessor = $accessors[0] . $field;
|
||||||
|
|
||||||
|
if (method_exists($object, '__call')) {
|
||||||
|
return $object->$accessor();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($object instanceof ArrayAccess) {
|
||||||
|
return $object[$field];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($object->$field)) {
|
||||||
|
return $object->$field;
|
||||||
|
}
|
||||||
|
|
||||||
|
// camelcase field name to support different variable naming conventions
|
||||||
|
$ccField = preg_replace_callback('/_(.?)/', static function ($matches) {
|
||||||
|
return strtoupper($matches[1]);
|
||||||
|
}, $field);
|
||||||
|
|
||||||
|
foreach ($accessors as $accessor) {
|
||||||
|
$accessor .= $ccField;
|
||||||
|
|
||||||
|
if (method_exists($object, $accessor)) {
|
||||||
|
return $object->$accessor();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $object->$field;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper for sorting arrays of objects based on multiple fields + orientations.
|
||||||
|
*
|
||||||
|
* @param string $name
|
||||||
|
* @param int $orientation
|
||||||
|
*
|
||||||
|
* @return Closure
|
||||||
|
*/
|
||||||
|
public static function sortByField($name, $orientation = 1, ?Closure $next = null)
|
||||||
|
{
|
||||||
|
if (! $next) {
|
||||||
|
$next = static function (): int {
|
||||||
|
return 0;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return static function ($a, $b) use ($name, $next, $orientation): int {
|
||||||
|
$aValue = ClosureExpressionVisitor::getObjectFieldValue($a, $name);
|
||||||
|
|
||||||
|
$bValue = ClosureExpressionVisitor::getObjectFieldValue($b, $name);
|
||||||
|
|
||||||
|
if ($aValue === $bValue) {
|
||||||
|
return $next($a, $b);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ($aValue > $bValue ? 1 : -1) * $orientation;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function walkComparison(Comparison $comparison)
|
||||||
|
{
|
||||||
|
$field = $comparison->getField();
|
||||||
|
$value = $comparison->getValue()->getValue(); // shortcut for walkValue()
|
||||||
|
|
||||||
|
switch ($comparison->getOperator()) {
|
||||||
|
case Comparison::EQ:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) === $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::NEQ:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) !== $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::LT:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) < $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::LTE:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) <= $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::GT:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) > $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::GTE:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return ClosureExpressionVisitor::getObjectFieldValue($object, $field) >= $value;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::IN:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
$fieldValue = ClosureExpressionVisitor::getObjectFieldValue($object, $field);
|
||||||
|
|
||||||
|
return in_array($fieldValue, $value, is_scalar($fieldValue));
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::NIN:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
$fieldValue = ClosureExpressionVisitor::getObjectFieldValue($object, $field);
|
||||||
|
|
||||||
|
return ! in_array($fieldValue, $value, is_scalar($fieldValue));
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::CONTAINS:
|
||||||
|
return static function ($object) use ($field, $value) {
|
||||||
|
return strpos(ClosureExpressionVisitor::getObjectFieldValue($object, $field), $value) !== false;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::MEMBER_OF:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
$fieldValues = ClosureExpressionVisitor::getObjectFieldValue($object, $field);
|
||||||
|
|
||||||
|
if (! is_array($fieldValues)) {
|
||||||
|
$fieldValues = iterator_to_array($fieldValues);
|
||||||
|
}
|
||||||
|
|
||||||
|
return in_array($value, $fieldValues, true);
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::STARTS_WITH:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return strpos(ClosureExpressionVisitor::getObjectFieldValue($object, $field), $value) === 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
case Comparison::ENDS_WITH:
|
||||||
|
return static function ($object) use ($field, $value): bool {
|
||||||
|
return $value === substr(ClosureExpressionVisitor::getObjectFieldValue($object, $field), -strlen($value));
|
||||||
|
};
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new RuntimeException('Unknown comparison operator: ' . $comparison->getOperator());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function walkValue(Value $value)
|
||||||
|
{
|
||||||
|
return $value->getValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function walkCompositeExpression(CompositeExpression $expr)
|
||||||
|
{
|
||||||
|
$expressionList = [];
|
||||||
|
|
||||||
|
foreach ($expr->getExpressionList() as $child) {
|
||||||
|
$expressionList[] = $this->dispatch($child);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch ($expr->getType()) {
|
||||||
|
case CompositeExpression::TYPE_AND:
|
||||||
|
return $this->andExpressions($expressionList);
|
||||||
|
|
||||||
|
case CompositeExpression::TYPE_OR:
|
||||||
|
return $this->orExpressions($expressionList);
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new RuntimeException('Unknown composite ' . $expr->getType());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param callable[] $expressions
|
||||||
|
*/
|
||||||
|
private function andExpressions(array $expressions): callable
|
||||||
|
{
|
||||||
|
return static function ($object) use ($expressions): bool {
|
||||||
|
foreach ($expressions as $expression) {
|
||||||
|
if (! $expression($object)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param callable[] $expressions
|
||||||
|
*/
|
||||||
|
private function orExpressions(array $expressions): callable
|
||||||
|
{
|
||||||
|
return static function ($object) use ($expressions): bool {
|
||||||
|
foreach ($expressions as $expression) {
|
||||||
|
if ($expression($object)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
80
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Comparison.php
vendored
Normal file
80
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Comparison.php
vendored
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Comparison of a field with a value by the given operator.
|
||||||
|
*/
|
||||||
|
class Comparison implements Expression
|
||||||
|
{
|
||||||
|
public const EQ = '=';
|
||||||
|
public const NEQ = '<>';
|
||||||
|
public const LT = '<';
|
||||||
|
public const LTE = '<=';
|
||||||
|
public const GT = '>';
|
||||||
|
public const GTE = '>=';
|
||||||
|
public const IS = '='; // no difference with EQ
|
||||||
|
public const IN = 'IN';
|
||||||
|
public const NIN = 'NIN';
|
||||||
|
public const CONTAINS = 'CONTAINS';
|
||||||
|
public const MEMBER_OF = 'MEMBER_OF';
|
||||||
|
public const STARTS_WITH = 'STARTS_WITH';
|
||||||
|
public const ENDS_WITH = 'ENDS_WITH';
|
||||||
|
|
||||||
|
/** @var string */
|
||||||
|
private $field;
|
||||||
|
|
||||||
|
/** @var string */
|
||||||
|
private $op;
|
||||||
|
|
||||||
|
/** @var Value */
|
||||||
|
private $value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param string $operator
|
||||||
|
* @param mixed $value
|
||||||
|
*/
|
||||||
|
public function __construct($field, $operator, $value)
|
||||||
|
{
|
||||||
|
if (! ($value instanceof Value)) {
|
||||||
|
$value = new Value($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->field = $field;
|
||||||
|
$this->op = $operator;
|
||||||
|
$this->value = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getField()
|
||||||
|
{
|
||||||
|
return $this->field;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Value
|
||||||
|
*/
|
||||||
|
public function getValue()
|
||||||
|
{
|
||||||
|
return $this->value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getOperator()
|
||||||
|
{
|
||||||
|
return $this->op;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function visit(ExpressionVisitor $visitor)
|
||||||
|
{
|
||||||
|
return $visitor->walkComparison($this);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,69 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
use RuntimeException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expression of Expressions combined by AND or OR operation.
|
||||||
|
*/
|
||||||
|
class CompositeExpression implements Expression
|
||||||
|
{
|
||||||
|
public const TYPE_AND = 'AND';
|
||||||
|
public const TYPE_OR = 'OR';
|
||||||
|
|
||||||
|
/** @var string */
|
||||||
|
private $type;
|
||||||
|
|
||||||
|
/** @var Expression[] */
|
||||||
|
private $expressions = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $type
|
||||||
|
* @param mixed[] $expressions
|
||||||
|
*
|
||||||
|
* @throws RuntimeException
|
||||||
|
*/
|
||||||
|
public function __construct($type, array $expressions)
|
||||||
|
{
|
||||||
|
$this->type = $type;
|
||||||
|
|
||||||
|
foreach ($expressions as $expr) {
|
||||||
|
if ($expr instanceof Value) {
|
||||||
|
throw new RuntimeException('Values are not supported expressions as children of and/or expressions.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! ($expr instanceof Expression)) {
|
||||||
|
throw new RuntimeException('No expression given to CompositeExpression.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->expressions[] = $expr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the list of expressions nested in this composite.
|
||||||
|
*
|
||||||
|
* @return Expression[]
|
||||||
|
*/
|
||||||
|
public function getExpressionList()
|
||||||
|
{
|
||||||
|
return $this->expressions;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getType()
|
||||||
|
{
|
||||||
|
return $this->type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function visit(ExpressionVisitor $visitor)
|
||||||
|
{
|
||||||
|
return $visitor->walkCompositeExpression($this);
|
||||||
|
}
|
||||||
|
}
|
14
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Expression.php
vendored
Normal file
14
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Expression.php
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expression for the {@link Selectable} interface.
|
||||||
|
*/
|
||||||
|
interface Expression
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function visit(ExpressionVisitor $visitor);
|
||||||
|
}
|
@ -0,0 +1,59 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
use RuntimeException;
|
||||||
|
|
||||||
|
use function get_class;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An Expression visitor walks a graph of expressions and turns them into a
|
||||||
|
* query for the underlying implementation.
|
||||||
|
*/
|
||||||
|
abstract class ExpressionVisitor
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Converts a comparison expression into the target query language output.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
abstract public function walkComparison(Comparison $comparison);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts a value expression into the target query language part.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
abstract public function walkValue(Value $value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts a composite expression into the target query language output.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
abstract public function walkCompositeExpression(CompositeExpression $expr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dispatches walking an expression to the appropriate handler.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*
|
||||||
|
* @throws RuntimeException
|
||||||
|
*/
|
||||||
|
public function dispatch(Expression $expr)
|
||||||
|
{
|
||||||
|
switch (true) {
|
||||||
|
case $expr instanceof Comparison:
|
||||||
|
return $this->walkComparison($expr);
|
||||||
|
|
||||||
|
case $expr instanceof Value:
|
||||||
|
return $this->walkValue($expr);
|
||||||
|
|
||||||
|
case $expr instanceof CompositeExpression:
|
||||||
|
return $this->walkCompositeExpression($expr);
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new RuntimeException('Unknown Expression ' . get_class($expr));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
33
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Value.php
vendored
Normal file
33
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Expr/Value.php
vendored
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections\Expr;
|
||||||
|
|
||||||
|
class Value implements Expression
|
||||||
|
{
|
||||||
|
/** @var mixed */
|
||||||
|
private $value;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $value
|
||||||
|
*/
|
||||||
|
public function __construct($value)
|
||||||
|
{
|
||||||
|
$this->value = $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getValue()
|
||||||
|
{
|
||||||
|
return $this->value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function visit(ExpressionVisitor $visitor)
|
||||||
|
{
|
||||||
|
return $visitor->walkValue($this);
|
||||||
|
}
|
||||||
|
}
|
181
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/ExpressionBuilder.php
vendored
Normal file
181
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/ExpressionBuilder.php
vendored
Normal file
@ -0,0 +1,181 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
use Doctrine\Common\Collections\Expr\Comparison;
|
||||||
|
use Doctrine\Common\Collections\Expr\CompositeExpression;
|
||||||
|
use Doctrine\Common\Collections\Expr\Value;
|
||||||
|
|
||||||
|
use function func_get_args;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Builder for Expressions in the {@link Selectable} interface.
|
||||||
|
*
|
||||||
|
* Important Notice for interoperable code: You have to use scalar
|
||||||
|
* values only for comparisons, otherwise the behavior of the comparison
|
||||||
|
* may be different between implementations (Array vs ORM vs ODM).
|
||||||
|
*/
|
||||||
|
class ExpressionBuilder
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param mixed ...$x
|
||||||
|
*
|
||||||
|
* @return CompositeExpression
|
||||||
|
*/
|
||||||
|
public function andX($x = null)
|
||||||
|
{
|
||||||
|
return new CompositeExpression(CompositeExpression::TYPE_AND, func_get_args());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed ...$x
|
||||||
|
*
|
||||||
|
* @return CompositeExpression
|
||||||
|
*/
|
||||||
|
public function orX($x = null)
|
||||||
|
{
|
||||||
|
return new CompositeExpression(CompositeExpression::TYPE_OR, func_get_args());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function eq($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::EQ, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function gt($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::GT, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function lt($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::LT, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function gte($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::GTE, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function lte($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::LTE, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function neq($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::NEQ, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function isNull($field)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::EQ, new Value(null));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed[] $values
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function in($field, array $values)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::IN, new Value($values));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed[] $values
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function notIn($field, array $values)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::NIN, new Value($values));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function contains($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::CONTAINS, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function memberOf($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::MEMBER_OF, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function startsWith($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::STARTS_WITH, new Value($value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return Comparison
|
||||||
|
*/
|
||||||
|
public function endsWith($field, $value)
|
||||||
|
{
|
||||||
|
return new Comparison($field, Comparison::ENDS_WITH, new Value($value));
|
||||||
|
}
|
||||||
|
}
|
30
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Selectable.php
vendored
Normal file
30
frontend/drupal9/vendor/doctrine/collections/lib/Doctrine/Common/Collections/Selectable.php
vendored
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Common\Collections;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for collections that allow efficient filtering with an expression API.
|
||||||
|
*
|
||||||
|
* Goal of this interface is a backend independent method to fetch elements
|
||||||
|
* from a collections. {@link Expression} is crafted in a way that you can
|
||||||
|
* implement queries from both in-memory and database-backed collections.
|
||||||
|
*
|
||||||
|
* For database backed collections this allows very efficient access by
|
||||||
|
* utilizing the query APIs, for example SQL in the ORM. Applications using
|
||||||
|
* this API can implement efficient database access without having to ask the
|
||||||
|
* EntityManager or Repositories.
|
||||||
|
*
|
||||||
|
* @psalm-template TKey as array-key
|
||||||
|
* @psalm-template T
|
||||||
|
*/
|
||||||
|
interface Selectable
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Selects all elements from a selectable that match the expression and
|
||||||
|
* returns a new collection containing these elements.
|
||||||
|
*
|
||||||
|
* @return Collection<mixed>
|
||||||
|
* @psalm-return Collection<TKey,T>
|
||||||
|
*/
|
||||||
|
public function matching(Criteria $criteria);
|
||||||
|
}
|
17
frontend/drupal9/vendor/doctrine/collections/phpstan.neon.dist
vendored
Normal file
17
frontend/drupal9/vendor/doctrine/collections/phpstan.neon.dist
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
parameters:
|
||||||
|
level: 3
|
||||||
|
paths:
|
||||||
|
- lib
|
||||||
|
ignoreErrors:
|
||||||
|
# Making classes final as suggested would be a BC-break
|
||||||
|
-
|
||||||
|
message: '~Unsafe usage of new static\(\)\.~'
|
||||||
|
paths:
|
||||||
|
- 'lib/Doctrine/Common/Collections/ArrayCollection.php'
|
||||||
|
- 'lib/Doctrine/Common/Collections/Criteria.php'
|
||||||
|
-
|
||||||
|
message: '~Array \(array\<TKey of \(int\|string\), T\>\) does not accept key int\.~'
|
||||||
|
path: 'lib/Doctrine/Common/Collections/ArrayCollection.php'
|
||||||
|
|
||||||
|
# This class is new in PHP 8.1 and PHPStan does not know it yet.
|
||||||
|
- '/Attribute class ReturnTypeWillChange does not exist./'
|
65
frontend/drupal9/vendor/doctrine/collections/psalm.xml.dist
vendored
Normal file
65
frontend/drupal9/vendor/doctrine/collections/psalm.xml.dist
vendored
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?xml version="1.0"?>
|
||||||
|
<psalm
|
||||||
|
totallyTyped="false"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="https://getpsalm.org/schema/config"
|
||||||
|
xsi:schemaLocation="https://getpsalm.org/schema/config vendor/vimeo/psalm/config.xsd"
|
||||||
|
>
|
||||||
|
<projectFiles>
|
||||||
|
<directory name="lib" />
|
||||||
|
<ignoreFiles>
|
||||||
|
<directory name="vendor" />
|
||||||
|
<directory name="lib/Doctrine/Common/Collections/Expr"/>
|
||||||
|
</ignoreFiles>
|
||||||
|
</projectFiles>
|
||||||
|
|
||||||
|
<issueHandlers>
|
||||||
|
<LessSpecificReturnType errorLevel="info" />
|
||||||
|
|
||||||
|
<!-- level 3 issues - slightly lazy code writing, but provably low false-negatives -->
|
||||||
|
|
||||||
|
<DeprecatedMethod errorLevel="info" />
|
||||||
|
<DeprecatedProperty errorLevel="info" />
|
||||||
|
<DeprecatedClass errorLevel="info" />
|
||||||
|
<DeprecatedConstant errorLevel="info" />
|
||||||
|
<DeprecatedInterface errorLevel="info" />
|
||||||
|
<DeprecatedTrait errorLevel="info" />
|
||||||
|
|
||||||
|
<InternalMethod errorLevel="info" />
|
||||||
|
<InternalProperty errorLevel="info" />
|
||||||
|
<InternalClass errorLevel="info" />
|
||||||
|
|
||||||
|
<MissingClosureReturnType errorLevel="info" />
|
||||||
|
<MissingReturnType errorLevel="info" />
|
||||||
|
<MissingPropertyType errorLevel="info" />
|
||||||
|
<InvalidDocblock errorLevel="info" />
|
||||||
|
|
||||||
|
<PropertyNotSetInConstructor errorLevel="info" />
|
||||||
|
<MissingConstructor errorLevel="info" />
|
||||||
|
<MissingClosureParamType errorLevel="info" />
|
||||||
|
<MissingParamType errorLevel="info" />
|
||||||
|
|
||||||
|
<RedundantCondition errorLevel="info" />
|
||||||
|
|
||||||
|
<DocblockTypeContradiction errorLevel="info" />
|
||||||
|
<RedundantConditionGivenDocblockType errorLevel="info" />
|
||||||
|
|
||||||
|
<UnresolvableInclude errorLevel="info" />
|
||||||
|
|
||||||
|
<RawObjectIteration errorLevel="info" />
|
||||||
|
|
||||||
|
<InvalidStringClass errorLevel="info" />
|
||||||
|
<UnsafeGenericInstantiation>
|
||||||
|
<errorLevel type="suppress">
|
||||||
|
<file name="lib/Doctrine/Common/Collections/ArrayCollection.php"/>
|
||||||
|
</errorLevel>
|
||||||
|
</UnsafeGenericInstantiation>
|
||||||
|
|
||||||
|
<UndefinedAttributeClass>
|
||||||
|
<errorLevel type="suppress">
|
||||||
|
<!-- This class is new in PHP 8.1 and Psalm does not know it yet. -->
|
||||||
|
<referencedClass name="ReturnTypeWillChange"/>
|
||||||
|
</errorLevel>
|
||||||
|
</UndefinedAttributeClass>
|
||||||
|
</issueHandlers>
|
||||||
|
</psalm>
|
18
frontend/drupal9/vendor/doctrine/common/.doctrine-project.json
vendored
Normal file
18
frontend/drupal9/vendor/doctrine/common/.doctrine-project.json
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"active": true,
|
||||||
|
"name": "Common",
|
||||||
|
"slug": "common",
|
||||||
|
"docsSlug": "doctrine-common",
|
||||||
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "master",
|
||||||
|
"branchName": "master",
|
||||||
|
"slug": "latest"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "2.11",
|
||||||
|
"branchName": "2.11",
|
||||||
|
"current": true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
3
frontend/drupal9/vendor/doctrine/common/.github/FUNDING.yml
vendored
Normal file
3
frontend/drupal9/vendor/doctrine/common/.github/FUNDING.yml
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
patreon: phpdoctrine
|
||||||
|
tidelift: packagist/doctrine%2Fcommon
|
||||||
|
custom: https://www.doctrine-project.org/sponsorship.html
|
19
frontend/drupal9/vendor/doctrine/common/LICENSE
vendored
Normal file
19
frontend/drupal9/vendor/doctrine/common/LICENSE
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
Copyright (c) 2006-2015 Doctrine Project
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is furnished to do
|
||||||
|
so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
11
frontend/drupal9/vendor/doctrine/common/README.md
vendored
Normal file
11
frontend/drupal9/vendor/doctrine/common/README.md
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
# Doctrine Common
|
||||||
|
|
||||||
|
[](https://travis-ci.org/doctrine/common)
|
||||||
|
|
||||||
|
The Doctrine Common project is a library that provides extensions to core PHP functionality.
|
||||||
|
|
||||||
|
## More resources:
|
||||||
|
|
||||||
|
* [Website](https://www.doctrine-project.org/)
|
||||||
|
* [Documentation](https://www.doctrine-project.org/projects/doctrine-common/en/latest/)
|
||||||
|
* [Downloads](https://github.com/doctrine/common/releases)
|
39
frontend/drupal9/vendor/doctrine/common/UPGRADE_TO_2_1
vendored
Normal file
39
frontend/drupal9/vendor/doctrine/common/UPGRADE_TO_2_1
vendored
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
This document details all the possible changes that you should investigate when updating
|
||||||
|
your project from Doctrine Common 2.0.x to 2.1
|
||||||
|
|
||||||
|
## AnnotationReader changes
|
||||||
|
|
||||||
|
The annotation reader was heavily refactored between 2.0 and 2.1-RC1. In theory the operation of the new reader should be backwards compatible, but it has to be setup differently to work that way:
|
||||||
|
|
||||||
|
$reader = new \Doctrine\Common\Annotations\AnnotationReader();
|
||||||
|
$reader->setDefaultAnnotationNamespace('Doctrine\ORM\Mapping\\');
|
||||||
|
// new code necessary starting here
|
||||||
|
$reader->setIgnoreNotImportedAnnotations(true);
|
||||||
|
$reader->setEnableParsePhpImports(false);
|
||||||
|
$reader = new \Doctrine\Common\Annotations\CachedReader(
|
||||||
|
new \Doctrine\Common\Annotations\IndexedReader($reader), new ArrayCache()
|
||||||
|
);
|
||||||
|
|
||||||
|
## Annotation Base class or @Annotation
|
||||||
|
|
||||||
|
Beginning after 2.1-RC2 you have to either extend ``Doctrine\Common\Annotations\Annotation`` or add @Annotation to your annotations class-level docblock, otherwise the class will simply be ignored.
|
||||||
|
|
||||||
|
## Removed methods on AnnotationReader
|
||||||
|
|
||||||
|
* AnnotationReader::setAutoloadAnnotations()
|
||||||
|
* AnnotationReader::getAutoloadAnnotations()
|
||||||
|
* AnnotationReader::isAutoloadAnnotations()
|
||||||
|
|
||||||
|
## AnnotationRegistry
|
||||||
|
|
||||||
|
Autoloading through the PHP autoloader is removed from the 2.1 AnnotationReader. Instead you have to use the global AnnotationRegistry for loading purposes:
|
||||||
|
|
||||||
|
\Doctrine\Common\Annotations\AnnotationRegistry::registerFile($fileWithAnnotations);
|
||||||
|
\Doctrine\Common\Annotations\AnnotationRegistry::registerAutoloadNamespace($namespace, $dirs = null);
|
||||||
|
\Doctrine\Common\Annotations\AnnotationRegistry::registerAutoloadNamespaces($namespaces);
|
||||||
|
\Doctrine\Common\Annotations\AnnotationRegistry::registerLoader($callable);
|
||||||
|
|
||||||
|
The $callable for registering a loader accepts a class as first and only parameter and must try to silently autoload it. On success true has to be returned.
|
||||||
|
The registerAutoloadNamespace function registers a PSR-0 compatible silent autoloader for all classes with the given namespace in the given directories.
|
||||||
|
If null is passed as directory the include path will be used.
|
||||||
|
|
61
frontend/drupal9/vendor/doctrine/common/UPGRADE_TO_2_2
vendored
Normal file
61
frontend/drupal9/vendor/doctrine/common/UPGRADE_TO_2_2
vendored
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
This document details all the possible changes that you should investigate when
|
||||||
|
updating your project from Doctrine Common 2.1 to 2.2:
|
||||||
|
|
||||||
|
## Annotation Changes
|
||||||
|
|
||||||
|
- AnnotationReader::setIgnoreNotImportedAnnotations has been removed, you need to
|
||||||
|
add ignore annotation names which are supposed to be ignored via
|
||||||
|
AnnotationReader::addGlobalIgnoredName
|
||||||
|
|
||||||
|
- AnnotationReader::setAutoloadAnnotations was deprecated by the AnnotationRegistry
|
||||||
|
in 2.1 and has been removed in 2.2
|
||||||
|
|
||||||
|
- AnnotationReader::setEnableParsePhpImports was added to ease transition to the new
|
||||||
|
annotation mechanism in 2.1 and is removed in 2.2
|
||||||
|
|
||||||
|
- AnnotationReader::isParsePhpImportsEnabled is removed (see above)
|
||||||
|
|
||||||
|
- AnnotationReader::setDefaultAnnotationNamespace was deprecated in favor of explicit
|
||||||
|
configuration in 2.1 and will be removed in 2.2 (for isolated projects where you
|
||||||
|
have full-control over _all_ available annotations, we offer a dedicated reader
|
||||||
|
class ``SimpleAnnotationReader``)
|
||||||
|
|
||||||
|
- AnnotationReader::setAnnotationCreationFunction was deprecated in 2.1 and will be
|
||||||
|
removed in 2.2. We only offer two creation mechanisms which cannot be changed
|
||||||
|
anymore to allow the same reader instance to work with all annotations regardless
|
||||||
|
of which library they are coming from.
|
||||||
|
|
||||||
|
- AnnotationReader::setAnnotationNamespaceAlias was deprecated in 2.1 and will be
|
||||||
|
removed in 2.2 (see setDefaultAnnotationNamespace)
|
||||||
|
|
||||||
|
- If you use a class as annotation which has not the @Annotation marker in it's
|
||||||
|
class block, we will now throw an exception instead of silently ignoring it. You
|
||||||
|
can however still achieve the previous behavior using the @IgnoreAnnotation, or
|
||||||
|
AnnotationReader::addGlobalIgnoredName (the exception message will contain detailed
|
||||||
|
instructions when you run into this problem).
|
||||||
|
|
||||||
|
## Cache Changes
|
||||||
|
|
||||||
|
- Renamed old AbstractCache to CacheProvider
|
||||||
|
|
||||||
|
- Dropped the support to the following functions of all cache providers:
|
||||||
|
|
||||||
|
- CacheProvider::deleteByWildcard
|
||||||
|
|
||||||
|
- CacheProvider::deleteByRegEx
|
||||||
|
|
||||||
|
- CacheProvider::deleteByPrefix
|
||||||
|
|
||||||
|
- CacheProvider::deleteBySuffix
|
||||||
|
|
||||||
|
- CacheProvider::deleteAll will not remove ALL entries, it will only mark them as invalid
|
||||||
|
|
||||||
|
- CacheProvider::flushAll will remove ALL entries, namespaced or not
|
||||||
|
|
||||||
|
- Added support to MemcachedCache
|
||||||
|
|
||||||
|
- Added support to WincacheCache
|
||||||
|
|
||||||
|
## ClassLoader Changes
|
||||||
|
|
||||||
|
- ClassLoader::fileExistsInIncludePath() no longer exists. Use the native stream_resolve_include_path() PHP function
|
54
frontend/drupal9/vendor/doctrine/common/composer.json
vendored
Normal file
54
frontend/drupal9/vendor/doctrine/common/composer.json
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
{
|
||||||
|
"name": "doctrine/common",
|
||||||
|
"type": "library",
|
||||||
|
"description": "PHP Doctrine Common project is a library that provides additional functionality that other Doctrine projects depend on such as better reflection support, persistence interfaces, proxies, event system and much more.",
|
||||||
|
"keywords": [
|
||||||
|
"php",
|
||||||
|
"common",
|
||||||
|
"doctrine"
|
||||||
|
],
|
||||||
|
"homepage": "https://www.doctrine-project.org/projects/common.html",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"},
|
||||||
|
{"name": "Roman Borschel", "email": "roman@code-factory.org"},
|
||||||
|
{"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"},
|
||||||
|
{"name": "Jonathan Wage", "email": "jonwage@gmail.com"},
|
||||||
|
{"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"},
|
||||||
|
{"name": "Marco Pivetta", "email": "ocramius@gmail.com"}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": "^7.1 || ^8.0",
|
||||||
|
"doctrine/inflector": "^1.0",
|
||||||
|
"doctrine/cache": "^1.0",
|
||||||
|
"doctrine/collections": "^1.0",
|
||||||
|
"doctrine/lexer": "^1.0",
|
||||||
|
"doctrine/annotations": "^1.0",
|
||||||
|
"doctrine/event-manager": "^1.0",
|
||||||
|
"doctrine/reflection": "^1.0",
|
||||||
|
"doctrine/persistence": "^1.3.3"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpstan/phpstan": "^0.11",
|
||||||
|
"phpstan/phpstan-phpunit": "^0.11",
|
||||||
|
"phpunit/phpunit": "^7.0",
|
||||||
|
"doctrine/coding-standard": "^1.0",
|
||||||
|
"squizlabs/php_codesniffer": "^3.0",
|
||||||
|
"symfony/phpunit-bridge": "^4.0.5"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Doctrine\\Common\\": "lib/Doctrine/Common"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload-dev": {
|
||||||
|
"psr-4": {
|
||||||
|
"Doctrine\\Tests\\": "tests/Doctrine/Tests"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "2.11.x-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
10
frontend/drupal9/vendor/doctrine/common/docs/en/index.rst
vendored
Normal file
10
frontend/drupal9/vendor/doctrine/common/docs/en/index.rst
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
Common Documentation
|
||||||
|
====================
|
||||||
|
|
||||||
|
Welcome to the Doctrine Common Library documentation.
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:depth: 2
|
||||||
|
:glob:
|
||||||
|
|
||||||
|
*
|
242
frontend/drupal9/vendor/doctrine/common/docs/en/reference/class-loading.rst
vendored
Normal file
242
frontend/drupal9/vendor/doctrine/common/docs/en/reference/class-loading.rst
vendored
Normal file
@ -0,0 +1,242 @@
|
|||||||
|
Class Loading
|
||||||
|
=============
|
||||||
|
|
||||||
|
Class loading is an essential part of any PHP application that
|
||||||
|
makes heavy use of classes and interfaces. Unfortunately, a lot of
|
||||||
|
people and projects spend a lot of time and effort on custom and
|
||||||
|
specialized class loading strategies. It can quickly become a pain
|
||||||
|
to understand what is going on when using multiple libraries and/or
|
||||||
|
frameworks, each with its own way to do class loading. Class
|
||||||
|
loading should be simple and it is an ideal candidate for
|
||||||
|
convention over configuration.
|
||||||
|
|
||||||
|
Overview
|
||||||
|
--------
|
||||||
|
|
||||||
|
The Doctrine Common ClassLoader implements a simple and efficient
|
||||||
|
approach to class loading that is easy to understand and use. The
|
||||||
|
implementation is based on the widely used and accepted convention
|
||||||
|
of mapping namespace and class names to a directory structure. This
|
||||||
|
approach is used for example by Symfony2, the Zend Framework and of
|
||||||
|
course, Doctrine.
|
||||||
|
|
||||||
|
For example, the following class:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
namespace MyProject\Shipping;
|
||||||
|
class ShippingStrategy { ... }
|
||||||
|
|
||||||
|
resides in the following directory structure:
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
src/
|
||||||
|
/MyProject
|
||||||
|
/Shipping
|
||||||
|
ShippingStrategy.php
|
||||||
|
|
||||||
|
Note that the name of "src" or the structure above or beside this
|
||||||
|
directory is completely arbitrary. "src" could be named "classes"
|
||||||
|
or "lib" or whatever. The only convention to adhere to is to map
|
||||||
|
namespaces to directories and classes to files named after the
|
||||||
|
class name.
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
To use a Doctrine Common ClassLoader, you first need to load the
|
||||||
|
class file containing the ClassLoader. This is the only class file
|
||||||
|
that actually needs to be loaded explicitly via ``require``. All
|
||||||
|
other classes will be loaded on demand by the configured class
|
||||||
|
loaders.
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
use Doctrine\Common\ClassLoader;
|
||||||
|
require '/path/to/Doctrine/Common/ClassLoader.php';
|
||||||
|
$classLoader = new ClassLoader('MyProject', '/path/to/src');
|
||||||
|
|
||||||
|
A ``ClassLoader`` takes two constructor parameters, both optional.
|
||||||
|
In the normal case both arguments are supplied. The first argument
|
||||||
|
specifies the namespace prefix this class loader should be
|
||||||
|
responsible for and the second parameter is the path to the root
|
||||||
|
directory where the classes can be found according to the
|
||||||
|
convention mentioned previously.
|
||||||
|
|
||||||
|
The class loader in the example above would thus be responsible for
|
||||||
|
all classes under the 'MyProject' namespace and it would look for
|
||||||
|
the class files starting at the directory '/path/to/src'.
|
||||||
|
|
||||||
|
Also note that the prefix supplied in the first argument need not
|
||||||
|
be a root namespace but can be an arbitrarily nested namespace as
|
||||||
|
well. This allows you to even have the sources of subnamespaces
|
||||||
|
split across different directories. For example, all projects under
|
||||||
|
the Doctrine umbrella reside in the Doctrine namespace, yet the
|
||||||
|
sources for each project usually do not reside under a common root
|
||||||
|
directory. The following is an example of configuring three class
|
||||||
|
loaders, one for each used Doctrine project:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
use Doctrine\Common\ClassLoader;
|
||||||
|
require '/path/to/Doctrine/Common/ClassLoader.php';
|
||||||
|
$commonLoader = new ClassLoader('Doctrine\Common', '/path/to/common/lib');
|
||||||
|
$dbalLoader = new ClassLoader('Doctrine\DBAL', '/path/to/dbal/lib');
|
||||||
|
$ormLoader = new ClassLoader('Doctrine\ORM', '/path/to/orm/lib');
|
||||||
|
$commonLoader->register();
|
||||||
|
$dbalLoader->register();
|
||||||
|
$ormLoader->register();
|
||||||
|
|
||||||
|
Do not be afraid of using multiple class loaders. Due to the
|
||||||
|
efficient class loading design you will not incur much overhead
|
||||||
|
from using many class loaders. Take a look at the implementation of
|
||||||
|
``ClassLoader#loadClass`` to see how simple and efficient the class
|
||||||
|
loading is. The iteration over the installed class loaders happens
|
||||||
|
in C (with the exception of using ``ClassLoader::classExists``).
|
||||||
|
|
||||||
|
A ClassLoader can be used in the following other variations,
|
||||||
|
however, these are rarely used/needed:
|
||||||
|
|
||||||
|
|
||||||
|
- If only the second argument is not supplied, the class loader
|
||||||
|
will be responsible for the namespace prefix given in the first
|
||||||
|
argument and it will rely on the PHP include_path.
|
||||||
|
|
||||||
|
- If only the first argument is not supplied, the class loader
|
||||||
|
will be responsible for *all* classes and it will try to look up
|
||||||
|
*all* classes starting at the directory given as the second
|
||||||
|
argument.
|
||||||
|
|
||||||
|
- If both arguments are not supplied, the class loader will be
|
||||||
|
responsible for *all* classes and it will rely on the PHP
|
||||||
|
include_path.
|
||||||
|
|
||||||
|
|
||||||
|
File Extension
|
||||||
|
--------------
|
||||||
|
|
||||||
|
By default, a ClassLoader uses the ``.php`` file extension for all
|
||||||
|
class files. You can change this behavior, for example to use a
|
||||||
|
ClassLoader to load classes from a library that uses the
|
||||||
|
".class.php" convention (but it must nevertheless adhere to the
|
||||||
|
directory structure convention!):
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
$customLoader = new ClassLoader('CustomLib', '/path/to/custom/lib');
|
||||||
|
$customLoader->setFileExtension('.class.php');
|
||||||
|
$customLoader->register();
|
||||||
|
|
||||||
|
Namespace Separator
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
By default, a ClassLoader uses the ``\`` namespace separator. You
|
||||||
|
can change this behavior, for example to use a ClassLoader to load
|
||||||
|
legacy Zend Framework classes that still use the underscore "_"
|
||||||
|
separator:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
$zend1Loader = new ClassLoader('Zend', '/path/to/zend/lib');
|
||||||
|
$zend1Loader->setNamespaceSeparator('_');
|
||||||
|
$zend1Loader->register();
|
||||||
|
|
||||||
|
Failing Silently and class_exists
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
A lot of class/autoloaders these days try to fail silently when a
|
||||||
|
class file is not found. For the most part this is necessary in
|
||||||
|
order to support using ``class_exists('ClassName', true)`` which is
|
||||||
|
supposed to return a boolean value but triggers autoloading. This
|
||||||
|
is a bad thing as it basically forces class loaders to fail
|
||||||
|
silently, which in turn requires costly file_exists or fopen calls
|
||||||
|
for each class being loaded, even though in at least 99% of the
|
||||||
|
cases this is not necessary (compare the number of
|
||||||
|
class_exists(..., true) invocations to the total number of classes
|
||||||
|
being loaded in a request).
|
||||||
|
|
||||||
|
The Doctrine Common ClassLoader does not fail silently, by design.
|
||||||
|
It therefore does not need any costly checks for file existence. A
|
||||||
|
ClassLoader is always responsible for all classes with a certain
|
||||||
|
namespace prefix and if a class is requested to be loaded and can
|
||||||
|
not be found this is considered to be a fatal error. This also
|
||||||
|
means that using class_exists(..., true) to check for class
|
||||||
|
existence when using a Doctrine Common ClassLoader is not possible
|
||||||
|
but this is not a bad thing. What class\_exists(..., true) actually
|
||||||
|
means is two things: 1) Check whether the class is already
|
||||||
|
defined/exists (i.e. class_exists(..., false)) and if not 2) check
|
||||||
|
whether a class file can be loaded for that class. In the Doctrine
|
||||||
|
Common ClassLoader the two responsibilities of loading a class and
|
||||||
|
checking for its existence are separated, which can be observed by
|
||||||
|
the existence of the two methods ``loadClass`` and
|
||||||
|
``canLoadClass``. Thereby ``loadClass`` does not invoke
|
||||||
|
``canLoadClass`` internally, by design. However, you are free to
|
||||||
|
use it yourself to check whether a class can be loaded and the
|
||||||
|
following code snippet is thus equivalent to class\_exists(...,
|
||||||
|
true):
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
// Equivalent to if (
|
||||||
|
('Foo', true)) if there is only 1 class loader to check
|
||||||
|
if (class_exists('Foo', false) || $classLoader->canLoadClass('Foo')) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
|
||||||
|
The only problem with this is that it is inconvenient as you need
|
||||||
|
to have a reference to the class loaders around (and there are
|
||||||
|
often multiple class loaders in use). Therefore, a simpler
|
||||||
|
alternative exists for the cases in which you really want to ask
|
||||||
|
all installed class loaders whether they can load the class:
|
||||||
|
``ClassLoader::classExists($className)``:
|
||||||
|
|
||||||
|
.. code-block:: php
|
||||||
|
|
||||||
|
<?php
|
||||||
|
// Equivalent to if (class_exists('Foo', true))
|
||||||
|
if (ClassLoader::classExists('Foo')) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
|
||||||
|
This static method can basically be used as a drop-in replacement
|
||||||
|
for class_exists(..., true). It iterates over all installed class
|
||||||
|
loaders and asks each of them via ``canLoadClass``, returning early
|
||||||
|
(with TRUE) as soon as one class loader returns TRUE from
|
||||||
|
``canLoadClass``. If this sounds like it can potentially be rather
|
||||||
|
costly then because that is true but it is exactly the same thing
|
||||||
|
that class_exists(..., true) does under the hood, it triggers a
|
||||||
|
complete interaction of all class/auto loaders. Checking for class
|
||||||
|
existence via invoking autoloading was never a cheap thing to do
|
||||||
|
but now it is more obvious and more importantly, this check is no
|
||||||
|
longer interleaved with regular class loading, which avoids having
|
||||||
|
to check each and every class for existence prior to loading it.
|
||||||
|
The vast majority of classes to be loaded are *not* optional and a
|
||||||
|
failure to load such a class is, and should be, a fatal error. The
|
||||||
|
ClassLoader design reflects this.
|
||||||
|
|
||||||
|
If you have code that requires the usage of class\_exists(...,
|
||||||
|
true) or ClassLoader::classExists during normal runtime of the
|
||||||
|
application (i.e. on each request) try to refactor your design to
|
||||||
|
avoid it.
|
||||||
|
|
||||||
|
Summary
|
||||||
|
-------
|
||||||
|
|
||||||
|
No matter which class loader you prefer to use (Doctrine classes do
|
||||||
|
not care about how they are loaded), we kindly encourage you to
|
||||||
|
adhere to the simple convention of mapping namespaces and class
|
||||||
|
names to a directory structure.
|
||||||
|
|
||||||
|
Class loading should be simple, automated and uniform. Time is
|
||||||
|
better invested in actual application development than in designing
|
||||||
|
special directory structures, autoloaders and clever caching
|
||||||
|
strategies for class loading.
|
||||||
|
|
||||||
|
|
11
frontend/drupal9/vendor/doctrine/common/humbug.json.dist
vendored
Normal file
11
frontend/drupal9/vendor/doctrine/common/humbug.json.dist
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"source": {
|
||||||
|
"directories": [
|
||||||
|
"lib\/Doctrine"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"timeout": 10,
|
||||||
|
"logs": {
|
||||||
|
"text": "reports/humbuglog.txt"
|
||||||
|
}
|
||||||
|
}
|
267
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/ClassLoader.php
vendored
Normal file
267
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/ClassLoader.php
vendored
Normal file
@ -0,0 +1,267 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common;
|
||||||
|
|
||||||
|
use function trigger_error;
|
||||||
|
use const E_USER_DEPRECATED;
|
||||||
|
|
||||||
|
@trigger_error(ClassLoader::class . ' is deprecated.', E_USER_DEPRECATED);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A <tt>ClassLoader</tt> is an autoloader for class files that can be
|
||||||
|
* installed on the SPL autoload stack. It is a class loader that either loads only classes
|
||||||
|
* of a specific namespace or all namespaces and it is suitable for working together
|
||||||
|
* with other autoloaders in the SPL autoload stack.
|
||||||
|
*
|
||||||
|
* If no include path is configured through the constructor or {@link setIncludePath}, a ClassLoader
|
||||||
|
* relies on the PHP <code>include_path</code>.
|
||||||
|
*
|
||||||
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
|
* @since 2.0
|
||||||
|
*
|
||||||
|
* @deprecated The ClassLoader is deprecated and will be removed in version 4.0 of doctrine/common.
|
||||||
|
*/
|
||||||
|
class ClassLoader
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* PHP file extension.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $fileExtension = '.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current namespace.
|
||||||
|
*
|
||||||
|
* @var string|null
|
||||||
|
*/
|
||||||
|
protected $namespace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Current include path.
|
||||||
|
*
|
||||||
|
* @var string|null
|
||||||
|
*/
|
||||||
|
protected $includePath;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PHP namespace separator.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $namespaceSeparator = '\\';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new <tt>ClassLoader</tt> that loads classes of the
|
||||||
|
* specified namespace from the specified include path.
|
||||||
|
*
|
||||||
|
* If no include path is given, the ClassLoader relies on the PHP include_path.
|
||||||
|
* If neither a namespace nor an include path is given, the ClassLoader will
|
||||||
|
* be responsible for loading all classes, thereby relying on the PHP include_path.
|
||||||
|
*
|
||||||
|
* @param string|null $ns The namespace of the classes to load.
|
||||||
|
* @param string|null $includePath The base include path to use.
|
||||||
|
*/
|
||||||
|
public function __construct($ns = null, $includePath = null)
|
||||||
|
{
|
||||||
|
$this->namespace = $ns;
|
||||||
|
$this->includePath = $includePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the namespace separator used by classes in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @param string $sep The separator to use.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setNamespaceSeparator($sep)
|
||||||
|
{
|
||||||
|
$this->namespaceSeparator = $sep;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the namespace separator used by classes in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getNamespaceSeparator()
|
||||||
|
{
|
||||||
|
return $this->namespaceSeparator;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the base include path for all class files in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @param string|null $includePath
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setIncludePath($includePath)
|
||||||
|
{
|
||||||
|
$this->includePath = $includePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the base include path for all class files in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @return string|null
|
||||||
|
*/
|
||||||
|
public function getIncludePath()
|
||||||
|
{
|
||||||
|
return $this->includePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the file extension of class files in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @param string $fileExtension
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setFileExtension($fileExtension)
|
||||||
|
{
|
||||||
|
$this->fileExtension = $fileExtension;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the file extension of class files in the namespace of this ClassLoader.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getFileExtension()
|
||||||
|
{
|
||||||
|
return $this->fileExtension;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers this ClassLoader on the SPL autoload stack.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function register()
|
||||||
|
{
|
||||||
|
spl_autoload_register([$this, 'loadClass']);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes this ClassLoader from the SPL autoload stack.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function unregister()
|
||||||
|
{
|
||||||
|
spl_autoload_unregister([$this, 'loadClass']);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads the given class or interface.
|
||||||
|
*
|
||||||
|
* @param string $className The name of the class to load.
|
||||||
|
*
|
||||||
|
* @return boolean TRUE if the class has been successfully loaded, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function loadClass($className)
|
||||||
|
{
|
||||||
|
if (self::typeExists($className)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! $this->canLoadClass($className)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
require($this->includePath !== null ? $this->includePath . DIRECTORY_SEPARATOR : '')
|
||||||
|
. str_replace($this->namespaceSeparator, DIRECTORY_SEPARATOR, $className)
|
||||||
|
. $this->fileExtension;
|
||||||
|
|
||||||
|
return self::typeExists($className);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Asks this ClassLoader whether it can potentially load the class (file) with
|
||||||
|
* the given name.
|
||||||
|
*
|
||||||
|
* @param string $className The fully-qualified name of the class.
|
||||||
|
*
|
||||||
|
* @return boolean TRUE if this ClassLoader can load the class, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public function canLoadClass($className)
|
||||||
|
{
|
||||||
|
if ($this->namespace !== null && strpos($className, $this->namespace . $this->namespaceSeparator) !== 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$file = str_replace($this->namespaceSeparator, DIRECTORY_SEPARATOR, $className) . $this->fileExtension;
|
||||||
|
|
||||||
|
if ($this->includePath !== null) {
|
||||||
|
return is_file($this->includePath . DIRECTORY_SEPARATOR . $file);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (false !== stream_resolve_include_path($file));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether a class with a given name exists. A class "exists" if it is either
|
||||||
|
* already defined in the current request or if there is an autoloader on the SPL
|
||||||
|
* autoload stack that is a) responsible for the class in question and b) is able to
|
||||||
|
* load a class file in which the class definition resides.
|
||||||
|
*
|
||||||
|
* If the class is not already defined, each autoloader in the SPL autoload stack
|
||||||
|
* is asked whether it is able to tell if the class exists. If the autoloader is
|
||||||
|
* a <tt>ClassLoader</tt>, {@link canLoadClass} is used, otherwise the autoload
|
||||||
|
* function of the autoloader is invoked and expected to return a value that
|
||||||
|
* evaluates to TRUE if the class (file) exists. As soon as one autoloader reports
|
||||||
|
* that the class exists, TRUE is returned.
|
||||||
|
*
|
||||||
|
* Note that, depending on what kinds of autoloaders are installed on the SPL
|
||||||
|
* autoload stack, the class (file) might already be loaded as a result of checking
|
||||||
|
* for its existence. This is not the case with a <tt>ClassLoader</tt>, who separates
|
||||||
|
* these responsibilities.
|
||||||
|
*
|
||||||
|
* @param string $className The fully-qualified name of the class.
|
||||||
|
*
|
||||||
|
* @return boolean TRUE if the class exists as per the definition given above, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
public static function classExists($className)
|
||||||
|
{
|
||||||
|
return self::typeExists($className, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the <tt>ClassLoader</tt> from the SPL autoload stack that is responsible
|
||||||
|
* for (and is able to load) the class with the given name.
|
||||||
|
*
|
||||||
|
* @param string $className The name of the class.
|
||||||
|
*
|
||||||
|
* @return ClassLoader|null The <tt>ClassLoader</tt> for the class or NULL if no such <tt>ClassLoader</tt> exists.
|
||||||
|
*/
|
||||||
|
public static function getClassLoader($className)
|
||||||
|
{
|
||||||
|
foreach (spl_autoload_functions() as $loader) {
|
||||||
|
if (is_array($loader)
|
||||||
|
&& ($classLoader = reset($loader))
|
||||||
|
&& $classLoader instanceof ClassLoader
|
||||||
|
&& $classLoader->canLoadClass($className)
|
||||||
|
) {
|
||||||
|
return $classLoader;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether a given type exists
|
||||||
|
*
|
||||||
|
* @param string $type
|
||||||
|
* @param bool $autoload
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
private static function typeExists($type, $autoload = false)
|
||||||
|
{
|
||||||
|
return class_exists($type, $autoload)
|
||||||
|
|| interface_exists($type, $autoload)
|
||||||
|
|| trait_exists($type, $autoload);
|
||||||
|
}
|
||||||
|
}
|
13
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/CommonException.php
vendored
Normal file
13
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/CommonException.php
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base exception class for package Doctrine\Common.
|
||||||
|
*
|
||||||
|
* @author heinrich
|
||||||
|
*
|
||||||
|
* @deprecated The doctrine/common package is deprecated, please use specific packages and their exceptions instead.
|
||||||
|
*/
|
||||||
|
class CommonException extends \Exception
|
||||||
|
{
|
||||||
|
}
|
28
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Comparable.php
vendored
Normal file
28
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Comparable.php
vendored
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Comparable interface that allows to compare two value objects to each other for similarity.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.2
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
|
*/
|
||||||
|
interface Comparable
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Compares the current object to the passed $other.
|
||||||
|
*
|
||||||
|
* Returns 0 if they are semantically equal, 1 if the other object
|
||||||
|
* is less than the current one, or -1 if its more than the current one.
|
||||||
|
*
|
||||||
|
* This method should not check for identity using ===, only for semantical equality for example
|
||||||
|
* when two different DateTime instances point to the exact same Date + TZ.
|
||||||
|
*
|
||||||
|
* @param mixed $other
|
||||||
|
*
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
public function compareTo($other);
|
||||||
|
}
|
25
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Lexer.php
vendored
Normal file
25
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Lexer.php
vendored
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common;
|
||||||
|
|
||||||
|
use Doctrine\Common\Lexer\AbstractLexer;
|
||||||
|
use function trigger_error;
|
||||||
|
use const E_USER_DEPRECATED;
|
||||||
|
|
||||||
|
@trigger_error(Lexer::class . ' is deprecated.', E_USER_DEPRECATED);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for writing simple lexers, i.e. for creating small DSLs.
|
||||||
|
*
|
||||||
|
* Lexer moved into its own Component Doctrine\Common\Lexer. This class
|
||||||
|
* only stays for being BC.
|
||||||
|
*
|
||||||
|
* @since 2.0
|
||||||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
|
* @author Jonathan Wage <jonwage@gmail.com>
|
||||||
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
|
*
|
||||||
|
* @deprecated Use Doctrine\Common\Lexer\AbstractLexer from doctrine/lexer package instead.
|
||||||
|
*/
|
||||||
|
abstract class Lexer extends AbstractLexer
|
||||||
|
{
|
||||||
|
}
|
246
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/AbstractProxyFactory.php
vendored
Normal file
246
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/AbstractProxyFactory.php
vendored
Normal file
@ -0,0 +1,246 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy;
|
||||||
|
|
||||||
|
use Doctrine\Persistence\Mapping\ClassMetadata;
|
||||||
|
use Doctrine\Persistence\Mapping\ClassMetadataFactory;
|
||||||
|
use Doctrine\Common\Proxy\Exception\InvalidArgumentException;
|
||||||
|
use Doctrine\Common\Proxy\Exception\OutOfBoundsException;
|
||||||
|
use Doctrine\Common\Util\ClassUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract factory for proxy objects.
|
||||||
|
*
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
*/
|
||||||
|
abstract class AbstractProxyFactory
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Never autogenerate a proxy and rely that it was generated by some
|
||||||
|
* process before deployment.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
const AUTOGENERATE_NEVER = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Always generates a new proxy in every request.
|
||||||
|
*
|
||||||
|
* This is only sane during development.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
const AUTOGENERATE_ALWAYS = 1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Autogenerate the proxy class when the proxy file does not exist.
|
||||||
|
*
|
||||||
|
* This strategy causes a file exists call whenever any proxy is used the
|
||||||
|
* first time in a request.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
const AUTOGENERATE_FILE_NOT_EXISTS = 2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate the proxy classes using eval().
|
||||||
|
*
|
||||||
|
* This strategy is only sane for development, and even then it gives me
|
||||||
|
* the creeps a little.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
const AUTOGENERATE_EVAL = 3;
|
||||||
|
|
||||||
|
private const AUTOGENERATE_MODES = [
|
||||||
|
self::AUTOGENERATE_NEVER,
|
||||||
|
self::AUTOGENERATE_ALWAYS,
|
||||||
|
self::AUTOGENERATE_FILE_NOT_EXISTS,
|
||||||
|
self::AUTOGENERATE_EVAL,
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Doctrine\Persistence\Mapping\ClassMetadataFactory
|
||||||
|
*/
|
||||||
|
private $metadataFactory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Doctrine\Common\Proxy\ProxyGenerator the proxy generator responsible for creating the proxy classes/files.
|
||||||
|
*/
|
||||||
|
private $proxyGenerator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var int Whether to automatically (re)generate proxy classes.
|
||||||
|
*/
|
||||||
|
private $autoGenerate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Doctrine\Common\Proxy\ProxyDefinition[]
|
||||||
|
*/
|
||||||
|
private $definitions = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param \Doctrine\Common\Proxy\ProxyGenerator $proxyGenerator
|
||||||
|
* @param \Doctrine\Persistence\Mapping\ClassMetadataFactory $metadataFactory
|
||||||
|
* @param bool|int $autoGenerate
|
||||||
|
*
|
||||||
|
* @throws \Doctrine\Common\Proxy\Exception\InvalidArgumentException When auto generate mode is not valid.
|
||||||
|
*/
|
||||||
|
public function __construct(ProxyGenerator $proxyGenerator, ClassMetadataFactory $metadataFactory, $autoGenerate)
|
||||||
|
{
|
||||||
|
$this->proxyGenerator = $proxyGenerator;
|
||||||
|
$this->metadataFactory = $metadataFactory;
|
||||||
|
$this->autoGenerate = (int) $autoGenerate;
|
||||||
|
|
||||||
|
if ( ! in_array($this->autoGenerate, self::AUTOGENERATE_MODES, true)) {
|
||||||
|
throw InvalidArgumentException::invalidAutoGenerateMode($autoGenerate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a reference proxy instance for the entity of the given type and identified by
|
||||||
|
* the given identifier.
|
||||||
|
*
|
||||||
|
* @param string $className
|
||||||
|
* @param array $identifier
|
||||||
|
*
|
||||||
|
* @return \Doctrine\Common\Proxy\Proxy
|
||||||
|
*
|
||||||
|
* @throws \Doctrine\Common\Proxy\Exception\OutOfBoundsException
|
||||||
|
*/
|
||||||
|
public function getProxy($className, array $identifier)
|
||||||
|
{
|
||||||
|
$definition = isset($this->definitions[$className])
|
||||||
|
? $this->definitions[$className]
|
||||||
|
: $this->getProxyDefinition($className);
|
||||||
|
$fqcn = $definition->proxyClassName;
|
||||||
|
$proxy = new $fqcn($definition->initializer, $definition->cloner);
|
||||||
|
|
||||||
|
foreach ($definition->identifierFields as $idField) {
|
||||||
|
if ( ! isset($identifier[$idField])) {
|
||||||
|
throw OutOfBoundsException::missingPrimaryKeyValue($className, $idField);
|
||||||
|
}
|
||||||
|
|
||||||
|
$definition->reflectionFields[$idField]->setValue($proxy, $identifier[$idField]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $proxy;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates proxy classes for all given classes.
|
||||||
|
*
|
||||||
|
* @param \Doctrine\Persistence\Mapping\ClassMetadata[] $classes The classes (ClassMetadata instances)
|
||||||
|
* for which to generate proxies.
|
||||||
|
* @param string $proxyDir The target directory of the proxy classes. If not specified, the
|
||||||
|
* directory configured on the Configuration of the EntityManager used
|
||||||
|
* by this factory is used.
|
||||||
|
* @return int Number of generated proxies.
|
||||||
|
*/
|
||||||
|
public function generateProxyClasses(array $classes, $proxyDir = null)
|
||||||
|
{
|
||||||
|
$generated = 0;
|
||||||
|
|
||||||
|
foreach ($classes as $class) {
|
||||||
|
if ($this->skipClass($class)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$proxyFileName = $this->proxyGenerator->getProxyFileName($class->getName(), $proxyDir);
|
||||||
|
|
||||||
|
$this->proxyGenerator->generateProxyClass($class, $proxyFileName);
|
||||||
|
|
||||||
|
$generated += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $generated;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reset initialization/cloning logic for an un-initialized proxy
|
||||||
|
*
|
||||||
|
* @param \Doctrine\Common\Proxy\Proxy $proxy
|
||||||
|
*
|
||||||
|
* @return \Doctrine\Common\Proxy\Proxy
|
||||||
|
*
|
||||||
|
* @throws \Doctrine\Common\Proxy\Exception\InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public function resetUninitializedProxy(Proxy $proxy)
|
||||||
|
{
|
||||||
|
if ($proxy->__isInitialized()) {
|
||||||
|
throw InvalidArgumentException::unitializedProxyExpected($proxy);
|
||||||
|
}
|
||||||
|
|
||||||
|
$className = ClassUtils::getClass($proxy);
|
||||||
|
$definition = isset($this->definitions[$className])
|
||||||
|
? $this->definitions[$className]
|
||||||
|
: $this->getProxyDefinition($className);
|
||||||
|
|
||||||
|
$proxy->__setInitializer($definition->initializer);
|
||||||
|
$proxy->__setCloner($definition->cloner);
|
||||||
|
|
||||||
|
return $proxy;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a proxy definition for the given class name.
|
||||||
|
*
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return ProxyDefinition
|
||||||
|
*/
|
||||||
|
private function getProxyDefinition($className)
|
||||||
|
{
|
||||||
|
$classMetadata = $this->metadataFactory->getMetadataFor($className);
|
||||||
|
$className = $classMetadata->getName(); // aliases and case sensitivity
|
||||||
|
|
||||||
|
$this->definitions[$className] = $this->createProxyDefinition($className);
|
||||||
|
$proxyClassName = $this->definitions[$className]->proxyClassName;
|
||||||
|
|
||||||
|
if ( ! class_exists($proxyClassName, false)) {
|
||||||
|
$fileName = $this->proxyGenerator->getProxyFileName($className);
|
||||||
|
|
||||||
|
switch ($this->autoGenerate) {
|
||||||
|
case self::AUTOGENERATE_NEVER:
|
||||||
|
require $fileName;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case self::AUTOGENERATE_FILE_NOT_EXISTS:
|
||||||
|
if ( ! file_exists($fileName)) {
|
||||||
|
$this->proxyGenerator->generateProxyClass($classMetadata, $fileName);
|
||||||
|
}
|
||||||
|
require $fileName;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case self::AUTOGENERATE_ALWAYS:
|
||||||
|
$this->proxyGenerator->generateProxyClass($classMetadata, $fileName);
|
||||||
|
require $fileName;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case self::AUTOGENERATE_EVAL:
|
||||||
|
$this->proxyGenerator->generateProxyClass($classMetadata, false);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->definitions[$className];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if this class should be skipped during proxy generation.
|
||||||
|
*
|
||||||
|
* @param \Doctrine\Persistence\Mapping\ClassMetadata $metadata
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
abstract protected function skipClass(ClassMetadata $metadata);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return ProxyDefinition
|
||||||
|
*/
|
||||||
|
abstract protected function createProxyDefinition($className);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface_exists(ClassMetadata::class);
|
||||||
|
interface_exists(ClassMetadataFactory::class);
|
80
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Autoloader.php
vendored
Normal file
80
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Autoloader.php
vendored
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy;
|
||||||
|
|
||||||
|
use Doctrine\Common\Proxy\Exception\InvalidArgumentException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Special Autoloader for Proxy classes, which are not PSR-0 compliant.
|
||||||
|
*
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class Autoloader
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Resolves proxy class name to a filename based on the following pattern.
|
||||||
|
*
|
||||||
|
* 1. Remove Proxy namespace from class name.
|
||||||
|
* 2. Remove namespace separators from remaining class name.
|
||||||
|
* 3. Return PHP filename from proxy-dir with the result from 2.
|
||||||
|
*
|
||||||
|
* @param string $proxyDir
|
||||||
|
* @param string $proxyNamespace
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*
|
||||||
|
* @throws InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public static function resolveFile($proxyDir, $proxyNamespace, $className)
|
||||||
|
{
|
||||||
|
if (0 !== strpos($className, $proxyNamespace)) {
|
||||||
|
throw InvalidArgumentException::notProxyClass($className, $proxyNamespace);
|
||||||
|
}
|
||||||
|
|
||||||
|
// remove proxy namespace from class name
|
||||||
|
$classNameRelativeToProxyNamespace = substr($className, strlen($proxyNamespace));
|
||||||
|
|
||||||
|
// remove namespace separators from remaining class name
|
||||||
|
$fileName = str_replace('\\', '', $classNameRelativeToProxyNamespace);
|
||||||
|
|
||||||
|
return $proxyDir . DIRECTORY_SEPARATOR . $fileName . '.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers and returns autoloader callback for the given proxy dir and namespace.
|
||||||
|
*
|
||||||
|
* @param string $proxyDir
|
||||||
|
* @param string $proxyNamespace
|
||||||
|
* @param callable|null $notFoundCallback Invoked when the proxy file is not found.
|
||||||
|
*
|
||||||
|
* @return \Closure
|
||||||
|
*
|
||||||
|
* @throws InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public static function register($proxyDir, $proxyNamespace, $notFoundCallback = null)
|
||||||
|
{
|
||||||
|
$proxyNamespace = ltrim($proxyNamespace, '\\');
|
||||||
|
|
||||||
|
if ( ! (null === $notFoundCallback || is_callable($notFoundCallback))) {
|
||||||
|
throw InvalidArgumentException::invalidClassNotFoundCallback($notFoundCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
$autoloader = function ($className) use ($proxyDir, $proxyNamespace, $notFoundCallback) {
|
||||||
|
if (0 === strpos($className, $proxyNamespace)) {
|
||||||
|
$file = Autoloader::resolveFile($proxyDir, $proxyNamespace, $className);
|
||||||
|
|
||||||
|
if ($notFoundCallback && ! file_exists($file)) {
|
||||||
|
call_user_func($notFoundCallback, $proxyDir, $proxyNamespace, $className);
|
||||||
|
}
|
||||||
|
|
||||||
|
require $file;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
spl_autoload_register($autoloader);
|
||||||
|
|
||||||
|
return $autoloader;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy\Exception;
|
||||||
|
|
||||||
|
use Doctrine\Persistence\Proxy;
|
||||||
|
use InvalidArgumentException as BaseInvalidArgumentException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Proxy Invalid Argument Exception.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.4
|
||||||
|
* @author Marco Pivetta <ocramius@gmail.com>
|
||||||
|
*/
|
||||||
|
class InvalidArgumentException extends BaseInvalidArgumentException implements ProxyException
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function proxyDirectoryRequired()
|
||||||
|
{
|
||||||
|
return new self('You must configure a proxy directory. See docs for details');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
* @param string $proxyNamespace
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function notProxyClass($className, $proxyNamespace)
|
||||||
|
{
|
||||||
|
return new self(sprintf('The class "%s" is not part of the proxy namespace "%s"', $className, $proxyNamespace));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $name
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function invalidPlaceholder($name)
|
||||||
|
{
|
||||||
|
return new self(sprintf('Provided placeholder for "%s" must be either a string or a valid callable', $name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function proxyNamespaceRequired()
|
||||||
|
{
|
||||||
|
return new self('You must configure a proxy namespace');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param Proxy $proxy
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function unitializedProxyExpected(Proxy $proxy)
|
||||||
|
{
|
||||||
|
return new self(sprintf('Provided proxy of type "%s" must not be initialized.', get_class($proxy)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $callback
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function invalidClassNotFoundCallback($callback)
|
||||||
|
{
|
||||||
|
$type = is_object($callback) ? get_class($callback) : gettype($callback);
|
||||||
|
|
||||||
|
return new self(sprintf('Invalid \$notFoundCallback given: must be a callable, "%s" given', $type));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function classMustNotBeAbstract($className)
|
||||||
|
{
|
||||||
|
return new self(sprintf('Unable to create a proxy for an abstract class "%s".', $className));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function classMustNotBeFinal($className)
|
||||||
|
{
|
||||||
|
return new self(sprintf('Unable to create a proxy for a final class "%s".', $className));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $value
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function invalidAutoGenerateMode($value) : self
|
||||||
|
{
|
||||||
|
return new self(sprintf('Invalid auto generate mode "%s" given.', $value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
interface_exists(Proxy::class);
|
@ -0,0 +1,24 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy\Exception;
|
||||||
|
|
||||||
|
use OutOfBoundsException as BaseOutOfBoundsException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Proxy Invalid Argument Exception.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @author Fredrik Wendel <fredrik_w@users.sourceforge.net>
|
||||||
|
*/
|
||||||
|
class OutOfBoundsException extends BaseOutOfBoundsException implements ProxyException
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
* @param string $idField
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function missingPrimaryKeyValue($className, $idField)
|
||||||
|
{
|
||||||
|
return new self(sprintf("Missing value for primary key %s on %s", $idField, $className));
|
||||||
|
}
|
||||||
|
}
|
13
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Exception/ProxyException.php
vendored
Normal file
13
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Exception/ProxyException.php
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy\Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base exception interface for proxy exceptions.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.4
|
||||||
|
* @author Marco Pivetta <ocramius@gmail.com>
|
||||||
|
*/
|
||||||
|
interface ProxyException
|
||||||
|
{
|
||||||
|
}
|
@ -0,0 +1,70 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy\Exception;
|
||||||
|
|
||||||
|
use UnexpectedValueException as BaseUnexpectedValueException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Proxy Unexpected Value Exception.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.4
|
||||||
|
* @author Marco Pivetta <ocramius@gmail.com>
|
||||||
|
*/
|
||||||
|
class UnexpectedValueException extends BaseUnexpectedValueException implements ProxyException
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @param string $proxyDirectory
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function proxyDirectoryNotWritable($proxyDirectory)
|
||||||
|
{
|
||||||
|
return new self(sprintf('Your proxy directory "%s" must be writable', $proxyDirectory));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
* @param string $methodName
|
||||||
|
* @param string $parameterName
|
||||||
|
* @param \Exception|null $previous
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function invalidParameterTypeHint(
|
||||||
|
$className,
|
||||||
|
$methodName,
|
||||||
|
$parameterName,
|
||||||
|
\Exception $previous = null
|
||||||
|
) {
|
||||||
|
return new self(
|
||||||
|
sprintf(
|
||||||
|
'The type hint of parameter "%s" in method "%s" in class "%s" is invalid.',
|
||||||
|
$parameterName,
|
||||||
|
$methodName,
|
||||||
|
$className
|
||||||
|
),
|
||||||
|
0,
|
||||||
|
$previous
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $className
|
||||||
|
* @param string $methodName
|
||||||
|
* @param \Exception|null $previous
|
||||||
|
*
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public static function invalidReturnTypeHint($className, $methodName, \Exception $previous = null)
|
||||||
|
{
|
||||||
|
return new self(
|
||||||
|
sprintf(
|
||||||
|
'The return type of method "%s" in class "%s" is invalid.',
|
||||||
|
$methodName,
|
||||||
|
$className
|
||||||
|
),
|
||||||
|
0,
|
||||||
|
$previous
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
72
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Proxy.php
vendored
Normal file
72
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/Proxy.php
vendored
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use Doctrine\Persistence\Proxy as BaseProxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface for proxy classes.
|
||||||
|
*
|
||||||
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
|
* @author Marco Pivetta <ocramius@gmail.com>
|
||||||
|
* @since 2.4
|
||||||
|
*/
|
||||||
|
interface Proxy extends BaseProxy
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Marks the proxy as initialized or not.
|
||||||
|
*
|
||||||
|
* @param boolean $initialized
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __setInitialized($initialized);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the initializer callback to be used when initializing the proxy. That
|
||||||
|
* initializer should accept 3 parameters: $proxy, $method and $params. Those
|
||||||
|
* are respectively the proxy object that is being initialized, the method name
|
||||||
|
* that triggered initialization and the parameters passed to that method.
|
||||||
|
*
|
||||||
|
* @param Closure|null $initializer
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __setInitializer(Closure $initializer = null);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the initializer callback used to initialize the proxy.
|
||||||
|
*
|
||||||
|
* @see __setInitializer
|
||||||
|
*
|
||||||
|
* @return Closure|null
|
||||||
|
*/
|
||||||
|
public function __getInitializer();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the callback to be used when cloning the proxy. That initializer should accept
|
||||||
|
* a single parameter, which is the cloned proxy instance itself.
|
||||||
|
*
|
||||||
|
* @param Closure|null $cloner
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __setCloner(Closure $cloner = null);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the callback to be used when cloning the proxy.
|
||||||
|
*
|
||||||
|
* @see __setCloner
|
||||||
|
*
|
||||||
|
* @return Closure|null
|
||||||
|
*/
|
||||||
|
public function __getCloner();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the list of lazy loaded properties for a given proxy
|
||||||
|
*
|
||||||
|
* @return array Keys are the property names, and values are the default values
|
||||||
|
* for those properties.
|
||||||
|
*/
|
||||||
|
public function __getLazyProperties();
|
||||||
|
}
|
51
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/ProxyDefinition.php
vendored
Normal file
51
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/ProxyDefinition.php
vendored
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Proxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Definition structure how to create a proxy.
|
||||||
|
*
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
*/
|
||||||
|
class ProxyDefinition
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $proxyClassName;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $identifierFields;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \ReflectionProperty[]
|
||||||
|
*/
|
||||||
|
public $reflectionFields;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var callable
|
||||||
|
*/
|
||||||
|
public $initializer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var callable
|
||||||
|
*/
|
||||||
|
public $cloner;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $proxyClassName
|
||||||
|
* @param array $identifierFields
|
||||||
|
* @param array $reflectionFields
|
||||||
|
* @param callable $initializer
|
||||||
|
* @param callable $cloner
|
||||||
|
*/
|
||||||
|
public function __construct($proxyClassName, array $identifierFields, array $reflectionFields, $initializer, $cloner)
|
||||||
|
{
|
||||||
|
$this->proxyClassName = $proxyClassName;
|
||||||
|
$this->identifierFields = $identifierFields;
|
||||||
|
$this->reflectionFields = $reflectionFields;
|
||||||
|
$this->initializer = $initializer;
|
||||||
|
$this->cloner = $cloner;
|
||||||
|
}
|
||||||
|
}
|
1152
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/ProxyGenerator.php
vendored
Normal file
1152
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Proxy/ProxyGenerator.php
vendored
Normal file
File diff suppressed because it is too large
Load Diff
91
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/ClassUtils.php
vendored
Normal file
91
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/ClassUtils.php
vendored
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Util;
|
||||||
|
|
||||||
|
use Doctrine\Persistence\Proxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class and reflection related functionality for objects that
|
||||||
|
* might or not be proxy objects at the moment.
|
||||||
|
*
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
* @author Johannes Schmitt <schmittjoh@gmail.com>
|
||||||
|
*/
|
||||||
|
class ClassUtils
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Gets the real class name of a class name that could be a proxy.
|
||||||
|
*
|
||||||
|
* @param string $class
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getRealClass($class)
|
||||||
|
{
|
||||||
|
if (false === $pos = strrpos($class, '\\' . Proxy::MARKER . '\\')) {
|
||||||
|
return $class;
|
||||||
|
}
|
||||||
|
|
||||||
|
return substr($class, $pos + Proxy::MARKER_LENGTH + 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the real class name of an object (even if its a proxy).
|
||||||
|
*
|
||||||
|
* @param object $object
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getClass($object)
|
||||||
|
{
|
||||||
|
return self::getRealClass(get_class($object));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the real parent class name of a class or object.
|
||||||
|
*
|
||||||
|
* @param string $className
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getParentClass($className)
|
||||||
|
{
|
||||||
|
return get_parent_class(self::getRealClass($className));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new reflection class.
|
||||||
|
*
|
||||||
|
* @param string $class
|
||||||
|
*
|
||||||
|
* @return \ReflectionClass
|
||||||
|
*/
|
||||||
|
public static function newReflectionClass($class)
|
||||||
|
{
|
||||||
|
return new \ReflectionClass(self::getRealClass($class));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new reflection object.
|
||||||
|
*
|
||||||
|
* @param object $object
|
||||||
|
*
|
||||||
|
* @return \ReflectionClass
|
||||||
|
*/
|
||||||
|
public static function newReflectionObject($object)
|
||||||
|
{
|
||||||
|
return self::newReflectionClass(self::getClass($object));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Given a class name and a proxy namespace returns the proxy name.
|
||||||
|
*
|
||||||
|
* @param string $className
|
||||||
|
* @param string $proxyNamespace
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function generateProxyClassName($className, $proxyNamespace)
|
||||||
|
{
|
||||||
|
return rtrim($proxyNamespace, '\\') . '\\' . Proxy::MARKER . '\\' . ltrim($className, '\\');
|
||||||
|
}
|
||||||
|
}
|
167
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/Debug.php
vendored
Normal file
167
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/Debug.php
vendored
Normal file
@ -0,0 +1,167 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Util;
|
||||||
|
|
||||||
|
use Doctrine\Common\Collections\Collection;
|
||||||
|
use Doctrine\Persistence\Proxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Static class containing most used debug methods.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.0
|
||||||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
|
* @author Jonathan Wage <jonwage@gmail.com>
|
||||||
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
|
* @author Giorgio Sironi <piccoloprincipeazzurro@gmail.com>
|
||||||
|
*
|
||||||
|
* @deprecated The Debug class is deprecated, please use symfony/var-dumper instead.
|
||||||
|
*/
|
||||||
|
final class Debug
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Private constructor (prevents instantiation).
|
||||||
|
*/
|
||||||
|
private function __construct()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prints a dump of the public, protected and private properties of $var.
|
||||||
|
*
|
||||||
|
* @link https://xdebug.org/
|
||||||
|
*
|
||||||
|
* @param mixed $var The variable to dump.
|
||||||
|
* @param integer $maxDepth The maximum nesting level for object properties.
|
||||||
|
* @param boolean $stripTags Whether output should strip HTML tags.
|
||||||
|
* @param boolean $echo Send the dumped value to the output buffer
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function dump($var, $maxDepth = 2, $stripTags = true, $echo = true)
|
||||||
|
{
|
||||||
|
$html = ini_get('html_errors');
|
||||||
|
|
||||||
|
if ($html !== true) {
|
||||||
|
ini_set('html_errors', true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (extension_loaded('xdebug')) {
|
||||||
|
ini_set('xdebug.var_display_max_depth', $maxDepth);
|
||||||
|
}
|
||||||
|
|
||||||
|
$var = self::export($var, $maxDepth);
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
var_dump($var);
|
||||||
|
|
||||||
|
$dump = ob_get_contents();
|
||||||
|
|
||||||
|
ob_end_clean();
|
||||||
|
|
||||||
|
$dumpText = ($stripTags ? strip_tags(html_entity_decode($dump)) : $dump);
|
||||||
|
|
||||||
|
ini_set('html_errors', $html);
|
||||||
|
|
||||||
|
if ($echo) {
|
||||||
|
echo $dumpText;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $dumpText;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mixed $var
|
||||||
|
* @param int $maxDepth
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public static function export($var, $maxDepth)
|
||||||
|
{
|
||||||
|
$return = null;
|
||||||
|
$isObj = is_object($var);
|
||||||
|
|
||||||
|
if ($var instanceof Collection) {
|
||||||
|
$var = $var->toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! $maxDepth) {
|
||||||
|
return is_object($var) ? get_class($var)
|
||||||
|
: (is_array($var) ? 'Array(' . count($var) . ')' : $var);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_array($var)) {
|
||||||
|
$return = [];
|
||||||
|
|
||||||
|
foreach ($var as $k => $v) {
|
||||||
|
$return[$k] = self::export($v, $maxDepth - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! $isObj) {
|
||||||
|
return $var;
|
||||||
|
}
|
||||||
|
|
||||||
|
$return = new \stdClass();
|
||||||
|
if ($var instanceof \DateTimeInterface) {
|
||||||
|
$return->__CLASS__ = get_class($var);
|
||||||
|
$return->date = $var->format('c');
|
||||||
|
$return->timezone = $var->getTimezone()->getName();
|
||||||
|
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$return->__CLASS__ = ClassUtils::getClass($var);
|
||||||
|
|
||||||
|
if ($var instanceof Proxy) {
|
||||||
|
$return->__IS_PROXY__ = true;
|
||||||
|
$return->__PROXY_INITIALIZED__ = $var->__isInitialized();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($var instanceof \ArrayObject || $var instanceof \ArrayIterator) {
|
||||||
|
$return->__STORAGE__ = self::export($var->getArrayCopy(), $maxDepth - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::fillReturnWithClassAttributes($var, $return, $maxDepth);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fill the $return variable with class attributes
|
||||||
|
* Based on obj2array function from {@see https://secure.php.net/manual/en/function.get-object-vars.php#47075}
|
||||||
|
*
|
||||||
|
* @param object $var
|
||||||
|
* @param \stdClass $return
|
||||||
|
* @param int $maxDepth
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
private static function fillReturnWithClassAttributes($var, \stdClass $return, $maxDepth)
|
||||||
|
{
|
||||||
|
$clone = (array) $var;
|
||||||
|
|
||||||
|
foreach (array_keys($clone) as $key) {
|
||||||
|
$aux = explode("\0", $key);
|
||||||
|
$name = end($aux);
|
||||||
|
if ($aux[0] === '') {
|
||||||
|
$name .= ':' . ($aux[1] === '*' ? 'protected' : $aux[1] . ':private');
|
||||||
|
}
|
||||||
|
$return->$name = self::export($clone[$key], $maxDepth - 1);
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a string representation of an object.
|
||||||
|
*
|
||||||
|
* @param object $obj
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function toString($obj)
|
||||||
|
{
|
||||||
|
return method_exists($obj, '__toString') ? (string) $obj : get_class($obj) . '@' . spl_object_hash($obj);
|
||||||
|
}
|
||||||
|
}
|
19
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/Inflector.php
vendored
Normal file
19
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Util/Inflector.php
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common\Util;
|
||||||
|
|
||||||
|
use Doctrine\Common\Inflector\Inflector as BaseInflector;
|
||||||
|
use function trigger_error;
|
||||||
|
use const E_USER_DEPRECATED;
|
||||||
|
|
||||||
|
@trigger_error(Inflector::class . ' is deprecated.', E_USER_DEPRECATED);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Doctrine inflector has static methods for inflecting text.
|
||||||
|
*
|
||||||
|
* Kept for backwards compatibility reasons, was moved to its own component.
|
||||||
|
*
|
||||||
|
* @deprecated The Inflector class is deprecated, use Doctrine\Common\Inflector\Inflector from doctrine/inflector package instead,
|
||||||
|
*/
|
||||||
|
class Inflector extends BaseInflector
|
||||||
|
{
|
||||||
|
}
|
37
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Version.php
vendored
Normal file
37
frontend/drupal9/vendor/doctrine/common/lib/Doctrine/Common/Version.php
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?php
|
||||||
|
namespace Doctrine\Common;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class to store and retrieve the version of Doctrine.
|
||||||
|
*
|
||||||
|
* @link www.doctrine-project.org
|
||||||
|
* @since 2.0
|
||||||
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
|
* @author Jonathan Wage <jonwage@gmail.com>
|
||||||
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
|
*
|
||||||
|
* @deprecated The Version class is deprecated, please refrain from checking the version of doctrine/common.
|
||||||
|
*/
|
||||||
|
class Version
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Current Doctrine Version.
|
||||||
|
*/
|
||||||
|
const VERSION = '2.12.0-DEV';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compares a Doctrine version with the current one.
|
||||||
|
*
|
||||||
|
* @param string $version Doctrine version to compare.
|
||||||
|
*
|
||||||
|
* @return int -1 if older, 0 if it is the same, 1 if version passed as argument is newer.
|
||||||
|
*/
|
||||||
|
public static function compare($version)
|
||||||
|
{
|
||||||
|
$currentVersion = str_replace(' ', '', strtolower(self::VERSION));
|
||||||
|
$version = str_replace(' ', '', $version);
|
||||||
|
|
||||||
|
return version_compare($version, $currentVersion);
|
||||||
|
}
|
||||||
|
}
|
46
frontend/drupal9/vendor/doctrine/common/phpstan.neon.dist
vendored
Normal file
46
frontend/drupal9/vendor/doctrine/common/phpstan.neon.dist
vendored
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
parameters:
|
||||||
|
level: 3
|
||||||
|
paths:
|
||||||
|
- %currentWorkingDirectory%/lib
|
||||||
|
- %currentWorkingDirectory%/tests
|
||||||
|
autoload_directories:
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/ClassLoaderTest
|
||||||
|
excludes_analyse:
|
||||||
|
- %currentWorkingDirectory%/lib/vendor/doctrine-build-common
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/InvalidReturnTypeClass.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/InvalidTypeHintClass.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/SerializedClass.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/VariadicTypeHintClass.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicTypedPropertiesTest.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/LazyLoadableObjectWithTypedProperties.php
|
||||||
|
- %currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/generated
|
||||||
|
ignoreErrors:
|
||||||
|
- '#Access to an undefined property Doctrine\\Common\\Proxy\\Proxy::\$publicField#'
|
||||||
|
-
|
||||||
|
message: '#^Result of method Doctrine\\Tests\\Common\\Proxy\\LazyLoadableObjectWithVoid::(adding|incrementing)AndReturningVoid\(\) \(void\) is used\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicVoidReturnTypeTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Property Doctrine\\Tests\\Common\\Proxy\\ProxyLogicTest::\$initializerCallbackMock \(callable&PHPUnit\\Framework\\MockObject\\MockObject\) does not accept PHPUnit\\Framework\\MockObject\\MockObject&stdClass\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Call to an undefined method PHPUnit\\Framework\\MockObject\\MockObject(&stdClass)?::(load|getName)\(\)\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Access to an undefined property Doctrine\\Common\\Proxy\\Proxy&Doctrine\\Tests\\Common\\Proxy\\LazyLoadableObject::\$non_existing_property\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Instantiated class Doctrine\\Tests\\Common\\ProxyProxy\\__CG__\\Doctrine\\Tests\\Common\\Proxy\\.* not found.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Instantiated class Doctrine\\Tests\\Common\\ProxyProxy\\__CG__\\Doctrine\\Tests\\Common\\Proxy\\.* not found.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicVoidReturnTypeTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Property Doctrine\\Tests\\Common\\Proxy\\ProxyLogicVoidReturnTypeTest::\$initializerCallbackMock \(callable&PHPUnit\\Framework\\MockObject\\MockObject\) does not accept PHPUnit\\Framework\\MockObject\\MockObject&stdClass\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/ProxyLogicVoidReturnTypeTest.php'
|
||||||
|
-
|
||||||
|
message: '#^Method Doctrine\\Tests\\Common\\Proxy\\MagicIssetClassWithInteger::__isset\(\) should return bool but returns int\.$#'
|
||||||
|
path: '%currentWorkingDirectory%/tests/Doctrine/Tests/Common/Proxy/MagicIssetClassWithInteger.php'
|
||||||
|
|
||||||
|
includes:
|
||||||
|
- vendor/phpstan/phpstan-phpunit/extension.neon
|
||||||
|
- vendor/phpstan/phpstan-phpunit/rules.neon
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user