source: temp/trunk/html/install/index.php @ 5095

Revision 5095, 17.4 KB checked in by kakinaka, 20 years ago (diff)

blank

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1<?php
2require_once("../require.php");
3$INSTALL_DIR = realpath(dirname( __FILE__));
4
5class LC_Page {
6    function LC_Page() {
7        $this->arrDB_TYPE = array(
8            'pgsql' => 'PostgreSQL',
9            'mysql' => 'mySQL' 
10        );
11    }
12}
13
14$objPage = new LC_Page();
15
16// ¥Æ¥ó¥×¥ì¡¼¥È¥³¥ó¥Ñ¥¤¥ë¥Ç¥£¥ì¥¯¥È¥ê¤Î½ñ¹þ¤ß¸¢¸Â¥Á¥§¥Ã¥¯
17$temp_dir = $INSTALL_DIR . '/temp';
18$mode = lfGetFileMode($temp_dir);
19
20if($mode != '777') {
21    sfErrorHeader($temp_dir . "¤Ë¥æ¡¼¥¶½ñ¹þ¤ß¸¢¸Â(777)¤òÉÕÍ¿¤·¤Æ²¼¤µ¤¤¡£", true);
22    exit;
23}
24
25$objView = new SC_InstallView($INSTALL_DIR . '/templates', $INSTALL_DIR . '/temp');
26
27// ¥Ñ¥é¥á¡¼¥¿´ÉÍý¥¯¥é¥¹
28$objWebParam = new SC_FormParam();
29$objDBParam = new SC_FormParam();
30// ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
31$objWebParam = lfInitWebParam($objWebParam);
32$objDBParam = lfInitDBParam($objDBParam);
33
34//¥Õ¥©¡¼¥àÇÛÎó¤Î¼èÆÀ
35$objWebParam->setParam($_POST);
36$objDBParam->setParam($_POST);
37
38switch($_POST['mode']) {
39// ¤è¤¦¤³¤½
40case 'welcome':
41    $objPage = lfDispStep0($objPage);
42    break;
43// ¥¢¥¯¥»¥¹¸¢¸Â¤Î¥Á¥§¥Ã¥¯
44case 'step0':
45    $objPage = lfDispStep0_1($objPage);
46    break; 
47// ¥Õ¥¡¥¤¥ë¤Î¥³¥Ô¡¼
48case 'step0_1':
49    $objPage = lfDispStep1($objPage);
50    break; 
51// WEB¥µ¥¤¥È¤ÎÀßÄê
52case 'step1':
53    //ÆþÎÏÃͤΥ¨¥é¡¼¥Á¥§¥Ã¥¯
54    $objPage->arrErr = lfCheckWEBError($objWebParam);
55    if(count($objPage->arrErr) == 0) {
56        $objPage = lfDispStep2($objPage);
57    } else {
58        $objPage = lfDispStep1($objPage);
59    }
60    break;
61// ¥Ç¡¼¥¿¥Ù¡¼¥¹¤ÎÀßÄê
62case 'step2':
63    //ÆþÎÏÃͤΥ¨¥é¡¼¥Á¥§¥Ã¥¯
64    if ($_POST['db_type'] == 'pgsql') {
65        $_POST['db_port'] = "";
66    }else{
67        $_POST['db_port'] = ":".$_POST['db_port'];
68        $objDBParam->setValue("db_port", $_POST['db_port']);
69    }
70   
71    $objPage->arrErr = lfCheckDBError($objDBParam);
72   
73    if(count($objPage->arrErr) == 0) {
74        $objPage = lfDispStep3($objPage);
75    } else {
76        $objPage = lfDispStep2($objPage);
77    }
78    break;
79// ¥Æ¡¼¥Ö¥ë¤ÎºîÀ®
80case 'step3':
81    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
82    $arrRet =  $objDBParam->getHashArray();
83    // ¥Æ¡¼¥Ö¥ë¤ÎºîÀ®
84    $objPage->arrErr = lfExecuteSQL("./create_table_".$arrRet['db_type']."sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port']);
85    if(count($objPage->arrErr) == 0) {
86        $objPage->tpl_message.="¡û¡§¥Æ¡¼¥Ö¥ë¤ÎºîÀ®¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
87    } else {
88        $objPage->tpl_message.="¡ß¡§¥Æ¡¼¥Ö¥ë¤ÎºîÀ®¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";       
89    }
90
91    // ¥Ó¥å¡¼¤ÎºîÀ®
92    if(count($objPage->arrErr) == 0 and $arrRet['db_type'] == 'pgsql') {
93        // ¥Ó¥å¡¼¤ÎºîÀ®
94        $objPage->arrErr = lfExecuteSQL("./create_view.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port']);
95        if(count($objPage->arrErr) == 0) {
96            $objPage->tpl_message.="¡û¡§¥Ó¥å¡¼¤ÎºîÀ®¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
97        } else {
98            $objPage->tpl_message.="¡ß¡§¥Ó¥å¡¼¤ÎºîÀ®¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";     
99        }
100    }   
101   
102    // ½é´ü¥Ç¡¼¥¿¤ÎºîÀ®
103    if(count($objPage->arrErr) == 0) {
104        $objPage->arrErr = lfExecuteSQL("./insert_data.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port']);
105        if(count($objPage->arrErr) == 0) {
106            $objPage->tpl_message.="¡û¡§½é´ü¥Ç¡¼¥¿¤ÎºîÀ®¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
107        } else {
108            $objPage->tpl_message.="¡ß¡§½é´ü¥Ç¡¼¥¿¤ÎºîÀ®¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";     
109        }
110    }   
111   
112    // ¥«¥é¥à¥³¥á¥ó¥È¤Î½ñ¹þ¤ß
113    if(count($objPage->arrErr) == 0) {
114        $objPage->arrErr = lfExecuteSQL("./column_comment.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port']);
115        if(count($objPage->arrErr) == 0) {
116            $objPage->tpl_message.="¡û¡§¥«¥é¥à¥³¥á¥ó¥È¤Î½ñ¹þ¤ß¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
117        } else {
118            $objPage->tpl_message.="¡ß¡§¥«¥é¥à¥³¥á¥ó¥È¤Î½ñ¹þ¤ß¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";       
119        }
120    }   
121   
122    // ¥Æ¡¼¥Ö¥ë¥³¥á¥ó¥È¤Î½ñ¹þ¤ß
123    if(count($objPage->arrErr) == 0) {
124        $objPage->arrErr = lfExecuteSQL("./table_comment.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port']);
125        if(count($objPage->arrErr) == 0) {
126            $objPage->tpl_message.="¡û¡§¥Æ¡¼¥Ö¥ë¥³¥á¥ó¥È¤Î½ñ¹þ¤ß¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
127        } else {
128            $objPage->tpl_message.="¡ß¡§¥Æ¡¼¥Ö¥ë¥³¥á¥ó¥È¤Î½ñ¹þ¤ß¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";     
129        }
130    }
131   
132    if(count($objPage->arrErr) == 0) {
133        // ÀßÄê¥Õ¥¡¥¤¥ë¤ÎÀ¸À®
134        lfMakeConfigFile();
135        $objPage = lfDispStep3($objPage);
136        $objPage->tpl_mode = 'complete';
137    } else {
138        $objPage = lfDispStep3($objPage);
139    }
140    break;
141// ¥Æ¡¼¥Ö¥ëÎàºï½ü
142case 'drop':
143    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
144    $arrRet =  $objDBParam->getHashArray();
145   
146    if ($arrRet['db_type'] == 'pgsql'){
147        // ¥Ó¥å¡¼¤Îºï½ü
148        $objPage->arrErr = lfExecuteSQL("./drop_view.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port'], false);
149        if(count($objPage->arrErr) == 0) {
150            $objPage->tpl_message.="¡û¡§¥Ó¥å¡¼¤Îºï½ü¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
151        } else {
152            $objPage->tpl_message.="¡ß¡§¥Ó¥å¡¼¤Îºï½ü¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";     
153        }
154    }
155
156
157    // ¥Æ¡¼¥Ö¥ë¤Îºï½ü
158    if(count($objPage->arrErr) == 0) {
159        $objPage->arrErr = lfExecuteSQL("./drop_table.sql", $arrRet['db_user'], $arrRet['db_password'], $arrRet['db_server'], $arrRet['db_name'], $arrRet['db_type'], $arrRet['db_port'], false);
160        if(count($objPage->arrErr) == 0) {
161            $objPage->tpl_message.="¡û¡§¥Æ¡¼¥Ö¥ë¤Îºï½ü¤ËÀ®¸ù¤·¤Þ¤·¤¿¡£<br>";
162        } else {
163            $objPage->tpl_message.="¡ß¡§¥Æ¡¼¥Ö¥ë¤Îºï½ü¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";       
164        }
165    }
166    $objPage = lfDispStep3($objPage);
167    break;
168// ´°Î»²èÌÌ
169case 'complete':
170    // ¥·¥ç¥Ã¥×¥Þ¥¹¥¿¾ðÊó¤Î½ñ¤­¹þ¤ß
171    $arrRet =  $objDBParam->getHashArray();
172    $dsn = "pgsql://".$arrRet['db_user'].":".$arrRet['db_password']."@".$arrRet['db_server']."/".$arrRet['db_name'];
173    $sqlval['shop_name'] = $objWebParam->getValue('shop_name');
174    $sqlval['email01'] = $objWebParam->getValue('admin_mail');
175    $sqlval['email02'] = $objWebParam->getValue('admin_mail');
176    $sqlval['email03'] = $objWebParam->getValue('admin_mail');
177    $sqlval['email04'] = $objWebParam->getValue('admin_mail');
178    $sqlval['email05'] = $objWebParam->getValue('admin_mail');
179    $sqlval['top_tpl'] = "default1";
180    $sqlval['product_tpl'] = "default1";
181    $sqlval['detail_tpl'] = "default1";
182    $sqlval['mypage_tpl'] = "default1";
183    $objQuery = new SC_Query($dsn);
184    $cnt = $objQuery->count("dtb_baseinfo");
185    if($cnt > 0) {
186        $objQuery->update("dtb_baseinfo", $sqlval);
187    } else {
188        $objQuery->insert("dtb_baseinfo", $sqlval);     
189    }
190    global $GLOBAL_ERR;
191    $GLOBAL_ERR = "";
192    $objPage = lfDispComplete($objPage);
193    break;
194case 'return_step0':
195    $objPage = lfDispStep0($objPage);
196    break; 
197case 'return_step1':
198    $objPage = lfDispStep1($objPage);
199    break;
200case 'return_step2':
201    $objPage = lfDispStep2($objPage);
202    break;
203case 'return_welcome':
204default:
205    $objPage = lfDispWelcome($objPage);
206    break;
207}
208
209//¥Õ¥©¡¼¥àÍѤΥѥé¥á¡¼¥¿¤òÊÖ¤¹
210$objPage->arrForm = $objWebParam->getFormParamList();
211$objPage->arrForm = array_merge($objPage->arrForm, $objDBParam->getFormParamList());
212
213// SiteInfo¤òÆÉ¤ß¹þ¤Þ¤Ê¤¤
214$objView->assignobj($objPage);
215$objView->display('install_frame.tpl');
216//-----------------------------------------------------------------------------------------------------------------------------------
217// ¤è¤¦¤³¤½²èÌ̤Îɽ¼¨
218function lfDispWelcome($objPage) {
219    global $objWebParam;
220    global $objDBParam;
221    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
222    $objPage->arrHidden = $objWebParam->getHashArray();
223    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
224    $objPage->arrHidden = array_merge($objPage->arrHidden, $objDBParam->getHashArray());
225    $objPage->tpl_mainpage = 'welcome.tpl';
226    $objPage->tpl_mode = 'welcome';
227    return $objPage;
228}
229
230// STEP0²èÌ̤Îɽ¼¨(¥Õ¥¡¥¤¥ë¸¢¸Â¥Á¥§¥Ã¥¯)
231function lfDispStep0($objPage) {
232    global $objWebParam;
233    global $objDBParam;
234    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
235    $objPage->arrHidden = $objWebParam->getHashArray();
236    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
237    $objPage->arrHidden = array_merge($objPage->arrHidden, $objDBParam->getHashArray());
238    $objPage->tpl_mainpage = 'step0.tpl';
239    $objPage->tpl_mode = 'step0';
240   
241    // ¥×¥í¥°¥é¥à¤Ç½ñ¹þ¤ß¤µ¤ì¤ë¥Õ¥¡¥¤¥ë¡¦¥Ç¥£¥ì¥¯¥È¥ê
242    $arrWriteFile = array(
243        "html/install.inc",
244        "html/user_data",
245        "html/upload",
246        "data/Smarty/templates_c",     
247        "data/update",
248        "data/logs",
249    );
250   
251    $mess = "";
252    $err_file = false;
253    foreach($arrWriteFile as $val) {
254        $path = "../../" . $val;       
255        if(file_exists($path)) {
256            $mode = lfGetFileMode("../../" . $val);
257           
258            // ¥Ç¥£¥ì¥¯¥È¥ê¤Î¾ì¹ç
259            if(is_dir($path)) {
260                if($mode == "777") {
261                    $mess.= ">> ¡û¡§$val($mode) ¤ÏÌäÂꤢ¤ê¤Þ¤»¤ó¡£<br>";                   
262                } else {
263                    $mess.= ">> ¡ß¡§$val($mode) ¤Ë¥æ¡¼¥¶½ñ¹þ¤ß¸¢¸Â(777)¤òÉÕÍ¿¤·¤Æ²¼¤µ¤¤¡£<br>";
264                    $err_file = true;                                       
265                }
266            } else {
267                if($mode == "666") {
268                    $mess.= ">> ¡û¡§$val($mode) ¤ÏÌäÂꤢ¤ê¤Þ¤»¤ó¡£<br>";                   
269                } else {
270                    $mess.= ">> ¡ß¡§$val($mode) ¤Ë¥æ¡¼¥¶½ñ¹þ¤ß¸¢¸Â(666)¤òÉÕÍ¿¤·¤Æ²¼¤µ¤¤¡£<br>";
271                    $err_file = true;                           
272                }
273            }   
274           
275        } else {
276            $mess.= ">> ¡ß¡§$val ¤¬¸«¤Ä¤«¤ê¤Þ¤»¤ó¡£<br>";
277            $err_file = true;
278        }
279    }
280   
281    // ¸¢¸Â¥¨¥é¡¼Åù¤¬È¯À¸¤·¤Æ¤¤¤Ê¤¤¾ì¹ç
282    if(!$err_file) {
283        $path = "../../data/Smarty/templates_c/admin";
284        if(!file_exists($path)) {
285            mkdir($path);
286        }
287        $path = "../../html/upload/save_image";
288        if(!file_exists($path)) {
289            mkdir($path);
290        }
291        $path = "../../html/upload/temp_image";
292        if(!file_exists($path)) {
293            mkdir($path);
294        }
295        $path = "../../html/upload/graph_image";
296        if(!file_exists($path)) {
297            mkdir($path);
298        }
299        $path = "../../html/upload/csv";
300        if(!file_exists($path)) {
301            mkdir($path);
302        }
303    }
304   
305    $objPage->mess = $mess;
306    $objPage->err_file = $err_file;
307
308    return $objPage;
309}
310
311
312// STEP0_1²èÌ̤Îɽ¼¨(¥Õ¥¡¥¤¥ë¤Î¥³¥Ô¡¼)
313function lfDispStep0_1($objPage) {
314    global $objWebParam;
315    global $objDBParam;
316    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
317    $objPage->arrHidden = $objWebParam->getHashArray();
318    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
319    $objPage->arrHidden = array_merge($objPage->arrHidden, $objDBParam->getHashArray());
320    $objPage->tpl_mainpage = 'step0_1.tpl';
321    $objPage->tpl_mode = 'step0_1';
322    // ¥Õ¥¡¥¤¥ë¥³¥Ô¡¼
323    $objPage->copy_mess = lfCopyDir("./user_data/", "../../html/user_data/", $objPage->copy_mess);
324    $objPage->copy_mess = lfCopyDir("./save_image/", "../../html/upload/save_image/", $objPage->copy_mess);
325    return $objPage;
326}
327
328function lfGetFileMode($path) {
329    $mode = substr(sprintf('%o', fileperms($path)), -3);
330    return $mode;
331}
332
333// STEP1²èÌ̤Îɽ¼¨
334function lfDispStep1($objPage) {
335    global $objDBParam;
336    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
337    $objPage->arrHidden = $objDBParam->getHashArray();
338    $objPage->tpl_mainpage = 'step1.tpl';
339    $objPage->tpl_mode = 'step1';
340    return $objPage;
341}
342
343// STEP2²èÌ̤Îɽ¼¨
344function lfDispStep2($objPage) {
345    global $objWebParam;
346    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
347    $objPage->arrHidden = $objWebParam->getHashArray();
348    $objPage->tpl_mainpage = 'step2.tpl';
349    $objPage->tpl_mode = 'step2';
350    return $objPage;
351}
352
353// STEP3²èÌ̤Îɽ¼¨
354function lfDispStep3($objPage) {
355    global $objWebParam;
356    global $objDBParam;
357    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
358    $objPage->arrHidden = $objWebParam->getHashArray();
359    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
360    $objPage->arrHidden = array_merge($objPage->arrHidden, $objDBParam->getHashArray());
361    $objPage->tpl_mainpage = 'step3.tpl';
362    $objPage->tpl_mode = 'step3';
363    return $objPage;
364}
365
366// ´°Î»²èÌ̤Îɽ¼¨
367function lfDispComplete($objPage) {
368    global $objWebParam;
369    global $objDBParam;
370    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
371    $objPage->arrHidden = $objWebParam->getHashArray();
372    // hidden¤ËÆþÎÏÃͤòÊÝ»ý
373    $objPage->arrHidden = array_merge($objPage->arrHidden, $objDBParam->getHashArray());
374    $objPage->tpl_mainpage = 'complete.tpl';
375    $objPage->tpl_mode = 'complete';
376    return $objPage;
377}
378
379// WEB¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
380function lfInitWebParam($objWebParam) {
381   
382    $install_dir = realpath(dirname( __FILE__) . "/../../") . "/";
383    $normal_url = "http://" . $_SERVER['HTTP_HOST'] . "/";
384    $secure_url = "http://" . $_SERVER['HTTP_HOST'] . "/";
385    $domain = ereg_replace("^[a-zA-Z0-9_~=&\?\/-]+\.", "", $_SERVER['HTTP_HOST']);
386    $objWebParam->addParam("Ź̾", "shop_name", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"));
387    $objWebParam->addParam("´ÉÍý¼Ô¥á¡¼¥ë¥¢¥É¥ì¥¹", "admin_mail", MTEXT_LEN, "", array("EXIST_CHECK","EMAIL_CHECK","EMAIL_CHAR_CHECK","MAX_LENGTH_CHECK"));
388    $objWebParam->addParam("¥¤¥ó¥¹¥È¡¼¥ë¥Ç¥£¥ì¥¯¥È¥ê", "install_dir", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"), $install_dir);
389    $objWebParam->addParam("URL(Ä̾ï)", "normal_url", MTEXT_LEN, "", array("EXIST_CHECK","URL_CHECK","MAX_LENGTH_CHECK"), $normal_url);
390    $objWebParam->addParam("URL(¥»¥­¥å¥¢)", "secure_url", MTEXT_LEN, "", array("EXIST_CHECK","URL_CHECK","MAX_LENGTH_CHECK"), $secure_url);
391    $objWebParam->addParam("¥É¥á¥¤¥ó", "domain", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"), $domain); 
392   
393    return $objWebParam;
394}
395
396// WEB¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
397function lfInitDBParam($objDBParam) {
398   
399    $db_server = "127.0.0.1";
400    $db_port = "3306";
401    $db_name = "eccube_db";
402    $db_user = "eccube_db_user";
403   
404    $objDBParam->addParam("DB¤Î¼ïÎà", "db_type", INT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"));
405    $objDBParam->addParam("DB¥µ¡¼¥Ð", "db_server", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"), $db_server);
406    $objDBParam->addParam("DB¥Ý¡¼¥È", "db_port", INT_LEN, "", array("MAX_LENGTH_CHECK"), $db_port);
407    $objDBParam->addParam("DB̾", "db_name", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"), $db_name);
408    $objDBParam->addParam("DB¥æ¡¼¥¶", "db_user", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"), $db_user);
409    $objDBParam->addParam("DB¥Ñ¥¹¥ï¡¼¥É", "db_password", MTEXT_LEN, "", array("EXIST_CHECK","MAX_LENGTH_CHECK"));   
410    return $objDBParam;
411}
412
413// ÆþÎÏÆâÍÆ¤Î¥Á¥§¥Ã¥¯
414function lfCheckWebError($objFormParam) {
415    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
416    $arrRet =  $objFormParam->getHashArray();
417    $objErr = new SC_CheckError($arrRet);
418    $objErr->arrErr = $objFormParam->checkError();
419    return $objErr->arrErr;
420}
421
422// ÆþÎÏÆâÍÆ¤Î¥Á¥§¥Ã¥¯
423function lfCheckDBError($objFormParam) {
424    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
425    $arrRet =  $objFormParam->getHashArray();
426   
427    $objErr = new SC_CheckError($arrRet);
428    $objErr->arrErr = $objFormParam->checkError();
429   
430    if(count($objErr->arrErr) == 0) {
431        // Àܳ³Îǧ
432        $dsn = $arrRet['db_type']."://".$arrRet['db_user'].":".$arrRet['db_password']."@".$arrRet['db_server'].$arrRet['db_port']."/".$arrRet['db_name'];
433        // Debug¥â¡¼¥É»ØÄê
434        $options['debug'] = 3;
435        $objDB = DB::connect($dsn, $options);
436        // Àܳ¥¨¥é¡¼
437        if(PEAR::isError($objDB)) {
438            $objErr->arrErr['all'] = ">> " . $objDB->message . "<br>";
439            // ¥¨¥é¡¼Ê¸¤ò¼èÆÀ¤¹¤ë
440            ereg("\[(.*)\]", $objDB->userinfo, $arrKey);
441            $objErr->arrErr['all'].= $arrKey[0] . "<br>";
442            gfPrintLog($objDB->userinfo, "./temp/install.log");
443        }
444    }
445    return $objErr->arrErr;
446}
447
448// SQLʸ¤Î¼Â¹Ô
449function lfExecuteSQL($filepath, $db_user, $db_password, $db_server, $db_name, $db_type, $db_port, $disp_err = true) {
450    $arrErr = array();
451
452    if(!file_exists($filepath)) {
453        $arrErr['all'] = ">> ¥¹¥¯¥ê¥×¥È¥Õ¥¡¥¤¥ë¤¬¸«¤Ä¤«¤ê¤Þ¤»¤ó";
454    } else {
455        if($fp = fopen($filepath,"r")) {
456            $sql = fread($fp, filesize($filepath));
457            fclose($fp);
458        }
459
460        $dsn = $db_type."://".$db_user.":".$db_password."@".$db_server.$db_port."/".$db_name;
461       
462        print($dsn);
463
464        $objDB = DB::connect($dsn);
465        // Àܳ¥¨¥é¡¼
466        if(!PEAR::isError($objDB)) {
467            // ²þ¹Ô¡¢¥¿¥Ö¤ò1¥¹¥Ú¡¼¥¹¤ËÊÑ´¹
468            $sql = preg_replace("/[\r\n\t]/"," ",$sql);
469            $sql_split = split(";",$sql);
470            foreach($sql_split as $key => $val){
471                if ($val != "") {
472                    $ret = $objDB->query($val);
473                    if(PEAR::isError($ret) and $disp_err) {
474                        $arrErr['all'] = ">> " . $ret->message . "<br>";
475                        // ¥¨¥é¡¼Ê¸¤ò¼èÆÀ¤¹¤ë
476                        ereg("\[(.*)\]", $ret->userinfo, $arrKey);
477                        $arrErr['all'].= $arrKey[0] . "<br>";
478                        $objPage->update_mess.=">> ¥Æ¡¼¥Ö¥ë¹½À®¤ÎÊѹ¹¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£<br>";
479                        gfPrintLog($ret->userinfo, "./temp/install.log");
480                    }
481                }
482            }
483           
484        } else {
485            $arrErr['all'] = ">> " . $objDB->message;
486            gfPrintLog($objDB->userinfo, "./temp/install.log");
487        }
488    }
489    return $arrErr;
490}
491
492// ÀßÄê¥Õ¥¡¥¤¥ë¤ÎºîÀ®
493function lfMakeConfigFile() {
494    global $objWebParam;
495    global $objDBParam;
496   
497    $filepath = $objWebParam->getValue('install_dir') . "/html/install.inc";
498    $domain = $objWebParam->getValue('domain');
499    if(!ereg("^\.", $domain)) {
500        $domain = "." . $domain;
501    }
502   
503    $root_dir = $objWebParam->getValue('install_dir');
504    if (!ereg("/$", $root_dir)) {
505        $root_dir = $root_dir . "/";
506    }
507   
508    $config_data =
509    "<?php\n".
510    "    define ('ECCUBE_INSTALL', 'ON');\n" .
511    "    define ('ROOT_DIR', '" . $root_dir . "');\n" .
512    "    define ('SITE_URL', '" . $objWebParam->getValue('normal_url') . "');\n" .
513    "    define ('SSL_URL', '" . $objWebParam->getValue('secure_url') . "');\n" .
514    "    define ('DOMAIN_NAME', '" . $domain . "');\n" .
515    "    define ('DB_USER', '" . $objDBParam->getValue('db_user') . "');\n" .
516    "    define ('DB_PASSWORD', '" . $objDBParam->getValue('db_password') . "');\n" .
517    "    define ('DB_SERVER', '" . $objDBParam->getValue('db_server') . "');\n" .
518    "    define ('DB_NAME', '" . $objDBParam->getValue('db_name') . "');\n" .
519    "?>";
520   
521    if($fp = fopen($filepath,"w")) {
522        fwrite($fp, $config_data);
523        fclose($fp);
524    }
525}
526
527// ¥Ç¥£¥ì¥¯¥È¥ê°Ê²¼¤Î¥Õ¥¡¥¤¥ë¤òºÆµ¢Åª¤Ë¥³¥Ô¡¼
528function lfCopyDir($src, $des, $mess, $override = false){
529    if(!is_dir($src)){
530        return false;
531    }
532
533    $oldmask = umask(0);
534    $mod= stat($src);
535   
536    // ¥Ç¥£¥ì¥¯¥È¥ê¤¬¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë
537    if(!file_exists($des)) {
538        mkdir($des, $mod[2]);
539    }
540   
541    $fileArray=glob( $src."*" );
542    foreach( $fileArray as $key => $data_ ){
543        // CVS´ÉÍý¥Õ¥¡¥¤¥ë¤Ï¥³¥Ô¡¼¤·¤Ê¤¤
544        if(ereg("/CVS/Entries", $data_)) {
545            break;
546        }
547        if(ereg("/CVS/Repository", $data_)) {
548            break;
549        }
550        if(ereg("/CVS/Root", $data_)) {
551            break;
552        }
553       
554        mb_ereg("^(.*[\/])(.*)",$data_, $matches);
555        $data=$matches[2];
556        if( is_dir( $data_ ) ){
557            $mess = lfCopyDir( $data_.'/', $des.$data.'/', $mess);
558        }else{
559            if(!$override && file_exists($des.$data)) {
560                $mess.= $des.$data . "¡§¥Õ¥¡¥¤¥ë¤¬Â¸ºß¤·¤Þ¤¹\n";
561            } else {
562                if(@copy( $data_, $des.$data)) {
563                    $mess.= $des.$data . "¡§¥³¥Ô¡¼À®¸ù\n";
564                } else {
565                    $mess.= $des.$data . "¡§¥³¥Ô¡¼¼ºÇÔ\n";
566                }
567            }
568            $mod=stat($data_ );
569        }
570    }
571    umask($oldmask);
572    return $mess;
573}
574?>
Note: See TracBrowser for help on using the repository browser.