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

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