source: branches/feature-module-paygent/data/downloads/module/mdl_paygent/mdl_paygent.php @ 15162

Revision 15162, 10.5 KB checked in by naka, 17 years ago (diff)

ペイジェント決済モジュール

Line 
1<?php
2/**
3 *
4 * @copyright   2000-2007 LOCKON CO.,LTD. All Rights Reserved.
5 * @version CVS: $Id: mdl_epsilon.php 1.2 2006-12-04 06:08:28Z kakinaka $
6 * @link        http://www.lockon.co.jp/
7 *
8 */
9require_once(MODULE_PATH . "mdl_paygent/mdl_paygent.inc");
10
11$arrPayment = array(
12    1 => '¥¯¥ì¥¸¥Ã¥È',
13    2 => '¥³¥ó¥Ó¥Ë',
14    3 => 'ATM·èºÑ',
15    4 => '¶ä¹Ô¥Í¥Ã¥È'
16);
17
18$arrCredit = array(
19    1 => 'VISA, MASTER, Diners',
20    2 => 'JCB, AMEX'
21);
22
23//¥Ú¡¼¥¸´ÉÍý¥¯¥é¥¹
24class LC_Page {
25    //¥³¥ó¥¹¥È¥é¥¯¥¿
26    function LC_Page() {
27        //¥á¥¤¥ó¥Æ¥ó¥×¥ì¡¼¥È¤Î»ØÄê
28        $this->tpl_mainpage = MODULE_PATH . 'mdl_paygent/mdl_paygent.tpl';
29        $this->tpl_subtitle = '¥Ú¥¤¥¸¥§¥ó¥È·èºÑ¥â¥¸¥å¡¼¥ë';
30        global $arrPayment;
31        $this->arrPayment = $arrPayment;
32        global $arrCredit;
33        $this->arrCredit = $arrCredit;
34        global $arrConvenience;
35        $this->arrConvenience = $arrConvenience;
36    }
37}
38$objPage = new LC_Page();
39$objView = new SC_AdminView();
40$objQuery = new SC_Query();
41
42// ¥³¥ó¥Ó¥ËÆþ¶â¥Á¥§¥Ã¥¯
43lfEpsilonCheck();
44
45// ǧ¾Ú³Îǧ
46$objSess = new SC_Session();
47sfIsSuccess($objSess);
48
49// ¥Ñ¥é¥á¡¼¥¿´ÉÍý¥¯¥é¥¹
50$objFormParam = new SC_FormParam();
51$objFormParam = lfInitParam($objFormParam);
52// POSTÃͤμèÆÀ
53$objFormParam->setParam($_POST);
54
55// ÈÆÍѹàÌܤòÄɲÃ(ɬ¿Ü¡ª¡ª)
56sfAlterMemo();
57
58switch($_POST['mode']) {
59case 'edit':
60    // ÆþÎÏ¥¨¥é¡¼È½Äê
61    $objPage->arrErr = lfCheckError();
62
63    // ¥¨¥é¡¼¤Ê¤·¤Î¾ì¹ç¤Ë¤Ï¥Ç¡¼¥¿¤ò¹¹¿·
64    if(count($objPage->arrErr) == 0) {
65        // ¥Ç¡¼¥¿¹¹¿·
66        lfUpdPaymentDB(MDL_PAYGENT_ID);
67       
68        // javascript¼Â¹Ô
69        $objPage->tpl_onload = 'alert("ÅÐÏ¿´°Î»¤·¤Þ¤·¤¿¡£\n´ðËܾðÊó¡ä»ÙʧÊýË¡ÀßÄê¤è¤ê¾ÜºÙÀßÄê¤ò¤·¤Æ¤¯¤À¤µ¤¤¡£"); window.close();';
70    }
71    break;
72case 'module_del':
73    // ÈÆÍѹàÌܤθºß¥Á¥§¥Ã¥¯
74    if(sfColumnExists("dtb_payment", "memo01")){
75        // ¥Ç¡¼¥¿¤Îºï½ü¥Õ¥é¥°¤ò¤¿¤Æ¤ë
76        $objQuery->query("UPDATE dtb_payment SET del_flg = 1 WHERE module_id = ?", array(MDL_EPSILON_ID));
77    }
78    break;
79default:
80    // ¥Ç¡¼¥¿¤Î¥í¡¼¥É
81    lfLoadData();   
82    break;
83}
84
85$objPage->arrForm = $objFormParam->getFormParamList();
86
87$objView->assignobj($objPage);                  //ÊÑ¿ô¤ò¥Æ¥ó¥×¥ì¡¼¥È¤Ë¥¢¥µ¥¤¥ó¤¹¤ë
88$objView->display($objPage->tpl_mainpage);      //¥Æ¥ó¥×¥ì¡¼¥È¤Î½ÐÎÏ
89//-------------------------------------------------------------------------------------------------------
90/* ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½ */
91function lfInitParam($objFormParam) {
92    $objFormParam->addParam("·ÀÌ󥳡¼¥É", "code", INT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
93    $objFormParam->addParam("ÀܳÀèURL", "url", URL_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "URL_CHECK"));
94    $objFormParam->addParam("ÍøÍÑ·èºÑ", "payment", "", "", array("EXIST_CHECK"));
95    $objFormParam->addParam("ÍøÍÑ¥¯¥ì¥¸¥Ã¥È", "credit");   
96    $objFormParam->addParam("ÍøÍÑ¥³¥ó¥Ó¥Ë", "convenience");
97    return $objFormParam;
98}
99
100// ¥¨¥é¡¼¥Á¥§¥Ã¥¯¤ò¹Ô¤¦
101function lfCheckError(){
102    global $objFormParam;
103   
104    $arrErr = $objFormParam->checkError();
105   
106    // ÍøÍÑ¥¯¥ì¥¸¥Ã¥È¡¢ÍøÍÑ¥³¥ó¥Ó¥Ë¤Î¥¨¥é¡¼¥Á¥§¥Ã¥¯
107    $arrChkPay = $_POST["payment"];
108    foreach((array)$arrChkPay as $key => $val){
109        // ÍøÍÑ¥¯¥ì¥¸¥Ã¥È
110        if($val == 1 and count($_POST["credit"]) <= 0){
111            $arrErr["credit"] = "ÍøÍÑ¥¯¥ì¥¸¥Ã¥È¤¬ÁªÂò¤µ¤ì¤Æ¤¤¤Þ¤»¤ó¡£<br />";
112        }
113        // ÍøÍÑ¥³¥ó¥Ó¥Ë
114        if($val == 2 and count($_POST["convenience"]) <= 0){
115            $arrErr["convenience"] = "ÍøÍÑ¥³¥ó¥Ó¥Ë¤¬ÁªÂò¤µ¤ì¤Æ¤¤¤Þ¤»¤ó¡£<br />";
116        }
117    }
118
119    // sslÂбþȽÄê
120    if(!extension_loaded('openssl') and ereg( "^https://", $_POST["url"] )){
121        $arrErr["url"] = "¤³¤Î¥µ¡¼¥Ð¡¼¤ÏSSL¤ËÂбþ¤·¤Æ¤¤¤Þ¤»¤ó¡£<br>http¤ÇÀܳ¤·¤Æ¤¯¤À¤µ¤¤¡£";
122    }
123
124    // Àܳ¥Á¥§¥Ã¥¯¤ò¹Ô¤¦
125    if(count($arrErr) == 0) $arrErr = lfChkConnect();
126
127    return $arrErr;
128}
129
130// Àܳ¥Á¥§¥Ã¥¯¤ò¹Ô¤¦
131function lfChkConnect(){
132    global $objQuery;
133    global $objPage;
134   
135    $arrRet = array();
136   
137    // ¥á¡¼¥ë¥¢¥É¥ì¥¹¼èÆÀ
138    $email = $objQuery->getone("SELECT email03 FROM dtb_baseinfo");
139
140    // ·ÀÌ󥳡¼¥É   
141    (in_array(1, (array)$_POST["payment"])) ? $cre = "1" : $cre = "0";
142    (in_array(2, (array)$_POST["payment"])) ? $con = "1" : $con = "0";
143    $st_code = $cre . "0" . $con . "00-0000-00000";
144   
145    // Á÷¿®¥Ç¡¼¥¿À¸À®
146    $arrSendData = array(
147        'contract_code' => $_POST["code"],      // ·ÀÌ󥳡¼¥É
148        'user_id' => "connect_test",            // ¥æ¡¼¥¶ID
149        'user_name' => "Àܳ¥Æ¥¹¥È",            // ¥æ¡¼¥¶Ì¾
150        'user_mail_add' => $email,              // ¥á¡¼¥ë¥¢¥É¥ì¥¹
151        'st_code' => $st_code,                  // ·èºÑ¶èʬ
152        'process_code' => '3',                  // ½èÍý¶èʬ(¸ÇÄê)
153        'xml' => '1',                           // ±þÅú·Á¼°(¸ÇÄê)
154    );
155    return $arrRet;
156}
157
158// ÅÐÏ¿¥Ç¡¼¥¿¤òÆɤ߹þ¤à
159function lfLoadData(){
160    global $objFormParam;
161   
162    //¥Ç¡¼¥¿¤ò¼èÆÀ
163    $arrRet = lfGetPaymentDB(MDL_PAYGENT_ID, "AND del_flg = '0'");
164   
165    // Ãͤò¥»¥Ã¥È
166    $objFormParam->setParam($arrRet[0]);
167
168    // ²èÌÌɽ¼¨ÍѤ˥ǡ¼¥¿¤òÊÑ´¹
169    $arrDisp = array();
170    foreach($arrRet as $key => $val){
171        // ÍøÍÑ·èºÑ¤òɽ¼¨ÍѤËÊÑ´¹
172        $arrDisp["payment"][$key] = $val["payment"];
173       
174        // ¥¯¥ì¥¸¥Ã¥È¤Î·èºÑ¶èʬ¤ò¼èÆÀ
175        if($val["payment"] == 1) $credit = $val["payment_code"];
176       
177        // ¥³¥ó¥Ó¥Ë
178        if($val["payment"] == 2) $arrDisp["convenience"] = $val["convenience"];
179    }
180    $objFormParam->setParam($arrDisp);
181    $objFormParam->splitParamCheckBoxes("convenience");
182   
183    // ¥¯¥ì¥¸¥Ã¥È
184    if(substr($credit, 0, 1)) $arrCredit["credit"][] = 1;
185    if(substr($credit, 1, 1)) $arrCredit["credit"][] = 2;
186    $objFormParam->setParam($arrCredit);
187}
188
189// DB¤«¤é¥Ç¡¼¥¿¤ò¼èÆÀ¤¹¤ë
190function lfGetPaymentDB($module_id, $where, $arrWhereVal = array()){
191    global $objQuery;
192   
193    $arrVal = array($module_id);
194    $arrVal = array_merge($arrVal, $arrWhereVal);
195   
196    $arrRet = array();
197    $sql = "SELECT
198                module_id,
199                memo01 as code,
200                memo02 as url,
201                memo03 as payment,
202                memo04 as payment_code,
203                memo05 as convenience
204            FROM dtb_payment WHERE module_id = ? " . $where;
205    $arrRet = $objQuery->getall($sql, $arrVal);
206
207    return $arrRet;
208}
209
210
211// ¥Ç¡¼¥¿¤Î¹¹¿·½èÍý
212function lfUpdPaymentDB($module_id){
213    global $objQuery;
214    global $objSess;
215   
216    // ÍøÍÑ¥³¥ó¥Ó¥Ë¤Ë¥Á¥§¥Ã¥¯¤¬Æþ¤Ã¤Æ¤¤¤ë¾ì¹ç¤Ë¤Ï¡¢¥Ï¥¤¥Õ¥ó¶èÀÚ¤ê¤ËÊÔ½¸¤¹¤ë
217    $convCnt = count($_POST["convenience"]);
218    if($convCnt > 0){
219        $convenience = $_POST["convenience"][0];
220        for($i = 1 ; $i < $convCnt ; $i++){
221            $convenience .= "-" . $_POST["convenience"][$i];
222        }
223    }
224       
225    // del_flg¤òºï½ü¤Ë¤·¤Æ¤ª¤¯
226    $del_sql = "UPDATE dtb_payment SET del_flg = 1 WHERE module_id = ? ";
227    $arrDel = array($module_id);
228    $objQuery->query($del_sql, $arrDel);
229   
230    // ¥Ç¡¼¥¿ÅÐÏ¿
231    foreach($_POST["payment"] as $key => $val){
232        // ¥é¥ó¥¯¤ÎºÇÂçÃͤò¼èÆÀ¤¹¤ë
233        $max_rank = $objQuery->getone("SELECT max(rank) FROM dtb_payment");
234
235        // »ÙʧÊýË¡¥Ç¡¼¥¿¤ò¼èÆÀ         
236        $arrPaymentData = lfGetPaymentDB(MDL_PAYGENT_ID, "AND memo03 = ?", array($val));
237       
238        // ¥¯¥ì¥¸¥Ã¥È¤Ë¥Á¥§¥Ã¥¯¤¬Æþ¤Ã¤Æ¤¤¤ì¤Ð¥¯¥ì¥¸¥Ã¥È¤òÅÐÏ¿¤¹¤ë
239        if($val == 1){
240            (in_array(1, $_POST["credit"])) ? $visa = "1" : $visa = "0";
241            (in_array(2, $_POST["credit"])) ? $jcb = "1" : $jcb = "0";
242            $arrData = array(           
243                "payment_method" => "PAYGENT¥¯¥ì¥¸¥Ã¥È"
244                ,"fix" => 3
245                ,"creator_id" => $objSess->member_id
246                ,"create_date" => "now()"
247                ,"update_date" => "now()"
248                ,"upper_rule" => 500000
249                ,"module_id" => $module_id
250                ,"module_path" => MODULE_PATH . "mdl_paygent/paygent_credit.php"
251                ,"memo01" => $_POST["code"]
252                ,"memo02" => $_POST["url"]
253                ,"memo03" => $val
254                ,"memo04" => $visa . $jcb . "000-0000-00000"
255                ,"del_flg" => "0"
256                ,"charge_flg" => "2"
257                ,"upper_rule_max" => CHARGE_MAX
258               
259            );
260        }
261       
262        // ¥³¥ó¥Ó¥Ë¤Ë¥Á¥§¥Ã¥¯¤¬Æþ¤Ã¤Æ¤¤¤ì¤Ð¥³¥ó¥Ó¥Ë¤òÅÐÏ¿¤¹¤ë
263        if($val == 2){
264           
265            // ¥»¥Ö¥ó¥¤¥ì¥Ö¥ó¤Î¤ßÁªÂò¤·¤¿¾ì¹ç¤Ë¤ÏÍøÍѾå¸Â¤ò30Ëü¤Ë¤¹¤ë¡£
266            if(count($_POST["convenience"]) == 1 and $_POST["convenience"][0] == 11) {
267                $upper_rule_max = SEVEN_CHARGE_MAX;
268                ($arrPaymentData["upper_rule"] > $upper_rule_max or $arrPaymentData["upper_rule"] == "") ? $upper_rule = $upper_rule_max : $upper_rule = $arrPaymentData["upper_rule"];
269            }else{
270                $upper_rule_max = CHARGE_MAX;
271                $upper_rule = $upper_rule_max;
272            }
273           
274            $arrData = array(
275                "payment_method" => "PAYGENT¥³¥ó¥Ó¥Ë"
276                ,"fix" => 3
277                ,"creator_id" => $objSess->member_id
278                ,"create_date" => "now()"
279                ,"update_date" => "now()"
280                ,"upper_rule" => $upper_rule
281                ,"module_id" => $module_id
282                ,"module_path" => MODULE_PATH . "mdl_paygent/paygent_conveni.php"
283                ,"memo01" => $_POST["code"]
284                ,"memo02" => $_POST["url"]
285                ,"memo03" => $val
286                ,"memo04" => "00100-0000-00000"
287                ,"memo05" => $convenience
288                ,"del_flg" => "0"
289                ,"charge_flg" => "1"
290                ,"upper_rule_max" => $upper_rule_max
291            );
292        }
293       
294        // ATM·èºÑ¤Ë¥Á¥§¥Ã¥¯¤¬Æþ¤Ã¤Æ¤¤¤ì¤ÐATM·èºÑ¤òÅÐÏ¿¤¹¤ë
295        if($val == 3){
296            $arrData = array(
297                "payment_method" => "PAYGENTATM·èºÑ"
298                ,"fix" => 3
299                ,"creator_id" => $objSess->member_id
300                ,"create_date" => "now()"
301                ,"update_date" => "now()"
302                ,"upper_rule" => $upper_rule
303                ,"module_id" => $module_id
304                ,"module_path" => MODULE_PATH . "mdl_paygent/paygent_atm.php"
305                ,"memo01" => $_POST["code"]
306                ,"memo02" => $_POST["url"]
307                ,"memo03" => $val
308                ,"memo04" => "00100-0000-00000"
309                ,"memo05" => $convenience
310                ,"del_flg" => "0"
311                ,"charge_flg" => "1"
312                ,"upper_rule_max" => $upper_rule_max
313            );
314        }
315       
316        // ¶ä¹ÔNET¤Ë¥Á¥§¥Ã¥¯¤¬Æþ¤Ã¤Æ¤¤¤ì¤ÐATM·èºÑ¤òÅÐÏ¿¤¹¤ë
317        if($val == 4){
318            $arrData = array(
319                "payment_method" => "PAYGENT¶ä¹Ô¥Í¥Ã¥È"
320                ,"fix" => 3
321                ,"creator_id" => $objSess->member_id
322                ,"create_date" => "now()"
323                ,"update_date" => "now()"
324                ,"upper_rule" => $upper_rule
325                ,"module_id" => $module_id
326                ,"module_path" => MODULE_PATH . "mdl_paygent/paygent_bank.php"
327                ,"memo01" => $_POST["code"]
328                ,"memo02" => $_POST["url"]
329                ,"memo03" => $val
330                ,"memo04" => "00100-0000-00000"
331                ,"memo05" => $convenience
332                ,"del_flg" => "0"
333                ,"charge_flg" => "1"
334                ,"upper_rule_max" => $upper_rule_max
335            );
336        }
337       
338       
339        // ¥Ç¡¼¥¿¤¬Â¸ºß¤·¤Æ¤¤¤ì¤ÐUPDATE¡¢Ìµ¤±¤ì¤ÐINSERT
340        if(count($arrPaymentData) > 0){
341            $objQuery->update("dtb_payment", $arrData, " module_id = '" . $module_id . "' AND memo03 = '" . $val ."'");
342        }else{
343            $arrData["rank"] = $max_rank + 1;
344            $objQuery->insert("dtb_payment", $arrData);
345        }
346    }
347}
348
349// ¥³¥ó¥Ó¥ËÆþ¶â³Îǧ½èÍý
350function lfEpsilonCheck(){
351    global $objQuery;
352   
353    // trans_code ¤ò»ØÄꤵ¤ì¤Æ¤¤¤Æ³î¤Ä¡¢Æþ¶âºÑ¤ß¤Î¾ì¹ç
354    if($_POST["trans_code"] != "" and $_POST["paid"] == 1 and $_POST["order_number"] != ""){
355        // ¥¹¥Æ¡¼¥¿¥¹¤òÆþ¶âºÑ¤ß¤ËÊѹ¹¤¹¤ë
356        $sql = "UPDATE dtb_order SET status = 6, update_date = now() WHERE order_id = ? AND memo04 = ? ";
357        $objQuery->query($sql, array($_POST["order_number"], $_POST["trans_code"]));
358       
359        // POST¤ÎÆâÍƤòÁ´¤Æ¥í¥°Êݸ
360        $log_path = DATA_PATH . "logs/epsilon.log";
361        gfPrintLog("epsilon conveni start---------------------------------------------------------", $log_path);
362        foreach($_POST as $key => $val){
363            gfPrintLog( "\t" . $key . " => " . $val, $log_path);
364        }
365        gfPrintLog("epsilon conveni end-----------------------------------------------------------", $log_path);
366       
367        //±þÅú·ë²Ì¤òɽ¼¨
368        echo "1";
369    }
370}
371
372?>
Note: See TracBrowser for help on using the repository browser.