Rule.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\rbac;
  8. use yii\base\BaseObject;
  9. /**
  10. * Rule represents a business constraint that may be associated with a role, permission or assignment.
  11. *
  12. * For more details and usage information on Rule, see the [guide article on security authorization](guide:security-authorization).
  13. *
  14. * @author Alexander Makarov <sam@rmcreative.ru>
  15. * @since 2.0
  16. */
  17. abstract class Rule extends BaseObject
  18. {
  19. /**
  20. * @var string name of the rule
  21. */
  22. public $name;
  23. /**
  24. * @var int UNIX timestamp representing the rule creation time
  25. */
  26. public $createdAt;
  27. /**
  28. * @var int UNIX timestamp representing the rule updating time
  29. */
  30. public $updatedAt;
  31. /**
  32. * Executes the rule.
  33. *
  34. * @param string|int $user the user ID. This should be either an integer or a string representing
  35. * the unique identifier of a user. See [[\yii\web\User::id]].
  36. * @param Item $item the role or permission that this rule is associated with
  37. * @param array $params parameters passed to [[CheckAccessInterface::checkAccess()]].
  38. * @return bool a value indicating whether the rule permits the auth item it is associated with.
  39. */
  40. abstract public function execute($user, $item, $params);
  41. }