ResourceLoaderUserTokensModule.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. /**
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation; either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along
  14. * with this program; if not, write to the Free Software Foundation, Inc.,
  15. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  16. * http://www.gnu.org/copyleft/gpl.html
  17. *
  18. * @file
  19. */
  20. /**
  21. * Module for user authorization tokens.
  22. *
  23. * @ingroup ResourceLoader
  24. * @internal
  25. */
  26. class ResourceLoaderUserTokensModule extends ResourceLoaderModule {
  27. protected $origin = self::ORIGIN_CORE_INDIVIDUAL;
  28. protected $targets = [ 'desktop', 'mobile' ];
  29. /**
  30. * Fetch the tokens for the current user.
  31. *
  32. * @param ResourceLoaderContext $context
  33. * @return array List of tokens keyed by token type
  34. */
  35. protected function contextUserTokens( ResourceLoaderContext $context ) {
  36. $user = $context->getUserObj();
  37. return [
  38. 'editToken' => $user->getEditToken(),
  39. 'patrolToken' => $user->getEditToken( 'patrol' ),
  40. 'watchToken' => $user->getEditToken( 'watch' ),
  41. 'csrfToken' => $user->getEditToken(),
  42. ];
  43. }
  44. /**
  45. * @param ResourceLoaderContext $context
  46. * @return string JavaScript code
  47. */
  48. public function getScript( ResourceLoaderContext $context ) {
  49. // Use FILTER_NOMIN annotation to prevent needless minification and caching (T84960).
  50. return ResourceLoader::FILTER_NOMIN
  51. . 'mw.user.tokens.set('
  52. . $context->encodeJson( $this->contextUserTokens( $context ) )
  53. . ');';
  54. }
  55. /**
  56. * @return bool
  57. */
  58. public function supportsURLLoading() {
  59. return false;
  60. }
  61. /**
  62. * @return string
  63. */
  64. public function getGroup() {
  65. return 'private';
  66. }
  67. }