1: <?php
2: /*****************************************************************************************
3: * X2Engine Open Source Edition is a customer relationship management program developed by
4: * X2Engine, Inc. Copyright (C) 2011-2016 X2Engine Inc.
5: *
6: * This program is free software; you can redistribute it and/or modify it under
7: * the terms of the GNU Affero General Public License version 3 as published by the
8: * Free Software Foundation with the addition of the following permission added
9: * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10: * IN WHICH THE COPYRIGHT IS OWNED BY X2ENGINE, X2ENGINE DISCLAIMS THE WARRANTY
11: * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12: *
13: * This program is distributed in the hope that it will be useful, but WITHOUT
14: * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15: * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
16: * details.
17: *
18: * You should have received a copy of the GNU Affero General Public License along with
19: * this program; if not, see http://www.gnu.org/licenses or write to the Free
20: * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21: * 02110-1301 USA.
22: *
23: * You can contact X2Engine, Inc. P.O. Box 66752, Scotts Valley,
24: * California 95067, USA. or at email address contact@x2engine.com.
25: *
26: * The interactive user interfaces in modified source and object code versions
27: * of this program must display Appropriate Legal Notices, as required under
28: * Section 5 of the GNU Affero General Public License version 3.
29: *
30: * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31: * these Appropriate Legal Notices must retain the display of the "Powered by
32: * X2Engine" logo. If the display of the logo is not reasonably feasible for
33: * technical reasons, the Appropriate Legal Notices must display the words
34: * "Powered by X2Engine".
35: *****************************************************************************************/
36:
37: /**
38: * This is the model class for table "x2_trigger_logs".
39: * @package application.models
40: */
41: class TriggerLog extends CActiveRecord {
42: /**
43: * Returns the static model of the specified AR class.
44: * @return Imports the static model class
45: */
46: public static function model($className=__CLASS__) {
47: return parent::model($className);
48: }
49:
50: public function behaviors() {
51: return array_merge (parent::behaviors (), array(
52: 'RecordLimitBehavior' => array(
53: 'class' => 'RecordLimitBehavior',
54: 'limit' => Yii::app()->settings->triggerLogMax,
55: 'timestampField' => 'triggeredAt',
56: ),
57: ));
58: }
59:
60:
61: /**
62: * @return string the associated database table name
63: */
64: public function tableName() {
65: return 'x2_trigger_logs';
66: }
67:
68: /**
69: * @return array validation rules for model attributes.
70: */
71: public function rules() {
72: // NOTE: you should only define rules for those attributes that
73: // will receive user inputs.
74: return array(
75: array('flowId', 'required'),
76: array('flowId', 'length', 'max' => 100)
77: );
78: }
79:
80: /**
81: * @return array customized attribute labels (name=>label)
82: */
83: public function attributeLabels() {
84: return array(
85: 'triggeredAt' => Yii::t('studio','Triggered At'),
86: 'triggerLog' => Yii::t('studio','Log Output')
87: );
88: }
89:
90: /**
91: * Appends flow trace to trigger log. This is called after a flow exectution is initiated
92: * by a cron action.
93: * @param Integer $triggerLogId the primary key of the trigger log model associated with the
94: * flow execution
95: * @param Array $flowTrace the return value of executeFlow
96: */
97: public static function appendTriggerLog ($triggerLogId, $flowTrace) {
98: $model = self::model ('TriggerLog')->findByPk ($triggerLogId);
99: if (!$model) {
100: return;
101: }
102:
103: $oldLog = CJSON::decode ($model->triggerLog);
104: $model->triggerLog = CJSON::encode (array_merge ($oldLog, $flowTrace));
105: $model->save ();
106: }
107:
108: }
109:
110: