-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCleanUpLog.php
More file actions
141 lines (128 loc) · 3.34 KB
/
CleanUpLog.php
File metadata and controls
141 lines (128 loc) · 3.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<?php
/**
* ファイルクリーンアップ ログ出力ライブラリ
*
* @author Mitsuru Mutaguchi <mutaguchi@opensource-workshop.jp>
* @link http://www.netcommons.org NetCommons Project
* @license http://www.netcommons.org/license.txt NetCommons License
* @copyright Copyright 2014, NetCommons Project
*/
/**
* ファイルクリーンアップ ログ出力ライブラリ
*
* @author Mitsuru Mutaguchi <mutaguchi@opensource-workshop.jp>
* @package NetCommons\CleanUp\Lib
*/
class CleanUpLog {
/**
* ロガーキー
*
* @var string
*/
const LOGGER_KEY = 'CleanUpFile';
/**
* ログファイル名
*
* @var string
*/
const LOG_FILE_NAME = 'CleanUp.log';
/**
* タイムゾーン。ログ出力時間 変更用
*
* @var string
*/
const TIMEZONE = 'Asia/Tokyo';
/**
* ログ開始時のタイムゾーン変更<br />
* タイムゾーンを一時的に変更。ログ出力時間を例えば日本時間に。
*
* @return string 日時
*/
public static function startLogTimezone() {
$timezone = date_default_timezone_get();
date_default_timezone_set(self::TIMEZONE);
return $timezone;
}
/**
* ログ終了時にタイムゾーン戻す
*
* @param string $timezone 日時
* @return void
*/
public static function endLogTimezone($timezone) {
date_default_timezone_set($timezone);
}
/**
* Setup log
*
* @return void
* @see Nc2ToNc3BaseBehavior::setup() よりコピー
* @see https://book.cakephp.org/2.0/ja/core-libraries/logging.html#id2 ログストリームの作成と設定, size,rotateのデフォルト値
*/
public static function setupLog() {
// ログ出力フォルダ作成
$logPath = LOGS . 'cleanup' . DS;
if (! file_exists($logPath)) {
$folder = new Folder();
$folder->create($logPath);
}
// CakeLog::writeでファイルとコンソールに出力していた。
// Consoleに出力すると<tag></tag>で囲われ見辛い。
// @see https://github.com/cakephp/cakephp/blob/2.9.4/lib/Cake/Console/ConsoleOutput.php#L230-L241
// CakeLog::infoをよびだし、debug.logとCleanUp.logの両方出力するようにした。
CakeLog::config(
self::LOGGER_KEY,
[
'engine' => 'FileLog',
'types' => ['info'],
'scopes' => ['CleanUp'],
'file' => self::LOG_FILE_NAME,
'size ' => '10MB', // デフォルト値 10MB
'rotate ' => 20, // デフォルト値 10
'path' => $logPath,
]
);
}
/**
* ログの内容
*
* @param int $logFileNo ログ番号
* @return string ログの内容
*/
public static function getLog($logFileNo = 0) {
if ($logFileNo == 0) {
$logFile = self::LOG_FILE_NAME;
} else {
$logFile = self::LOG_FILE_NAME . '.' . $logFileNo;
}
$logPath = LOGS . 'cleanup' . DS . $logFile;
$cleanUpLog = '';
if (file_exists($logPath)) {
$cleanUpLog = file_get_contents($logPath);
} else {
$cleanUpLog = __d('clean_up', 'None.');
}
return $cleanUpLog;
}
/**
* ログファイル名 ゲット
*
* @return array ログファイル名
*/
public static function getLogFileNames() {
//インスタンスを作成
$dir = new Folder(LOGS);
$files = $dir->read();
$logFileNames = [];
foreach ($files[1] as $file) {
if (strpos($file, self::LOG_FILE_NAME) !== false) {
$logFileNames[] = $file;
}
}
// 空の場合セット
if (empty($logFileNames)) {
$logFileNames[] = self::LOG_FILE_NAME;
}
return $logFileNames;
}
}