class RateVote in Rate 8
Returns responses for Rate routes.
Hierarchy
- class \Drupal\rate\RateVote uses StringTranslationTrait
Expanded class hierarchy of RateVote
1 file declares its use of RateVote
- VoteController.php in src/
Controller/ VoteController.php
1 string reference to 'RateVote'
1 service uses RateVote
File
- src/
RateVote.php, line 15
Namespace
Drupal\rateView source
class RateVote {
use StringTranslationTrait;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* Votingapi result manager.
*
* @var \Drupal\votingapi\VoteResultFunctionManager
*/
protected $resultManager;
/**
* Database connection object.
*
* @var \Drupal\Core\Database\Connection
*/
protected $database;
/**
* Database connection object.
*
* @var \Drupal\rate\RateBotDetector
*/
protected $botDetector;
/**
* Account proxy (the current user).
*
* @var \Drupal\Core\Session\AccountProxyInterface
*/
protected $accountProxy;
/**
* Messenger service.
*
* @var \Drupal\Core\Messenger\MessengerInterface
*/
protected $messenger;
/**
* Constructor for vote service.
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\votingapi\VoteResultFunctionManager $result_manager
* The vote result manager.
* @param \Drupal\Core\Database\Connection $database
* The entity type manager.
* @param \Drupal\rate\RateBotDetector $bot_detector
* The bot detector service.
* @param \Drupal\Core\Session\AccountProxyInterface $account_proxy
* The current user.
* @param \Drupal\Core\Messenger\MessengerInterface $messenger
* The messenger service.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager, VoteResultFunctionManager $result_manager, Connection $database, RateBotDetector $bot_detector, AccountProxyInterface $account_proxy, MessengerInterface $messenger) {
$this->entityTypeManager = $entity_type_manager;
$this->resultManager = $result_manager;
$this->database = $database;
$this->botDetector = $bot_detector;
$this->accountProxy = $account_proxy;
$this->messenger = $messenger;
}
/**
* Record a vote.
*
* @param string $entity_type_id
* Entity type ID such as node.
* @param int $entity_id
* Entity id of the entity type.
* @param string $vote_type_id
* Vote type id.
* @param int $value
* The vote value.
* @param bool $show_messages
* If TRUE, standard Drupal message will be set.
*/
public function vote($entity_type_id, $entity_id, $vote_type_id, $value, $show_messages = TRUE) {
if (!$this
->validateVoteValue($vote_type_id, $value)) {
return;
}
$entity = $this->entityTypeManager
->getStorage($entity_type_id)
->load($entity_id);
$is_bot_vote = $this->botDetector
->checkIsBot();
if (!$is_bot_vote && $this->accountProxy
->hasPermission('cast rate vote on ' . $entity_type_id . ' of ' . $entity
->bundle())) {
/** @var \Drupal\votingapi\VoteStorageInterface $vote_storage */
$vote_storage = $this->entityTypeManager
->getStorage('vote');
$vote_ids = $vote_storage
->getUserVotes($this->accountProxy
->id(), $vote_type_id, $entity_type_id, $entity_id);
// If user hasn't voted, save the vote.
if (empty($vote_ids)) {
/** @var \Drupal\votingapi\VoteTypeInterface $vote_type */
$vote_type = $this->entityTypeManager
->getStorage('vote_type')
->load($vote_type_id);
/** @var \Drupal\votingapi\VoteInterface $vote */
$vote = $vote_storage
->create([
'type' => $vote_type_id,
]);
$vote
->setVotedEntityId($entity_id);
$vote
->setVotedEntityType($entity_type_id);
$vote
->setValueType($vote_type
->getValueType());
$vote
->setValue($value);
$vote
->save();
$this->resultManager
->recalculateResults($entity_type_id, $entity_id, $vote_type_id);
if ($show_messages) {
$this->messenger
->addStatus($this
->t('Your :type vote was added.', [
':type' => $vote_type_id,
]));
}
}
elseif ($show_messages) {
$this->messenger
->addWarning($this
->t('You are not allowed to vote the same way multiple times.'));
}
}
}
/**
* Undo a vote.
*
* @param string $entity_type_id
* Entity type ID such as node.
* @param int $entity_id
* Entity id of the entity type.
* @param bool $show_messages
* If TRUE, standard Drupal message will be set.
*/
public function undoVote($entity_type_id, $entity_id, $show_messages = TRUE) {
$entity = $this->entityTypeManager
->getStorage($entity_type_id)
->load($entity_id);
$is_bot_vote = $this->botDetector
->checkIsBot();
if (!$is_bot_vote && $this->accountProxy
->hasPermission('cast rate vote on ' . $entity_type_id . ' of ' . $entity
->bundle())) {
$vote_storage = $this->entityTypeManager
->getStorage('vote');
$vote_result = $vote_storage
->getUserVotes($this->accountProxy
->id(), NULL, $entity_type_id, $entity_id);
// If a vote has been found, remove it.
if (!empty($vote_result)) {
$vote_ids = array_keys($vote_result);
$vote_id = array_pop($vote_ids);
$vote = $vote_storage
->load($vote_id);
if ($vote) {
$vote
->delete();
}
if ($show_messages) {
$this->messenger
->addStatus($this
->t('Your vote was canceled.'));
}
}
elseif ($show_messages) {
// Otherwise, inform user of previous vote.
$this->messenger
->addWarning($this
->t('A previous vote was not found.'));
}
}
}
/**
* Validates whether a value is allowed for a given vote type.
*
* @param $vote_type_id
* Vote type id.
* @param $value
* The vote value.
*
* @return bool
* Returns TRUE if the value is allowed, FALSE otherwise.
*/
public function validateVoteValue($vote_type_id, $value) {
$allowed_values = [
-1,
1,
];
if ($vote_type_id == 'fivestar') {
$allowed_values = [
1,
2,
3,
4,
5,
];
}
return in_array($value, $allowed_values);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
RateVote:: |
protected | property | Account proxy (the current user). | |
RateVote:: |
protected | property | Database connection object. | |
RateVote:: |
protected | property | Database connection object. | |
RateVote:: |
protected | property | The entity type manager. | |
RateVote:: |
protected | property | Messenger service. | |
RateVote:: |
protected | property | Votingapi result manager. | |
RateVote:: |
public | function | Undo a vote. | |
RateVote:: |
public | function | Validates whether a value is allowed for a given vote type. | |
RateVote:: |
public | function | Record a vote. | |
RateVote:: |
public | function | Constructor for vote service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |