本文整理匯總了PHP中Owner::getTeamStats方法的典型用法代碼示例。如果您正苦於以下問題:PHP Owner::getTeamStats方法的具體用法?PHP Owner::getTeamStats怎麽用?PHP Owner::getTeamStats使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Owner
的用法示例。
在下文中一共展示了Owner::getTeamStats方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: getStats
/**
* Collect overall projects stats
*
* @return array
*/
public function getStats($model, $cron = false, $publishing = false, $period = 'alltime', $limit = 3)
{
// Incoming
$period = Request::getVar('period', $period);
$limit = Request::getInt('limit', $limit);
if ($cron == true) {
$publicOnly = false;
$saveLog = true;
} else {
$publicOnly = $model->reviewerAccess('admin') ? false : true;
$saveLog = false;
}
// Collectors
$stats = array();
$updated = NULL;
$lastLog = NULL;
$pastMonth = Date::of(time() - 32 * 24 * 60 * 60)->toSql('Y-m-d');
$thisYearNum = Date::format('y');
$thisMonthNum = Date::format('m');
$thisWeekNum = Date::format('W');
// Pull recent stats
if ($this->loadLog($thisYearNum, $thisMonthNum, $thisWeekNum)) {
$lastLog = json_decode($this->stats, true);
$updated = $this->processed;
} else {
// Save stats
$saveLog = true;
}
// Get project table class
$tbl = $model->table();
// Get inlcude /exclude lists
$exclude = $tbl->getProjectsByTag('test', true, 'id');
$include = $tbl->getProjectsByTag('test', false, 'id');
$validProjects = $tbl->getProjectsByTag('test', false, 'alias');
$validCount = count($validProjects) > 0 ? count($validProjects) : 1;
// Collect overview stats
$stats['general'] = array('total' => $tbl->getCount(array('exclude' => $exclude, 'all' => 1), true), 'setup' => $tbl->getCount(array('exclude' => $exclude, 'setup' => 1), true), 'active' => $tbl->getCount(array('exclude' => $exclude, 'active' => 1), true), 'public' => $tbl->getCount(array('exclude' => $exclude, 'private' => '0'), true), 'sponsored' => $tbl->getCount(array('exclude' => $exclude, 'reviewer' => 'sponsored'), true), 'sensitive' => $tbl->getCount(array('exclude' => $exclude, 'reviewer' => 'sensitive'), true), 'new' => $tbl->getCount(array('exclude' => $exclude, 'created' => date('Y-m', time()), 'all' => 1), true));
$active = $stats['general']['active'] ? $stats['general']['active'] : 1;
$total = $stats['general']['total'] ? $stats['general']['total'] : 1;
// Activity stats
$objAA = new Activity($this->_db);
$recentlyActive = $tbl->getCount(array('exclude' => $exclude, 'timed' => $pastMonth, 'active' => 1), true);
$perc = round($recentlyActive * 100 / $active) . '%';
$stats['activity'] = array('total' => $objAA->getActivityStats($include, 'total'), 'average' => $objAA->getActivityStats($include, 'average'), 'usage' => $perc);
$stats['topActiveProjects'] = $objAA->getTopActiveProjects($exclude, 5, $publicOnly);
// Collect team stats
$objO = new Owner($this->_db);
$multiTeam = $objO->getTeamStats($exclude, 'multi');
$activeTeam = $objO->getTeamStats($exclude, 'registered');
$invitedTeam = $objO->getTeamStats($exclude, 'invited');
$multiProjectUsers = $objO->getTeamStats($exclude, 'multiusers');
$teamTotal = $activeTeam + $invitedTeam;
$perc = round($multiTeam * 100 / $total) . '%';
$stats['team'] = array('total' => $teamTotal, 'average' => $objO->getTeamStats($exclude, 'average'), 'multi' => $perc, 'multiusers' => $multiProjectUsers);
$stats['topTeamProjects'] = $objO->getTopTeamProjects($exclude, $limit, $publicOnly);
// Collect files stats
if ($lastLog) {
$stats['files'] = $lastLog['files'];
} else {
// Get repo model
require_once PATH_CORE . DS . 'components' . DS . 'com_projects' . DS . 'models' . DS . 'repo.php';
// Compute
$repo = new \Components\Projects\Models\Repo();
$fTotal = $repo->getStats($validProjects);
$fAverage = number_format($fTotal / $validCount, 0);
$fUsage = $repo->getStats($validProjects, 'usage');
$fDSpace = $repo->getStats($validProjects, 'diskspace');
$fCommits = $repo->getStats($validProjects, 'commitCount');
$pDSpace = $repo->getStats($validProjects, 'pubspace');
$perc = round($fUsage * 100 / $active) . '%';
$stats['files'] = array('total' => $fTotal, 'average' => $fAverage, 'usage' => $perc, 'diskspace' => \Hubzero\Utility\Number::formatBytes($fDSpace), 'commits' => $fCommits, 'pubspace' => \Hubzero\Utility\Number::formatBytes($pDSpace));
}
// Collect publication stats
if ($publishing) {
$objP = new \Components\Publications\Tables\Publication($this->_db);
$objPV = new \Components\Publications\Tables\Version($this->_db);
$prPub = $objP->getPubStats($include, 'usage');
$perc = round($prPub * 100 / $total) . '%';
$stats['pub'] = array('total' => $objP->getPubStats($include, 'total'), 'average' => $objP->getPubStats($include, 'average'), 'usage' => $perc, 'released' => $objP->getPubStats($include, 'released'), 'versions' => $objPV->getPubStats($include));
}
// Save weekly stats
if ($saveLog) {
$this->year = $thisYearNum;
$this->month = $thisMonthNum;
$this->week = $thisWeekNum;
$this->processed = Date::toSql();
$this->stats = json_encode($stats);
$this->store();
}
$stats['updated'] = $updated ? $updated : NULL;
return $stats;
}