array('POST'), 'generics' => array('POST'), 'createuser' => array('POST'), 'homebanners' => array('POST'), 'verifysignuplink' => array('POST'), 'completesignuplink'=> array('POST'), 'createmobileuser' => array('POST'), 'completemobileuser' => array('POST'), 'startresetpasword' => array('POST'), 'stepresetpass' => array('POST'), 'userlogin' => array('POST'), 'authlogin' => array('POST'), 'startjoblist' => array('POST'), 'dashdata' => array('POST'), 'getjobsdata' => array('POST'), 'offerslist' => array('POST'), 'offersresponse' => array('POST'), 'activejoblist' => array('POST'), 'loadprofile' => array('POST'), 'updateprofile'=> array('POST'), 'account' => array('POST'), 'message' => array('POST'), 'pendingjob' => array('POST'), 'paymenthx' => array('POST'), 'purchasehx' => array('POST'), 'couponhx' => array('POST'), 'getjob' => array('POST'), 'mybanklist' => array('POST'), 'countrybanks' => array('POST'), 'sendmoney' => array('POST'), 'sendinterest' => array('POST'), 'sendmoneyfee' => array('POST'), 'getpendingjobs' => array('POST'), 'taskmessage' => array('POST'), 'sendtaskmessage' => array('POST'), 'activejobmsglist' => array('POST'), 'getwallets' => array('POST'), 'sitecontact' => array('POST'), 'signupcountry' => array('POST'), 'userscards' => array('POST'), 'blogdata' => array('POST'), 'blogitem' => array('POST'), 'couponpending' => array('POST'), 'couponredeem' => array('POST'), 'sendinterestmessage' => array('POST'), 'replyinterestmessage' => array('POST'), 'disableaccount' => array('POST'), 'myjobs' => array('POST'), 'recipients' => array('POST'), 'addrecipient' => array('POST'), 'sendreferral' => array('POST'), 'refferhx' => array('POST'), 'accounttypes' => array('POST'), 'jobmanageragree' => array('POST'), 'jobmanagerlist' => array('POST'), 'jobmanageroffers' => array('POST'), 'jobmanageractive' => array('POST'), 'jobmanagercreatejob' => array('POST'), 'jobmanagerupdatejob' => array('POST'), 'jobmanagerdeletejob' => array('POST'), 'activetaskslist' => array('POST'), 'profilepasschange' => array('POST'), 'starttopup' => array('POST'), 'familylist' => array('POST'), 'familyadd' => array('POST'), 'familyupdate' => array('POST'), 'familymanage' => array('POST'), 'pendingjobextend' => array('POST'), 'pendingjobsendtome' => array('POST'), 'pendingjobcancel' => array('POST'), 'assigntask' => array('POST'), 'resources'=> array('POST'), ); $call_backend = true; // sometimes we need to overwite the call to the extenstion API $local_out = []; // use local out to send output when the result is not from the extenstion $ret = -1; /* header("Access-Control-Allow-Origin: *"); header("Access-Control-Allow-Headers", "Cache-Control, Pragma, Origin, Authorization, Content-Type, X-Requested-With"); header("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE, OPTIONS"); //header("Access-Control-Expose-Headers: Access-Control-Allow-Origin"); header('Content-type: application/json'); if ( "OPTIONS" === $_SERVER['REQUEST_METHOD'] ) { die(); } */ header("Access-Control-Allow-Origin: *"); header("Access-Control-Expose-Headers: Access-Control-Allow-Origin"); header("Access-Control-Allow-Headers: Cache-Control, Pragma, Origin, Authorization, Content-Type, X-Requested-With"); header("Access-Control-Allow-Methods: POST, GET, PUT, DELETE, OPTIONS"); header('Content-type: application/json'); if ("OPTIONS" === $_SERVER['REQUEST_METHOD']) { exit(); } $endpoint = strtolower(str_replace('/svs/user/', '', strtok($_SERVER['REQUEST_URI'], '?'))); $id = 0; // update, get & delete actions require ID //if (substr($endpoint, 0, 19) == 'gettransportrequest' || substr($endpoint, 0, 13) == 'updateprofile') { // $endpoint = strtok($endpoint, '/'); // $id = strtok('/'); //} if (!isset($endpoints[$endpoint])) { header('HTTP/1.1 400 Bad Request'); header('Status: 400 Bad Request'); echo "{\"status\":\"Invalid endpoint url WRB\"}"; exit(); } $methods = $endpoints[$endpoint]; if (array_search($_SERVER['REQUEST_METHOD'], $methods) === false) { header('HTTP/1.1 405 Method Not Allowed'); header('Status: 405 Method Not Allowed'); echo "{\"status\":\"Invalid request method\"}"; exit(); } if ($_SERVER["REQUEST_METHOD"] == "POST") { $in = flatten(json_decode(file_get_contents('php://input'), true)); } if ($_SERVER["REQUEST_METHOD"] == "PUT") { parse_str(file_get_contents('php://input'), $in); } if ($_SERVER["REQUEST_METHOD"] == "GET") { $in = $_GET; } $in["loc"] = $_SERVER["REMOTE_ADDR"]; switch ($endpoint) { case 'assigntask': $in["action"] = WRENCHBOARD_JOB_OFFER_SYSTEM; break; case 'pendingjobextend': $in["action"] = WRENCHBOARD_JOB_EXTEND_EXPIRE; break; case 'pendingjobsendtome': $in["action"] = WRENCHBOARD_JOB_RESEND_MESSAGE; break; case 'pendingjobcancel': $in["action"] = WRENCHBOARD_JOB_CANCEL_OFFER; break; case 'familylist': $in["action"] = WRENCHBOARD_FAMILY_LIST; break; case 'activetaskslist': $in["action"] = WRENCHBOARD_JOB_USERACTIVE; break; case 'familyadd': $in["action"] = WRENCHBOARD_FAMILY_ADD; break; case 'familyupdate': $in["action"] = WRENCHBOARD_FAMILY_UPDATE; break; case 'familymanage': $in["action"] = WRENCHBOARD_FAMILY_MANAGE; break; case 'jobmanagercreatejob': $in["action"] = WRENCHBOARD_JOB_CREATEJOB; $in["job_mode"] = ADD_JOB; break; case 'jobmanagerupdatejob': $in["action"] = WRENCHBOARD_JOB_CREATEJOB; $in["job_mode"] = UPDATE_JOB; break; case 'jobmanageractive': $in["action"] = WRENCHBOARD_JOB_ACTIVE; break; case 'jobmanagerdeletejob': $in["action"] = WRENCHBOARD_JOB_DELETEJOB; break; case 'jobmanageroffers': $in["action"] = WRENCHBOARD_JOB_OFFERS; break; case 'stepresetpass': if($in['step']==300){ $in["action"] = WRENCHBOARD_COMPLETE_PASSWORDRESET; } break; case 'starttopup': $in["action"] = WRENCHBOARD_ACCOUNT_PREPARE_TOPUP; break; case 'profilepasschange': $in["action"] = WRENCHBOARD_PROFILE_RESETPASS; break; case 'addrecipient': $in["action"] = WRENCHBOARD_ACCOUNT_ADD_RECIPEINT; break; case 'jobmanageragree': $in["action"] = WRENCHBOARD_JOB_POSTAGREE; break; case 'jobmanagerlist': $in["action"] = WRENCHBOARD_JOB_LISTJOBS; break; case 'homebanners': $in["action"] = WRENCHBOARD_ACCOUNT_HOMEBANNERS ; break; case 'verifysignuplink': $in["action"] = WRENCHBOARD_VERIFY_PENDING_LINK ; break; case 'disableaccount': $in['action'] = WRENCHBOARD_USER_DELETEACC; break; case 'replyinterestmessage': $in["action"] = WRENCHBOARD_JOB_REPLY_QUESTION; break; case 'sendinterestmessage': // $in['offer_code'] = $this->input->get('offer_code'); $in['yourmessage'] = $in["question"]; //$in['member_id'] = $_SESSION['member_id']; // just maing sure $in['msg_type'] = 'JOB'; // $in['action'] = WRENCHBOARD_JOB_SEND_QUESTION; $in["action"] = WRENCHBOARD_JOB_SEND_QUESTION; break; case 'couponredeem': $in["action"] = WRENCHBOARD_COUPON_REDEEM; break; case 'couponpending': $in["action"] = WRENCHBOARD_COUPON_PENDLIST; break; case 'couponhx': $in["action"] = WRENCHBOARD_COUPON_MEMLIST; break; case 'signupcountry': // checi if in cache if not read $local_out = [ 'result'=>'100', 'signup_country'=>[ ['NG', 'Nigeria'], ['US', 'United States'] ] ]; $call_backend = false; break; case 'blogitem': $blogData = getBlogItem(); $local_out = [ 'result'=>'100', 'blog_data'=> $blogData ]; $call_backend = false; break; case 'blogdata': $blogData = getBlogData(); $local_out = [ 'result'=>'100', 'blog_data'=> $blogData ]; $call_backend = false; break; case 'userscards': $in["action"] = WRENCHBOARD_CARDS_GETCARDLIST; $local_out = [ 'result'=>'100', 'result_list'=>[ ['title'=>'This is your coupon', 'description'=>'This is the description of the description', 'card_type'=>'COUPON', 'card_style' =>'card1', 'card_icon' =>'icon1', 'assign_id'=> 0, 'Nigeria'], ['title'=>'A Recommended Story', 'description'=>'This is the description of the description', 'card_type'=>'BLOG', 'card_style' =>'card2', 'card_icon' =>'icon1', 'assign_id'=> 0, 'United States'], ['title'=>'You have a new task sent to you', 'description'=>'This is the description of the description', 'card_type'=>'NEWTASK', 'card_style' =>'card1', 'card_icon' =>'icon1', 'assign_id'=> 0, 'United States'], ['title'=>'You just Earned some token', 'description'=>'This is the description of the description', 'card_type'=>'TOKEN', 'card_style' =>'card2', 'card_icon' =>'icon1', 'assign_id'=> 0, 'United States'] ] ]; // $call_backend = false; break; case 'myjobs': $in["action"] = WRENCHBOARD_ACCOUNT_JOBLIST; break; case 'sitecontact': $local_out = ['result'=>'100','msg'=>'Received']; $call_backend = false; break; case 'generics': case 'apigate': //$in["action"] = WRENCHBOARD_ACCOUNT_LOGIN; break; case 'startjoblist': $in["action"] = WRENCHBOARD_START_JOBLIST; if (!array_key_exists("limit",$in)) $in["limit"] = 10; if (!array_key_exists("page",$in)) $in["page"] = 1; break; case 'createmobileuser': $in["action"] = WRENCHBOARD_CREATE_MOBILEUSER; $in["loc"] = $_SERVER["REMOTE_ADDR"]; $in["news"] = 0; $in["terms"] = 1; $in["mobile"] = "MOBILE"; break; case 'completemobileuser': $in["action"] = WRENCHBOARD_COMPLETE_MOBILEUSER; $in["loc"] = $_SERVER["REMOTE_ADDR"]; break; case 'completesignuplink': $in["action"] = WRENCHBOARD_COMPLETE_MOBILEUSER; $in["loc"] = $_SERVER["REMOTE_ADDR"]; break; case 'startresetpasword': $in["action"] = WRENCHBOARD_RESET_PASSWORD; break; case 'createuser': $in["action"] = WRENCHBOARD_ACCOUNT_PENDING; $in["street1"] = $in["streetaddress"]; $in["zipcode"] = $in["zip"]; $in["country"] = "US"; $in["loc"] = $_SERVER["REMOTE_ADDR"]; $in["mobile"] = "MOBILE"; break; case 'activejoblist': $in["action"] = WRENCHBOARD_MOBILE_ACTIVEJOB; break; case 'message': $in["action"] = WRENCHBOARD_MOBILE_MESSAGE; break; case 'paymenthx': $in["action"] = WRENCHBOARD_MOBILE_PAYMENTHX; break; case 'purchasehx': $in["action"] = WRENCHBOARD_MOBILE_PURCHASEHX; break; case 'getjobsdata': $in["action"] = WRENCHBOARD_ACCOUNT_JOBLIST; break; case 'userlogin': $in["action"] = WRENCHBOARD_ACCOUNT_LOGIN; if (!isset($in["login_mode"])){ $in["login_mode"] = MOBILE_LOGIN; } break; case 'dashdata': $in["action"] = WRENCHBOARD_ACCOUNT_DASHDATA; break; case 'offerslist': $in["action"] = WRENCHBOARD_MOBILE_OFFERSLIST; break; case 'offersresponse': $in["action"] = WRENCHBOARD_MOBILE_OFFERSRESP; break; case 'loadprofile': $in["action"] = WRENCHBOARD_MOBILE_LOADPROFILE; break; case 'updateprofile': $in["action"] = WRENCHBOARD_MOBILE_UPDATEPROFILE; break; case 'account': $in["action"] = WRENCHBOARD_MOBILE_ACCOUNT; break; case 'getpendingjobs': $in["action"] = WRENCHBOARD_ACCOUNT_PENDJOB; break; case 'pendingjob': break; case 'getjob': break; case 'mybanklist':$in["action"] = WRENCHBOARD_USER_GETBANKLIST; break; case 'sendmoney':$in["action"] = WRENCHBOARD_USER_SENDMONEY; $out["internal_return"] = 0; $in["InitiatingChannel"] = 7; $in["InitiatingPaymentMethodCode"] = "CA"; $in["InitiatingCurrencyCode"] = '566'; // 566 - NRN - Naira $in["InitiatingEntityCode"] = "MBA"; $in["transaction_id"] = "T" . rand(120000, 999999); $in["TerminatingPaymentMethodCode"] = "AC"; $in["TerminatingCurrencyCode"] = '566'; // 566 - NRN - Naira $in["TerminatingCountryCode"] = 'NG'; // NG - Nigeria $in["bankid"] = $in["recipientid"]; $in["InitiatingAmount"] = $in["amount"]; $in["TerminatingAmount"] = $in["amount"]; break; case 'sendinterest':$in["action"] = WRENCHBOARD_USER_SENDJOBINT; $out["internal_return"] = 0; break; case 'sendmoneyfee': $in["action"] = WRENCHBOARD_SMONEY_PROCFEE; break; case 'taskmessage': $in["action"] = WRENCHBOARD_MOBILE_TASKMESSAGE; break; case 'sendtaskmessage': $in["action"] = WRENCHBOARD_MOBILE_SENDTASKMESSAGE; break; case 'activejobmsglist': $in["action"] = WRENCHBOARD_CONTRACT_MSGLIST; break; case 'getwallets': $in["action"] = WRENCHBOARD_ACCOUNT_WALLETS; break; case WRENCHBOARD_ACCOUNT_PRICE_COMBO: break ; // 11171); case WRENCHBOARD_ACCOUNT_JOBPOST_DURATION: break ; //11173); case 'recipients': $in["action"] =WRENCHBOARD_ACCOUNT_USER_RECIPEINT; break; // 11175); case 'accounttypes': $in["action"] = WRENCHBOARD_ACCOUNT_ACCOUNT_TYPES; break ; // 11177); case WRENCHBOARD_ACCOUNT_COUNTRY_COMBO: break ; // 11179); case WRENCHBOARD_ACCOUNT_JOB_COUNTRY: break ; // 11181); case 'sendreferral': $in["action"] =WRENCHBOARD_ACCOUNT_SENDREFER; break; case 'refferhx': $in["action"] = WRENCHBOARD_ACCOUNT_REFFERHX; break; case 'countrybanks': $in["action"] =WRENCHBOARD_ACCOUNT_COUNTRY_BANKS; break; } $in["pid"] = 100; //file_put_contents("in_debug.log", $in); // DEBUG $out = array(); if ( $call_backend == true && $in["action"] !='' ){ $ret = $wrenchboard->wrenchboard_api($in, $out); $out['internal_return'] = $ret; // this is reserved array parameter - to be captured and received before you use the out array() } else { $out = $local_out; $out['internal_return'] = 100; // to match the other } header("HTTP/1.1 200 OK"); header("Status: 200 OK"); //$out = array_merge($in, $out); // DEBUG echo json_encode(processOutJson($in, $out)); exit(); function flatten($data, $parentkey = "") { $result = array(); foreach ($data as $key => $val) { if (is_array($val)) { $result = array_merge($result, flatten($val, $parentkey . $key . "_")); } else { $result[$parentkey . $key] = $val; } } return $result; } // vi:ts=2