@rnaga/wp-node 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (517) hide show
  1. package/application.d.ts +76 -0
  2. package/application.d.ts.map +1 -0
  3. package/application.js +132 -0
  4. package/common/async-constructor.d.ts +2 -0
  5. package/common/async-constructor.d.ts.map +1 -0
  6. package/common/async-constructor.js +7 -0
  7. package/common/config/define-post-status.config.d.ts +4 -0
  8. package/common/config/define-post-status.config.d.ts.map +1 -0
  9. package/common/config/define-post-status.config.js +26 -0
  10. package/common/config/define-post-type.config.d.ts +4 -0
  11. package/common/config/define-post-type.config.d.ts.map +1 -0
  12. package/common/config/define-post-type.config.js +39 -0
  13. package/common/config/define-taxonomies.config.d.ts +4 -0
  14. package/common/config/define-taxonomies.config.d.ts.map +1 -0
  15. package/common/config/define-taxonomies.config.js +26 -0
  16. package/common/config/define-wp.config..d.ts +12 -0
  17. package/common/config/define-wp.config..d.ts.map +1 -0
  18. package/common/config/define-wp.config..js +110 -0
  19. package/common/config/index.d.ts +5 -0
  20. package/common/config/index.d.ts.map +1 -0
  21. package/common/config/index.js +20 -0
  22. package/common/date.d.ts +19 -0
  23. package/common/date.d.ts.map +1 -0
  24. package/common/date.js +116 -0
  25. package/common/define-hooks.d.ts +4 -0
  26. package/common/define-hooks.d.ts.map +1 -0
  27. package/common/define-hooks.js +16 -0
  28. package/common/diff.d.ts +3 -0
  29. package/common/diff.d.ts.map +1 -0
  30. package/common/diff.js +23 -0
  31. package/common/files.d.ts +14 -0
  32. package/common/files.d.ts.map +1 -0
  33. package/common/files.js +160 -0
  34. package/common/formatting.d.ts +47 -0
  35. package/common/formatting.d.ts.map +1 -0
  36. package/common/formatting.js +218 -0
  37. package/common/hierarchy.d.ts +21 -0
  38. package/common/hierarchy.d.ts.map +1 -0
  39. package/common/hierarchy.js +78 -0
  40. package/common/hooks-command.d.ts +7 -0
  41. package/common/hooks-command.d.ts.map +1 -0
  42. package/common/hooks-command.js +21 -0
  43. package/common/index.d.ts +11 -0
  44. package/common/index.d.ts.map +1 -0
  45. package/common/index.js +49 -0
  46. package/common/password.d.ts +4 -0
  47. package/common/password.d.ts.map +1 -0
  48. package/common/password.js +224 -0
  49. package/common/php-serialize.d.ts +3 -0
  50. package/common/php-serialize.d.ts.map +1 -0
  51. package/common/php-serialize.js +17 -0
  52. package/common/validating.d.ts +10 -0
  53. package/common/validating.d.ts.map +1 -0
  54. package/common/validating.js +65 -0
  55. package/config.d.ts +99 -0
  56. package/config.d.ts.map +1 -0
  57. package/config.js +76 -0
  58. package/constants/async-init.d.ts +2 -0
  59. package/constants/async-init.d.ts.map +1 -0
  60. package/constants/async-init.js +4 -0
  61. package/constants/component.d.ts +3 -0
  62. package/constants/component.d.ts.map +1 -0
  63. package/constants/component.js +5 -0
  64. package/constants/database.d.ts +2 -0
  65. package/constants/database.d.ts.map +1 -0
  66. package/constants/database.js +9 -0
  67. package/constants/default-database-tables.d.ts +7 -0
  68. package/constants/default-database-tables.d.ts.map +1 -0
  69. package/constants/default-database-tables.js +26 -0
  70. package/constants/index.d.ts +9 -0
  71. package/constants/index.d.ts.map +1 -0
  72. package/constants/index.js +24 -0
  73. package/constants/role-capabilities.d.ts +3 -0
  74. package/constants/role-capabilities.d.ts.map +1 -0
  75. package/constants/role-capabilities.js +67 -0
  76. package/constants/role-capability-actions.d.ts +2 -0
  77. package/constants/role-capability-actions.d.ts.map +1 -0
  78. package/constants/role-capability-actions.js +90 -0
  79. package/constants/role-names.d.ts +2 -0
  80. package/constants/role-names.d.ts.map +1 -0
  81. package/constants/role-names.js +12 -0
  82. package/constants/scope.d.ts +6 -0
  83. package/constants/scope.d.ts.map +1 -0
  84. package/constants/scope.js +9 -0
  85. package/core/async-init-reflect.d.ts +5 -0
  86. package/core/async-init-reflect.d.ts.map +1 -0
  87. package/core/async-init-reflect.js +18 -0
  88. package/core/blog.d.ts +20 -0
  89. package/core/blog.d.ts.map +1 -0
  90. package/core/blog.js +123 -0
  91. package/core/capabilities.d.ts +12 -0
  92. package/core/capabilities.d.ts.map +1 -0
  93. package/core/capabilities.js +625 -0
  94. package/core/comment.d.ts +111 -0
  95. package/core/comment.d.ts.map +1 -0
  96. package/core/comment.js +173 -0
  97. package/core/components.d.ts +13 -0
  98. package/core/components.d.ts.map +1 -0
  99. package/core/components.js +129 -0
  100. package/core/context.d.ts +38 -0
  101. package/core/context.d.ts.map +1 -0
  102. package/core/context.js +77 -0
  103. package/core/current.d.ts +33 -0
  104. package/core/current.d.ts.map +1 -0
  105. package/core/current.js +229 -0
  106. package/core/date-time.d.ts +18 -0
  107. package/core/date-time.d.ts.map +1 -0
  108. package/core/date-time.js +71 -0
  109. package/core/hooks/action.d.ts +16 -0
  110. package/core/hooks/action.d.ts.map +1 -0
  111. package/core/hooks/action.js +44 -0
  112. package/core/hooks/actions/init.d.ts +5 -0
  113. package/core/hooks/actions/init.d.ts.map +1 -0
  114. package/core/hooks/actions/init.js +28 -0
  115. package/core/hooks/default-hooks.d.ts +7 -0
  116. package/core/hooks/default-hooks.d.ts.map +1 -0
  117. package/core/hooks/default-hooks.js +19 -0
  118. package/core/hooks/filter.d.ts +12 -0
  119. package/core/hooks/filter.d.ts.map +1 -0
  120. package/core/hooks/filter.js +76 -0
  121. package/core/hooks/filters/capabilities.d.ts +16 -0
  122. package/core/hooks/filters/capabilities.d.ts.map +1 -0
  123. package/core/hooks/filters/capabilities.js +395 -0
  124. package/core/hooks/hooks-command.d.ts +9 -0
  125. package/core/hooks/hooks-command.d.ts.map +1 -0
  126. package/core/hooks/hooks-command.js +28 -0
  127. package/core/hooks/hooks-reflect.d.ts +42 -0
  128. package/core/hooks/hooks-reflect.d.ts.map +1 -0
  129. package/core/hooks/hooks-reflect.js +73 -0
  130. package/core/hooks/hooks.d.ts +61 -0
  131. package/core/hooks/hooks.d.ts.map +1 -0
  132. package/core/hooks/hooks.js +82 -0
  133. package/core/hooks/index.d.ts +4 -0
  134. package/core/hooks/index.d.ts.map +1 -0
  135. package/core/hooks/index.js +19 -0
  136. package/core/installer.d.ts +56 -0
  137. package/core/installer.d.ts.map +1 -0
  138. package/core/installer.js +395 -0
  139. package/core/logger.d.ts +22 -0
  140. package/core/logger.d.ts.map +1 -0
  141. package/core/logger.js +65 -0
  142. package/core/meta.d.ts +20 -0
  143. package/core/meta.d.ts.map +1 -0
  144. package/core/meta.js +123 -0
  145. package/core/options.d.ts +20 -0
  146. package/core/options.d.ts.map +1 -0
  147. package/core/options.js +148 -0
  148. package/core/post.d.ts +39 -0
  149. package/core/post.d.ts.map +1 -0
  150. package/core/post.js +164 -0
  151. package/core/query.d.ts +14 -0
  152. package/core/query.d.ts.map +1 -0
  153. package/core/query.js +39 -0
  154. package/core/role.d.ts +21 -0
  155. package/core/role.d.ts.map +1 -0
  156. package/core/role.js +71 -0
  157. package/core/roles.d.ts +16 -0
  158. package/core/roles.d.ts.map +1 -0
  159. package/core/roles.js +84 -0
  160. package/core/schema.d.ts +13 -0
  161. package/core/schema.d.ts.map +1 -0
  162. package/core/schema.js +83 -0
  163. package/core/site.d.ts +28 -0
  164. package/core/site.d.ts.map +1 -0
  165. package/core/site.js +105 -0
  166. package/core/tables.d.ts +18 -0
  167. package/core/tables.d.ts.map +1 -0
  168. package/core/tables.js +64 -0
  169. package/core/taxonomy.d.ts +23 -0
  170. package/core/taxonomy.d.ts.map +1 -0
  171. package/core/taxonomy.js +83 -0
  172. package/core/term.d.ts +104 -0
  173. package/core/term.d.ts.map +1 -0
  174. package/core/term.js +136 -0
  175. package/core/user.d.ts +32 -0
  176. package/core/user.d.ts.map +1 -0
  177. package/core/user.js +273 -0
  178. package/core/utils/blog.util.d.ts +14 -0
  179. package/core/utils/blog.util.d.ts.map +1 -0
  180. package/core/utils/blog.util.js +97 -0
  181. package/core/utils/comment.util.d.ts +23 -0
  182. package/core/utils/comment.util.d.ts.map +1 -0
  183. package/core/utils/comment.util.js +312 -0
  184. package/core/utils/crud.util.d.ts +40 -0
  185. package/core/utils/crud.util.d.ts.map +1 -0
  186. package/core/utils/crud.util.js +97 -0
  187. package/core/utils/date-time.util.d.ts +9 -0
  188. package/core/utils/date-time.util.d.ts.map +1 -0
  189. package/core/utils/date-time.util.js +29 -0
  190. package/core/utils/link.util.d.ts +23 -0
  191. package/core/utils/link.util.d.ts.map +1 -0
  192. package/core/utils/link.util.js +148 -0
  193. package/core/utils/meta.util.d.ts +13 -0
  194. package/core/utils/meta.util.d.ts.map +1 -0
  195. package/core/utils/meta.util.js +73 -0
  196. package/core/utils/post.util.d.ts +34 -0
  197. package/core/utils/post.util.d.ts.map +1 -0
  198. package/core/utils/post.util.js +272 -0
  199. package/core/utils/query.util.d.ts +36 -0
  200. package/core/utils/query.util.d.ts.map +1 -0
  201. package/core/utils/query.util.js +168 -0
  202. package/core/utils/revision.util.d.ts +67 -0
  203. package/core/utils/revision.util.d.ts.map +1 -0
  204. package/core/utils/revision.util.js +105 -0
  205. package/core/utils/roles.util.d.ts +30 -0
  206. package/core/utils/roles.util.d.ts.map +1 -0
  207. package/core/utils/roles.util.js +189 -0
  208. package/core/utils/signup.util.d.ts +33 -0
  209. package/core/utils/signup.util.d.ts.map +1 -0
  210. package/core/utils/signup.util.js +227 -0
  211. package/core/utils/site.util.d.ts +22 -0
  212. package/core/utils/site.util.d.ts.map +1 -0
  213. package/core/utils/site.util.js +122 -0
  214. package/core/utils/taxonomy.util.d.ts +19 -0
  215. package/core/utils/taxonomy.util.d.ts.map +1 -0
  216. package/core/utils/taxonomy.util.js +52 -0
  217. package/core/utils/term.util.d.ts +13 -0
  218. package/core/utils/term.util.d.ts.map +1 -0
  219. package/core/utils/term.util.js +113 -0
  220. package/core/utils/trx.util.d.ts +24 -0
  221. package/core/utils/trx.util.d.ts.map +1 -0
  222. package/core/utils/trx.util.js +86 -0
  223. package/core/utils/user-self-registration.util.d.ts +46 -0
  224. package/core/utils/user-self-registration.util.d.ts.map +1 -0
  225. package/core/utils/user-self-registration.util.js +171 -0
  226. package/core/utils/user.util.d.ts +153 -0
  227. package/core/utils/user.util.d.ts.map +1 -0
  228. package/core/utils/user.util.js +550 -0
  229. package/core/utils/utils.d.ts +36 -0
  230. package/core/utils/utils.d.ts.map +1 -0
  231. package/core/utils/utils.js +85 -0
  232. package/core/validator.d.ts +11 -0
  233. package/core/validator.d.ts.map +1 -0
  234. package/core/validator.js +40 -0
  235. package/core/vars.d.ts +19 -0
  236. package/core/vars.d.ts.map +1 -0
  237. package/core/vars.js +54 -0
  238. package/crud/blog.crud.d.ts +56 -0
  239. package/crud/blog.crud.d.ts.map +1 -0
  240. package/crud/blog.crud.js +301 -0
  241. package/crud/comment.crud.d.ts +104 -0
  242. package/crud/comment.crud.d.ts.map +1 -0
  243. package/crud/comment.crud.js +431 -0
  244. package/crud/crud.d.ts +63 -0
  245. package/crud/crud.d.ts.map +1 -0
  246. package/crud/crud.js +278 -0
  247. package/crud/error.d.ts +23 -0
  248. package/crud/error.d.ts.map +1 -0
  249. package/crud/error.js +51 -0
  250. package/crud/meta.crud.d.ts +69 -0
  251. package/crud/meta.crud.d.ts.map +1 -0
  252. package/crud/meta.crud.js +244 -0
  253. package/crud/options.crud.d.ts +37 -0
  254. package/crud/options.crud.d.ts.map +1 -0
  255. package/crud/options.crud.js +178 -0
  256. package/crud/post.crud.d.ts +225 -0
  257. package/crud/post.crud.d.ts.map +1 -0
  258. package/crud/post.crud.js +589 -0
  259. package/crud/revision.crud.d.ts +76 -0
  260. package/crud/revision.crud.d.ts.map +1 -0
  261. package/crud/revision.crud.js +155 -0
  262. package/crud/roles.crud.d.ts +50 -0
  263. package/crud/roles.crud.d.ts.map +1 -0
  264. package/crud/roles.crud.js +198 -0
  265. package/crud/settings.crud.d.ts +50 -0
  266. package/crud/settings.crud.d.ts.map +1 -0
  267. package/crud/settings.crud.js +153 -0
  268. package/crud/site.crud.d.ts +62 -0
  269. package/crud/site.crud.d.ts.map +1 -0
  270. package/crud/site.crud.js +241 -0
  271. package/crud/sitemeta.crud.d.ts +55 -0
  272. package/crud/sitemeta.crud.d.ts.map +1 -0
  273. package/crud/sitemeta.crud.js +97 -0
  274. package/crud/term.crud.d.ts +85 -0
  275. package/crud/term.crud.d.ts.map +1 -0
  276. package/crud/term.crud.js +285 -0
  277. package/crud/user-self-registration.crud.d.ts +57 -0
  278. package/crud/user-self-registration.crud.d.ts.map +1 -0
  279. package/crud/user-self-registration.crud.js +173 -0
  280. package/crud/user.crud.d.ts +147 -0
  281. package/crud/user.crud.d.ts.map +1 -0
  282. package/crud/user.crud.js +626 -0
  283. package/database.d.ts +18 -0
  284. package/database.d.ts.map +1 -0
  285. package/database.js +80 -0
  286. package/decorators/async-init.d.ts +2 -0
  287. package/decorators/async-init.d.ts.map +1 -0
  288. package/decorators/async-init.js +7 -0
  289. package/decorators/component.d.ts +12 -0
  290. package/decorators/component.d.ts.map +1 -0
  291. package/decorators/component.js +47 -0
  292. package/decorators/hooks.d.ts +5 -0
  293. package/decorators/hooks.d.ts.map +1 -0
  294. package/decorators/hooks.js +30 -0
  295. package/defaults/extensions.d.ts +4 -0
  296. package/defaults/extensions.d.ts.map +1 -0
  297. package/defaults/extensions.js +34 -0
  298. package/defaults/index.d.ts +11 -0
  299. package/defaults/index.d.ts.map +1 -0
  300. package/defaults/index.js +49 -0
  301. package/defaults/options.d.ts +6 -0
  302. package/defaults/options.d.ts.map +1 -0
  303. package/defaults/options.js +267 -0
  304. package/defaults/post-status.d.ts +10 -0
  305. package/defaults/post-status.d.ts.map +1 -0
  306. package/defaults/post-status.js +83 -0
  307. package/defaults/post-types.d.ts +4 -0
  308. package/defaults/post-types.d.ts.map +1 -0
  309. package/defaults/post-types.js +72 -0
  310. package/defaults/roles.d.ts +31 -0
  311. package/defaults/roles.d.ts.map +1 -0
  312. package/defaults/roles.js +213 -0
  313. package/defaults/seeder.d.ts +34 -0
  314. package/defaults/seeder.d.ts.map +1 -0
  315. package/defaults/seeder.js +201 -0
  316. package/defaults/sitemeta.d.ts +2 -0
  317. package/defaults/sitemeta.d.ts.map +1 -0
  318. package/defaults/sitemeta.js +38 -0
  319. package/defaults/subdirectory-reserved-names.d.ts +2 -0
  320. package/defaults/subdirectory-reserved-names.d.ts.map +1 -0
  321. package/defaults/subdirectory-reserved-names.js +16 -0
  322. package/defaults/taxonomies.d.ts +5 -0
  323. package/defaults/taxonomies.d.ts.map +1 -0
  324. package/defaults/taxonomies.js +57 -0
  325. package/defaults/timezone.d.ts +2 -0
  326. package/defaults/timezone.d.ts.map +1 -0
  327. package/defaults/timezone.js +353 -0
  328. package/package.json +51 -0
  329. package/query-builder/alias.d.ts +24 -0
  330. package/query-builder/alias.d.ts.map +1 -0
  331. package/query-builder/alias.js +64 -0
  332. package/query-builder/blogs.query.d.ts +22 -0
  333. package/query-builder/blogs.query.d.ts.map +1 -0
  334. package/query-builder/blogs.query.js +85 -0
  335. package/query-builder/comments.query.d.ts +35 -0
  336. package/query-builder/comments.query.d.ts.map +1 -0
  337. package/query-builder/comments.query.js +211 -0
  338. package/query-builder/common.query.d.ts +18 -0
  339. package/query-builder/common.query.d.ts.map +1 -0
  340. package/query-builder/common.query.js +58 -0
  341. package/query-builder/index.d.ts +12 -0
  342. package/query-builder/index.d.ts.map +1 -0
  343. package/query-builder/index.js +27 -0
  344. package/query-builder/meta.query.d.ts +45 -0
  345. package/query-builder/meta.query.d.ts.map +1 -0
  346. package/query-builder/meta.query.js +188 -0
  347. package/query-builder/options.query.d.ts +19 -0
  348. package/query-builder/options.query.d.ts.map +1 -0
  349. package/query-builder/options.query.js +57 -0
  350. package/query-builder/posts.query.d.ts +30 -0
  351. package/query-builder/posts.query.d.ts.map +1 -0
  352. package/query-builder/posts.query.js +208 -0
  353. package/query-builder/query-builder.d.ts +21 -0
  354. package/query-builder/query-builder.d.ts.map +1 -0
  355. package/query-builder/query-builder.js +70 -0
  356. package/query-builder/query-builders.d.ts +18 -0
  357. package/query-builder/query-builders.d.ts.map +1 -0
  358. package/query-builder/query-builders.js +64 -0
  359. package/query-builder/site.query.d.ts +22 -0
  360. package/query-builder/site.query.d.ts.map +1 -0
  361. package/query-builder/site.query.js +85 -0
  362. package/query-builder/terms.query.d.ts +47 -0
  363. package/query-builder/terms.query.d.ts.map +1 -0
  364. package/query-builder/terms.query.js +233 -0
  365. package/query-builder/users.query.d.ts +37 -0
  366. package/query-builder/users.query.d.ts.map +1 -0
  367. package/query-builder/users.query.js +188 -0
  368. package/schema-builder/proxy.d.ts +10 -0
  369. package/schema-builder/proxy.d.ts.map +1 -0
  370. package/schema-builder/proxy.js +19 -0
  371. package/schema-builder/schema-builder.d.ts +21 -0
  372. package/schema-builder/schema-builder.d.ts.map +1 -0
  373. package/schema-builder/schema-builder.js +207 -0
  374. package/schema-builder/schema.d.ts +20 -0
  375. package/schema-builder/schema.d.ts.map +1 -0
  376. package/schema-builder/schema.js +527 -0
  377. package/transactions/blog.trx.d.ts +37 -0
  378. package/transactions/blog.trx.d.ts.map +1 -0
  379. package/transactions/blog.trx.js +296 -0
  380. package/transactions/comment.trx.d.ts +22 -0
  381. package/transactions/comment.trx.d.ts.map +1 -0
  382. package/transactions/comment.trx.js +311 -0
  383. package/transactions/index.d.ts +15 -0
  384. package/transactions/index.d.ts.map +1 -0
  385. package/transactions/index.js +30 -0
  386. package/transactions/link.trx.d.ts +22 -0
  387. package/transactions/link.trx.d.ts.map +1 -0
  388. package/transactions/link.trx.js +208 -0
  389. package/transactions/meta.trx.d.ts +30 -0
  390. package/transactions/meta.trx.d.ts.map +1 -0
  391. package/transactions/meta.trx.js +197 -0
  392. package/transactions/options.trx.d.ts +31 -0
  393. package/transactions/options.trx.d.ts.map +1 -0
  394. package/transactions/options.trx.js +192 -0
  395. package/transactions/post.trx.d.ts +48 -0
  396. package/transactions/post.trx.d.ts.map +1 -0
  397. package/transactions/post.trx.js +906 -0
  398. package/transactions/registration-log.trx.d.ts +14 -0
  399. package/transactions/registration-log.trx.d.ts.map +1 -0
  400. package/transactions/registration-log.trx.js +103 -0
  401. package/transactions/revision.trx.d.ts +32 -0
  402. package/transactions/revision.trx.d.ts.map +1 -0
  403. package/transactions/revision.trx.js +278 -0
  404. package/transactions/roles.trx.d.ts +20 -0
  405. package/transactions/roles.trx.d.ts.map +1 -0
  406. package/transactions/roles.trx.js +144 -0
  407. package/transactions/seeder.trx.d.ts +43 -0
  408. package/transactions/seeder.trx.d.ts.map +1 -0
  409. package/transactions/seeder.trx.js +530 -0
  410. package/transactions/signup.trx.d.ts +53 -0
  411. package/transactions/signup.trx.d.ts.map +1 -0
  412. package/transactions/signup.trx.js +305 -0
  413. package/transactions/site.trx.d.ts +21 -0
  414. package/transactions/site.trx.d.ts.map +1 -0
  415. package/transactions/site.trx.js +167 -0
  416. package/transactions/term.trx.d.ts +51 -0
  417. package/transactions/term.trx.d.ts.map +1 -0
  418. package/transactions/term.trx.js +838 -0
  419. package/transactions/trx.d.ts +9 -0
  420. package/transactions/trx.d.ts.map +1 -0
  421. package/transactions/trx.js +20 -0
  422. package/transactions/user.trx.d.ts +45 -0
  423. package/transactions/user.trx.d.ts.map +1 -0
  424. package/transactions/user.trx.js +535 -0
  425. package/types/capabilities.d.ts +71 -0
  426. package/types/common.d.ts +16 -0
  427. package/types/component.d.ts +3 -0
  428. package/types/config.d.ts +33 -0
  429. package/types/crud.d.ts +230 -0
  430. package/types/database.d.ts +50 -0
  431. package/types/hooks/actions.d.ts +67 -0
  432. package/types/hooks/command.d.ts +17 -0
  433. package/types/hooks/filters.d.ts +86 -0
  434. package/types/hooks/index.d.ts +11 -0
  435. package/types/index.d.ts +18 -0
  436. package/types/logging.d.ts +1 -0
  437. package/types/meta.d.ts +9 -0
  438. package/types/options.d.ts +3 -0
  439. package/types/post.d.ts +54 -0
  440. package/types/query-builder.d.ts +11 -0
  441. package/types/role.d.ts +34 -0
  442. package/types/schema.d.ts +11 -0
  443. package/types/schema.d.ts.map +1 -0
  444. package/types/schema.js +2 -0
  445. package/types/taxonomy.d.ts +29 -0
  446. package/types/timezone.d.ts +3 -0
  447. package/types/transactions.d.ts +32 -0
  448. package/types/user.d.ts +12 -0
  449. package/types/validating.d.ts +9 -0
  450. package/types/validating.d.ts.map +1 -0
  451. package/types/validating.js +2 -0
  452. package/validators/config.d.ts +948 -0
  453. package/validators/config.d.ts.map +1 -0
  454. package/validators/config.js +149 -0
  455. package/validators/crud.d.ts +571 -0
  456. package/validators/crud.d.ts.map +1 -0
  457. package/validators/crud.js +281 -0
  458. package/validators/database.d.ts +958 -0
  459. package/validators/database.d.ts.map +1 -0
  460. package/validators/database.js +245 -0
  461. package/validators/date.d.ts +4 -0
  462. package/validators/date.d.ts.map +1 -0
  463. package/validators/date.js +15 -0
  464. package/validators/helpers.d.ts +16 -0
  465. package/validators/helpers.d.ts.map +1 -0
  466. package/validators/helpers.js +86 -0
  467. package/validators/index.d.ts +10 -0
  468. package/validators/index.d.ts.map +1 -0
  469. package/validators/index.js +48 -0
  470. package/validators/options.d.ts +303 -0
  471. package/validators/options.d.ts.map +1 -0
  472. package/validators/options.js +106 -0
  473. package/validators/post-status.d.ts +42 -0
  474. package/validators/post-status.d.ts.map +1 -0
  475. package/validators/post-status.js +18 -0
  476. package/validators/query.d.ts +534 -0
  477. package/validators/query.d.ts.map +1 -0
  478. package/validators/query.js +110 -0
  479. package/validators/roles.d.ts +22 -0
  480. package/validators/roles.d.ts.map +1 -0
  481. package/validators/roles.js +9 -0
  482. package/validators/sitemeta.d.ts +105 -0
  483. package/validators/sitemeta.d.ts.map +1 -0
  484. package/validators/sitemeta.js +39 -0
  485. package/validators/transactions/blog.d.ts +225 -0
  486. package/validators/transactions/blog.d.ts.map +1 -0
  487. package/validators/transactions/blog.js +63 -0
  488. package/validators/transactions/comment.d.ts +155 -0
  489. package/validators/transactions/comment.d.ts.map +1 -0
  490. package/validators/transactions/comment.js +68 -0
  491. package/validators/transactions/index.d.ts +11 -0
  492. package/validators/transactions/index.d.ts.map +1 -0
  493. package/validators/transactions/index.js +26 -0
  494. package/validators/transactions/link.d.ts +128 -0
  495. package/validators/transactions/link.d.ts.map +1 -0
  496. package/validators/transactions/link.js +60 -0
  497. package/validators/transactions/meta.d.ts +23 -0
  498. package/validators/transactions/meta.d.ts.map +1 -0
  499. package/validators/transactions/meta.js +18 -0
  500. package/validators/transactions/post.d.ts +234 -0
  501. package/validators/transactions/post.d.ts.map +1 -0
  502. package/validators/transactions/post.js +100 -0
  503. package/validators/transactions/roles.d.ts +18 -0
  504. package/validators/transactions/roles.d.ts.map +1 -0
  505. package/validators/transactions/roles.js +13 -0
  506. package/validators/transactions/signup.d.ts +35 -0
  507. package/validators/transactions/signup.d.ts.map +1 -0
  508. package/validators/transactions/signup.js +51 -0
  509. package/validators/transactions/site.d.ts +36 -0
  510. package/validators/transactions/site.d.ts.map +1 -0
  511. package/validators/transactions/site.js +49 -0
  512. package/validators/transactions/term.d.ts +57 -0
  513. package/validators/transactions/term.d.ts.map +1 -0
  514. package/validators/transactions/term.js +44 -0
  515. package/validators/transactions/user.d.ts +182 -0
  516. package/validators/transactions/user.d.ts.map +1 -0
  517. package/validators/transactions/user.js +104 -0
@@ -0,0 +1,625 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.Capabilities = void 0;
13
+ const config_1 = require("../config");
14
+ const constants_1 = require("../constants");
15
+ /* eslint-disable no-case-declarations */
16
+ const component_1 = require("../decorators/component");
17
+ const components_1 = require("./components");
18
+ const current_1 = require("./current");
19
+ const options_1 = require("./options");
20
+ const user_1 = require("./user");
21
+ const comment_util_1 = require("./utils/comment.util");
22
+ const meta_util_1 = require("./utils/meta.util");
23
+ const post_util_1 = require("./utils/post.util");
24
+ const taxonomy_util_1 = require("./utils/taxonomy.util");
25
+ const term_util_1 = require("./utils/term.util");
26
+ const user_util_1 = require("./utils/user.util");
27
+ const vars_1 = require("./vars");
28
+ let Capabilities = class Capabilities {
29
+ config;
30
+ components;
31
+ constructor(config, components) {
32
+ this.config = config;
33
+ this.components = components;
34
+ }
35
+ addCap(set, postType, key) {
36
+ if (!postType.capabilities || !postType.capabilities[key]) {
37
+ return;
38
+ }
39
+ set.add(postType.capabilities[key]);
40
+ }
41
+ async check(action, user, ...args) {
42
+ //let results: string[] = [];
43
+ let results = new Set();
44
+ let post, postType;
45
+ const options = this.components.get(options_1.Options);
46
+ const current = this.components.get(current_1.Current);
47
+ const postUtil = this.components.get(post_util_1.PostUtil);
48
+ const userUtil = this.components.get(user_util_1.UserUtil);
49
+ const commentUtil = this.components.get(comment_util_1.CommentUtil);
50
+ const metaUtil = this.components.get(meta_util_1.MetaUtil);
51
+ const taxonomyUtil = this.components.get(taxonomy_util_1.TaxonomyUtil);
52
+ const termUtil = this.components.get(term_util_1.TermUtil);
53
+ const vars = this.components.get(vars_1.Vars);
54
+ if (!(user instanceof user_1.User)) {
55
+ user = await userUtil.get(user);
56
+ }
57
+ const role = await user.role();
58
+ if (!user) {
59
+ return [constants_1.DO_NOT_ALLOW];
60
+ }
61
+ switch (action) {
62
+ case "remove_user":
63
+ // In multisite the user must be a super admin to remove themselves.
64
+ if (args[0] && user.props?.ID == args[0] && !role.isSuperAdmin()) {
65
+ results.add(constants_1.DO_NOT_ALLOW);
66
+ }
67
+ else {
68
+ results.add("remove_users");
69
+ }
70
+ break;
71
+ case "promote_user":
72
+ case "add_users":
73
+ results.add("promote_users");
74
+ break;
75
+ case "edit_user":
76
+ case "edit_users":
77
+ // Allow user to edit themselves.
78
+ if ("edit_user" === action && args[0] && user.props?.ID == args[0]) {
79
+ break;
80
+ }
81
+ const targetUser = await userUtil.get(args[0]);
82
+ const targetRole = await targetUser.role();
83
+ // In multisite the user must have manage_network_users caps. If editing a super admin, the user must be a super admin.
84
+ if (this.config.isMultiSite() &&
85
+ ((!role.isSuperAdmin() &&
86
+ "edit_user" === action &&
87
+ targetRole.isSuperAdmin()) ||
88
+ !role.has("manage_network_users"))) {
89
+ results.add(constants_1.DO_NOT_ALLOW);
90
+ }
91
+ else {
92
+ results.add("edit_users"); // edit_user maps to edit_users.
93
+ }
94
+ break;
95
+ case "delete_post":
96
+ case "delete_page":
97
+ if (!args[0]) {
98
+ // When checking for the %s capability, you must always check it against a specific post.
99
+ results.add(constants_1.DO_NOT_ALLOW);
100
+ break;
101
+ }
102
+ post = await postUtil.get(args[0]);
103
+ if (!post.props?.ID) {
104
+ results.add(constants_1.DO_NOT_ALLOW);
105
+ break;
106
+ }
107
+ if ("revision" === post.props.post_type) {
108
+ results.add(constants_1.DO_NOT_ALLOW);
109
+ break;
110
+ }
111
+ if (parseInt((await options.get("page_for_posts")) ?? "-1") ==
112
+ post.props.ID ||
113
+ parseInt((await options.get("page_on_front")) ?? "-1") ==
114
+ post.props.ID) {
115
+ results.add("manage_options");
116
+ break;
117
+ }
118
+ postType = postUtil.getTypeObject(post.props.post_type);
119
+ // The post type %1$s is not registered, so it may not be reliable
120
+ // to check the capability %2$s against a post of that type.
121
+ if (!postType) {
122
+ results.add("edit_others_posts");
123
+ break;
124
+ }
125
+ if (!postType.mapMetaCap) {
126
+ this.addCap(results, postType, action);
127
+ break;
128
+ }
129
+ //If the post author is set and the user is the author...
130
+ if (post.props.post_author &&
131
+ user.props?.ID == post.props.post_author) {
132
+ // If the post is published or scheduled...
133
+ //if ( in_array( $post->post_status, array( 'publish', 'future' ), true ) ) {
134
+ if (["publish", "future"].includes(post.props.post_status)) {
135
+ this.addCap(results, postType, "delete_published_posts");
136
+ }
137
+ else if ("trash" === post.props.post_status) {
138
+ const postStatus = await post.meta.get("_wp_trash_meta_status");
139
+ if (postStatus && ["publish", "future"].includes(postStatus)) {
140
+ this.addCap(results, postType, "delete_published_posts");
141
+ }
142
+ else {
143
+ this.addCap(results, postType, "delete_posts");
144
+ }
145
+ }
146
+ else {
147
+ // If the post is draft...
148
+ this.addCap(results, postType, "delete_posts");
149
+ }
150
+ }
151
+ else {
152
+ // The user is trying to edit someone else's post.
153
+ this.addCap(results, postType, "delete_others_posts");
154
+ // The post is published or scheduled, extra cap required.
155
+ if (["publish", "future"].includes(post.props.post_status)) {
156
+ this.addCap(results, postType, "delete_published_posts");
157
+ }
158
+ else if ("private" === post.props.post_status) {
159
+ this.addCap(results, postType, "delete_private_posts");
160
+ }
161
+ }
162
+ break;
163
+ /*
164
+ * edit_post breaks down to edit_posts, edit_published_posts, or
165
+ * edit_others_posts.
166
+ */
167
+ case "edit_post":
168
+ case "edit_page":
169
+ if (!args[0]) {
170
+ // When checking for the %s capability, you must always check it against a specific post.'
171
+ results.add(constants_1.DO_NOT_ALLOW);
172
+ break;
173
+ }
174
+ post = await postUtil.get(args[0]);
175
+ if (!post.props?.ID) {
176
+ results.add(constants_1.DO_NOT_ALLOW);
177
+ break;
178
+ }
179
+ if ("revision" === post.props.post_type) {
180
+ post = await postUtil.get(post.props.post_parent);
181
+ if (!post.props?.ID) {
182
+ results.add(constants_1.DO_NOT_ALLOW);
183
+ break;
184
+ }
185
+ }
186
+ postType = postUtil.getTypeObject(post.props.post_type);
187
+ if (!postType) {
188
+ // 'The post type %1$s is not registered,
189
+ // so it may not be reliable to check the capability %2$s against a post of that type.'
190
+ results.add("edit_others_posts");
191
+ break;
192
+ }
193
+ if (!postType.mapMetaCap) {
194
+ this.addCap(results, postType, action);
195
+ break;
196
+ }
197
+ // If the post author is set and the user is the author...
198
+ if (post.props.post_author &&
199
+ user.props?.ID == post.props.post_author) {
200
+ // If the post is published or scheduled...
201
+ if (["publish", "future"].includes(post.props.post_status)) {
202
+ this.addCap(results, postType, "edit_published_posts");
203
+ }
204
+ else if ("trash" === post.props.post_status) {
205
+ const postStatus = await post.meta.get("_wp_trash_meta_status");
206
+ if (postStatus && ["publish", "future"].includes(postStatus)) {
207
+ this.addCap(results, postType, "edit_published_posts");
208
+ }
209
+ else {
210
+ this.addCap(results, postType, "edit_posts");
211
+ }
212
+ }
213
+ else {
214
+ // If the post is draft...
215
+ this.addCap(results, postType, "edit_posts");
216
+ }
217
+ }
218
+ else {
219
+ // The user is trying to edit someone else's post.
220
+ this.addCap(results, postType, "edit_others_posts");
221
+ // The post is published or scheduled, extra cap required.
222
+ if (["publish", "future"].includes(post.props.post_status)) {
223
+ this.addCap(results, postType, "edit_published_posts");
224
+ }
225
+ else if ("private" === post.props.post_status) {
226
+ this.addCap(results, postType, "edit_private_posts");
227
+ }
228
+ }
229
+ break;
230
+ case "read_post":
231
+ case "read_page":
232
+ if (!args[0]) {
233
+ // 'When checking for the %s capability, you must always check it against a specific post.'
234
+ // 'When checking for the %s capability, you must always check it against a specific page.'
235
+ results.add(constants_1.DO_NOT_ALLOW);
236
+ break;
237
+ }
238
+ post = await postUtil.get(args[0]);
239
+ if (!post.props?.ID) {
240
+ results.add(constants_1.DO_NOT_ALLOW);
241
+ break;
242
+ }
243
+ if ("revision" === post.props.post_type) {
244
+ post = await postUtil.get(post.props.post_parent);
245
+ if (!post.props?.ID) {
246
+ results.add(constants_1.DO_NOT_ALLOW);
247
+ break;
248
+ }
249
+ }
250
+ postType = postUtil.getTypeObject(post.props.post_type);
251
+ if (!postType) {
252
+ // 'The post type %1$s is not registered,
253
+ // so it may not be reliable to check the capability %2$s against a post of that type.'
254
+ results.add("edit_others_posts");
255
+ break;
256
+ }
257
+ if (!postType.mapMetaCap) {
258
+ this.addCap(results, postType, action);
259
+ break;
260
+ }
261
+ const postStatusObject = postUtil.getStatusObject(await postUtil.getStatus(post));
262
+ if (!postStatusObject) {
263
+ // The post status %1$s is not registered,
264
+ // so it may not be reliable to check the capability %2$s against a post with that status.
265
+ results.add("edit_others_posts");
266
+ break;
267
+ }
268
+ if (postStatusObject.public) {
269
+ this.addCap(results, postType, "read");
270
+ break;
271
+ }
272
+ if (post.props.post_author &&
273
+ user.props?.ID == post.props.post_author) {
274
+ this.addCap(results, postType, "read");
275
+ }
276
+ else if (postStatusObject.private) {
277
+ this.addCap(results, postType, "read_private_posts");
278
+ }
279
+ else {
280
+ results = new Set(await this.check("edit_post", user, post.props.ID));
281
+ }
282
+ break;
283
+ case "publish_post":
284
+ if (!args[0]) {
285
+ // 'When checking for the %s capability, you must always check it against a specific post.'
286
+ results.add(constants_1.DO_NOT_ALLOW);
287
+ break;
288
+ }
289
+ post = await postUtil.get(args[0]);
290
+ if (!post.props?.ID) {
291
+ results.add(constants_1.DO_NOT_ALLOW);
292
+ break;
293
+ }
294
+ postType = postUtil.getTypeObject(post.props.post_type);
295
+ if (!postType) {
296
+ // The post type %1$s is not registered,
297
+ // so it may not be reliable to check the capability %2$s against a post of that type
298
+ results.add("edit_others_posts");
299
+ break;
300
+ }
301
+ this.addCap(results, postType, "publish_posts");
302
+ break;
303
+ case "edit_post_meta":
304
+ case "delete_post_meta":
305
+ case "add_post_meta":
306
+ case "edit_comment_meta":
307
+ case "delete_comment_meta":
308
+ case "add_comment_meta":
309
+ case "edit_term_meta":
310
+ case "delete_term_meta":
311
+ case "add_term_meta":
312
+ case "edit_user_meta":
313
+ case "delete_user_meta":
314
+ case "add_user_meta":
315
+ const objectType = action.split("_")[1] ?? "";
316
+ if (!args[0]) {
317
+ results.add(constants_1.DO_NOT_ALLOW);
318
+ break;
319
+ }
320
+ const objectId = parseInt(args[0]);
321
+ const objectSubType = await metaUtil.getObjectSubtype(objectType, objectId);
322
+ if (!objectSubType) {
323
+ results.add(constants_1.DO_NOT_ALLOW);
324
+ break;
325
+ }
326
+ results = new Set(await this.check(`edit_${objectType}`, user, objectId));
327
+ if (typeof args[1] == "string" && metaUtil.isProtected(args[1])) {
328
+ results.add(action);
329
+ }
330
+ break;
331
+ case "edit_comment":
332
+ if (!args[0]) {
333
+ results.add(constants_1.DO_NOT_ALLOW);
334
+ break;
335
+ }
336
+ const comment = await commentUtil.get(args[0]);
337
+ if (!comment.props?.comment_ID) {
338
+ results.add(constants_1.DO_NOT_ALLOW);
339
+ break;
340
+ }
341
+ post = await postUtil.get(comment.props.comment_post_ID);
342
+ /*
343
+ * If the post doesn't exist, we have an orphaned comment.
344
+ * Fall back to the edit_posts capability, instead.
345
+ */
346
+ if (post.props?.ID) {
347
+ results = new Set(await this.check("edit_post", user, post.props.ID));
348
+ }
349
+ else {
350
+ results = new Set(await this.check("edit_posts", user));
351
+ }
352
+ break;
353
+ case "unfiltered_upload":
354
+ if (this.config.config.constants.ALLOW_UNFILTERED_UPLOADS &&
355
+ (!this.config.isMultiSite() || role.isSuperAdmin())) {
356
+ results.add(action);
357
+ }
358
+ else {
359
+ results.add(constants_1.DO_NOT_ALLOW);
360
+ }
361
+ break;
362
+ case "edit_css":
363
+ case "unfiltered_html":
364
+ // Disallow unfiltered_html for all users, even admins and super admins.
365
+ if (this.config.config.constants.DISALLOW_UNFILTERED_HTML) {
366
+ results.add(constants_1.DO_NOT_ALLOW);
367
+ }
368
+ else if (this.config.isMultiSite() && !role.isSuperAdmin()) {
369
+ results.add(constants_1.DO_NOT_ALLOW);
370
+ }
371
+ else {
372
+ results.add("unfiltered_html");
373
+ }
374
+ break;
375
+ case "edit_files":
376
+ case "edit_plugins":
377
+ case "edit_themes":
378
+ // Disallow the file editors.
379
+ if (this.config.config.constants.DISALLOW_FILE_EDIT) {
380
+ results.add(constants_1.DO_NOT_ALLOW);
381
+ }
382
+ else if (this.config.isMultiSite() && !role.isSuperAdmin()) {
383
+ results.add(constants_1.DO_NOT_ALLOW);
384
+ }
385
+ else {
386
+ results.add(action);
387
+ }
388
+ break;
389
+ case "update_plugins":
390
+ case "delete_plugins":
391
+ case "install_plugins":
392
+ case "upload_plugins":
393
+ case "update_themes":
394
+ case "delete_themes":
395
+ case "install_themes":
396
+ case "upload_themes":
397
+ case "update_core":
398
+ /*
399
+ * Disallow anything that creates, deletes, or updates core, plugin, or theme files.
400
+ * Files in uploads are excepted.
401
+ */
402
+ if (this.config.isMultiSite() && !role.isSuperAdmin()) {
403
+ results.add(constants_1.DO_NOT_ALLOW);
404
+ }
405
+ else if ("upload_themes" === action) {
406
+ results.add("install_themes");
407
+ }
408
+ else if ("upload_plugins" === action) {
409
+ results.add("install_plugins");
410
+ }
411
+ else {
412
+ results.add(action);
413
+ }
414
+ break;
415
+ case "install_languages":
416
+ case "update_languages":
417
+ if (this.config.isMultiSite() && !role.isSuperAdmin()) {
418
+ results.add(constants_1.DO_NOT_ALLOW);
419
+ }
420
+ else {
421
+ results.add("install_languages");
422
+ }
423
+ break;
424
+ case "activate_plugins":
425
+ case "deactivate_plugins":
426
+ case "activate_plugin":
427
+ case "deactivate_plugin":
428
+ results.add("activate_plugins");
429
+ if (this.config.isMultiSite()) {
430
+ // update_, install_, and delete_ are handled above with is_super_admin().
431
+ const menuPerms = await options.get("menu_items", {
432
+ siteId: current.site?.props.site?.id,
433
+ default: {},
434
+ });
435
+ if (Array.isArray(menuPerms?.plugins)) {
436
+ results.add("manage_network_plugins");
437
+ }
438
+ }
439
+ break;
440
+ case "resume_plugin":
441
+ results.add("resume_plugins");
442
+ break;
443
+ case "resume_theme":
444
+ results.add("resume_themes");
445
+ break;
446
+ case "delete_user":
447
+ case "delete_users":
448
+ // If multisite only super admins can delete users.
449
+ if (this.config.isMultiSite() && !role.isSuperAdmin()) {
450
+ results.add(constants_1.DO_NOT_ALLOW);
451
+ break;
452
+ }
453
+ if (action == "delete_user") {
454
+ const context = vars.CONTEXT;
455
+ results = await context.hooks.filter.asyncApply("core_map_meta_cap_delete_user", results, context, user, ...args);
456
+ }
457
+ results.add("delete_users"); // delete_user maps to delete_users.
458
+ break;
459
+ case "create_users":
460
+ if (!this.config.isMultiSite()) {
461
+ results.add(action);
462
+ }
463
+ else if (role.isSuperAdmin() ||
464
+ 1 ===
465
+ (await options.get("add_new_users", {
466
+ siteId: current.site?.props.site?.id,
467
+ }))) {
468
+ results.add(action);
469
+ }
470
+ else {
471
+ results.add(constants_1.DO_NOT_ALLOW);
472
+ }
473
+ break;
474
+ case "manage_links":
475
+ if (await options.get("link_manager_enabled")) {
476
+ results.add(action);
477
+ }
478
+ else {
479
+ results.add(constants_1.DO_NOT_ALLOW);
480
+ }
481
+ break;
482
+ case "customize":
483
+ results.add("edit_theme_options");
484
+ break;
485
+ case "delete_site":
486
+ if (this.config.isMultiSite()) {
487
+ results.add("manage_options");
488
+ }
489
+ else {
490
+ results.add(constants_1.DO_NOT_ALLOW);
491
+ }
492
+ break;
493
+ case "edit_term":
494
+ case "delete_term":
495
+ case "assign_term":
496
+ if (!args[0]) {
497
+ // 'When checking for the %s capability, you must always check it against a specific term.'
498
+ results.add(constants_1.DO_NOT_ALLOW);
499
+ break;
500
+ }
501
+ const term = await termUtil.get(args[0]);
502
+ if (!term.props?.term_id) {
503
+ results.add(constants_1.DO_NOT_ALLOW);
504
+ break;
505
+ }
506
+ const taxonomy = await taxonomyUtil.get(term.props.taxonomy ?? "");
507
+ if (taxonomy.isDefault) {
508
+ results.add(constants_1.DO_NOT_ALLOW);
509
+ break;
510
+ }
511
+ if ("delete_term" === action &&
512
+ ((await options.get(`default_${term.props.taxonomy}`)) ==
513
+ term.props.term_id ||
514
+ (await options.get(`default_term_${term.props.taxonomy}`)) == term.props.term_id)) {
515
+ results.add(constants_1.DO_NOT_ALLOW);
516
+ break;
517
+ }
518
+ results = new Set(await this.check(taxonomy.props?.capabilities?.[`${action}s`], user, term.props.term_id));
519
+ break;
520
+ case "manage_post_tags":
521
+ case "edit_categories":
522
+ case "edit_post_tags":
523
+ case "delete_categories":
524
+ case "delete_post_tags":
525
+ results.add("manage_categories");
526
+ break;
527
+ case "assign_categories":
528
+ case "assign_post_tags":
529
+ results.add("edit_posts");
530
+ break;
531
+ case "create_sites":
532
+ case "delete_sites":
533
+ case "manage_network":
534
+ case "manage_sites":
535
+ case "manage_network_plugins":
536
+ case "manage_network_themes":
537
+ case "manage_network_options":
538
+ case "upgrade_network":
539
+ results.add(action);
540
+ break;
541
+ case "manage_network_users":
542
+ const context = vars.CONTEXT;
543
+ results = await context.hooks.filter.asyncApply("core_map_meta_cap_manage_network_users", results, context, user, ...args);
544
+ if (this.config.isMultiSite() &&
545
+ !results.has("manage_network_users") &&
546
+ !results.has(constants_1.DO_NOT_ALLOW)) {
547
+ results.add("manage_network_users");
548
+ }
549
+ break;
550
+ case "setup_network":
551
+ if (this.config.isMultiSite()) {
552
+ results.add("manage_network_options");
553
+ }
554
+ else {
555
+ results.add("manage_options");
556
+ }
557
+ break;
558
+ case "update_php":
559
+ if (this.config.isMultiSite() && !role.isSuperAdmin()) {
560
+ results.add(constants_1.DO_NOT_ALLOW);
561
+ }
562
+ else {
563
+ results.add("update_core");
564
+ }
565
+ break;
566
+ case "update_https":
567
+ if (this.config.isMultiSite() && !role.isSuperAdmin()) {
568
+ results.add(constants_1.DO_NOT_ALLOW);
569
+ }
570
+ else {
571
+ results.add("manage_options");
572
+ results.add("update_core");
573
+ }
574
+ break;
575
+ case "export_others_personal_data":
576
+ case "erase_others_personal_data":
577
+ case "manage_privacy_options":
578
+ results.add(this.config.isMultiSite() ? "manage_network" : "manage_options");
579
+ break;
580
+ case "create_app_password":
581
+ case "list_app_passwords":
582
+ case "read_app_password":
583
+ case "edit_app_password":
584
+ case "delete_app_passwords":
585
+ case "delete_app_password":
586
+ results = new Set(await this.check("edit_user", user, args[0]));
587
+ break;
588
+ default:
589
+ // Handle meta capabilities for custom post types.
590
+ postType = postUtil.getTypeObject("post");
591
+ if (postType?.capabilities &&
592
+ postType?.capabilities[action] &&
593
+ action != postType?.capabilities[action]) {
594
+ results = new Set(await this.check(postType.capabilities[action], user, ...args));
595
+ break;
596
+ }
597
+ // Block capabilities map to their post equivalent.
598
+ const blockCaps = [
599
+ "edit_blocks",
600
+ "edit_others_blocks",
601
+ "publish_blocks",
602
+ "read_private_blocks",
603
+ "delete_blocks",
604
+ "delete_private_blocks",
605
+ "delete_published_blocks",
606
+ "delete_others_blocks",
607
+ "edit_private_blocks",
608
+ "edit_published_blocks",
609
+ ];
610
+ if (blockCaps.includes(action)) {
611
+ action = action.replace("_blocks", "_posts");
612
+ }
613
+ // If no meta caps match, return the original cap.
614
+ results.add(action);
615
+ }
616
+ const context = vars.CONTEXT;
617
+ results = await context.hooks.filter.asyncApply("core_map_meta_cap", results, context, action, user, ...args);
618
+ return Array.from(results);
619
+ }
620
+ };
621
+ exports.Capabilities = Capabilities;
622
+ exports.Capabilities = Capabilities = __decorate([
623
+ (0, component_1.component)(),
624
+ __metadata("design:paramtypes", [config_1.Config, components_1.Components])
625
+ ], Capabilities);