source: temp/trunk/html/admin/system/bkup.php @ 5868

Revision 5868, 14.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
2/*
3 * Copyright ¢í 2000-2006 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7 
8require_once("../require.php");
9require_once("../../../data/module/Tar.php");
10
11//¥Ú¡¼¥¸´ÉÍý¥¯¥é¥¹
12class LC_Page {
13    //¥³¥ó¥¹¥È¥é¥¯¥¿
14    function LC_Page() {
15        //¥á¥¤¥ó¥Æ¥ó¥×¥ì¡¼¥È¤Î»ØÄê
16        $this->tpl_mainpage = 'system/bkup.tpl';
17        $this->tpl_subnavi = 'system/subnavi.tpl';
18        $this->tpl_mainno = 'system';       
19        $this->tpl_subno = 'bkup';
20        $this->tpl_subtitle = '¥Ð¥Ã¥¯¥¢¥Ã¥×´ÉÍý';
21       
22//      $this->bkup_dir = ROOT_DIR . USER_DIR . "bkup/";
23        $this->bkup_dir = ROOT_DIR . "html/test/" . "bkup/";
24    }
25}
26
27$objPage = new LC_Page();
28$objView = new SC_AdminView();
29$objQuery = new SC_Query();
30
31// ¥»¥Ã¥·¥ç¥ó¥¯¥é¥¹
32$objSess = new SC_Session();
33// ǧ¾Ú²ÄÈݤÎȽÄê
34sfIsSuccess($objSess);
35
36// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Æ¡¼¥Ö¥ë¤¬¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë
37lfCreateBkupTable();
38
39switch($_POST['mode']) {
40// ¥Ð¥Ã¥¯¥¢¥Ã¥×¤òºîÀ®¤¹¤ë
41case 'bkup':
42    // ÆþÎÏʸ»úÎó¤ÎÊÑ´¹
43    $arrData = lfConvertParam($_POST);
44
45    // ¥¨¥é¡¼¥Á¥§¥Ã¥¯
46    $arrErr = lfCheckError($arrData);
47
48    // ¥¨¥é¡¼¤¬¤Ê¤±¤ì¤Ð¥Ð¥Ã¥¯¥¢¥Ã¥×½èÍý¤ò¹Ô¤¦   
49    if (count($arrErr) <= 0) {
50        // ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Õ¥¡¥¤¥ëºîÀ®
51        $arrErr = lfCreateBkupData($arrData['bkup_name']);
52       
53        // DB¤Ë¥Ç¡¼¥¿¹¹¿·
54        if (count($arrErr) <= 0) {
55            lfUpdBkupData($arrData);
56        }else{
57            $arrForm = $arrData;
58        }
59       
60        $objPage->tpl_onload = "alert('¥Ð¥Ã¥¯¥¢¥Ã¥×´°Î»¤·¤Þ¤·¤¿');";
61    }else{
62        $arrForm = $arrData;
63    }
64
65    break;
66   
67// ¥ê¥¹¥È¥¢
68case 'restore':
69case 'restore_config':
70    if ($_POST['mode'] == 'restore_config') {
71        $objPage->mode = "restore_config";
72    }
73
74    lfRestore($_POST['list_name']);
75
76    break;
77   
78// ºï½ü
79case 'del':
80    // ¥Õ¥¡¥¤¥ë¤Îºï½ü
81    unlink($objPage->bkup_dir.$_POST['list_name'] . ".tar.gz");
82
83    // DB¤«¤éºï½ü
84    $delsql = "DELETE FROM dtb_bkup WHERE bkup_name = ?";
85    $objQuery->query($delsql, array($_POST['list_name']));
86
87    break;
88default:
89    break;
90}
91
92// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥ê¥¹¥È¤ò¼èÆÀ¤¹¤ë
93$arrBkupList = lfGetBkupData("ORDER BY create_date DESC");
94
95// ¥Æ¥ó¥×¥ì¡¼¥È¥Õ¥¡¥¤¥ë¤ËÅϤ¹¥Ç¡¼¥¿¤ò¥»¥Ã¥È
96$objPage->arrErr = $arrErr;
97$objPage->arrForm = $arrForm;
98$objPage->arrBkupList = $arrBkupList;
99
100$objView->assignobj($objPage);      //ÊÑ¿ô¤ò¥Æ¥ó¥×¥ì¡¼¥È¤Ë¥¢¥µ¥¤¥ó¤¹¤ë
101$objView->display(MAIN_FRAME);      //¥Æ¥ó¥×¥ì¡¼¥È¤Î½ÐÎÏ
102
103//-------------------------------------------------------------------------------------------------------
104/* ¼èÆÀʸ»úÎó¤ÎÊÑ´¹ */
105function lfConvertParam($array) {
106    /*
107     *  ʸ»úÎó¤ÎÊÑ´¹
108     *  K :  ¡ÖȾ³Ñ(ŽÊŽÝ޶ޏ)ÊÒ²¾Ì¾¡×¤ò¡ÖÁ´³ÑÊÒ²¾Ì¾¡×¤ËÊÑ´¹
109     *  C :  ¡ÖÁ´³Ñ¤Ò¤é²¾Ì¾¡×¤ò¡ÖÁ´³Ñ¤«¤¿²¾Ì¾¡×¤ËÊÑ´¹
110     *  V :  ÂùÅÀÉÕ¤­¤Îʸ»ú¤ò°ìʸ»ú¤ËÊÑ´¹¡£"K","H"¤È¶¦¤Ë»ÈÍѤ·¤Þ¤¹ 
111     *  n :  ¡ÖÁ´³Ñ¡×¿ô»ú¤ò¡ÖȾ³Ñ(ŽÊŽÝ޶ޏ)¡×¤ËÊÑ´¹
112     *  a :  Á´³Ñ±Ñ¿ô»ú¤òȾ³Ñ±Ñ¿ô»ú¤ËÊÑ´¹¤¹¤ë
113     */
114    $arrConvList['bkup_name'] = "a";
115    $arrConvList['bkup_memo'] = "KVa";
116   
117    // ʸ»úÊÑ´¹
118    foreach ($arrConvList as $key => $val) {
119        // POST¤µ¤ì¤Æ¤­¤¿ÃͤΤßÊÑ´¹¤¹¤ë¡£
120        if(isset($array[$key])) {
121            $array[$key] = mb_convert_kana($array[$key] ,$val);
122        }
123    }
124    return $array;
125}
126
127// ¥¨¥é¡¼¥Á¥§¥Ã¥¯
128function lfCheckError($array){
129    $objErr = new SC_CheckError($array);
130   
131    $objErr->doFunc(array("¥Ð¥Ã¥¯¥¢¥Ã¥×̾", "bkup_name", STEXT_LEN), array("EXIST_CHECK","MAX_LENGTH_CHECK","NO_SPTAB","ALNUM_CHECK"));
132    $objErr->doFunc(array("¥Ð¥Ã¥¯¥¢¥Ã¥×¥á¥â", "bkup_memo", MTEXT_LEN), array("MAX_LENGTH_CHECK"));
133   
134    // ½ÅÊ£¥Á¥§¥Ã¥¯
135    $ret = lfGetBkupData("WHERE bkup_name = ?", array($array['bkup_name']));
136    if (count($ret) > 0) {
137        $objErr->arrErr['bkup_name'] = "¥Ð¥Ã¥¯¥¢¥Ã¥×̾¤¬½ÅÊ£¤·¤Æ¤¤¤Þ¤¹¡£ÊÌ̾¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤¡£";
138    }
139
140    return $objErr->arrErr;
141}
142
143// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Õ¥¡¥¤¥ëºîÀ®
144function lfCreateBkupData($bkup_name){
145    global $objPage;
146    $objQuery = new SC_Query();
147    $csv_data = "";
148    $csv_autoinc = "";
149    $err = true;
150   
151    $bkup_dir = $objPage->bkup_dir;
152    $bkup_dir = $bkup_dir . $bkup_name . "/";
153
154    // Á´¥Æ¡¼¥Ö¥ë¼èÆÀ
155    $arrTableList = lfGetTableList();
156   
157    // ³Æ¥Æ¡¼¥Ö¥ë¾ðÊó¤ò¼èÆÀ¤¹¤ë
158    foreach($arrTableList as $key => $val){
159       
160        if ($val != "dtb_bkup") {
161           
162            // ¼«Æ°ºÎÈÖ·¿¤Î¹½À®¤ò¼èÆÀ¤¹¤ë
163            $csv_autoinc .= lfGetAutoIncrement($val);
164           
165            // Á´¥Ç¡¼¥¿¤ò¼èÆÀ
166            if ($val == "dtb_pagelayout"){
167                $arrData = $objQuery->getAll("SELECT * FROM $val ORDER BY page_id");
168            }else{
169                $arrData = $objQuery->getAll("SELECT * FROM $val");
170            }
171           
172            // CSV¥Ç¡¼¥¿À¸À®
173            if (count($arrData) > 0) {
174               
175                // ¥«¥é¥à¤òCSV·Á¼°¤ËÀ°¤¨¤ë
176                $arrKyes = sfGetCommaList(array_keys($arrData[0]), false);
177               
178                // ¥Ç¡¼¥¿¤òCSV·Á¼°¤ËÀ°¤¨¤ë
179                $data = "";
180                foreach($arrData as $data_key => $data_val){
181                    $data .= lfGetCSVList($arrData[$data_key]);
182                }
183                // CSV½ÐÎϥǡ¼¥¿À¸À®
184                $csv_data .= $val . "\n";
185                $csv_data .= $arrKyes . "\n";
186                $csv_data .= $data;
187                $csv_data .= "\n";
188            }   
189        }
190    }
191
192    $csv_file = $bkup_dir . "bkup_data.csv";
193    $csv_autoinc_file = $bkup_dir . "autoinc_data.csv";
194    // CSV½ÐÎÏ
195    // ¥Ç¥£¥ì¥¯¥È¥ê¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë     
196    if (!is_dir(dirname($csv_file))) {
197        $err = mkdir(dirname($csv_file));
198    }
199    if ($err) {
200        // data¤òCSV½ÐÎÏ
201        $fp = fopen($csv_file,"w");
202        if($fp) {
203            if($csv_data != ""){
204                $err = fwrite($fp, $csv_data);
205            }
206            fclose($fp);
207        }
208       
209        // ¼«Æ°ºÎÈÖ¤òCSV½ÐÎÏ
210        $fp = fopen($csv_autoinc_file,"w");
211        if($fp) {
212            if($csv_autoinc != ""){
213                $err = fwrite($fp, $csv_autoinc);
214            }
215            fclose($fp);
216        }
217    }
218
219    // ³Æ¼ï¥Õ¥¡¥¤¥ë¥³¥Ô¡¼
220    if ($err) {
221        // ¾¦ÉʲèÁü¥Õ¥¡¥¤¥ë¤ò¥³¥Ô¡¼
222        // ¥Ç¥£¥ì¥¯¥È¥ê¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë     
223        $image_dir = $bkup_dir . "save_image/";
224        if (!is_dir(dirname($image_dir))) $err = mkdir(dirname($image_dir));       
225        $copy_mess = "";
226        $copy_mess = sfCopyDir("../../upload/save_image/",$image_dir, $copy_mess);
227       
228        // ¥Æ¥ó¥×¥ì¡¼¥È¥Õ¥¡¥¤¥ë¤ò¥³¥Ô¡¼
229        // ¥Ç¥£¥ì¥¯¥È¥ê¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë     
230        $templates_dir = $bkup_dir . "templates/";
231        if (!is_dir(dirname($templates_dir))) $err = mkdir(dirname($templates_dir));       
232        $copy_mess = "";
233        $copy_mess = sfCopyDir("../../user_data/templates/",$templates_dir, $copy_mess);
234       
235        // ¥¤¥ó¥¯¥ë¡¼¥É¥Õ¥¡¥¤¥ë¤ò¥³¥Ô¡¼
236        // ¥Ç¥£¥ì¥¯¥È¥ê¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë     
237        $inc_dir = $bkup_dir . "include/";
238        if (!is_dir(dirname($inc_dir))) $err = mkdir(dirname($inc_dir));       
239        $copy_mess = "";
240        $copy_mess = sfCopyDir("../../user_data/include/",$inc_dir, $copy_mess);
241   
242        // CSS¥Õ¥¡¥¤¥ë¤ò¥³¥Ô¡¼
243        // ¥Ç¥£¥ì¥¯¥È¥ê¤¬Â¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®¤¹¤ë     
244        $css_dir = $bkup_dir . "css/";
245        if (!is_dir(dirname($css_dir))) $err = mkdir(dirname($css_dir));       
246        $copy_mess = "";
247        $copy_mess = sfCopyDir("../../user_data/css/",$css_dir, $copy_mess);
248
249        //°µ½Ì¥Õ¥é¥°TRUE¤Ïgzip°µ½Ì¤ò¤ª¤³¤Ê¤¦
250        $tar = new Archive_Tar($objPage->bkup_dir . $bkup_name.".tar.gz", TRUE);
251
252        //bkup¥Õ¥©¥ë¥À¤Ë°Üư¤¹¤ë
253        chdir($objPage->bkup_dir);
254
255        //°µ½Ì¤ò¤ª¤³¤Ê¤¦
256        $zip = $tar->create("./" . $bkup_name . "/");
257
258        // ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Ç¡¼¥¿¤Îºï½ü
259        if ($zip) sfDelFile($bkup_dir);
260    }
261
262    if (!$err) {
263        $arrErr['bkup_name'] = "¥Ð¥Ã¥¯¥¢¥Ã¥×¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£";
264        // ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Ç¡¼¥¿¤Îºï½ü
265        sfDelFile($bkup_dir);
266    }
267   
268    return $arrErr;
269}
270
271/* ÇÛÎó¤ÎÍ×ÁǤòCSV¥Õ¥©¡¼¥Þ¥Ã¥È¤Ç½ÐÎϤ¹¤ë¡£*/
272function lfGetCSVList($array) {
273    if (count($array) > 0) {
274        foreach($array as $key => $val) {
275            if ($val == "") {
276                $line .= "NULL,";
277            }else{
278                $data = str_replace("'", "\'", $val);
279                $line .= "'".$data."',";
280            }
281        }
282        $line = ereg_replace(",$", "\n", $line);
283        return $line;
284    }else{
285        return false;
286    }
287}
288
289// Á´¥Æ¡¼¥Ö¥ë¥ê¥¹¥È¤ò¼èÆÀ¤¹¤ë
290function lfGetTableList(){
291    $objQuery = new SC_Query();
292   
293    if(DB_TYPE == "pgsql"){
294        $sql = "SELECT tablename FROM pg_tables WHERE tableowner = ? ORDER BY tablename ; ";
295        $arrRet = $objQuery->getAll($sql, array(DB_USER));
296        $arrRet = sfSwapArray($arrRet);
297        $arrRet = $arrRet['tablename'];
298    }else if(DB_TYPE == "mysql"){
299        $sql = "SHOW TABLES;";
300        $arrRet = $objQuery->getAll($sql);
301        $arrRet = sfSwapArray($arrRet);
302        $arrRet = $arrRet['Tables_in_eccube_db'];
303    }
304   
305    return $arrRet;
306}
307
308// ¼«Æ°ºÎÈÖ·¿¤òCSV½ÐÎÏ·Á¼°¤ËÊÑ´¹¤¹¤ë
309function lfGetAutoIncrement($table_name){
310    $arrColList = lfGetColumnList($table_name);
311    $ret = "";
312   
313    if(DB_TYPE == "pgsql"){
314        $match = 'nextval(\'';
315    }else if(DB_TYPE == "mysql"){
316        $match = "auto_incr";
317    }
318
319    foreach($arrColList['col_def'] as $key => $val){
320       
321        if (substr($val,0,9) == $match) {
322            $col = $arrColList['col_name'][$key];
323            $autoVal = lfGetAutoIncrementVal($table_name, $col);
324            $ret .= "$table_name,$col,$autoVal\n";
325        }
326    }
327   
328    return $ret;
329}
330
331// ¥Æ¡¼¥Ö¥ë¹½À®¤ò¼èÆÀ¤¹¤ë
332function lfGetColumnList($table_name){
333    $objQuery = new SC_Query();
334
335    if(DB_TYPE == "pgsql"){
336        $sql = "SELECT
337                    a.attname, t.typname, a.attnotnull, d.adsrc as defval, a.atttypmod, a.attnum as fldnum, e.description
338                FROM
339                    pg_class c,
340                    pg_type t,
341                    pg_attribute a left join pg_attrdef d on (a.attrelid=d.adrelid and a.attnum=d.adnum)
342                                   left join pg_description e on (a.attrelid=e.objoid and a.attnum=e.objsubid)
343                WHERE (c.relname=?) AND (c.oid=a.attrelid) AND (a.atttypid=t.oid) AND a.attnum > 0
344                ORDER BY fldnum";
345        $arrColList = $objQuery->getAll($sql, array($table_name));
346        $arrColList = sfSwapArray($arrColList);
347       
348        $arrRet['col_def'] = $arrColList['defval'];
349        $arrRet['col_name'] = $arrColList['attname'];
350    }else if(DB_TYPE == "mysql"){
351        $sql = "SHOW COLUMNS FROM $table_name";
352        $arrColList = $objQuery->getAll($sql);
353        $arrColList = sfSwapArray($arrColList);
354       
355        $arrRet['col_def'] = $arrColList['Extra'];
356        $arrRet['col_name'] = $arrColList['Field'];
357    }
358    return $arrRet;
359}
360
361// ¼«Æ°ºÎÈÖ·¿¤ÎÃͤò¼èÆÀ¤¹¤ë
362function lfGetAutoIncrementVal($table_name , $colname = ""){
363    $objQuery = new SC_Query();
364    $ret = "";
365
366    if(DB_TYPE == "pgsql"){
367        $ret = $objQuery->nextval($table_name, $colname);
368    }else if(DB_TYPE == "mysql"){
369        $sql = "SHOW TABLE STATUS LIKE ?";
370        $arrData = $objQuery->getAll($sql, array($table_name));
371        $ret = $arrData[0]['Auto_increment'];
372    }
373    return $ret;
374}
375
376// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Æ¡¼¥Ö¥ë¤Ë¥Ç¡¼¥¿¤ò¹¹¿·¤¹¤ë
377function lfUpdBkupData($data){
378    $objQuery = new SC_Query();
379   
380    $sql = "INSERT INTO dtb_bkup (bkup_name,bkup_memo,create_date) values (?,?,now())";
381    $objQuery->query($sql, array($data['bkup_name'],$data['bkup_memo']));
382}
383
384// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Æ¡¼¥Ö¥ë¤«¤é¥Ç¡¼¥¿¤ò¼èÆÀ¤¹¤ë
385function lfGetBkupData($where = "", $data = array()){
386    $objQuery = new SC_Query();
387   
388    $sql = "SELECT bkup_name, bkup_memo, create_date FROM dtb_bkup ";
389    if ($where != "")   $sql .= $where;
390   
391    $ret = $objQuery->getall($sql,$data);
392   
393    return $ret;
394}
395
396// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Õ¥¡¥¤¥ë¤ò¥ê¥¹¥È¥¢¤¹¤ë
397function lfRestore($bkup_name){
398    global $objPage;
399    $objQuery = new SC_Query("", false);
400    $csv_data = "";
401    $err = true;
402   
403    $bkup_dir = $objPage->bkup_dir . $bkup_name . "/";
404   
405    //¥Ð¥Ã¥¯¥¢¥Ã¥×¥Õ¥©¥ë¥À¤Ë°Üư¤¹¤ë
406    chdir($objPage->bkup_dir);
407   
408    //°µ½Ì¥Õ¥é¥°TRUE¤Ïgzip²òÅà¤ò¤ª¤³¤Ê¤¦
409    $tar = new Archive_Tar($bkup_name . ".tar.gz", TRUE);
410   
411    //»ØÄꤵ¤ì¤¿¥Õ¥©¥ë¥ÀÆâ¤Ë²òÅह¤ë
412    $err = $tar->extract("./");
413   
414    // ̵»ö²òÅà¤Ç¤­¤ì¤Ð¡¢¥ê¥¹¥È¥¢¤ò¹Ô¤¦
415    if ($err) {
416       
417        // ¥È¥é¥ó¥¶¥¯¥·¥ç¥ó³«»Ï
418        $objQuery->begin();
419       
420        // DB¤ò¥¯¥ê¥¢
421        $err = lfDeleteAll($objQuery);
422       
423        // INSERT¼Â¹Ô
424        if ($err) $err = lfExeInsertSQL($objQuery, $bkup_dir . "bkup_data.csv");
425
426        // ¼«Æ°ºÎÈÖ¤ÎÃͤò¥»¥Ã¥È
427        if ($err) lfSetAutoInc($objQuery, $bkup_dir . "autoinc_data.csv");
428
429        // ³Æ¼ï¥Õ¥¡¥¤¥ë¤Î¥³¥Ô¡¼
430        if ($err) {
431            // ²èÁü¤Î¥³¥Ô¡¼
432            $image_dir = $bkup_dir . "save_image/";
433            $copy_mess = "";
434            $copy_mess = sfCopyDir($image_dir, "../../upload/save_image/", $copy_mess, true);       
435   
436            // ¥Æ¥ó¥×¥ì¡¼¥È¤Î¥³¥Ô¡¼
437            $tmp_dir = $bkup_dir . "templates/";
438            $copy_mess = "";
439            $copy_mess = sfCopyDir($tmp_dir, "../../user_data/templates/", $copy_mess, true);       
440           
441            // ¥¤¥ó¥¯¥ë¡¼¥É¥Õ¥¡¥¤¥ë¤Î¥³¥Ô¡¼
442            $inc_dir = $bkup_dir . "include/";
443            $copy_mess = "";
444            $copy_mess = sfCopyDir($inc_dir, "../../user_data/include/", $copy_mess, true);     
445           
446            // CSS¤Î¥³¥Ô¡¼
447            $css_dir = $bkup_dir . "css/";
448            $copy_mess = "";
449            $copy_mess = sfCopyDir($css_dir, "../../user_data/css/", $copy_mess, true);     
450
451            // ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Ç¡¼¥¿¤Îºï½ü
452            sfDelFile($bkup_dir);
453        }
454
455        // ¥ê¥¹¥È¥¢À®¸ù¤Ê¤é¥³¥ß¥Ã¥È¼ºÇԤʤé¥í¡¼¥ë¥Ð¥Ã¥¯
456        if ($err) {
457            $objQuery->commit();
458            $objPage->restore_msg = "¥ê¥¹¥È¥¢½ªÎ»¤·¤Þ¤·¤¿¡£";
459            $objPage->restore_err = true;
460        }else{
461            $objQuery->rollback();
462            $objPage->restore_msg = "¥ê¥¹¥È¥¢¤Ë¼ºÇÔ¤·¤Þ¤·¤¿¡£";
463            $objPage->restore_name = $bkup_name;
464            $objPage->restore_err = false;
465        }
466
467    }
468}
469
470// CSV¥Õ¥¡¥¤¥ë¤«¤é¥¤¥ó¥µ¡¼¥È¼Â¹Ô
471function lfExeInsertSQL($objQuery, $csv){
472    global $objPage;
473    // csv¥Õ¥¡¥¤¥ë¤«¤é¥Ç¡¼¥¿¤Î¼èÆÀ
474    $arrCsvData = file($csv);
475
476    $sql = "";
477    $base_sql = "";
478    $tbl_flg = false;
479    $col_flg = false;
480    $ret = true;
481    $pagelayout_flg = false;
482    $mode = $objPage->mode;
483       
484    foreach($arrCsvData as $key => $val){
485        $data = trim($val);
486       
487        //¶õÇò¹Ô¤Î¤È¤­¤Ï¥Æ¡¼¥Ö¥ëÊѹ¹
488        if ($data == "") {
489            $base_sql = "";
490            $tbl_flg = false;
491            $col_flg = false;
492            continue;
493        }
494       
495        // ¥Æ¡¼¥Ö¥ë¥Õ¥é¥°¤¬¤¿¤Ã¤Æ¤¤¤Ê¤¤¾ì¹ç¤Ë¤Ï¥Æ¡¼¥Ö¥ë̾¥»¥Ã¥È
496        if (!$tbl_flg) {
497            $base_sql = "INSERT INTO $data ";
498            $tbl_flg = true;
499           
500            if($data == "dtb_pagelayout"){
501                $pagelayout_flg = true;
502            }
503           
504            continue;
505        }
506       
507        // ¥«¥é¥à¥Õ¥é¥°¤¬¤¿¤Ã¤Æ¤¤¤Ê¤¤¾ì¹ç¤Ë¤Ï¥«¥é¥à¥»¥Ã¥È
508        if (!$col_flg) {
509            if ($mode != "restore_config"){
510                $base_sql .= " ($data) ";
511            }
512            $col_flg = true;
513            continue;
514        }
515
516        /*
517        // ¥¤¥ó¥µ¡¼¥È¤¹¤ëÃͤò¥»¥Ã¥È
518        $sql = $base_sql . "VALUES ( ?";
519        $arrInsdata = split(",",$data);
520        for($i = 1; $i < count($arrInsdata); $i++){
521            $sql .= ",?";
522        }
523        $sql .= ");";
524        $err = $objQuery->query($sql, $arrInsdata);
525        */
526        // ¥¤¥ó¥µ¡¼¥È¤¹¤ëÃͤò¥»¥Ã¥È
527        $sql = $base_sql . "VALUES ($data);\n";
528        $err = $objQuery->query($sql);
529
530        $objQuery->getlastquery();
531        // ¥¨¥é¡¼¤¬¤¢¤ì¤Ð½ªÎ»
532        if ($err->message != ""){
533            $objQuery->getlastquery();
534            return false;
535        }
536       
537        if ($pagelayout_flg) {
538            // dtb_pagelayout¤Î¾ì¹ç¤Ë¤ÏºÇ½é¤Î¥Ç¡¼¥¿¤Ïpage_id = 0¤Ë¤¹¤ë
539            $sql = "UPDATE dtb_pagelayout SET page_id = 0";
540            $objQuery->query($sql);
541            $pagelayout_flg = false;
542        }
543       
544    }
545    return $ret;
546}
547
548// ¼«Æ°ºÎÈÖ¤ò¥»¥Ã¥È
549function lfSetAutoInc($objQuery, $csv){
550    // csv¥Õ¥¡¥¤¥ë¤«¤é¥Ç¡¼¥¿¤Î¼èÆÀ
551    $arrCsvData = file($csv);
552
553    foreach($arrCsvData as $key => $val){
554        $arrData = split(",", trim($val));
555        $objQuery->setval($arrData[0], $arrData[1], $arrData[2]);
556    }
557}
558
559// DB¤òÁ´¤Æ¥¯¥ê¥¢¤¹¤ë
560function lfDeleteAll($objQuery){
561    $ret = true;
562
563    $arrTableList = lfGetTableList();
564   
565    foreach($arrTableList as $key => $val){
566        // ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Æ¡¼¥Ö¥ë¤Ïºï½ü¤·¤Ê¤¤
567        if ($val != "dtb_bkup") {
568            $trun_sql = "DELETE FROM $val;";
569            $ret = $objQuery->query($trun_sql);
570           
571            if (!$ret) return $ret;
572        }
573    }
574   
575    return $ret;
576}
577
578// ¥Ð¥Ã¥¯¥¢¥Ã¥×¥Æ¡¼¥Ö¥ë¤òºîÀ®¤¹¤ë
579function lfCreateBkupTable(){
580    $objQuery = new SC_Query();
581   
582    // ¥Æ¡¼¥Ö¥ë¤Î¸ºß¥Á¥§¥Ã¥¯
583    $arrTableList = lfGetTableList();
584   
585    if(!in_array("dtb_bkup", $arrTableList)){
586        // ¸ºß¤·¤Æ¤¤¤Ê¤±¤ì¤ÐºîÀ®
587        $cre_sql = "
588            create table dtb_bkup
589            (
590                bkup_name   text,
591                bkup_memo   text,
592                create_date timestamp
593            );
594        ";
595       
596        $objQuery->query($cre_sql);
597    }
598}
599
600?>
Note: See TracBrowser for help on using the repository browser.