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