Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

DefaultTokenMapper.php 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @copyright Copyright (c) 2016, ownCloud, Inc.
  5. *
  6. * @author Bjoern Schiessle <bjoern@schiessle.org>
  7. * @author Christoph Wurst <christoph@owncloud.com>
  8. * @author Joas Schilling <coding@schilljs.com>
  9. * @author Lukas Reschke <lukas@statuscode.ch>
  10. * @author Marcel Waldvogel <marcel.waldvogel@uni-konstanz.de>
  11. * @author Robin Appelman <robin@icewind.nl>
  12. * @author Roeland Jago Douma <roeland@famdouma.nl>
  13. *
  14. * @license AGPL-3.0
  15. *
  16. * This code is free software: you can redistribute it and/or modify
  17. * it under the terms of the GNU Affero General Public License, version 3,
  18. * as published by the Free Software Foundation.
  19. *
  20. * This program is distributed in the hope that it will be useful,
  21. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  22. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  23. * GNU Affero General Public License for more details.
  24. *
  25. * You should have received a copy of the GNU Affero General Public License, version 3,
  26. * along with this program. If not, see <http://www.gnu.org/licenses/>
  27. *
  28. */
  29. namespace OC\Authentication\Token;
  30. use OCP\AppFramework\Db\DoesNotExistException;
  31. use OCP\AppFramework\Db\QBMapper;
  32. use OCP\DB\QueryBuilder\IQueryBuilder;
  33. use OCP\IDBConnection;
  34. use OCP\IUser;
  35. class DefaultTokenMapper extends QBMapper {
  36. public function __construct(IDBConnection $db) {
  37. parent::__construct($db, 'authtoken');
  38. }
  39. /**
  40. * Invalidate (delete) a given token
  41. *
  42. * @param string $token
  43. */
  44. public function invalidate(string $token) {
  45. /* @var $qb IQueryBuilder */
  46. $qb = $this->db->getQueryBuilder();
  47. $qb->delete('authtoken')
  48. ->where($qb->expr()->eq('token', $qb->createParameter('token')))
  49. ->setParameter('token', $token)
  50. ->execute();
  51. }
  52. /**
  53. * @param int $olderThan
  54. * @param int $remember
  55. */
  56. public function invalidateOld(int $olderThan, int $remember = IToken::DO_NOT_REMEMBER) {
  57. /* @var $qb IQueryBuilder */
  58. $qb = $this->db->getQueryBuilder();
  59. $qb->delete('authtoken')
  60. ->where($qb->expr()->lt('last_activity', $qb->createNamedParameter($olderThan, IQueryBuilder::PARAM_INT)))
  61. ->andWhere($qb->expr()->eq('type', $qb->createNamedParameter(IToken::TEMPORARY_TOKEN, IQueryBuilder::PARAM_INT)))
  62. ->andWhere($qb->expr()->eq('remember', $qb->createNamedParameter($remember, IQueryBuilder::PARAM_INT)))
  63. ->execute();
  64. }
  65. /**
  66. * Get the user UID for the given token
  67. *
  68. * @param string $token
  69. * @throws DoesNotExistException
  70. * @return DefaultToken
  71. */
  72. public function getToken(string $token): DefaultToken {
  73. /* @var $qb IQueryBuilder */
  74. $qb = $this->db->getQueryBuilder();
  75. $result = $qb->select('*')
  76. ->from('authtoken')
  77. ->where($qb->expr()->eq('token', $qb->createNamedParameter($token)))
  78. ->execute();
  79. $data = $result->fetch();
  80. $result->closeCursor();
  81. if ($data === false) {
  82. throw new DoesNotExistException('token does not exist');
  83. }
  84. return DefaultToken::fromRow($data);
  85. }
  86. /**
  87. * Get the token for $id
  88. *
  89. * @param int $id
  90. * @throws DoesNotExistException
  91. * @return DefaultToken
  92. */
  93. public function getTokenById(int $id): DefaultToken {
  94. /* @var $qb IQueryBuilder */
  95. $qb = $this->db->getQueryBuilder();
  96. $result = $qb->select('*')
  97. ->from('authtoken')
  98. ->where($qb->expr()->eq('id', $qb->createNamedParameter($id)))
  99. ->execute();
  100. $data = $result->fetch();
  101. $result->closeCursor();
  102. if ($data === false) {
  103. throw new DoesNotExistException('token does not exist');
  104. }
  105. return DefaultToken::fromRow($data);
  106. }
  107. /**
  108. * Get all tokens of a user
  109. *
  110. * The provider may limit the number of result rows in case of an abuse
  111. * where a high number of (session) tokens is generated
  112. *
  113. * @param IUser $user
  114. * @return DefaultToken[]
  115. */
  116. public function getTokenByUser(IUser $user): array {
  117. /* @var $qb IQueryBuilder */
  118. $qb = $this->db->getQueryBuilder();
  119. $qb->select('*')
  120. ->from('authtoken')
  121. ->where($qb->expr()->eq('uid', $qb->createNamedParameter($user->getUID())))
  122. ->setMaxResults(1000);
  123. $result = $qb->execute();
  124. $data = $result->fetchAll();
  125. $result->closeCursor();
  126. $entities = array_map(function ($row) {
  127. return DefaultToken::fromRow($row);
  128. }, $data);
  129. return $entities;
  130. }
  131. /**
  132. * @param IUser $user
  133. * @param int $id
  134. */
  135. public function deleteById(IUser $user, int $id) {
  136. /* @var $qb IQueryBuilder */
  137. $qb = $this->db->getQueryBuilder();
  138. $qb->delete('authtoken')
  139. ->where($qb->expr()->eq('id', $qb->createNamedParameter($id)))
  140. ->andWhere($qb->expr()->eq('uid', $qb->createNamedParameter($user->getUID())));
  141. $qb->execute();
  142. }
  143. /**
  144. * delete all auth token which belong to a specific client if the client was deleted
  145. *
  146. * @param string $name
  147. */
  148. public function deleteByName(string $name) {
  149. $qb = $this->db->getQueryBuilder();
  150. $qb->delete('authtoken')
  151. ->where($qb->expr()->eq('name', $qb->createNamedParameter($name), IQueryBuilder::PARAM_STR));
  152. $qb->execute();
  153. }
  154. }