53 lines
1.3 KiB
PHP
53 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace Kanboard\Model;
|
|
|
|
/**
|
|
* User Notification Type
|
|
*
|
|
* @package Kanboard\Model
|
|
* @author Frederic Guillot
|
|
*/
|
|
class UserNotificationTypeModel extends NotificationTypeModel
|
|
{
|
|
/**
|
|
* SQL table name
|
|
*
|
|
* @var string
|
|
*/
|
|
const TABLE = 'user_has_notification_types';
|
|
|
|
/**
|
|
* Get selected notification types for a given user
|
|
*
|
|
* @access public
|
|
* @param integer $user_id
|
|
* @return array
|
|
*/
|
|
public function getSelectedTypes($user_id)
|
|
{
|
|
$types = $this->db->table(self::TABLE)->eq('user_id', $user_id)->asc('notification_type')->findAllByColumn('notification_type');
|
|
return $this->filterTypes($types);
|
|
}
|
|
|
|
/**
|
|
* Save notification types for a given user
|
|
*
|
|
* @access public
|
|
* @param integer $user_id
|
|
* @param string[] $types
|
|
* @return boolean
|
|
*/
|
|
public function saveSelectedTypes($user_id, array $types)
|
|
{
|
|
$results = array();
|
|
$this->db->table(self::TABLE)->eq('user_id', $user_id)->remove();
|
|
|
|
foreach ($types as $type) {
|
|
$results[] = $this->db->table(self::TABLE)->insert(array('user_id' => $user_id, 'notification_type' => $type));
|
|
}
|
|
|
|
return ! in_array(false, $results, true);
|
|
}
|
|
}
|