Subversion Repositories php-qbpwcf

Rev

Rev 226 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 liveuser 1
#!/usr/bin/php
2
<?php
3
 
4
/*
5
 
6
        QBPWCF, Quick Build PHP website Component base on Fedora Linux.
239 liveuser 7
    Copyright (C) 2014~2026 MIN ZHI, CHEN
1 liveuser 8
 
9
    This file is part of QBPWCF.
10
 
11
    QBPWCF is free software: you can redistribute it and/or modify
12
    it under the terms of the GNU General Public License as published by
13
    the Free Software Foundation, either version 3 of the License, or
14
    (at your option) any later version.
15
 
16
    QBPWCF is distributed in the hope that it will be useful,
17
    but WITHOUT ANY WARRANTY; without even the implied warranty of
18
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
    GNU General Public License for more details.
20
 
21
    You should have received a copy of the GNU General Public License
22
    along with QBPWCF.  If not, see <http://www.gnu.org/licenses/>.
23
 
24
*/
25
 
26
#使用命名空間qbpwcf
27
namespace qbpwcf;
28
 
29
#初始化輸出
30
$output=array();
31
 
32
#取得 lib path
100 liveuser 33
exec("php -f ".escapeshellarg(pathinfo(__FILE__)["dirname"]."/../../../../usr/bin/libexec/folderOfUsrLib.php"),$output,$status);
1 liveuser 34
 
35
#如果執行失敗
36
if($status!==0){
37
 
38
	#debug
39
	var_dump(__LINE__,$output);
40
 
41
	#結束執行,回傳shell 1.
42
	exit(1);
43
 
44
	}#if end
45
 
46
#儲存lib path
47
$folderOfUsrLib=$output[0];
48
 
49
#初始化輸出
50
$output=array();
51
 
52
#以該檔案的實際位置的 lib path 為 include path 首位
100 liveuser 53
exec("cd ".pathinfo(__FILE__)["dirname"]."/../../../../usr/".$folderOfUsrLib."/qbpwcf;pwd;",$output,$status);
1 liveuser 54
set_include_path($output[0].PATH_SEPARATOR.get_include_path());
55
 
56
#匯入套件
57
require_once("allInOne.php");
58
 
59
#建議的log位置
60
$logFile=$_SERVER["DOCUMENT_ROOT"].$_SERVER["PHP_SELF"].".log";
61
 
62
#要使用的範例name
63
$nameOfSample="20241212";
64
 
65
#函式說明:
66
#抓取命令列的參數.
67
#回傳結果:
68
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
69
#$reuslt["error"],執行不正常結束的錯訊息陣列.
70
#$result["function"],當前執行的函式名稱.
71
#$result["argu"],使用的參數陣列.
72
#$result["content"],要回傳的參數陣列.
73
#$result["count"],參數的數量.
74
#$result["_GET"],收到的 HTTP GET 參數陣列.
75
#$result["_POST"],收到的 HTTP POST 參數陣列.
76
#必填參數:
77
#無
78
#可省略參數:
79
#$conf["echo"],字串,"true"代表要將抓到的參數一個個印出來,"false"代表用回傳的方式,預設為"false".
80
#$conf["echo"]="false";
81
#$conf["httpGetToArgu"],字串,"true"代表要將 http get 參數變成參數來取得,像是 $_GET["p1"] 會變成 $result["content"]["p1"] 回傳,預設為"false"代表不使用.
82
$conf["httpGetToArgu"]="true";
83
#$conf["httpPostToArgu"],字串,"true"代表要將 http post 參數變成參數來取得,像是 $_POST["p1"] 會變成 $result["content"]["p1"] 回傳,預設為"false"代表不使用.
84
$conf["httpPostToArgu"]="true";
85
#參考資料:
86
#無.
87
#備註:
88
#無.
89
$getArgu=cmd::getArgu($conf);
90
unset($conf);
91
 
92
#如果執行失敗
93
if($getArgu["status"]==="false"){
94
 
95
	#函式說明:
96
	#撰寫log
97
	#回傳結果:
98
	#$result["status"],狀態,"true"或"false".
99
	#$result["error"],錯誤訊息陣列.
100
	#$result["function"],當前函式的名稱.
101
	#$result["argu"],使用的參數.
102
	#必填參數:
103
	#$conf["path"],字串,log檔案的路徑與名稱.
104
	$conf["path"]=$logFile;
105
	#$conf["content"],any,要寫的內容,若內容不為字串則會用var_dump的格式寫入.
106
	$conf["content"]=$getArgu;
107
	#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
108
	$conf["fileArgu"]=__FILE__;
109
	#可省略參數:
110
	#$conf["rewrite"],預設為"false",接續寫入;反之"true"代表重新寫入.
111
	#$conf["rewrite"]="false";
112
	#參考資料:
113
	#無.
114
	#備註:
115
	#無.
116
	$record=logs::record($conf);
117
	unset($conf);
226 liveuser 118
 
1 liveuser 119
	#如果寫log失敗
120
	if($record["status"]==="false"){
226 liveuser 121
 
1 liveuser 122
		#印出結果
123
		var_dump($record);
226 liveuser 124
 
1 liveuser 125
		}#if end
226 liveuser 126
 
1 liveuser 127
	#結束執行,回傳錯誤代碼1
128
	exit(1);
129
 
130
	}#if end
226 liveuser 131
 
1 liveuser 132
#如果有指定參數
133
if($getArgu["count"]>0){
134
 
135
	#預設第2個參數為 $nameOfSample 的指定數值
136
	$nameOfSample=$getArgu["content"][0];
137
 
138
	}#if end
139
 
140
#存放範例的資料夾
141
$sampleFolder="cmd::rsync";
142
 
143
#設置測試案例的檔案名稱與路徑
144
$fileNameOfSample=$sampleFolder."/".$nameOfSample.".php";
145
 
146
#初始化儲存範例代碼
147
$samples=array();
148
 
149
#增加 cmd::rsync 的範例資訊
150
$samples[]=array("name"=>"20241212","comnent"=>"chown folder and it's content.");
151
 
152
#針對每個範例資訊
153
foreach($samples as $sample){
154
 
155
	#如果找到對應的範例
156
	if($sample["name"]===$nameOfSample){
226 liveuser 157
 
1 liveuser 158
		#如果存放範例的資料夾不存在
159
		if(!file_exists($sampleFolder)){
226 liveuser 160
 
1 liveuser 161
			#提示訊息
162
			echo "存放範例的資料夾(".$sampleFolder.")不存在".PHP_EOL;
226 liveuser 163
 
1 liveuser 164
			#結束執行,並回傳1給shell
165
			exit(1);
226 liveuser 166
 
1 liveuser 167
			}#if end
226 liveuser 168
 
1 liveuser 169
		#如果對應的範例檔案不存在
170
		if(!file_exists($fileNameOfSample)){
226 liveuser 171
 
1 liveuser 172
			#提示訊息
173
			echo "範例檔案(".$fileNameOfSample.")不存在".PHP_EOL;
226 liveuser 174
 
1 liveuser 175
			#結束執行,並回傳1給shell
176
			exit(1);
226 liveuser 177
 
1 liveuser 178
			}#if end
226 liveuser 179
 
1 liveuser 180
		#匯入範例
181
		require_once($fileNameOfSample);
226 liveuser 182
 
1 liveuser 183
		#結束執行
184
		exit;
226 liveuser 185
 
1 liveuser 186
		}#if end
187
 
188
	}#foreach end
226 liveuser 189
 
1 liveuser 190
#執行到這邊代表沒有對應的範例
191
 
192
#提示範例不存在
193
echo "範例(".$nameOfSample.")不存在".PHP_EOL;
194
 
195
#結束執行,並回傳1給shell
196
exit(1);
197
 
226 liveuser 198
?>