source: branches/version-2/data/class/pages/admin/contents/LC_Page_Admin_Contents_Campaign.php @ 17494

Revision 17494, 18.8 KB checked in by adachi, 16 years ago (diff)

merge r17277 (yammy) #283 キャンペーン管理でディレクトリの書き込み権限チェックがされていない不具合の修正

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id Revision Date
  • Property svn:mime-type set to text/x-httpd-php
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24// {{{ requires
25require_once(CLASS_PATH . "pages/LC_Page.php");
26require_once(CLASS_EX_PATH . "helper_extends/SC_Helper_CSV_Ex.php");
27require_once(CLASS_EX_PATH . "helper_extends/SC_Helper_FileManager_Ex.php");
28
29/**
30 * キャンペーン管理 のページクラス.
31 *
32 * @package Page
33 * @author LOCKON CO.,LTD.
34 * @version $Id$
35 */
36class LC_Page_Admin_Contents_Campaign extends LC_Page {
37
38    // }}}
39    // {{{ functions
40
41    /**
42     * Page を初期化する.
43     *
44     * @return void
45     */
46    function init() {
47        parent::init();
48        $this->tpl_mainpage = 'contents/campaign.tpl';
49        $this->tpl_subnavi = 'contents/subnavi.tpl';
50        $this->tpl_subno = "campaign";
51        $this->tpl_mainno = 'contents';
52        $this->tpl_subtitle = 'キャンペーン管理';
53        // カートに商品が入っているにチェックが入っているかチェック
54        $this->tpl_onload = "fnIsCartOn();";
55    }
56
57    /**
58     * Page のプロセス.
59     *
60     * @return void
61     */
62    function process() {
63        //---- 認証可否の判定
64        $objSess = new SC_Session();
65        SC_Utils_Ex::sfIsSuccess($objSess);
66
67        $objView = new SC_AdminView();
68        $objQuery = new SC_Query();
69        $objFormParam = new SC_FormParam();
70        $objCSV = new SC_Helper_CSV_Ex();
71
72        // パラメータ情報の初期化
73        $this->lfInitParam($objFormParam);
74        // フォームの値をセット
75        $objFormParam->setParam($_POST);
76
77        // 編集処理の場合は状態を保持
78        $this->is_update = isset($_POST['is_update']) ? $_POST['is_update'] : "";
79
80        // フォームの値をテンプレートへ渡す
81        $this->arrForm = $objFormParam->getHashArray();
82        $campaign_id = isset($_POST['campaign_id']) ? $_POST['campaign_id'] : "";
83
84        if (!isset($_POST['mode'])) $_POST['mode'] = "";
85
86        switch($_POST['mode']) {
87            // 新規登録/編集登録
88        case 'regist':
89            // エラーチェック
90            $this->arrErr = $this->lfErrorCheck($campaign_id, $objQuery, $objFormParam);
91
92            if(count($this->arrErr) <= 0) {
93                // 登録
94                $this->lfRegistCampaign($campaign_id, $objQuery, $objFormParam);
95
96                // キャンペーンTOPへリダイレクト
97                $this->sendRedirect($this->getLocation(URL_CAMPAIGN_TOP));
98            }
99
100            break;
101            // 編集押下時
102        case 'update':
103            // キャンペーン情報を取得
104            $this->arrForm = $this->lfGetCampaign($campaign_id, &$objQuery);
105            $this->is_update = true;
106            break;
107            // 削除押下時
108        case 'delete':
109            // 削除
110            $this->lfDeleteCampaign($campaign_id, &$objQuery);
111            // キャンペーンTOPへリダイレクト
112            $this->sendRedirect($this->getLocation(URL_CAMPAIGN_TOP));
113            break;
114            // CSV出力
115        case 'csv':
116            // オプションの指定
117            $option = "ORDER BY create_date DESC";
118
119            // CSV出力タイトル行の作成
120            $arrCsvOutput = SC_Utils_Ex::sfSwapArray($objCSV->sfgetCsvOutput(4, " WHERE csv_id = 4 AND status = 1"));
121
122            if (count($arrCsvOutput) <= 0) break;
123
124            $arrCsvOutputCols = $arrCsvOutput['col'];
125            $arrCsvOutputTitle = $arrCsvOutput['disp_name'];
126            $head = SC_Utils_Ex::sfGetCSVList($arrCsvOutputTitle);
127            $data = $objCSV->lfGetCSV("dtb_campaign_order", "campaign_id = ?", $option, array($campaign_id), $arrCsvOutputCols);
128
129            // CSVを送信する。
130            SC_Utils_Ex::sfCSVDownload($head.$data);
131            exit;
132            break;
133        default:
134            break;
135        }
136
137        // キャンペーン一覧取得
138        $this->arrCampaign = $this->lfGetCampaignList($objQuery);
139        $this->campaign_id = $campaign_id;
140
141        // キャンペーン期間用
142        $objDate = new SC_Date();
143        $this->arrYear = $objDate->getYear();
144        $this->arrMonth = $objDate->getMonth();
145        $this->arrDay = $objDate->getDay();
146        $this->arrHour = $objDate->getHour();
147        $this->arrMinutes = $objDate->getMinutes();
148
149        //---- ページ表示
150        $objView->assignobj($this);
151        $objView->display(MAIN_FRAME);
152    }
153
154    /**
155     * デストラクタ.
156     *
157     * @return void
158     */
159    function destroy() {
160        parent::destroy();
161    }
162
163    /**
164     * 入力情報の初期化
165     */
166    function lfInitParam(&$objFormParam) {
167
168        $objFormParam->addParam("キャンペーン名", "campaign_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
169
170        $objFormParam->addParam("開始日時", "start_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
171        $objFormParam->addParam("開始日時", "start_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
172        $objFormParam->addParam("開始日時", "start_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
173        $objFormParam->addParam("開始日時", "start_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
174        $objFormParam->addParam("開始日時", "start_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
175
176        $objFormParam->addParam("停止日時", "end_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
177        $objFormParam->addParam("停止日時", "end_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
178        $objFormParam->addParam("停止日時", "end_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
179        $objFormParam->addParam("停止日時", "end_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
180        $objFormParam->addParam("停止日時", "end_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
181
182        $objFormParam->addParam("ディレクトリ名", "directory_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","ALNUM_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
183        $objFormParam->addParam("申込数制御", "limit_count", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
184        $objFormParam->addParam("重複申込制御", "orverlapping_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
185        $objFormParam->addParam("カートに商品を入れる", "cart_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
186        $objFormParam->addParam("送料無料設定", "deliv_free_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
187
188    }
189
190    /*
191     * 関数名:lfErrorCheck()
192     * 引数1 :キャンペーンID
193     * 説明 :エラーチェック
194     * 戻り値:エラー文字格納配列
195     */
196    function lfErrorCheck($campaign_id = "", &$objQuery, &$objFormParam) {
197
198        $arrList = $objFormParam->getHashArray();
199        $objErr = new SC_CheckError($arrList);
200        $objErr->arrErr = $objFormParam->checkError();
201
202        $objErr->doFunc(array("開始日時", "start_year", "start_month", "start_day", "start_hour", "start_minute", "0"), array("CHECK_DATE2"));
203        $objErr->doFunc(array("停止日時", "end_year", "end_month", "end_day", "end_hour", "end_minute", "0"), array("CHECK_DATE2"));
204        $objErr->doFunc(array("開始日時", "停止日時", "start_year", "start_month", "start_day", "start_hour", "start_minute", "00", "end_year", "end_month", "end_day", "end_hour", "end_minute", "59"), array("CHECK_SET_TERM2"));
205
206        if (!is_writable(CAMPAIGN_TEMPLATE_PATH)) {
207            $objErr->arrErr['campaign_template_path'] = "※" . CAMPAIGN_TEMPLATE_PATH . " へ書き込み権限を与えてください。 <br/>";
208        }
209        if (!is_writable(CAMPAIGN_PATH)) {
210            $objErr->arrErr['campaign_path'] = "※" . CAMPAIGN_PATH . " へ書き込み権限を与えてください。<br/>";
211        }
212
213        if(count($objErr->arrErr) <= 0) {
214
215            // 編集時用に元のディレクトリ名を取得する。
216            if($campaign_id != "") {
217                $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
218            } else {
219                $directory_name = "";
220            }
221
222            // 同名のフォルダが存在する場合はエラー
223            if(file_exists(CAMPAIGN_TEMPLATE_PATH.$arrList['directory_name']) && $directory_name != $arrList['directory_name']) {
224                $objErr->arrErr['directory_name'] = "※ 同名のディレクトリがすでに存在します。<br/>";
225            }
226            $ret = $objQuery->get("dtb_campaign", "directory_name", "directory_name = ? AND del_flg = 0", array($arrList['directory_name']));
227            // DBにすでに登録されていないかチェック
228            if($ret != "" && $directory_name != $arrList['directory_name']) {
229                $objErr->arrErr['directory_name'] = "※ すでに登録されているディレクトリ名です。<br/>";
230            }
231        }
232
233        return $objErr->arrErr;
234    }
235
236    /*
237     * 関数名:lfRegistCampaign()
238     * 引数1 :キャンペーンID(アップデート時に指定)
239     * 説明 :キャンペーン登録/更新
240     * 戻り値:無し
241     */
242    function lfRegistCampaign($campaign_id = "", &$objQuery, &$objFormParam) {
243
244        $objSiteInfo = new SC_SiteInfo();
245        $arrInfo = $objSiteInfo->data;
246        $arrList = $objFormParam->getHashArray();
247
248        // 開始日時・終了日時整形
249        $start_date = $arrList['start_year']."-".sprintf("%02d", $arrList['start_month'])."-".sprintf("%02d", $arrList['start_day'])." ".sprintf("%02d", $arrList['start_hour']).":".sprintf("%02d", $arrList['start_minute']).":00";
250        $end_date = $arrList['end_year']."-".sprintf("%02d", $arrList['end_month'])."-".sprintf("%02d", $arrList['end_day'])." ".sprintf("%02d", $arrList['end_hour']).":".sprintf("%02d", $arrList['end_minute']).":00";
251
252        // ポイントレートは設定されていなければ0を挿入
253        if($arrInfo['point_rate'] == "") $arrInfo['point_rate'] = "0";
254        // フラグは設定されていなければ0を挿入
255        if(!$arrList['limit_count']) $arrList['limit_count'] = "0";
256        if(!$arrList['orverlapping_flg']) $arrList['orverlapping_flg'] = "0";
257        if(!$arrList['cart_flg']) $arrList['cart_flg'] = "0";
258        if(!$arrList['deliv_free_flg']) $arrList['deliv_free_flg'] = "0";
259
260        $sqlval['campaign_name'] = $arrList['campaign_name'];
261        $sqlval['campaign_point_rate'] = $arrInfo['point_rate'];
262        $sqlval['start_date'] = $start_date;
263        $sqlval['end_date'] = $end_date;
264        $sqlval['directory_name'] = $arrList['directory_name'];
265        $sqlval['limit_count'] = $arrList['limit_count'];
266        $sqlval['orverlapping_flg'] = $arrList['orverlapping_flg'];
267        $sqlval['cart_flg'] = $arrList['cart_flg'];
268        $sqlval['deliv_free_flg'] = $arrList['deliv_free_flg'];
269        $sqlval['update_date'] = "now()";
270
271        // キャンペーンIDで指定されている場合はupdate
272        if($campaign_id != "") {
273
274            // 元のディレクトリ名を取得名
275            $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
276            // ファイル名を変更
277            @rename(CAMPAIGN_TEMPLATE_PATH . $directory_name , CAMPAIGN_TEMPLATE_PATH . $arrList['directory_name']);
278            @rename(CAMPAIGN_PATH . $directory_name , CAMPAIGN_PATH . $arrList['directory_name']);
279
280            // update
281            $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
282
283        } else {
284
285            // キャンペーンページディレクトリ作成
286            $this->lfCreateTemplate(CAMPAIGN_TEMPLATE_PATH, $arrList['directory_name'], $objFormParam);
287
288            $sqlval['create_date'] = "now()";
289            // insert
290            $objQuery->insert("dtb_campaign", $sqlval);
291        }
292    }
293
294    /*
295     * 関数名:lfGetCampaignList()
296     * 説明 :キャンペーン一覧を取得
297     * 戻り値:キャンペーン一覧配列
298     */
299    function lfGetCampaignList(&$objQuery) {
300
301        $col = "campaign_id,campaign_name,directory_name,total_count";
302        $objQuery->setorder("update_date DESC");
303        $arrRet = $objQuery->select($col, "dtb_campaign", "del_flg = 0");
304
305        return $arrRet;
306    }
307
308    /*
309     * 関数名:lfGetCampaign()
310     * 引数1 :キャンペーンID
311     * 説明 :キャンペーン情報取得
312     * 戻り値:キャンペーン情報配列
313     */
314    function lfGetCampaign($campaign_id, &$objQuery) {
315
316        $col = "campaign_id,campaign_name,start_date,end_date,directory_name,limit_count,orverlapping_flg,cart_flg,deliv_free_flg";
317        $arrRet = $objQuery->select($col, "dtb_campaign", "campaign_id = ?", array($campaign_id));
318
319        // 開始日時・停止日時を分解
320        $start_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['start_date'])));
321        list($arrRet[0]['start_year'],$arrRet[0]['start_month'],$arrRet[0]['start_day'],$arrRet[0]['start_hour'], $arrRet[0]['start_minute'], $arrRet[0]['start_second']) = split("/", $start_date);
322        $end_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['end_date'])));
323        list($arrRet[0]['end_year'],$arrRet[0]['end_month'],$arrRet[0]['end_day'],$arrRet[0]['end_hour'], $arrRet[0]['end_minute'], $arrRet[0]['end_second']) = split("/", $end_date);
324
325        return $arrRet[0];
326    }
327
328    /*
329     * 関数名:lfDeleteCampaign()
330     * 引数1 :キャンペーンID
331     * 説明 :キャンペーン削除
332     * 戻り値:無し
333     */
334    function lfDeleteCampaign($campaign_id, &$objQuery) {
335        $objFileManager = new SC_Helper_FileManager_Ex();
336
337        // ディレクトリ名を取得名
338        $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
339        // ファイルを削除
340        $objFileManager->sfDeleteDir(CAMPAIGN_TEMPLATE_PATH . $directory_name);
341        $objFileManager->sfDeleteDir(CAMPAIGN_PATH . $directory_name);
342
343        $sqlval['del_flg'] = 1;
344        $sqlval['update_date'] = "now()";
345        // delete
346        $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
347    }
348
349    /*
350     * 関数名:lfCreateTemplate()
351     * 引数1 :ディレクトリパス
352     * 引数2 :作成ファイル名
353     * 説明 :キャンペーンの初期テンプレート作成
354     * 戻り値:無し
355     */
356    function lfCreateTemplate($dir, $file, &$objFormParam) {
357
358        $objFileManager = new SC_Helper_FileManager_Ex();
359        $arrRet = $objFormParam->getHashArray();
360
361
362        // 作成ファイルディレクトリ
363        $create_dir = $dir . $file;
364        $create_active_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
365        $create_end_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_END;
366        // デフォルトファイルディレクトリ
367        $default_dir = TEMPLATE_DIR . CAMPAIGN_TEMPLATE_DIR;
368        $default_active_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
369        $default_end_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_END;
370
371        $ret = $objFileManager->sfCreateFile($create_dir, 0755);
372        $ret = $objFileManager->sfCreateFile($create_active_dir, 0755);
373        $ret = $objFileManager->sfCreateFile($create_end_dir, 0755);
374
375        // キャンペーン実行PHPをコピー
376        $ret = $objFileManager->sfCreateFile(CAMPAIGN_PATH . $file);
377        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "index.php", CAMPAIGN_PATH . $file . "/index.php");
378        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "application.php", CAMPAIGN_PATH . $file . "/application.php");
379        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "complete.php", CAMPAIGN_PATH . $file . "/complete.php");
380        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "entry.php", CAMPAIGN_PATH . $file . "/entry.php");
381
382        // デフォルトテンプレート作成(キャンペーン中)
383        $header = $this->lfGetFileContents($default_active_dir."header.tpl");
384        SC_Utils_Ex::sfWriteFile($header, $create_active_dir."header.tpl", "w");
385        $contents = $this->lfGetFileContents($default_active_dir."contents.tpl");
386        if(!$arrRet['cart_flg']) {
387            $contents .= "\n" . '<!--{*ログインフォーム*}-->' . "\n";
388            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "login.tpl");
389            $contents .= '<!--{*会員登録フォーム*}-->'."\n";
390            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "entry.tpl");
391        }
392        SC_Utils_Ex::sfWriteFile($contents, $create_active_dir."contents.tpl", "w");
393        $footer = $this->lfGetFileContents($default_active_dir."footer.tpl");
394        SC_Utils_Ex::sfWriteFile($footer, $create_active_dir."footer.tpl", "w");
395
396        // サイトフレーム作成
397        $site_frame  = $header."\n";
398        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/navi.js"></script>'."\n";
399        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/site.js"></script>'."\n";
400        $site_frame .= '<!--{include file=$tpl_mainpage}-->'."\n";
401        $site_frame .= $footer."\n";
402        SC_Utils_Ex::sfWriteFile($site_frame, $create_active_dir."site_frame.tpl", "w");
403
404        /* デフォルトテンプレート作成(キャンペーン終了) */
405        $header = $this->lfGetFileContents($default_end_dir."header.tpl");
406        SC_Utils_Ex::sfWriteFile($header, $create_end_dir."header.tpl", "w");
407        $contents = $this->lfGetFileContents($default_end_dir."contents.tpl");
408        SC_Utils_Ex::sfWriteFile($contents, $create_end_dir."contents.tpl", "w");
409        $footer = $this->lfGetFileContents($default_end_dir."footer.tpl");
410        SC_Utils_Ex::sfWriteFile($footer, $create_end_dir."footer.tpl", "w");
411    }
412
413    /*
414     * 関数名:lfGetFileContents()
415     * 引数1 :ファイルパス
416     * 説明 :ファイル読込
417     * 戻り値:無し
418     */
419    function lfGetFileContents($read_file) {
420
421        if(file_exists($read_file)) {
422            $contents = file_get_contents($read_file);
423        } else {
424            $contents = "";
425        }
426
427        return $contents;
428    }
429}
430?>
Note: See TracBrowser for help on using the repository browser.