_a['table'] = 'idf_commits'; $this->_a['model'] = __CLASS__; $this->_a['cols'] = array( // It is mandatory to have an "id" column. 'id' => array( 'type' => 'Pluf_DB_Field_Sequence', 'blank' => true, ), 'project' => array( 'type' => 'Pluf_DB_Field_Foreignkey', 'model' => 'IDF_Project', 'blank' => false, 'verbose' => __('project'), 'relate_name' => 'commits', ), 'author' => array( 'type' => 'Pluf_DB_Field_Foreignkey', 'model' => 'Pluf_User', 'is_null' => true, 'verbose' => __('submitter'), 'relate_name' => 'submitted_commit', 'help_text' => 'This will allow us to list the latest commits of a user in its profile.', ), 'origauthor' => array( 'type' => 'Pluf_DB_Field_Varchar', 'blank' => false, 'size' => 150, 'help_text' => 'As we do not necessary have the mapping between the author in the database and the scm, we store the scm author commit information here. That way we can update the author info later in the process.', ), 'scm_id' => array( 'type' => 'Pluf_DB_Field_Varchar', 'blank' => false, 'size' => 50, 'index' => true, 'help_text' => 'The id of the commit. For git, it will be the SHA1 hash, for subversion it will be the revision id.', ), 'summary' => array( 'type' => 'Pluf_DB_Field_Varchar', 'blank' => false, 'size' => 250, 'verbose' => __('summary'), ), 'fullmessage' => array( 'type' => 'Pluf_DB_Field_Text', 'blank' => true, 'verbose' => __('changelog'), 'help_text' => 'This is the full message of the commit.', ), 'creation_dtime' => array( 'type' => 'Pluf_DB_Field_Datetime', 'blank' => true, 'verbose' => __('creation date'), 'index' => true, 'help_text' => 'Date of creation by the scm', ), ); } function __toString() { return $this->summary.' - ('.$this->scm_id.')'; } function _toIndex() { $str = str_repeat($this->summary.' ', 4).' '.$this->fullmessage; return Pluf_Text::cleanString(html_entity_decode($str, ENT_QUOTES, 'UTF-8')); } function postSave($create=false) { IDF_Search::index($this); if ($create) { IDF_Timeline::insert($this, $this->get_project(), $this->get_author(), $this->creation_dtime); } } function preDelete() { IDF_Timeline::remove($this); IDF_Search::remove($this); } /** * Create a commit from a simple class commit info of a changelog. * * @param stdClass Commit info * @param IDF_Project Current project * @return IDF_Commit */ public static function getOrAdd($change, $project) { $sql = new Pluf_SQL('project=%s AND scm_id=%s', array($project->id, $change->commit)); $r = Pluf::factory('IDF_Commit')->getList(array('filter'=>$sql->gen())); if ($r->count() > 0) { return $r[0]; } if (!isset($change->full_message)) { $change->full_message = ''; } $scm = IDF_Scm::get($project); $commit = new IDF_Commit(); $commit->project = $project; $commit->scm_id = $change->commit; $commit->summary = self::toUTF8($change->title); $commit->fullmessage = self::toUTF8($change->full_message); $commit->author = $scm->findAuthor($change->author); $commit->origauthor = self::toUTF8($change->author); $commit->creation_dtime = $change->date; $commit->create(); $commit->notify($project->getConf()); return $commit; } /** * Convert encoding to UTF8. * * If an array is given, the encoding is detected only on the * first value and then used to convert all the strings. * * @param mixed String or array of string to be converted * @param bool Returns the encoding together with the converted text (false) * @return mixed String or array of string or array of res + encoding */ public static function toUTF8($text, $get_encoding=False) { $enc = 'ASCII, UTF-8, ISO-8859-1, JIS, EUC-JP, SJIS'; $ref = $text; if (is_array($text)) { $ref = $text[0]; } if (Pluf_Text_UTF8::check($ref)) { return (!$get_encoding) ? $text : array($text, 'UTF-8'); } $encoding = mb_detect_encoding($ref, $enc, true); if ($encoding == false) { $encoding = Pluf_Text_UTF8::detect_cyr_charset($ref); } if (is_array($text)) { foreach ($text as $t) { $res[] = mb_convert_encoding($t, 'UTF-8', $encoding); } return (!$get_encoding) ? $res : array($res, $encoding); } else { $res = mb_convert_encoding($text, 'UTF-8', $encoding); return (!$get_encoding) ? $res : array($res, $encoding); } } /** * Returns the timeline fragment for the commit. * * * @param Pluf_HTTP_Request * @return Pluf_Template_SafeString */ public function timelineFragment($request) { $url = Pluf_HTTP_URL_urlForView('IDF_Views_Source::commit', array($request->project->shortname, $this->scm_id)); $out = '