Пример #1
0
 public static function mercorder($oid, $account, $merc)
 {
     $v = GsonCrypt::verify($merc, $account);
     if (!$v) {
         return array(0, "Unable to verify the account key");
     }
     if ($v != md5(gio::readfile(GsonCrypt::getkey($account)))) {
         return array(0, "Incorrect Key");
     }
     $r = self::status($oid, $account, true);
     return $r;
 }
Пример #2
0
 public static function notification($msg, $account)
 {
     $m = GsonCrypt::verify($msg, $account);
     if (!$m) {
         return array(0, "SRA did not verify bank's message as authentic");
     }
     $m = Gmsg::extract($m);
     if (!$m || !is_array($m)) {
         return array(0, "SRA did not extract bank's message correctly");
     }
     list($id, $req) = each($m);
     $rtime = time();
     $client = Tools::address($req['client']);
     $merchant = Tools::address($req['merchant']);
     $coins = storage::load($client['srakey']);
     $pcoins = $req['coins'];
     $errorcode = 0;
     $amount = 0;
     $least = 0;
     $most = 0;
     $leastcoin = array();
     $mostcoin = array();
     $ecashrejected = array();
     if (mine::checkcoins($pcoins)) {
         foreach ($pcoins as $id => $coin) {
             $pcval = $coin['value'];
             if (!array_key_exists($id, $coins[$pcval])) {
                 $errorcode = $errorcode ? $errorcode : 2;
                 $tmsg = "Already spent eCash detected";
                 $ecids[] = $id;
                 if ($errorcode == 2) {
                     $rejectedecash[] = $id;
                 }
             } else {
                 $secret = GsonCrypt::unseal($coin['secret']);
                 if ($coins[$pcval][$id]['secret'] != $secret) {
                     $errorcode = $errorcode ? $errorcode : 3;
                     $tmsg = "Invalid secret detected";
                     $ecids[] = $id;
                     if ($errorcode == 3) {
                         $rejectedecash[] = $id;
                     }
                 } else {
                     $secrets[$id] = Tools::makesecrets();
                     $pcoins[$id]['secret'] = GsonCrypt::seal($secrets[$id], $merchant['srakey']);
                     $pcoins[$id]['transactioncount'] = intval($pcoins[$id]['transactioncount']) + 1;
                     $amount += $pcoins[$id]['value'];
                     if ($pcoins[$id]['value'] > $most) {
                         $most = $pcoins[$id]['value'];
                         $mostcoin['id'] = $id;
                         $mostcoin['coin'] = $pcoins[$id];
                     }
                     if ($pcoins[$id]['value'] < $least || $least == 0) {
                         $least = $pcoins[$id]['value'];
                         $leastcoin['id'] = $id;
                         $leastcoin['coin'] = $pcoins[$id];
                     }
                     $ecids[] = $id;
                     unset($coins[$pcval][$id]);
                 }
             }
         }
         $ecids = join(", ", array_values($ecids));
     } else {
         $ecids = join(", ", array_keys($pcoins));
         $errorcode = 1;
         $tmsg = "Invalid/Counterfeit eCash detected";
     }
     if (!$errorcode && $amount < $req['amount']) {
         $errorcode = 4;
         $tmsg = sprintf("Additional %d value is required to complete the transaction", $req['amount'] - $amount);
     }
     if (!$errorcode && $amount > $req['amount']) {
         $diff = $amount - $req['amount'];
         $rem = $leastcoin['coin']['value'] - $diff;
         $chg = self::splitvalue($diff, false);
         $dval = self::splitvalue($rem, false);
         if (!$chg || !$dval) {
             $errorcode = 5;
             $tmsg = "SRA Internal Error while splitting tokens.";
         } else {
             $mycoin = storage::load();
             $chgcoins = self::getcoins($chg, $client['srakey'], $secrets, $mycoin);
             $dvalcoins = self::getcoins($dval, $merchant['srakey'], $secrets, $mycoin);
             if (!$chgcoins || !$dvalcoins) {
                 $errorcode = 6;
                 $tmsg = "SRA Internal Error while splitting tokens";
             } else {
                 $leastcoin['coin']['secret'] = "";
                 $mycoin[$leastcoin['coin']['value']][$leastcoin['id']] = $leastcoin['coin'];
                 foreach ($chgcoins as $id => $coin) {
                     $cval = $coin['value'];
                     $coin['secret'] = $secrets[$id];
                     $coins[$cval][$id] = $coin;
                 }
                 unset($pcoins[$leastcoin['id']]);
             }
         }
     }
     foreach ($pcoins as $id => $coin) {
         $val = $coin['value'];
         if (isset($coins[$val][$id])) {
             unset($coins[$val][$id]);
         }
     }
     if (isset($dvalcoins)) {
         $pcoins += $dvalcoins;
     }
     $req['coins'] = $pcoins;
     $tmsg = $errorcode ? $tmsg : "pending";
     $tid = md5(uniqid(rand(), true));
     $dtime = time();
     $req['acknowledgement'] = array("id" => "{$tid}", "completed" => $dtime, "status" => "{$errorcode}", "message" => "{$tmsg}", "amount" => $amount, "ecashids" => "{$ecids}");
     //if(isset($rejectedecash)&&!empty($ecashrejected)) $req['acknowledgement']['rejectedecash'] = join(", ",$rejectedecash);
     if (strtolower($client['bank']) != strtolower($merchant['bank'])) {
         $m = GsonCrypt::sign(Gmsg::create($req));
         $merchant['response'] = Gmsg::create(Gmsg::Prepare($m, "acknowledgement", $merchant['bank']));
         $net = new Gnet();
         $c = $net->connect($merchant['address'], intval($merchant['port']));
         if (!$c) {
             return array(0, "Merchant's bank is unreachable");
         }
         $r = $net->send($merchant['response']);
         if (!$r) {
             $req['acknowledgement']['status'] = 10;
             $req['acknowledgement']['message'] = "Invalid response from merchant's bank";
         }
         $r = Gmsg::extract(GsonCrypt::verify($r, $merchant['bank']));
         if (!$r) {
             $req['acknowledgement']['status'] = 11;
             $req['acknowledgement']['message'] = "Invalid response from merchant's bank";
         } else {
             if ($r['status']) {
                 $old = storage::load($merchant['srakey']);
                 if (!$old) {
                     $old = array();
                 }
                 foreach ($pcoins as $id => $coin) {
                     $val = $coin['value'];
                     $old[$val][$id] = $coin;
                 }
                 storage::save($old, $merchant['srakey']);
                 storage::save($coins, $client['srakey']);
                 if (isset($mycoin)) {
                     storage::save($mycoin);
                 }
                 $req['acknowledgement']['message'] =& $r['response'];
             } else {
                 $req['acknowledgement']['status'] = 12;
                 $req['acknowledgement']['message'] = $r['response'];
             }
         }
     } else {
         if (!$errorcode) {
             $old = storage::load($merchant['srakey']);
             if (!$old) {
                 $old = array();
             }
             foreach ($pcoins as $id => $coin) {
                 $coin['secret'] = $secrets[$id];
                 $val = $coin['value'];
                 $old[$val][$id] = $coin;
             }
             storage::save($old, $merchant['srakey']);
             storage::save($coins, $client['srakey']);
             if (isset($mycoin)) {
                 storage::save($mycoin);
             }
         }
         $status = $req['acknowledgement']['status'] ? 0 : 1;
         if ($status) {
             $req['acknowledgement']['message'] = "Payment was successful";
         }
     }
     $status = $req['acknowledgement']['status'] ? 0 : 1;
     if (!$status) {
         unset($req['coins']);
         unset($req['change']);
         if ($errorcode <= 3) {
             $req['acknowledgement']['amount'] = 0;
         }
     }
     if ($status && isset($chgcoins)) {
         $req['change'] = $chgcoins;
     }
     $resp = $req;
     self::log($resp);
     return array($status, $req);
 }
Пример #3
0
 public static function pullcoins($msg, $account)
 {
     $m = GsonCrypt::verify($msg, $account);
     if (!$m) {
         return array(0, "Bank did not verify your message as authentic");
     }
     $m = Gmsg::extract($m);
     if (!$m) {
         return array(0, "Bank did not extract your message correctly");
     }
     if ($m['account'] == $account) {
         $n = self::coins($account, $coins);
         return array(1, $coins);
     }
     return array(0, "Failed!");
 }
Пример #4
0
 public static function pullcoins()
 {
     $m = Gmsg::create(Gmsg::prepare(GsonCrypt::sign(Gmsg::create(array('account' => config::$accountId))), 'pullcoins', config::$bankId));
     $net = new Gnet();
     $r = $net->send($m);
     $v = GsonCrypt::verify($r, config::$bankId);
     if (!$v) {
         $status = 0;
         gio::log("Unable to verify response from bank while pulling coins", E_USER_WARNING);
     } else {
         $v = Gmsg::extract($v);
         if (!$v) {
             $status = 0;
             gio::log("Unable to understand the response while pulling coins", E_USER_WARNING);
         } else {
             $status = $v['status'];
             $res = $v['response'];
         }
     }
     if (!$status) {
         gio::output("Could not pull eCash from bank");
     } else {
         if (!is_array($res)) {
             gio::output("Could not pull eCash from bank");
         } else {
             $check = 1;
             foreach ($res as $val => $ccs) {
                 foreach ($ccs as $id => $coin) {
                     $res[$val][$id]['secret'] = GsonCrypt::unseal($coin['secret']);
                     if (!$res[$val][$id]['secret']) {
                         $check = 0;
                     }
                 }
             }
             if (!$check) {
                 gio::output("Could not get the secret of some eCash");
             }
         }
         if (is_array($res) && count($res)) {
             $old = storage::load();
             if (!$old) {
                 $old = array();
             }
             foreach ($res as $val => $ccs) {
                 foreach ($ccs as $id => $coin) {
                     $val = $coin['value'];
                     $old[$val][$id] = $coin;
                 }
             }
             storage::save($old);
         }
     }
 }
Пример #5
0
 public static function status($oid)
 {
     $m = GsonCrypt::sign(Gmsg::create(array("oid" => $oid)));
     if (!$m) {
         $status = 0;
         $res = "Unable to sign status report for '{$oid}'";
     } else {
         $m = Gmsg::create(Gmsg::Prepare($m, "statusrequest", config::$bankId));
         $net = new Gnet();
         $r = $net->send($m);
         unset($net);
         if (!$r) {
             $status = 0;
             $res = "Unable to send status report for '{$oid}'";
         } else {
             $v = GsonCrypt::verify($r, config::$bankId);
             if (!$v) {
                 $status = 0;
                 $res = "Unable to verify response from bank for '{$oid}'";
             } else {
                 $v = Gmsg::extract($v);
                 if (!$v) {
                     $status = 0;
                     $res = "Unable to understand the response in relation to '{$oid}'";
                 } else {
                     $status = $v['status'];
                     $res = $v['response'];
                 }
             }
         }
     }
     return array($status, $res);
 }