diff --git a/modules/basket/controllers/admin_configure.php b/modules/basket/controllers/admin_configure.php
index 58a246ea..7831734d 100644
--- a/modules/basket/controllers/admin_configure.php
+++ b/modules/basket/controllers/admin_configure.php
@@ -27,14 +27,12 @@ class Admin_Configure_Controller extends Controller
{
$form = basket::get_configure_form();
if (request::method() == "post") {
- // @todo move the "save" part of this into a separate controller function
access::verify_csrf();
if ($form->validate()) {
basket::extractForm($form);
message::success(t("Basket Module Configured!"));
- //url::redirect("admin/recaptcha");
}
}
else
@@ -45,11 +43,121 @@ class Admin_Configure_Controller extends Controller
$view = new Admin_View("admin.html");
$view->content = new View("admin_configure.html");
-
-
$view->content->form = $form;
- //$view->content->products = ORM::factory("product")->orderby("name")->find_all();
print $view;
}
+
+ /**
+ * the index page of the user homes admin
+ */
+ public function templates()
+ {
+ $form = basket::get_template_form();
+ if (request::method() == "post") {
+ access::verify_csrf();
+
+ if ($form->validate()) {
+
+ basket::extractTemplateForm($form);
+ message::success(t("Basket Module Configured!"));
+ }
+ }
+ else
+ {
+ basket::populateTemplateForm($form);
+ }
+
+ $view = new Admin_View("admin.html");
+ $view->content = new View("admin_templates.html");
+
+ $view->content->form = $form;
+
+ print $view;
+ }
+
+ public function paypal_encrypt_wizard_step1()
+ {
+ $view = new Admin_View("admin.html");
+ $view->content = new View("pew1.html");
+
+ $view->content->form = self::keyGenerationForm();
+
+ print $view;
+
+ }
+
+ public function paypal_encrypt_wizard_step2()
+ {
+ access::verify_csrf();
+
+ $form = self::keyGenerationForm();
+
+ if (!$form->validate()) {
+
+ self::paypal_encrypt_wizard_step1();
+ return;
+ }
+
+ $ssldir = str_replace('\\','/',VARPATH.'certificate');
+ $ssldir= rtrim($ssldir, '/').'/';
+
+ if ( ! is_dir($ssldir))
+ {
+ // Create the upload directory
+ mkdir($ssldir, 0777, TRUE);
+ }
+
+ $prkeyfile = $ssldir . "myprvkey.pem";
+ $pubcertfile = $ssldir . "mypubcert.pem";
+ $certreqfile = $ssldir . "mycertreq.pem";
+
+ $dn = array("countryName" => $form->encrypt->countryName->value,
+ "stateOrProvinceName" => $form->encrypt->stateOrProvinceName->value,
+ "localityName" => $form->encrypt->localityName->value,
+ "organizationName" => $form->encrypt->organizationName->value,
+ "organizationalUnitName" => $form->encrypt->organizationalUnitName->value,
+ "commonName" => $form->encrypt->commonName->value,
+ "emailAddress" => $form->encrypt->emailAddress->value);
+ $privkeypass = $form->encrypt->privKeyPass->value;
+ $numberofdays = 365;
+ $config = array(
+ "private_key_bits" => 1024
+ );
+
+ $privkey = openssl_pkey_new($config);
+ $csr = openssl_csr_new($dn, $privkey);
+ $sscert = openssl_csr_sign($csr, null, $privkey, $numberofdays);
+ openssl_x509_export($sscert, $publickey);
+ openssl_pkey_export($privkey, $privatekey, $privkeypass);
+ openssl_csr_export($csr, $csrStr);
+
+ openssl_x509_export_to_file($sscert, $pubcertfile);
+ openssl_pkey_export_to_file ($privkey, $prkeyfile, $privkeypass);
+ openssl_csr_export_to_file($csr, $certreqfile);
+
+ //echo "Your Public Certificate has been saved to " . $pubcertfile . "
";
+ //echo "Your Private Key has been saved to " . $prkeyfile . "
";
+ //echo "Your Certificate Request has been saved to " . $certreqfile . "
";
+
+ //echo $privatekey; // Will hold the exported PriKey
+ //echo $publickey; // Will hold the exported PubKey
+ //echo $csrStr; // Will hold the exported Certificate
+ }
+
+ private function keyGenerationForm()
+ {
+ $form = new Forge("admin/configure/paypal_encrypt_wizard_step2", "", "post", array("id" => "generateKeys", "name" =>"generateKeys"));
+ $group = $form->group("encrypt")->label(t("Key Generation Details"));
+ $group->input("countryName")->label(t("Country Name"))->id("countryName");
+ $group->input("stateOrProvinceName")->label(t("State or Province Name"))->id("stateOrProvinceName");
+ $group->input("localityName")->label(t("Locality Name"))->id("localityName");
+ $group->input("organizationName")->label(t("Organization Name"))->id("organizationName");
+ $group->input("organizationalUnitName")->label(t("Organizational Unit Name"))->id("organizationalUnitName");
+ $group->input("commonName")->label(t("Common Name"))->id("commonName");
+ $group->input("emailAddress")->label(t("E-Mail Address"))->id("emailAddress");
+ $group->input("privKeyPass")->label(t("Private Key Pass"))->id("privkeypass");
+ return $form;
+ }
+
}
diff --git a/modules/basket/controllers/admin_postage_bands.php b/modules/basket/controllers/admin_postage_bands.php
index f843d0ca..535ad4ed 100644
--- a/modules/basket/controllers/admin_postage_bands.php
+++ b/modules/basket/controllers/admin_postage_bands.php
@@ -27,7 +27,7 @@ class Admin_Postage_Bands_Controller extends Controller
{
$view = new Admin_View("admin.html");
$view->content = new View("admin_postage_bands.html");
- $view->content->postage_bands = ORM::factory("postage_band")->orderby("name")->find_all();
+ $view->content->postage_bands = ORM::factory("postage_band")->order_by("name")->find_all();
print $view;
}
@@ -43,8 +43,8 @@ class Admin_Postage_Bands_Controller extends Controller
$form = postage_band::get_add_form_admin();
$valid = $form->validate();
$name = $form->add_postage->inputs["name"]->value;
- $postage = ORM::factory("postage_band")->where("name", $name)->find();
- if ($postage->loaded) {
+ $postage = ORM::factory("postage_band")->where("name","=", $name)->find();
+ if ($postage->loaded()) {
$form->add_postage->inputs["name"]->add_error("in_use", 1);
$valid = false;
}
@@ -59,16 +59,15 @@ class Admin_Postage_Bands_Controller extends Controller
$postage->save();
message::success(t("Created postage band %postage_name", array(
"postage_name" => html::clean($postage->name))));
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
}
public function delete_postage_band_form($id) {
$postage = ORM::factory("postage_band", $id);
- if (!$postage->loaded) {
+ if (!$postage->loaded()) {
kohana::show_404();
}
print postage_band::get_delete_form_admin($postage);
@@ -82,7 +81,7 @@ class Admin_Postage_Bands_Controller extends Controller
}
$postage = ORM::factory("postage_band", $id);
- if (!$postage->loaded) {
+ if (!$postage->loaded()) {
kohana::show_404();
}
@@ -91,21 +90,20 @@ class Admin_Postage_Bands_Controller extends Controller
$name = $postage->name;
$postage->delete();
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
$message = t("Deleted user %postage_band", array("postage_band" => html::clean($name)));
log::success("user", $message);
message::success($message);
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
}
public function edit_postage_band($id) {
access::verify_csrf();
$postage = ORM::factory("postage_band", $id);
- if (!$postage->loaded) {
+ if (!$postage->loaded()) {
kohana::show_404();
}
@@ -115,10 +113,10 @@ class Admin_Postage_Bands_Controller extends Controller
$new_name = $form->edit_postage->inputs["name"]->value;
if ($new_name != $postage->name &&
ORM::factory("postage_band")
- ->where("name", $new_name)
- ->where("id !=", $postage->id)
+ ->where("name", "=", $new_name)
+ ->where("id","!=", $postage->id)
->find()
- ->loaded) {
+ ->loaded()) {
$form->edit_postage->inputs["name"]->add_error("in_use", 1);
$valid = false;
} else {
@@ -133,16 +131,15 @@ class Admin_Postage_Bands_Controller extends Controller
message::success(t("Changed postage band %postage_name",
array("postage_name" => html::clean($postage->name))));
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
}
public function edit_postage_band_form($id) {
$postage = ORM::factory("postage_band", $id);
- if (!$postage->loaded) {
+ if (!$postage->loaded()) {
kohana::show_404();
}
diff --git a/modules/basket/controllers/admin_product_lines.php b/modules/basket/controllers/admin_product_lines.php
index f063ad36..6fd7054a 100644
--- a/modules/basket/controllers/admin_product_lines.php
+++ b/modules/basket/controllers/admin_product_lines.php
@@ -27,7 +27,7 @@ class Admin_Product_Lines_Controller extends Controller
{
$view = new Admin_View("admin.html");
$view->content = new View("admin_product_lines.html");
- $view->content->products = ORM::factory("product")->orderby("name")->find_all();
+ $view->content->products = ORM::factory("product")->order_by("name")->find_all();
print $view;
}
@@ -43,8 +43,8 @@ class Admin_Product_Lines_Controller extends Controller
$form = product::get_add_form_admin();
$valid = $form->validate();
$name = $form->add_product->inputs["name"]->value;
- $product = ORM::factory("product")->where("name", $name)->find();
- if ($product->loaded) {
+ $product = ORM::factory("product")->where("name", "=", $name)->find();
+ if ($product->loaded()) {
$form->add_product->inputs["name"]->add_error("in_use", 1);
$valid = false;
}
@@ -60,16 +60,15 @@ class Admin_Product_Lines_Controller extends Controller
$product->save();
message::success(t("Created product %product_name", array(
"product_name" => html::clean($product->name))));
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
}
public function delete_product_form($id) {
$product = ORM::factory("product", $id);
- if (!$product->loaded) {
+ if (!$product->loaded()) {
kohana::show_404();
}
print product::get_delete_form_admin($product);
@@ -83,7 +82,7 @@ class Admin_Product_Lines_Controller extends Controller
}
$product = ORM::factory("product", $id);
- if (!$product->loaded) {
+ if (!$product->loaded()) {
kohana::show_404();
}
@@ -92,21 +91,20 @@ class Admin_Product_Lines_Controller extends Controller
$name = $product->name;
$product->delete();
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
$message = t("Deleted user %product_name", array("product_name" => html::clean($name)));
log::success("user", $message);
message::success($message);
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
}
public function edit_product($id) {
access::verify_csrf();
$product = ORM::factory("product", $id);
- if (!$product->loaded) {
+ if (!$product->loaded()) {
kohana::show_404();
}
@@ -116,10 +114,10 @@ class Admin_Product_Lines_Controller extends Controller
$new_name = $form->edit_product->inputs["name"]->value;
if ($new_name != $product->name &&
ORM::factory("product")
- ->where("name", $new_name)
- ->where("id !=", $product->id)
+ ->where("name", "=", $new_name)
+ ->where("id","!=", $product->id)
->find()
- ->loaded) {
+ ->loaded()) {
$form->edit_product->inputs["name"]->add_error("in_use", 1);
$valid = false;
} else {
@@ -135,16 +133,15 @@ class Admin_Product_Lines_Controller extends Controller
message::success(t("Changed product %product_name",
array("product_name" => html::clean($product->name))));
- print json_encode(array("result" => "success"));
+ print json::reply(array("result" => "success"));
} else {
- print json_encode(array("result" => "error",
- "form" => $form->__toString()));
+ print $form;
}
}
public function edit_product_form($id) {
$product = ORM::factory("product", $id);
- if (!$product->loaded) {
+ if (!$product->loaded()) {
kohana::show_404();
}
diff --git a/modules/basket/controllers/basket.php b/modules/basket/controllers/basket.php
index 2e85f60c..a4ecbee3 100644
--- a/modules/basket/controllers/basket.php
+++ b/modules/basket/controllers/basket.php
@@ -19,19 +19,173 @@
*/
class Basket_Controller extends Controller {
- public function view_basket() {
+ public function temp(){
+ $db = Database::instance();
+ $db->query("ALTER TABLE {orders} ADD COLUMN `method` int(9) DEFAULT 0;");
+ }
+ public function view_basket($pp="") {
$template = new Theme_View("page.html", "basket");
+ $basket = Session_Basket::get();
+ if (isset($pp)){
+ if ($pp=="nopp"){
+ $basket->disablepp();
+ }
+ elseif ($pp=="ppon"){
+ $basket->enablepp();
+ }
+ }
+
$view = new View("view_basket.html");
- $view->basket = Session_Basket::get();
+ $view->basket = $basket;
+
$template->content = $view;
print $template;
}
- private function getCheckoutForm(){
+ public function preview($id) {
+ $item = ORM::factory("item", $id);
+
+ print "";
+
+ }
+
+ public function view_orders() {
+ self::check_view_orders();
+ $template = new Theme_View("page.html", "basket");
+
+ $incomplete_orders = ORM::factory("order")->where('status',"<",20)->find_all();
+
+ $view = new View("view_orders.html");
+
+ $view->orders = $incomplete_orders;
+
+ $template->content = $view;
+
+ print $template;
+ }
+
+
+ public function view_ipn($orderid){
+ self::check_view_orders();
+
+ $template = new Theme_View("page.html", "basket");
+
+ $order = ORM::factory("order")->where("id","=",$orderid)->find();
+ $ipn_messages = ORM::factory("ipn_message")->where("key","=",$orderid)->find_all();
+ //$ipn_messages = ORM::factory("ipn_message")->find_all();
+
+ $view = new View("view_ipn.html");
+
+ $view->order = $order;
+ $view->ipn_messages = $ipn_messages;
+
+ $template->content = $view;
+
+ print $template;
+
+ }
+
+ public function check_view_orders() {
+ if (!basket::can_view_orders()){
+ die("Invalid access.");
+ }
+ }
+
+ public function print_order($id){
+
+ access::verify_csrf();
+ self::check_view_orders();
+
+
+ $prefix = basket::getOrderPrefix();
+ $length = strlen($prefix);
+ if (strlen($id)>$length ){
+ if ($prefix === strtolower(substr($id,0,$length ))){
+ $id = substr($id,$length);
+ }
+ }
+ $order = ORM::factory("order", $id);
+ $view = new View("print_order.html");
+
+ if ($order->loaded()){
+ $view->order = str_replace(array("\r\n", "\n", "\r"),"
",$order->text);
+ }else{
+ $view->order = "Order ".$id." not found.";
+ }
+ print $view;
+ }
+
+ public function show_order($id){
+
+ access::verify_csrf();
+ self::check_view_orders();
+ $prefix = basket::getOrderPrefix();
+ $length = strlen($prefix);
+ if (strlen($id)>$length ){
+ if ($prefix === strtolower(substr($id,0,$length ))){
+ $id = substr($id,$length);
+ }
+ }
+
+ $order = ORM::factory("order", $id);
+
+ if ($order->loaded()){
+ $view = new View("view_order.html");
+ $view->order = $order;
+ print $view;
+ }else{
+ print "Order ".$id." not found.";
+ }
+ }
+
+ public function show_ipn($id){
+ access::verify_csrf();
+ self::check_view_orders();
+ $ipn_message = ORM::factory("ipn_message", $id);
+
+ if ($ipn_message->loaded()){
+ print $ipn_message->text;
+ }else{
+ print "IPN Message ".$id." not found.";
+ }
+
+ }
+
+ public function confirm_order_delivery($id){
+ access::verify_csrf();
+ self::check_view_orders();
+ $order = ORM::factory("order", $id);
+
+ if ($order->loaded()){
+ if ($order->status == 2)
+ {
+ $order->status = 20;
+ $order->save();
+ }
+ }
+ url::redirect("basket/view_orders");
+ }
+
+ public function confirm_order_payment($id){
+ access::verify_csrf();
+ self::check_view_orders();
+ $order = ORM::factory("order", $id);
+
+ if ($order->loaded()){
+ if ($order->status == 1)
+ {
+ $order->status = 2;
+ $order->save();
+ }
+ }
+ url::redirect("basket/view_orders");
+ }
+
+ private function getCheckoutForm(){
$form = new Forge("basket/confirm", "", "post", array("id" => "checkout", "name" =>"checkout"));
$group = $form->group("contact")->label(t("Contact Details"));
$group->input("fullname")->label(t("Name"))->id("fullname");
@@ -42,6 +196,7 @@ class Basket_Controller extends Controller {
$group->input("postcode")->label(t("Postcode"))->id("postcode");
$group->input("email")->label(t("E-Mail Address"))->id("email");
$group->input("phone")->label(t("Telephone Number"))->id("phone");
+ $group->hidden("paypal")->id("paypal");
return $form;
}
@@ -80,6 +235,12 @@ class Basket_Controller extends Controller {
if ($valid){
$basket = Session_Basket::get();
+
+ if (!isset($basket->contents ) || count($basket->contents) == 0) {
+ self::view_basket();
+ return;
+ }
+
$basket->name = $form->contact->fullname->value;
$basket->house = $form->contact->house->value;
$basket->street = $form->contact->street->value;
@@ -89,14 +250,33 @@ class Basket_Controller extends Controller {
$basket->email = $form->contact->email->value;
$basket->phone = $form->contact->phone->value;
+ $paypal=$form->contact->paypal->value=="true";
$template = new Theme_View("page.html", "basket");
- $form = new Forge("basket/complete", "", "post", array("id" => "confirm", "name" =>"confirm"));
- $view = new View("confirm_order.html");
- $view->basket = $basket;
- $template->content = $view;
- $view->form = $form;
- print $template;
+ if ($paypal){
+ // create a prelimary order
+ $order = basket::createOrder($basket, Order_Model::PAYMENT_PAYPAL);
+ $paypal = new Paypal();
+
+ // create the order first
+ $view = new View("paypal_redirect.html");
+ $view ->form = $paypal->process($basket,
+ url::site("basket/paypal_complete/$order->id", "http"),
+ url::site("basket/paypal_cancel/$order->id", "http"),
+ url::site("basket/paypal_ipn/$order->id", "http"));
+ $template->content = $view;
+ print $template;
+
+ // redirect to paypal
+ }else
+ {
+ $form = new Forge("basket/complete", "", "post", array("id" => "confirm", "name" =>"confirm"));
+ $view = new View("confirm_order.html");
+ $view->basket = $basket;
+ $template->content = $view;
+ $view->form = $form;
+ print $template;
+ }
}
else
{
@@ -105,53 +285,80 @@ class Basket_Controller extends Controller {
}
}
- public function complete () {
- access::verify_csrf();
+ function paypal_ipn($id){
+ $order = ORM::factory("order")->where("id","=",$id)->find();
+ if ($order->loaded()){
+
+ $paypal = new Paypal();
+
+ if ($paypal->validate_ipn($id)){
+ if ($paypal->ipn_data['payment_status'] == "Completed"){
+
+ $order->status = Order_Model::PAYMENT_CONFIRMED;
+
+ // send e-mails
+ basket::send_order($order);
+ basket::send_invoice($order);
+
+ $order->save();
+ }
+ return;
+ }
+ print "invalid access. tut tut!";
+ }
+ return;
+
+ }
+
+ public function paypal_complete($id) {
+ $order = ORM::factory("order")->where("id","=",$id)->find();
$basket = Session_Basket::get();
+ $basket->clear();
+ $this->_complete($order);
+ }
- //$admin_address = basket::getEmailAddress();
- $postage = $basket->postage_cost();
- $product_cost = $basket->cost();
+ public function paypal_cancel($id){
+ $order = ORM::factory("order")->where("id","=",$id)->find();
- $admin_email = "Order for :
-".$basket->name."
-".$basket->house."
-".$basket->street."
-".$basket->suburb."
-".$basket->town."
-".$basket->postcode."
-".$basket->email."
-".$basket->phone."
-Placed at ".date("d F Y - H:i" ,time())."
-Cost of Ordered Products = ".$product_cost."
-Postage and Packaging Costs + ".$postage."
-Total Owed ".($product_cost+$postage)." Total in ".basket::getCurrency()."
-
-Items Ordered:
-
-";
-
- // create the order items
- foreach ($basket->contents as $basket_item){
- $item = $basket_item->getItem();
- $prod = ORM::factory("product", $basket_item->product);
- $admin_email = $admin_email."
-".$item->title." - ".$item->url()."
-".$prod->name." - ".$prod->description."
-".$basket_item->quantity." @ ".$prod->cost."
-
-";
+ if ($order->loaded()){
+ $order->delete();
}
+ $this->checkout();
+ }
- $from = "From: ".basket::getEmailAddress();
- mail(basket::getEmailAddress(), "Order from ".$basket->name, $admin_email, $from);
+ public function complete () {
+ access::verify_csrf();
+ $basket = Session_Basket::get();
+
+ if (!isset($basket->contents ) || count($basket->contents) == 0) {
+ self::view_basket();
+ return;
+ }
+
+ // create order
+ $order = basket::createOrder($basket, Order_Model::PAYMENT_OFFLINE);
$basket->clear();
+ // send e-mails
+ basket::send_order($order);
+ basket::send_invoice($order);
+
+
+ $this->_complete($order);
+ }
+
+ private function _complete($order){
$template = new Theme_View("page.html", "basket");
$view = new View("order_complete.html");
+ $ordernumber = basket::getOrderPrefix().$order->id;
+ $view->ordernumber = $ordernumber;
+ $view->order = $order;
+ $view->total_cost = $order->cost;
+
$template->content = $view;
+
print $template;
}
@@ -189,7 +396,11 @@ Items Ordered:
$form->add_to_basket->product->value,
$form->add_to_basket->quantity->value);
- print json_encode(array("result" => "success"));
+ $item = ORM::factory("item", $form->add_to_basket->id->value);
+
+ Session::instance()->set("redirect_home", $item->parent_id);
+
+ print json::reply(array("result" => "success"));
}
else
{
@@ -205,7 +416,7 @@ Items Ordered:
// get the item to add
$item = ORM::factory("item", $id);
- if (!$item->loaded)
+ if (!$item->loaded())
{
//TODO
die("Not loaded id");
diff --git a/modules/basket/css/basket.css b/modules/basket/css/basket.css
index f660685d..107b8229 100644
--- a/modules/basket/css/basket.css
+++ b/modules/basket/css/basket.css
@@ -1,5 +1,17 @@
#basket {float:right;}
#add_to_basket {float:right}
-#basketForm {max-width:200px}
-#basketThumb {float:left; padding:10px 10px 0 0;}
+#basketForm {max-width:200px;float:left;}
+#basketThumb {float:left; padding:10px;}
#basketThumb img{max-width:100px;}
+#payment {float:right; width:50%}
+#checkout input,
+#checkout select,
+#checkout textarea {
+ display: block;
+ clear: both;
+ padding: .2em;
+ width: 100%;
+}
+#sidebar-basket {max-height:300px; overflow-y:auto; overflow-x:hidden;}
+.order-status-1 a{color:#AA0000 !important}
+.order-status-2 a{color:#00AA00 !important}
diff --git a/modules/basket/helpers/basket.php b/modules/basket/helpers/basket.php
index 45ab988f..b9be6726 100644
--- a/modules/basket/helpers/basket.php
+++ b/modules/basket/helpers/basket.php
@@ -40,6 +40,26 @@ class basket_Core {
"MXN" => "Mexican Peso");
static $format= array(
+ "AUD" => "$",
+ "CAD" => "$",
+ "EUR" => "€",
+ "GBP" => "£",
+ "JPY" => "¥",
+ "USD" => "$",
+ "NZD" => "$",
+ "CHF" => "",
+ "HKD" => "$",
+ "SGD" => "$",
+ "SEK" => "",
+ "DKK" => "",
+ "PLN" => "",
+ "NOK" => "",
+ "HUF" => "",
+ "CZK" => "",
+ "ILS" => "",
+ "MXN" => "");
+
+ static $formatweb= array(
"AUD" => "$",
"CAD" => "$",
"EUR" => "€",
@@ -60,37 +80,108 @@ class basket_Core {
"MXN" => "");
- static function get_configure_form() {
- $form = new Forge("admin/configure", "", "post", array("id" => "gConfigureForm"));
- $group = $form->group("configure")->label(t("Configure Basket"));
- $group->input("email")->label(t("Offline Paying Email Address"))->id("gOrderEmailAddress");
- $group->dropdown("currency")
- ->label(t("Currency"))
- ->options(self::$currencies);
+ static public function can_view_orders()
+ {
+ if (identity::active_user()->admin){
+ return true;
+ }
- $group->checkbox("paypal")->label(t("Use Paypal"))->id("gPaypal");
- $group->input("paypal_account")->label(t("Paypal E-Mail Address"))->id("gPaypalAddress");
+ print identity::active_user();
+ foreach (identity::active_user()->groups() as $group){
+ if ($group->name == 'shop'){
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+
+ static function get_configure_form() {
+ $form = new Forge("admin/configure", "", "post", array("id" => "g-configure-form"));
+ $group = $form->group("configure")->label(t("Configure Basket"));
+ $group->input("email")->label(t("Offline Paying Email Address"))->id("g-order-email-address");
+ $group->dropdown("currency")
+ ->label(t("Currency"))
+ ->options(self::$currencies);
+
+ $group->checkbox("side_bar")->label(t("Use only side bar"))->id("g-side-bar-only");
+
+ $group->checkbox("paypal")->label(t("Use Paypal"))->id("g-paypal");
+ $group->input("paypal_account")->label(t("Paypal E-Mail Address"))->id("g-paypal-address");
+ $group->checkbox("allow_pickup")->label(t("Allow Product Pickup"))->id("g-allow-pickup");
+ $group->input("order_prefix")->label(t("Order Number Prefix"))->id("g-order-prefix");
+ $group->submit("")->value(t("Save"));
+ return $form;
+ }
+
+ static function get_template_form() {
+ $form = new Forge("admin/configure/templates", "", "post", array("id" => "g-configure-form"));
+ $group = $form->group("configure")->label(t("Configure Basket"));
+ $group->textarea("payment_details")->label(t("Payment Details Description"))->id("g-payment-details");
+ $group->textarea("order_complete_page")->label(t("Order Complete Page"))->id("g-order-complete_page");
+ $group->input("order_complete_email_subject")->label(t("Order Complete Email Subject"))->id("g-order-complete_email_subject");
+ $group->textarea("order_complete_email")->label(t("Order Complete Email"))->id("g-order-complete_email");
$group->submit("")->value(t("Save"));
return $form;
}
static function populateForm($form){
- $form->configure->email->value(basket::getEmailAddress());
- $form->configure->paypal->checked(basket::isPaypal());
- $form->configure->paypal_account->value(basket::getPaypalAccount());
- $form->configure->currency->selected(basket::getCurrency());
+ $form->configure->email->value(basket::getEmailAddress());
+ $form->configure->side_bar->checked(basket::is_side_bar_only());
+ $form->configure->paypal->checked(basket::isPaypal());
+ $form->configure->paypal_account->value(basket::getPaypalAccount());
+ $form->configure->currency->selected(basket::getCurrency());
+ $form->configure->allow_pickup->checked(basket::isAllowPickup());
+ $form->configure->order_prefix->value(basket::getOrderPrefix());
+ }
+
+ static function populateTemplateForm($form){
+ $form->configure->payment_details->value(basket::getPaymentDetails());
+ $form->configure->order_complete_page->value(basket::getOrderCompletePage());
+ $form->configure->order_complete_email_subject->value(basket::getOrderCompleteEmailSubject());
+ $form->configure->order_complete_email->value(basket::getOrderCompleteEmail());
}
static function extractForm($form){
- $email = $form->configure->email->value;
- $isPaypal = $form->configure->paypal->value;
- $paypal_account = $form->configure->paypal_account->value;
- $currency = $form->configure->currency->selected;
- basket::setEmailAddress($email);
- basket::setPaypal($isPaypal);
- basket::setPaypalAccount($paypal_account);
- basket::setCurrency($currency);
+ $email = $form->configure->email->value;
+ $is_side_bar = $form->configure->side_bar->value;
+ $isPaypal = $form->configure->paypal->value;
+ $paypal_account = $form->configure->paypal_account->value;
+ $currency = $form->configure->currency->selected;
+ $allow_pickup = $form->configure->allow_pickup->value;
+ $order_prefix = $form->configure->order_prefix->value;
+ basket::setEmailAddress($email);
+ basket::set_side_bar_only($is_side_bar);
+ basket::setPaypal($isPaypal);
+ basket::setPaypalAccount($paypal_account);
+ basket::setCurrency($currency);
+ basket::setAllowPickup($allow_pickup);
+ basket::setOrderPrefix($order_prefix);
}
+ static function extractTemplateForm($form){
+ $payment_details = $form->configure->payment_details->value;
+ $order_complete_page = $form->configure->order_complete_page->value;
+ $order_complete_email_subject = $form->configure->order_complete_email_subject->value;
+ $order_complete_email = $form->configure->order_complete_email->value;
+ basket::setPaymentDetails($payment_details);
+ basket::setOrderCompletePage($order_complete_page);
+ basket::setOrderCompleteEmailSubject($order_complete_email_subject);
+ basket::setOrderCompleteEmail($order_complete_email);
+ }
+
+ static public function is_side_bar_only()
+ {
+ return module::get_var("basket","is_side_bar_only");
+
+ }
+
+ static public function set_side_bar_only($value)
+ {
+ module::set_var("basket","is_side_bar_only",$value);
+
+ }
+
static function getEmailAddress(){
return module::get_var("basket","email");
@@ -113,10 +204,51 @@ class basket_Core {
return $cur;
}
+ static function getPaymentDetails(){
+ return module::get_var("basket","payment_details");
+ }
+
+ static function getOrderPrefix(){
+ return module::get_var("basket","order_prefix");
+ }
+
+ static function isAllowPickup(){
+ return module::get_var("basket","allow_pickup");
+ }
+
+ static function getOrderCompletePage(){
+ return module::get_var("basket","order_complete_page");
+ }
+
+ static function getOrderCompleteEmail(){
+ return module::get_var("basket","order_complete_email");
+ }
+
+ static function getOrderCompleteEmailSubject(){
+ return module::get_var("basket","order_complete_email_subject");
+ }
+
static function formatMoney($money){
return self::$format[self::getCurrency()].number_format($money,2);
}
+ static function formatMoneyForWeb($money){
+ return self::$formatweb[self::getCurrency()].number_format($money,2);
+ }
+
+ static function replaceStrings($string, $key_values) {
+ // Replace x_y before replacing x.
+ krsort($key_values, SORT_STRING);
+
+ $keys = array();
+ $values = array();
+ foreach ($key_values as $key => $value) {
+ $keys[] = "%$key";
+ $values[] = $value;
+ }
+ return str_replace($keys, $values, $string);
+ }
+
static function setEmailAddress($email){
module::set_var("basket","email",$email);
}
@@ -133,32 +265,129 @@ class basket_Core {
module::set_var("basket","currency",$currency);
}
- static function generatePaypalForm($session_basket){
- $form = "
-
Use the following options to pay for this order.
+Send a chequre to..
+Visit the shop..
+By using internet banking..
" + ); + basket::setOrderPrefix("ORDER"); + basket::setOrderCompletePage( +"Your order number is %order_number. To pay for this order please either:
+- Send a cheque for %total_cost to with reference %order_number..
+- Visit the shop and quote the order %order_number..
+- Transfer %total_cost using internet banking with reference %order_number..
+Order will be processed as soon as payment is received. You should receive an e-mail with your order details shortly.
" + ); + basket::setOrderCompleteEmail( +"Hi %name, - module::set_version("basket", 2); +Thank you for your order the order details are below. To pay for this order please either: + +- Send a cheque for %total_cost to with reference %order_number.. +- Visit the shop and quote the order %order_number.. +- Transfer %total_cost using internet banking with reference %order_number.. + +Order will be processed as soon as payment is received. For order pick-ups please visit.. + +Order Details +------------- +%order_details + +Thanks"); + basket::setOrderCompleteEmailSubject( +"Photography Order %order_number"); + + module::set_version("basket", 4); } @@ -89,6 +144,73 @@ class basket_installer module::set_version("basket", $version = 2); } + + if ($version == 2) { + $db->query("CREATE TABLE IF NOT EXISTS {orders} ( + `id` int(9) NOT NULL auto_increment, + `text` TEXT NOT NULL, + PRIMARY KEY (`id`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + basket::setPaymentDetails( +"Use the following options to pay for this order.
+Send a chequre to..
+Visit the shop..
+By using internet banking..
" + ); + basket::setOrderPrefix("ORDER"); + basket::setOrderCompletePage( +"Your order number is %order_number. To pay for this order please either:
+- Send a cheque for %total_cost to with reference %order_number..
+- Visit the shop and quote the order %order_number..
+- Transfer %total_cost using internet banking with reference %order_number..
+Order will be processed as soon as payment is received. You should receive an e-mail with your order details shortly.
" + ); + basket::setOrderCompleteEmail( +"Hi %name, + +Thank you for your order the order details are below. To pay for this order please either: + +- Send a cheque for %total_cost to with reference %order_number.. +- Visit the shop and quote the order %order_number.. +- Transfer %total_cost using internet banking with reference %order_number.. + +Order will be processed as soon as payment is received. For order pick-ups please visit.. + +Order Details +------------- +%order_details + +Thanks"); + basket::setOrderCompleteEmailSubject( +"Photography Order %order_number"); + + module::set_version("basket", $version = 3); + } + + if ($version ==3 ){ + $db->query("ALTER TABLE {orders} ADD COLUMN `status` int(9) DEFAULT 0;"); + + $db->query("CREATE TABLE IF NOT EXISTS {ipn_messages} ( + `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT, + `date` int(11) NOT NULL, + `key` varchar(20) NOT NULL, + `txn_id` varchar(20) NOT NULL, + `status` varchar(20) NOT NULL, + `success` bool default false, + `text` text, + PRIMARY KEY (`id`) + ) ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + module::set_version("basket", $version = 4); + + } + + if ($version==4){ + $db->query("ALTER TABLE {orders} ADD COLUMN `name` varchar(1024);"); + $db->query("ALTER TABLE {orders} ADD COLUMN `email` varchar(1024);"); + $db->query("ALTER TABLE {orders} ADD COLUMN `method` int(9) DEFAULT 0;"); + $db->query("ALTER TABLE {orders} ADD COLUMN `cost` DECIMAL(10,2) default 0"); + module::set_version("basket", $version = 5); + } } static function uninstall(){ @@ -97,5 +219,6 @@ class basket_installer $db->query("DROP TABLE IF EXISTS {product_overrides}"); $db->query("DROP TABLE IF EXISTS {item_products}"); $db->query("DROP TABLE IF EXISTS {postage_bands}"); + $db->query("DROP TABLE IF EXISTS {orders}"); } } diff --git a/modules/basket/helpers/basket_theme.php b/modules/basket/helpers/basket_theme.php index b8d513e9..1ad535e5 100644 --- a/modules/basket/helpers/basket_theme.php +++ b/modules/basket/helpers/basket_theme.php @@ -24,10 +24,15 @@ class basket_theme_Core { } static function header_top($theme) { - $view = new View("basket.html"); - $view->basket = Session_Basket::get(); - return $view->render(); + if (!basket::is_side_bar_only()) + { + $view = new View("basket.html"); + + $view->basket = Session_Basket::get(); + return $view->render(); + } + return ""; } static function admin_head($theme) { @@ -36,12 +41,15 @@ class basket_theme_Core { } } static function photo_top($theme){ - if ( product::isForSale($theme->item()->id)){ - $view = new View("add_to_basket.html"); + if (!basket::is_side_bar_only()) + { + if ( product::isForSale($theme->item()->id)){ + $view = new View("add_to_basket.html"); - $view->item = $theme->item(); + $view->item = $theme->item(); - return $view->render(); + return $view->render(); + } } return ""; } diff --git a/modules/basket/helpers/postage_band.php b/modules/basket/helpers/postage_band.php index b69f84c4..ca679d53 100644 --- a/modules/basket/helpers/postage_band.php +++ b/modules/basket/helpers/postage_band.php @@ -28,7 +28,6 @@ class postage_band_Core { $group->input("per_item")->label(t("Per Item"))->id("gPetItem"); $group->submit("")->value(t("Add Postage Band")); $postage = ORM::factory("postage_band"); - $form->add_rules_from($postage); return $form; } @@ -44,7 +43,6 @@ class postage_band_Core { value($postage->per_item); $group->submit("")->value(t("Modify Postage Band")); - $form->add_rules_from($postage); return $form; } @@ -67,8 +65,8 @@ class postage_band_Core { * @return User_Model */ static function create($name, $flatrate, $peritemcost) { - $postage = ORM::factory("postage_band")->where("name", $name)->find(); - if ($postage->loaded) { + $postage = ORM::factory("postage_band")->where("name", "=", $name)->find(); + if ($postage->loaded()) { throw new Exception("@todo postage already EXISTS $name"); } diff --git a/modules/basket/helpers/product.php b/modules/basket/helpers/product.php index cb4261a0..a4a13c8c 100644 --- a/modules/basket/helpers/product.php +++ b/modules/basket/helpers/product.php @@ -31,11 +31,11 @@ class product_Core { ->options(postage_band::getPostageArray()); $group->submit("")->value(t("Add Product")); $product = ORM::factory("product"); - $form->add_rules_from($product); return $form; } static function get_edit_form_admin($product) { + $form = new Forge("admin/product_lines/edit_product/$product->id", "", "post", array("id" => "gEditProductForm")); $group = $form->group("edit_product")->label(t("Edit Product")); @@ -51,7 +51,6 @@ class product_Core { ->selected($product->postage_band_id); $group->submit("")->value(t("Modify Product")); - $form->add_rules_from($product); return $form; } @@ -74,8 +73,8 @@ class product_Core { * @return User_Model */ static function create($name, $cost, $description, $postage_band) { - $product = ORM::factory("product")->where("name", $name)->find(); - if ($product->loaded) { + $product = ORM::factory("product")->where("name", "=", $name)->find(); + if ($product->loaded()) { throw new Exception("@todo USER_ALREADY_EXISTS $name"); } @@ -90,9 +89,9 @@ class product_Core { static function getProductArray($id){ $producta = array(); // check for product override - $product_override = ORM::factory("product_override")->where('item_id', $id)->find(); + $product_override = ORM::factory("product_override")->where('item_id', "=", $id)->find(); - if (!$product_override->loaded){ + if (!$product_override->loaded()){ // no override found so check parents // check parents for product override $item = ORM::factory("item",$id); @@ -100,24 +99,25 @@ class product_Core { $parents = $item->parents(); foreach ($parents as $parent){ // check for product override - $product_override = ORM::factory("product_override")->where('item_id', $parent->id)->find(); - if ($product_override->loaded){ - break; + $temp_override = ORM::factory("product_override")->where('item_id', "=", $parent->id)->find(); + if ($temp_override ->loaded()){ + $product_override = $temp_override; + //break; } - } + } } $products = ORM::factory("product")->find_all(); foreach ($products as $product){ $show = true; $cost = $product->cost; - if ($product_override->loaded){ + if ($product_override->loaded()){ $show = !$product_override->none; $item_product = ORM::factory("item_product") - ->where('product_override_id', $product_override->id) - ->where('product_id', $product->id)->find(); + ->where('product_override_id', "=", $product_override->id) + ->where('product_id', "=", $product->id)->find(); - if ($item_product->loaded){ + if ($item_product->loaded()){ $cost = $item_product->cost; if (!$show){ $show = $item_product->include; @@ -127,7 +127,7 @@ class product_Core { if ($show) { - $producta[$product->id] = $product->description." (".basket::formatMoney($cost).")"; + $producta[$product->id] = html::clean($product->description)." (".basket::formatMoneyForWeb($cost).")"; } } @@ -136,10 +136,12 @@ class product_Core { static function isForSale($id){ + try + { // check for product override - $product_override = ORM::factory("product_override")->where('item_id', $id)->find(); + $product_override = ORM::factory("product_override")->where('item_id', "=", $id)->find(); - if (!$product_override->loaded){ + if (!$product_override->loaded()){ // no override found so check parents // check parents for product override $item = ORM::factory("item",$id); @@ -147,24 +149,25 @@ class product_Core { $parents = $item->parents(); foreach ($parents as $parent){ // check for product override - $product_override = ORM::factory("product_override")->where('item_id', $parent->id)->find(); - if ($product_override->loaded){ - break; + $temp_override = ORM::factory("product_override")->where('item_id', "=", $parent->id)->find(); + if ($temp_override ->loaded()){ + $product_override = $temp_override; + //break; } } } $products = ORM::factory("product")->find_all(); - if ($product_override->loaded && $product_override->none){ + if ($product_override->loaded() && $product_override->none){ foreach ($products as $product){ $item_product = ORM::factory("item_product") - ->where('product_override_id', $product_override->id) - ->where('product_id', $product->id)->find(); + ->where('product_override_id', "=", $product_override->id) + ->where('product_id', "=", $product->id)->find(); - if ($item_product->loaded){ + if ($item_product->loaded()){ if ($item_product->include){ return true; @@ -177,5 +180,10 @@ class product_Core { } else { return count($products) > 0; } + } + catch (Exception $e) + { + echo $e; + } } } \ No newline at end of file diff --git a/modules/basket/libraries/Paypal.php b/modules/basket/libraries/Paypal.php new file mode 100644 index 00000000..c18ee058 --- /dev/null +++ b/modules/basket/libraries/Paypal.php @@ -0,0 +1,330 @@ +add_field('business', 'somebody@domain.com'); + * $p->add_field('first_name', $_POST['first_name']); + * ... (add all your fields in the same manor) + * $p->submit_paypal_post(); + * + * To process an IPN, have your IPN processing file contain: + * + * $p = new paypal_class; + * if ($p->validate_ipn()) { + * ... (IPN is verified. Details are in the ipn_data() array) + * } + * + * + * In case you are new to paypal, here is some information to help you: + * + * 1. Download and read the Merchant User Manual and Integration Guide from + * http://www.paypal.com/en_US/pdf/integration_guide.pdf. This gives + * you all the information you need including the fields you can pass to + * paypal (using add_field() with this class) aswell as all the fields + * that are returned in an IPN post (stored in the ipn_data() array in + * this class). It also diagrams the entire transaction process. + * + * 2. Create a "sandbox" account for a buyer and a seller. This is just + * a test account(s) that allow you to test your site from both the + * seller and buyer perspective. The instructions for this is available + * at https://developer.paypal.com/ as well as a great forum where you + * can ask all your paypal integration questions. Make sure you follow + * all the directions in setting up a sandbox test environment, including + * the addition of fake bank accounts and credit cards. + * + ******************************************************************************* + */ + +class Paypal_Core { + + var $last_error; // holds the last error encountered + + var $ipn_response; // holds the IPN response from paypal + public $ipn_data = array(); // array contains the POST values for IPN + + var $fields = array(); // array holds the fields to submit to paypal + + + public function __construct() + { + // initialization constructor. Called when class is created. + + // sandbox paypal + + //$this->paypal_url = "https://www.sandbox.paypal.com/cgi-bin/webscr"; + //$this->secure_url = "ssl://www.sandbox.paypal.com"; + + // normal paypal + $this->paypal_url = "https://www.paypal.com/cgi-bin/webscr"; + $this->secure_url = "ssl://www.paypal.com"; + + $this->last_error = ''; + + //$this->ipn_log_file = Kohana::log_directory().Kohana::config('paypal.ipn_logfile'); + //$this->ipn_log = true; + $this->ipn_response = ''; + + // populate $fields array with a few default values. See the paypal + // documentation for a list of fields and their data types. These defaul + // values can be overwritten by the calling script. + + + } + + function add_field($field, $value) { + + // adds a key=>value pair to the fields array, which is what will be + // sent to paypal as POST variables. If the value is already in the + // array, it will be overwritten. + + $this->fields["$field"] = $value; + } + + public function process($session_basket, $return_url, $cancel_url, $notify_url){ + + $this->add_field('rm','2'); + $this->add_field('cmd','_cart'); + $this->add_field('upload','1'); + + $this->add_field('currency_code', basket::getCurrency()); + $this->add_field('business', basket::getPaypalAccount()); + + // IPN stuff + $this->add_field('return', $return_url); + $this->add_field('cancel_return', $cancel_url); + $this->add_field('notify_url', $notify_url); + + // postage + if ($session_basket->ispp()){ + $postage = $session_basket->postage_cost(); + if ($postage > 0) { + $this->add_field('shipping_1',$postage); + } + } + + // basket contents + $id = 1; + foreach ($session_basket->contents as $key => $basket_item){ + $this->add_field("item_name_$id", $basket_item->getCode()); + $this->add_field("amount_$id", $basket_item->cost_per); + $this->add_field("quantity_$id",$basket_item->quantity); + $id++; + } + + // shipping address + $this->add_field("payer_email", $session_basket->email); + $this->add_field("address_name", $session_basket->name); + $this->add_field("address_street", $session_basket->house." ".$session_basket->street); + $this->add_field("address_city", $session_basket->town); + $this->add_field("address_zip", $session_basket->postcode); + $this->add_field("contact_phone", $session_basket->phone); + + $string = ""; + return $string; + } + + function validate_ipn($key) { + + // parse the paypal URL + $url_parsed=parse_url($this->paypal_url); + + // generate the post string from the _POST vars aswell as load the + // _POST vars into an arry so we can play with them from the calling + // script. + $post_string = 'cmd=_notify-validate'; + foreach ($_POST as $field=>$value) { + $this->ipn_data["$field"] = $value; + $value = urlencode(stripslashes($value)); + $value = preg_replace('/(.*[^%^0^D])(%0A)(.*)/i','${1}%0D%0A${3}',$value); + $post_string .= '&'.$field.'='.$value; + } + + // open the connection to paypal + + $fp = fsockopen($this->secure_url,443,$err_num,$err_str,30); + if(!$fp) { + + // could not open the connection. If loggin is on, the error message + // will be in the log. + $this->last_error = "fsockopen error no. $errnum: $errstr"; + $this->log_ipn_results($key,false); + return false; + + } else { + + // Post the data back to paypal + fputs($fp, "POST ".$url_parsed['path']." HTTP/1.1\r\n"); + fputs($fp, "Host: ".$url_parsed['host']."\r\n"); + fputs($fp, "Content-type: application/x-www-form-urlencoded\r\n"); + + fputs($fp, "Content-length: ".strlen($post_string)."\r\n\r\n"); + //fputs($fp, "Connection: close\r\n\r\n"); + fputs($fp, $post_string . "\r\n\r\n"); + + // loop through the response from the server and append to variable + while(!feof($fp)) { + $this->ipn_response .= fgets($fp, 1024); + } + + fclose($fp); // close connection + + } + + if (stristr($this->ipn_response,"VERIFIED")===false) + { + // Invalid IPN transaction. Check the log for details. + $this->last_error = 'IPN Validation Failed. '.$url_parsed['host'].'\\'.$url_parsed['path']; + $this->log_ipn_results($key,false); + return false; + } + else{ + + // Valid IPN transaction. + + // check recievers e-mail + $business = basket::getPaypalAccount(); + + if ($this->ipn_data['receiver_email']!=$business) + { + $this->last_error = 'receivers e-mail did not match '.$business; + $this->log_ipn_results($key,false); + return false; + } + + // if confirmed check message has not been received already + if ($this->ipn_data['payment_status'] == "Completed"){ + + $message = ORM::factory("ipn_message") + ->where('key',"=",$key) + ->where('status',"=",'completed') + ->where('txn_id',"=",$this->ipn_data['txn_id'])->find(); + + if ($message->loaded()){ + $this->last_error = 'Message alread received.'; + $this->log_ipn_results($key,false); + return false; + } + } + + $this->log_ipn_results($key,true); + return true; + + } + + } + + function log_ipn_results($key, $success) { + + // Timestamp + $text = '['.date('m/d/Y g:i A').'] - '; + + $message = ORM::factory("ipn_message"); + $message->date = time(); + $message->key = $key; + $message->txn_id = $this->ipn_data['txn_id']; + $message->status = $this->ipn_data['payment_status']; + $message->success = $success; + + // Success or failure being logged? + if ($success) $text .= "SUCCESS!\n"; + else $text .= 'FAIL: '.$this->last_error."\n"; + + // Log the POST variables + $text .= "IPN POST Vars from Paypal:\n"; + foreach ($this->ipn_data as $key=>$value) { + $text .= "$key=$value \n"; + } + + // Log the response from the paypal server + $text .= "\nIPN Response from Paypal Server:\n ".$this->ipn_response; + + $message->text = $text; + $message->save(); + } + + function dump_fields() { + + // Used for debugging, this function will output all the field/value pairs + // that are currently defined in the instance of the class using the + // add_field() function. + + echo "Field Name | +Value | +
$key | ".urldecode($value)." |
- = t("Use this page to configure the shopping basket. If you have paypal you can use this to processs the final payments.") ?> -
- = $form ?> += t("Use this page to configure the shopping basket. If you have paypal you can use this to processs the final payments.") ?> +
+= $form ?>