dsn; } /** * Return UUID * @return string **/ function uuid() { return $this->uuid; } /** * Return MongoDB profiler results * @return string **/ function log() { $cursor=$this->selectcollection('system.profile')->find(); foreach (iterator_to_array($cursor) as $frame) if (!preg_match('/\.system\..+$/',$frame['ns'])) $this->log.=date('r',$frame['ts']->sec).' ('. sprintf('%.1f',$frame['millis']).'ms) '. $frame['ns'].' ['.$frame['op'].'] '. (empty($frame['query'])? '':json_encode($frame['query'])). (empty($frame['command'])? '':json_encode($frame['command'])). PHP_EOL; return $this->log; } /** * Intercept native call to re-enable profiler * @return int **/ function drop() { $out=parent::drop(); $this->setprofilinglevel(2); return $out; } /** * Instantiate class * @param $dsn string * @param $dbname string * @param $options array **/ function __construct($dsn,$dbname,array $options=NULL) { $this->uuid=\Base::instance()->hash($this->dsn=$dsn); $class=class_exists('\MongoClient')?'\MongoClient':'\Mongo'; parent::__construct(new $class($dsn,$options?:array()),$dbname); $this->setprofilinglevel(2); } }