clrghouz/app/Traits/UseMongo.php

104 lines
2.0 KiB
PHP
Raw Normal View History

<?php
/**
* Models that store data in Mongo
*/
namespace App\Traits;
2021-10-26 23:19:55 +11:00
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Support\Arr;
2021-10-26 23:19:55 +11:00
trait UseMongo
{
/**
* Resolve a connection instance.
* We need to do this, because our relations are in pgsql and somehow loading a relation changes this models
* connection information. Using protected $connection is not enough.
*
* @param string|null $connection
*/
public static function resolveConnection($connection = null)
{
return static::$resolver->connection('mongodb');
}
/* ATTRIBUTES */
public function getMsgAttribute($value): string
{
return utf8_decode($value);
}
public function setMsgAttribute($value): void
{
$this->attributes['msg'] = utf8_encode($value);
}
2021-08-26 22:32:32 +10:00
public function getSubjectAttribute($value): string
{
return utf8_decode($value);
}
public function setSubjectAttribute($value): void
{
$this->attributes['subject'] = utf8_encode($value);
}
2021-10-26 23:19:55 +11:00
/* METHODS */
2021-11-20 17:58:46 +11:00
public static function countGroupBy(array $fields,array $where=[]): Collection
2021-10-26 23:19:55 +11:00
{
$query = collect();
if (count($where)) {
$where_condition = [];
foreach ($where as $key => $values) {
if (! is_array($values))
throw new \Exception('Where values must be an array.');
switch ($x=Arr::get($values,0)) {
case '$gt':
case '$gte':
$where_condition[$key] = [ $x => Arr::get($values,1)];
break;
case '$in':
default:
$where_condition[$key] = ['$in' => $values];
}
2021-10-26 23:19:55 +11:00
}
$query->push([
'$match' => [ '$and'=> [$where_condition]]
2021-10-26 23:19:55 +11:00
]);
}
2021-11-20 17:58:46 +11:00
$gb = collect();
foreach ($fields as $field)
if (is_array($field)) {
foreach ($field as $k=>$v) {
$gb->put('datetime',['$dateToString'=>['format'=>$v,'date'=>'$'.$k]]);
}
} else {
$gb->put($field,'$'.$field);
}
2021-10-26 23:19:55 +11:00
$query->push([
'$group' => [
2021-11-20 17:58:46 +11:00
'_id' => $gb->toArray(),
2021-10-26 23:19:55 +11:00
'count' => ['$sum' => 1]
]
]);
return (new self)
->groupBy($field)
->raw(function($collection) use ($query) {
return $collection->aggregate(
$query->toArray()
);
});
}
}