人人商城

statistics.mod.php 5.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <?php
  2. /**
  3. * [WeEngine System] Copyright (c) 2014 WE7.CC
  4. * WeEngine is NOT a free software, it under the license terms, visited http://www.we7.cc/ for more details.
  5. */
  6. defined('IN_IA') or exit('Access Denied');
  7. function stat_visit_info($type, $time_type, $module = '', $daterange = array(), $is_system_stat = false) {
  8. global $_W;
  9. $result = array();
  10. if (empty($type) || empty($time_type) || !empty($type) && !in_array($type, array('web', 'app', 'api', 'all'))) {
  11. return $result;
  12. }
  13. $params = array();
  14. if ($type != 'all') {
  15. $params['type'] = $type;
  16. }
  17. if (empty($is_system_stat)) {
  18. $params['uniacid'] = $_W['uniacid'];
  19. }
  20. if (!empty($module)) {
  21. $params['module'] = $module;
  22. }
  23. switch ($time_type) {
  24. case 'today':
  25. $params['date'] = date('Ymd');
  26. break;
  27. case 'yesterday':
  28. $params['date'] = date('Ymd', strtotime('-1 days'));
  29. break;
  30. case 'week':
  31. $params['date >'] = date('Ymd', strtotime('-7 days'));
  32. $params['date <='] = date('Ymd');
  33. break;
  34. case 'month':
  35. $params['date >'] = date('Ymd', strtotime('-30 days'));
  36. $params['date <='] = date('Ymd');
  37. break;
  38. case 'daterange':
  39. if (empty($daterange)) {
  40. return stat_visit_info($type, 'month', $module, array(), $is_system_stat);
  41. }
  42. $params['date >='] = date('Ymd', strtotime($daterange['start']));
  43. $params['date <='] = date('Ymd', strtotime($daterange['end']));
  44. break;
  45. }
  46. $visit_info = table('statistics')->visitList($params);
  47. if (!empty($visit_info)) {
  48. $result = $visit_info;
  49. }
  50. return $result;
  51. }
  52. function stat_visit_app_byuniacid($time_type, $module = '', $daterange = array(), $is_system_stat = false) {
  53. $result = array();
  54. $visit_info = stat_visit_info('app', $time_type, $module, $daterange, $is_system_stat);
  55. if (empty($visit_info)) {
  56. return $result;
  57. }
  58. foreach ($visit_info as $info) {
  59. if ($is_system_stat) {
  60. if (empty($info['uniacid'])) {
  61. continue;
  62. }
  63. if ($result[$info['uniacid']]['uniacid'] == $info['uniacid']) {
  64. $result[$info['uniacid']]['count'] += $info['count'];
  65. $result[$info['uniacid']]['highest'] = $result[$info['uniacid']]['highest'] >= $info['count'] ? $result[$info['uniacid']]['highest'] : $info['count'];
  66. } else {
  67. $result[$info['uniacid']] = $info;
  68. $result[$info['uniacid']]['highest'] = $info['count'];
  69. }
  70. } else {
  71. if (empty($info['module'])) {
  72. continue;
  73. }
  74. if ($result[$info['module']]['module'] == $info['module']) {
  75. $result[$info['module']]['count'] += $info['count'];
  76. $result[$info['module']]['highest'] = $result[$info['module']]['highest'] >= $info['count'] ? $result[$info['module']]['highest'] : $info['count'];
  77. } else {
  78. $result[$info['module']] = $info;
  79. $result[$info['module']]['highest'] = $info['count'];
  80. }
  81. }
  82. }
  83. $modules = stat_modules_except_system();
  84. $count = count($modules);
  85. foreach ($result as $key => $val) {
  86. $result[$key]['avg'] = round($val['count'] / $count);
  87. }
  88. return $result;
  89. }
  90. function stat_visit_app_bydate($time_type, $module = '', $daterange = array(), $is_system_stat = false) {
  91. $result = array();
  92. $visit_info = stat_visit_info('app', $time_type, $module, $daterange, $is_system_stat);
  93. if (empty($visit_info)) {
  94. return $result;
  95. }
  96. $count = stat_account_count();
  97. foreach ($visit_info as $info) {
  98. if (empty($info['uniacid']) || empty($info['date'])) {
  99. continue;
  100. }
  101. if ($result[$info['date']]['date'] == $info['date']) {
  102. $result[$info['date']]['count'] += $info['count'];
  103. $result[$info['date']]['highest'] = $result[$info['date']]['highest'] >= $info['count'] ? $result[$info['date']]['highest'] : $info['count'];
  104. } else {
  105. unset($info['module'], $info['uniacid']);
  106. $result[$info['date']] = $info;
  107. $result[$info['date']]['highest'] = $info['count'];
  108. }
  109. }
  110. if (empty($result)) {
  111. return $result;
  112. }
  113. foreach ($result as $key => $val) {
  114. $result[$key]['avg'] = round($val['count'] / $count);
  115. }
  116. return $result;
  117. }
  118. function stat_visit_all_bydate($time_type, $daterange = array(), $is_system_stat = false) {
  119. $result = array();
  120. $visit_info = stat_visit_info('all', $time_type, '', $daterange, $is_system_stat);
  121. if (empty($visit_info)) {
  122. return $result;
  123. } else {
  124. foreach ($visit_info as $visit) {
  125. $result[$visit['date']] += $visit['count'];
  126. }
  127. }
  128. return $result;
  129. }
  130. function stat_all_visit_statistics($type, $data) {
  131. if ($type == 'current_account') {
  132. $modules = stat_modules_except_system();
  133. $count = count($modules);
  134. } elseif ($type == 'all_account') {
  135. $count = stat_account_count();
  136. }
  137. $result = array(
  138. 'visit_sum' => 0,
  139. 'visit_highest' => 0,
  140. 'visit_avg' => 0
  141. );
  142. if (empty($data)) {
  143. return $result;
  144. }
  145. foreach ($data as $val) {
  146. $result['visit_sum'] += $val['count'];
  147. if ($result['visit_highest'] < $val['count']) {
  148. $result['visit_highest'] = $val['count'];
  149. }
  150. }
  151. $result['visit_avg'] = round($result['visit_sum'] / $count);
  152. return $result;
  153. }
  154. function stat_modules_except_system() {
  155. $modules = uni_modules();
  156. if (!empty($modules)) {
  157. foreach ($modules as $key => $module) {
  158. if (!empty($module['issystem'])) {
  159. unset($modules[$key]);
  160. }
  161. }
  162. }
  163. return $modules;
  164. }
  165. function stat_account_count() {
  166. $count = 0;
  167. $account_table = table('account');
  168. $account_table->searchWithType(array(ACCOUNT_TYPE_OFFCIAL_NORMAL, ACCOUNT_TYPE_OFFCIAL_AUTH));
  169. $account_table->accountRankOrder();
  170. $account_list = $account_table->searchAccountList();
  171. $count = count($account_list);
  172. return $count;
  173. }
  174. function stat_date_range($start, $end) {
  175. $result = array();
  176. if (empty($start) || empty($end)) {
  177. return $result;
  178. }
  179. $start = strtotime($start);
  180. $end = strtotime($end);
  181. $i = 0;
  182. while(strtotime(end($result)) < $end) {
  183. $result[] = date('Ymd', $start + $i * 86400);
  184. $i++;
  185. }
  186. return $result;
  187. }