diff options
Diffstat (limited to 'app/Model/ProjectActivity.php')
| -rw-r--r-- | app/Model/ProjectActivity.php | 22 | 
1 files changed, 19 insertions, 3 deletions
diff --git a/app/Model/ProjectActivity.php b/app/Model/ProjectActivity.php index 87c9bb56..bbcb7f5b 100644 --- a/app/Model/ProjectActivity.php +++ b/app/Model/ProjectActivity.php @@ -22,7 +22,7 @@ class ProjectActivity extends Base       *       * @var integer       */ -    const MAX_EVENTS = 5000; +    const MAX_EVENTS = 1000;      /**       * Add a new event for the project @@ -43,7 +43,7 @@ class ProjectActivity extends Base              'creator_id' => $creator_id,              'event_name' => $event_name,              'date_creation' => time(), -            'data' => serialize($data), +            'data' => json_encode($data),          );          $this->cleanup(self::MAX_EVENTS - 1); @@ -91,7 +91,7 @@ class ProjectActivity extends Base          foreach ($events as &$event) { -            $event += unserialize($event['data']); +            $event += $this->decode($event['data']);              unset($event['data']);              $event['author'] = $event['author_name'] ?: $event['author_username']; @@ -174,4 +174,20 @@ class ProjectActivity extends Base                  return '';          }      } + +    /** +     * Decode event data, supports unserialize() and json_decode() +     * +     * @access public +     * @param  string   $data   Serialized data +     * @return array +     */ +    public function decode($data) +    { +        if ($data{0} === 'a') { +            return unserialize($data); +        } + +        return json_decode($data, true) ?: array(); +    }  }  | 
