diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..e9c37ab
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,14 @@
+
+build
+.DS_Store
+*.log
+
+# IDE
+.project
+.settings
+.buildpath
+*.bak
+
+# Composer
+vendor
+composer.lock
diff --git a/CHANGELOG.md b/CHANGELOG.md
new file mode 100644
index 0000000..ec7af6f
--- /dev/null
+++ b/CHANGELOG.md
@@ -0,0 +1,7 @@
+CHANGELOG
+=========
+
+V0.5.0 (March 07, 2013)
+-----------------------
+
+ * Initial Release
diff --git a/LICENSE.txt b/LICENSE.txt
new file mode 100644
index 0000000..ad030e5
--- /dev/null
+++ b/LICENSE.txt
@@ -0,0 +1,41 @@
+PAYPAL, INC.
+
+SDK LICENSE
+
+NOTICE TO USER: PayPal, Inc. is providing the Software and Documentation for use under the terms of this Agreement. Any use, reproduction, modification or distribution of the Software or Documentation, or any derivatives or portions hereof, constitutes your acceptance of this Agreement.
+
+As used in this Agreement, "PayPal" means PayPal, Inc. "Software" means the software code accompanying this agreement. "Documentation" means the documents, specifications and all other items accompanying this Agreement other than the Software.
+
+1. LICENSE GRANT Subject to the terms of this Agreement, PayPal hereby grants you a non-exclusive, worldwide, royalty free license to use, reproduce, prepare derivative works from, publicly display, publicly perform, distribute and sublicense the Software for any purpose, provided the copyright notice below appears in a conspicuous location within the source code of the distributed Software and this license is distributed in the supporting documentation of the Software you distribute. Furthermore, you must comply with all third party licenses in order to use the third party software contained in the Software.
+
+Subject to the terms of this Agreement, PayPal hereby grants you a non-exclusive, worldwide, royalty free license to use, reproduce, publicly display, publicly perform, distribute and sublicense the Documentation for any purpose. You may not modify the Documentation.
+
+No title to the intellectual property in the Software or Documentation is transferred to you under the terms of this Agreement. You do not acquire any rights to the Software or the Documentation except as expressly set forth in this Agreement.
+
+If you choose to distribute the Software in a commercial product, you do so with the understanding that you agree to defend, indemnify and hold harmless PayPal and its suppliers against any losses, damages and costs arising from the claims, lawsuits or other legal actions arising out of such distribution. You may distribute the Software in object code form under your own license, provided that your license agreement:
+
+(a) complies with the terms and conditions of this license agreement;
+
+(b) effectively disclaims all warranties and conditions, express or implied, on behalf of PayPal;
+
+(c) effectively excludes all liability for damages on behalf of PayPal;
+
+(d) states that any provisions that differ from this Agreement are offered by you alone and not PayPal; and
+
+(e) states that the Software is available from you or PayPal and informs licensees how to obtain it in a reasonable manner on or through a medium customarily used for software exchange.
+
+2. DISCLAIMER OF WARRANTY
+PAYPAL LICENSES THE SOFTWARE AND DOCUMENTATION TO YOU ONLY ON AN "AS IS" BASIS WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. PAYPAL MAKES NO WARRANTY THAT THE SOFTWARE OR DOCUMENTATION WILL BE ERROR-FREE. Each user of the Software or Documentation is solely responsible for determining the appropriateness of using and distributing the Software and Documentation and assumes all risks associated with its exercise of rights under this Agreement, including but not limited to the risks and costs of program errors, compliance with applicable laws, damage to or loss of data, programs, or equipment, and unavailability or interruption of operations. Use of the Software and Documentation is made with the understanding that PayPal will not provide you with any technical or customer support or maintenance. Some states or jurisdictions do not allow the exclusion of implied warranties or limitations on how long an implied warranty may last, so the above limitations may not apply to you. To the extent permissible, any implied warranties are limited to ninety (90) days.
+
+
+3. LIMITATION OF LIABILITY
+PAYPAL AND ITS SUPPLIERS SHALL NOT BE LIABLE FOR LOSS OR DAMAGE ARISING OUT OF THIS AGREEMENT OR FROM THE USE OF THE SOFTWARE OR DOCUMENTATION. IN NO EVENT WILL PAYPAL OR ITS SUPPLIERS BE LIABLE TO YOU OR ANY THIRD PARTY FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, INCIDENTAL, OR SPECIAL DAMAGES INCLUDING LOST PROFITS, LOST SAVINGS, COSTS, FEES, OR EXPENSES OF ANY KIND ARISING OUT OF ANY PROVISION OF THIS AGREEMENT OR THE USE OR THE INABILITY TO USE THE SOFTWARE OR DOCUMENTATION, HOWEVER CAUSED AND UNDER ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR TORT INCLUDING NEGLIGENCE OR OTHERWISE), EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. PAYPAL'S AGGREGATE LIABILITY AND THAT OF ITS SUPPLIERS UNDER OR IN CONNECTION WITH THIS AGREEMENT SHALL BE LIMITED TO THE AMOUNT PAID BY YOU FOR THE SOFTWARE AND DOCUMENTATION.
+
+4. TRADEMARK USAGE
+PayPal is a trademark PayPal, Inc. in the United States and other countries. Such trademarks may not be used to endorse or promote any product unless expressly permitted under separate agreement with PayPal.
+
+5. TERM
+Your rights under this Agreement shall terminate if you fail to comply with any of the material terms or conditions of this Agreement and do not cure such failure in a reasonable period of time after becoming aware of such noncompliance. If all your rights under this Agreement terminate, you agree to cease use and distribution of the Software and Documentation as soon as reasonably practicable.
+
+6. GOVERNING LAW AND JURISDICTION. This Agreement is governed by the statutes and laws of the State of California, without regard to the conflicts of law principles thereof. If any part of this Agreement is found void and unenforceable, it will not affect the validity of the balance of the Agreement, which shall remain valid and enforceable according to its terms. Any dispute arising out of or related to this Agreement shall be brought in the courts of Santa Clara County, California, USA.
+
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..cbb0ff8
--- /dev/null
+++ b/README.md
@@ -0,0 +1,61 @@
+REST API SDK for PHP (V0.5.0)
+==============================
+
+ PayPal's PHP SDK for the RESTful APIs
+
+
+Prerequisites
+-------------
+
+ * PHP 5.3 or above
+ * curl, json & openssl extensions must be enabled
+ * composer for running the sample out of the box (See http://getcomposer.org)
+
+
+Running the sample
+------------------
+
+ * Ensure that you have composer installed on your machine.
+ * Navigate to the samples folder and run 'composer update'.
+ * Optionally, update the sdk_config.ini file with your own client Id and client secret.
+ * Run any of the command line samples in the folder to see what the APIs can do.
+
+
+Usage
+-----
+
+To write an app that uses the SDK
+
+ * Copy the composer.json file from the sample folder over to your project and run 'composer update' to fetch all
+dependencies
+ * Copy the sample configuration file sdk_config.ini to a location of your choice and let the SDK know your config path using the following define directive
+
+ define('PP_SDK_CONFIG_PATH', /path/to/your/sdk_config.ini);
+
+ * Obtain your clientId and client secret from the developer portal and add them to your config file
+ * Now you are all set to make your first API call. Create a resource object as per your need and call the relevant operation or invoke one of the static methods on your resource class.
+
+ $payment = new Payment();
+
+ $payment->setIntent("Sale");
+
+ ...
+
+ $payment->create();
+
+ *OR*
+
+ $payment = Payment::get('payment_id');
+
+ These examples pick the client id / secret automatically from your config file. You can also set API credentials dynamically. See the sample code for how you can do this.
+
+
+Contributing
+------------
+
+More help
+---------
+
+ * API Reference
+ * Reporting issues / feature requests
+
diff --git a/build.xml b/build.xml
new file mode 100644
index 0000000..5c927f4
--- /dev/null
+++ b/build.xml
@@ -0,0 +1,69 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Composer is installed
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/composer.json b/composer.json
new file mode 100644
index 0000000..8cd0749
--- /dev/null
+++ b/composer.json
@@ -0,0 +1,28 @@
+{
+ "name": "paypal/rest-api-sdk-php",
+ "description": "PayPal's PHP SDK for REST APIs",
+ "keywords": ["paypal", "payments", "rest", "sdk"],
+ "type": "library",
+ "license": "Apache2",
+ "homepage": "https://github.com/paypal/rest-api-sdk-php",
+ "authors": [
+ {
+ "name": "PayPal",
+ "homepage": "https://github.com/paypal/rest-api-sdk-php/contributors"
+ }
+ ],
+ "require": {
+ "php": ">=5.3.0",
+ "ext-curl": "*",
+ "ext-json": "*",
+ "paypal/sdk-core-php": "1.2.*"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "3.7.*"
+ },
+ "autoload": {
+ "psr-0": {
+ "PayPal": "lib/"
+ }
+ }
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Address.php b/lib/PayPal/Api/Address.php
new file mode 100644
index 0000000..70f0376
--- /dev/null
+++ b/lib/PayPal/Api/Address.php
@@ -0,0 +1,132 @@
+line1 = $line1;
+ }
+
+ /**
+ * Getter for line1
+ */
+ public function getLine1() {
+ return $this->line1;
+ }
+
+ /**
+ * Setter for line2
+ * @param string $line2
+ */
+ public function setLine2($line2) {
+ $this->line2 = $line2;
+ }
+
+ /**
+ * Getter for line2
+ */
+ public function getLine2() {
+ return $this->line2;
+ }
+
+ /**
+ * Setter for city
+ * @param string $city
+ */
+ public function setCity($city) {
+ $this->city = $city;
+ }
+
+ /**
+ * Getter for city
+ */
+ public function getCity() {
+ return $this->city;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for postal_code
+ * @param string $postal_code
+ */
+ public function setPostal_code($postal_code) {
+ $this->postal_code = $postal_code;
+ }
+
+ /**
+ * Getter for postal_code
+ */
+ public function getPostal_code() {
+ return $this->postal_code;
+ }
+
+ /**
+ * Setter for country_code
+ * @param string $country_code
+ */
+ public function setCountry_code($country_code) {
+ $this->country_code = $country_code;
+ }
+
+ /**
+ * Getter for country_code
+ */
+ public function getCountry_code() {
+ return $this->country_code;
+ }
+
+ /**
+ * Setter for type
+ * @param string $type
+ */
+ public function setType($type) {
+ $this->type = $type;
+ }
+
+ /**
+ * Getter for type
+ */
+ public function getType() {
+ return $this->type;
+ }
+
+ /**
+ * Setter for phone
+ * @param string $phone
+ */
+ public function setPhone($phone) {
+ $this->phone = $phone;
+ }
+
+ /**
+ * Getter for phone
+ */
+ public function getPhone() {
+ return $this->phone;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Amount.php b/lib/PayPal/Api/Amount.php
new file mode 100644
index 0000000..ad7191d
--- /dev/null
+++ b/lib/PayPal/Api/Amount.php
@@ -0,0 +1,57 @@
+total = $total;
+ }
+
+ /**
+ * Getter for total
+ */
+ public function getTotal() {
+ return $this->total;
+ }
+
+ /**
+ * Setter for currency
+ * @param string $currency
+ */
+ public function setCurrency($currency) {
+ $this->currency = $currency;
+ }
+
+ /**
+ * Getter for currency
+ */
+ public function getCurrency() {
+ return $this->currency;
+ }
+
+ /**
+ * Setter for details
+ * @param PayPal\Api\AmountDetails $details
+ */
+ public function setDetails($details) {
+ $this->details = $details;
+ }
+
+ /**
+ * Getter for details
+ */
+ public function getDetails() {
+ return $this->details;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/AmountDetails.php b/lib/PayPal/Api/AmountDetails.php
new file mode 100644
index 0000000..65e5a33
--- /dev/null
+++ b/lib/PayPal/Api/AmountDetails.php
@@ -0,0 +1,72 @@
+subtotal = $subtotal;
+ }
+
+ /**
+ * Getter for subtotal
+ */
+ public function getSubtotal() {
+ return $this->subtotal;
+ }
+
+ /**
+ * Setter for tax
+ * @param string $tax
+ */
+ public function setTax($tax) {
+ $this->tax = $tax;
+ }
+
+ /**
+ * Getter for tax
+ */
+ public function getTax() {
+ return $this->tax;
+ }
+
+ /**
+ * Setter for shipping
+ * @param string $shipping
+ */
+ public function setShipping($shipping) {
+ $this->shipping = $shipping;
+ }
+
+ /**
+ * Getter for shipping
+ */
+ public function getShipping() {
+ return $this->shipping;
+ }
+
+ /**
+ * Setter for fee
+ * @param string $fee
+ */
+ public function setFee($fee) {
+ $this->fee = $fee;
+ }
+
+ /**
+ * Getter for fee
+ */
+ public function getFee() {
+ return $this->fee;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Authorization.php b/lib/PayPal/Api/Authorization.php
new file mode 100644
index 0000000..3b4b82c
--- /dev/null
+++ b/lib/PayPal/Api/Authorization.php
@@ -0,0 +1,117 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for create_time
+ * @param string $create_time
+ */
+ public function setCreate_time($create_time) {
+ $this->create_time = $create_time;
+ }
+
+ /**
+ * Getter for create_time
+ */
+ public function getCreate_time() {
+ return $this->create_time;
+ }
+
+ /**
+ * Setter for update_time
+ * @param string $update_time
+ */
+ public function setUpdate_time($update_time) {
+ $this->update_time = $update_time;
+ }
+
+ /**
+ * Getter for update_time
+ */
+ public function getUpdate_time() {
+ return $this->update_time;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for amount
+ * @param PayPal\Api\Amount $amount
+ */
+ public function setAmount($amount) {
+ $this->amount = $amount;
+ }
+
+ /**
+ * Getter for amount
+ */
+ public function getAmount() {
+ return $this->amount;
+ }
+
+ /**
+ * Setter for parent_payment
+ * @param string $parent_payment
+ */
+ public function setParent_payment($parent_payment) {
+ $this->parent_payment = $parent_payment;
+ }
+
+ /**
+ * Getter for parent_payment
+ */
+ public function getParent_payment() {
+ return $this->parent_payment;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Capture.php b/lib/PayPal/Api/Capture.php
new file mode 100644
index 0000000..3c36e5a
--- /dev/null
+++ b/lib/PayPal/Api/Capture.php
@@ -0,0 +1,147 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for create_time
+ * @param string $create_time
+ */
+ public function setCreate_time($create_time) {
+ $this->create_time = $create_time;
+ }
+
+ /**
+ * Getter for create_time
+ */
+ public function getCreate_time() {
+ return $this->create_time;
+ }
+
+ /**
+ * Setter for update_time
+ * @param string $update_time
+ */
+ public function setUpdate_time($update_time) {
+ $this->update_time = $update_time;
+ }
+
+ /**
+ * Getter for update_time
+ */
+ public function getUpdate_time() {
+ return $this->update_time;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for amount
+ * @param PayPal\Api\Amount $amount
+ */
+ public function setAmount($amount) {
+ $this->amount = $amount;
+ }
+
+ /**
+ * Getter for amount
+ */
+ public function getAmount() {
+ return $this->amount;
+ }
+
+ /**
+ * Setter for parent_payment
+ * @param string $parent_payment
+ */
+ public function setParent_payment($parent_payment) {
+ $this->parent_payment = $parent_payment;
+ }
+
+ /**
+ * Getter for parent_payment
+ */
+ public function getParent_payment() {
+ return $this->parent_payment;
+ }
+
+ /**
+ * Setter for authorization_id
+ * @param string $authorization_id
+ */
+ public function setAuthorization_id($authorization_id) {
+ $this->authorization_id = $authorization_id;
+ }
+
+ /**
+ * Getter for authorization_id
+ */
+ public function getAuthorization_id() {
+ return $this->authorization_id;
+ }
+
+ /**
+ * Setter for description
+ * @param string $description
+ */
+ public function setDescription($description) {
+ $this->description = $description;
+ }
+
+ /**
+ * Getter for description
+ */
+ public function getDescription() {
+ return $this->description;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/CreditCard.php b/lib/PayPal/Api/CreditCard.php
new file mode 100644
index 0000000..7486242
--- /dev/null
+++ b/lib/PayPal/Api/CreditCard.php
@@ -0,0 +1,253 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for valid_until
+ * @param string $valid_until
+ */
+ public function setValid_until($valid_until) {
+ $this->valid_until = $valid_until;
+ }
+
+ /**
+ * Getter for valid_until
+ */
+ public function getValid_until() {
+ return $this->valid_until;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for payer_id
+ * @param string $payer_id
+ */
+ public function setPayer_id($payer_id) {
+ $this->payer_id = $payer_id;
+ }
+
+ /**
+ * Getter for payer_id
+ */
+ public function getPayer_id() {
+ return $this->payer_id;
+ }
+
+ /**
+ * Setter for type
+ * @param string $type
+ */
+ public function setType($type) {
+ $this->type = $type;
+ }
+
+ /**
+ * Getter for type
+ */
+ public function getType() {
+ return $this->type;
+ }
+
+ /**
+ * Setter for number
+ * @param string $number
+ */
+ public function setNumber($number) {
+ $this->number = $number;
+ }
+
+ /**
+ * Getter for number
+ */
+ public function getNumber() {
+ return $this->number;
+ }
+
+ /**
+ * Setter for expire_month
+ * @param string $expire_month
+ */
+ public function setExpire_month($expire_month) {
+ $this->expire_month = $expire_month;
+ }
+
+ /**
+ * Getter for expire_month
+ */
+ public function getExpire_month() {
+ return $this->expire_month;
+ }
+
+ /**
+ * Setter for expire_year
+ * @param string $expire_year
+ */
+ public function setExpire_year($expire_year) {
+ $this->expire_year = $expire_year;
+ }
+
+ /**
+ * Getter for expire_year
+ */
+ public function getExpire_year() {
+ return $this->expire_year;
+ }
+
+ /**
+ * Setter for cvv2
+ * @param string $cvv2
+ */
+ public function setCvv2($cvv2) {
+ $this->cvv2 = $cvv2;
+ }
+
+ /**
+ * Getter for cvv2
+ */
+ public function getCvv2() {
+ return $this->cvv2;
+ }
+
+ /**
+ * Setter for first_name
+ * @param string $first_name
+ */
+ public function setFirst_name($first_name) {
+ $this->first_name = $first_name;
+ }
+
+ /**
+ * Getter for first_name
+ */
+ public function getFirst_name() {
+ return $this->first_name;
+ }
+
+ /**
+ * Setter for last_name
+ * @param string $last_name
+ */
+ public function setLast_name($last_name) {
+ $this->last_name = $last_name;
+ }
+
+ /**
+ * Getter for last_name
+ */
+ public function getLast_name() {
+ return $this->last_name;
+ }
+
+ /**
+ * Setter for billing_address
+ * @param PayPal\Api\Address $billing_address
+ */
+ public function setBilling_address($billing_address) {
+ $this->billing_address = $billing_address;
+ }
+
+ /**
+ * Getter for billing_address
+ */
+ public function getBilling_address() {
+ return $this->billing_address;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+
+ /**
+ * @path /v1/vault/credit-card
+ * @method POST
+
+ * @param PayPal\Rest\ApiContext $apiContext optional
+ */
+ public function create( $apiContext=null) {
+ $payLoad = $this->toJSON();
+ if($apiContext == null) {
+ $apiContext = new ApiContext(self::$credential);
+ }
+ $call = new Call();
+ $json = $call->execute("/v1/vault/credit-card", "POST", $payLoad, $apiContext);
+ $this->fromJson($json);
+ return $this;
+ }
+
+ /**
+ * @path /v1/vault/credit-card/:credit-card-id
+ * @method GET
+ * @param string $creditcardid
+ */
+ public static function get( $creditcardid) {
+ if (($creditcardid == null) || (strlen($creditcardid) <= 0)) {
+ throw new \InvalidArgumentException("creditcardid cannot be null or empty");
+ }
+ $payLoad = "";
+
+ $apiContext = new ApiContext(self::$credential); $call = new Call();
+ $json = $call->execute("/v1/vault/credit-card/$creditcardid", "GET", $payLoad, $apiContext);
+ $ret = new CreditCard();
+ $ret->fromJson($json);
+ return $ret;
+
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/CreditCardToken.php b/lib/PayPal/Api/CreditCardToken.php
new file mode 100644
index 0000000..7ca48f1
--- /dev/null
+++ b/lib/PayPal/Api/CreditCardToken.php
@@ -0,0 +1,42 @@
+credit_card_id = $credit_card_id;
+ }
+
+ /**
+ * Getter for credit_card_id
+ */
+ public function getCredit_card_id() {
+ return $this->credit_card_id;
+ }
+
+ /**
+ * Setter for payer_id
+ * @param string $payer_id
+ */
+ public function setPayer_id($payer_id) {
+ $this->payer_id = $payer_id;
+ }
+
+ /**
+ * Getter for payer_id
+ */
+ public function getPayer_id() {
+ return $this->payer_id;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/FundingInstrument.php b/lib/PayPal/Api/FundingInstrument.php
new file mode 100644
index 0000000..7fc07a0
--- /dev/null
+++ b/lib/PayPal/Api/FundingInstrument.php
@@ -0,0 +1,42 @@
+credit_card = $credit_card;
+ }
+
+ /**
+ * Getter for credit_card
+ */
+ public function getCredit_card() {
+ return $this->credit_card;
+ }
+
+ /**
+ * Setter for credit_card_token
+ * @param PayPal\Api\CreditCardToken $credit_card_token
+ */
+ public function setCredit_card_token($credit_card_token) {
+ $this->credit_card_token = $credit_card_token;
+ }
+
+ /**
+ * Getter for credit_card_token
+ */
+ public function getCredit_card_token() {
+ return $this->credit_card_token;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Item.php b/lib/PayPal/Api/Item.php
new file mode 100644
index 0000000..7d547ae
--- /dev/null
+++ b/lib/PayPal/Api/Item.php
@@ -0,0 +1,87 @@
+name = $name;
+ }
+
+ /**
+ * Getter for name
+ */
+ public function getName() {
+ return $this->name;
+ }
+
+ /**
+ * Setter for sku
+ * @param string $sku
+ */
+ public function setSku($sku) {
+ $this->sku = $sku;
+ }
+
+ /**
+ * Getter for sku
+ */
+ public function getSku() {
+ return $this->sku;
+ }
+
+ /**
+ * Setter for price
+ * @param string $price
+ */
+ public function setPrice($price) {
+ $this->price = $price;
+ }
+
+ /**
+ * Getter for price
+ */
+ public function getPrice() {
+ return $this->price;
+ }
+
+ /**
+ * Setter for currency
+ * @param string $currency
+ */
+ public function setCurrency($currency) {
+ $this->currency = $currency;
+ }
+
+ /**
+ * Getter for currency
+ */
+ public function getCurrency() {
+ return $this->currency;
+ }
+
+ /**
+ * Setter for quantity
+ * @param string $quantity
+ */
+ public function setQuantity($quantity) {
+ $this->quantity = $quantity;
+ }
+
+ /**
+ * Getter for quantity
+ */
+ public function getQuantity() {
+ return $this->quantity;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/ItemList.php b/lib/PayPal/Api/ItemList.php
new file mode 100644
index 0000000..2c7fe18
--- /dev/null
+++ b/lib/PayPal/Api/ItemList.php
@@ -0,0 +1,42 @@
+items = $items;
+ }
+
+ /**
+ * Getter for items
+ */
+ public function getItems() {
+ return $this->items;
+ }
+
+ /**
+ * Setter for shipping_address
+ * @param PayPal\Api\ShippingAddress $shipping_address
+ */
+ public function setShipping_address($shipping_address) {
+ $this->shipping_address = $shipping_address;
+ }
+
+ /**
+ * Getter for shipping_address
+ */
+ public function getShipping_address() {
+ return $this->shipping_address;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Link.php b/lib/PayPal/Api/Link.php
new file mode 100644
index 0000000..643c95c
--- /dev/null
+++ b/lib/PayPal/Api/Link.php
@@ -0,0 +1,57 @@
+href = $href;
+ }
+
+ /**
+ * Getter for href
+ */
+ public function getHref() {
+ return $this->href;
+ }
+
+ /**
+ * Setter for rel
+ * @param string $rel
+ */
+ public function setRel($rel) {
+ $this->rel = $rel;
+ }
+
+ /**
+ * Getter for rel
+ */
+ public function getRel() {
+ return $this->rel;
+ }
+
+ /**
+ * Setter for method
+ * @param string $method
+ */
+ public function setMethod($method) {
+ $this->method = $method;
+ }
+
+ /**
+ * Getter for method
+ */
+ public function getMethod() {
+ return $this->method;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Payee.php b/lib/PayPal/Api/Payee.php
new file mode 100644
index 0000000..ab3cba3
--- /dev/null
+++ b/lib/PayPal/Api/Payee.php
@@ -0,0 +1,57 @@
+merchant_id = $merchant_id;
+ }
+
+ /**
+ * Getter for merchant_id
+ */
+ public function getMerchant_id() {
+ return $this->merchant_id;
+ }
+
+ /**
+ * Setter for email
+ * @param string $email
+ */
+ public function setEmail($email) {
+ $this->email = $email;
+ }
+
+ /**
+ * Getter for email
+ */
+ public function getEmail() {
+ return $this->email;
+ }
+
+ /**
+ * Setter for phone
+ * @param string $phone
+ */
+ public function setPhone($phone) {
+ $this->phone = $phone;
+ }
+
+ /**
+ * Getter for phone
+ */
+ public function getPhone() {
+ return $this->phone;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Payer.php b/lib/PayPal/Api/Payer.php
new file mode 100644
index 0000000..f083087
--- /dev/null
+++ b/lib/PayPal/Api/Payer.php
@@ -0,0 +1,57 @@
+payment_method = $payment_method;
+ }
+
+ /**
+ * Getter for payment_method
+ */
+ public function getPayment_method() {
+ return $this->payment_method;
+ }
+
+ /**
+ * Setter for payer_info
+ * @param PayPal\Api\PayerInfo $payer_info
+ */
+ public function setPayer_info($payer_info) {
+ $this->payer_info = $payer_info;
+ }
+
+ /**
+ * Getter for payer_info
+ */
+ public function getPayer_info() {
+ return $this->payer_info;
+ }
+
+ /**
+ * Setter for funding_instruments
+ * @param PayPal\Api\FundingInstrument $funding_instruments
+ */
+ public function setFunding_instruments($funding_instruments) {
+ $this->funding_instruments = $funding_instruments;
+ }
+
+ /**
+ * Getter for funding_instruments
+ */
+ public function getFunding_instruments() {
+ return $this->funding_instruments;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/PayerInfo.php b/lib/PayPal/Api/PayerInfo.php
new file mode 100644
index 0000000..5d6a108
--- /dev/null
+++ b/lib/PayPal/Api/PayerInfo.php
@@ -0,0 +1,102 @@
+email = $email;
+ }
+
+ /**
+ * Getter for email
+ */
+ public function getEmail() {
+ return $this->email;
+ }
+
+ /**
+ * Setter for first_name
+ * @param string $first_name
+ */
+ public function setFirst_name($first_name) {
+ $this->first_name = $first_name;
+ }
+
+ /**
+ * Getter for first_name
+ */
+ public function getFirst_name() {
+ return $this->first_name;
+ }
+
+ /**
+ * Setter for last_name
+ * @param string $last_name
+ */
+ public function setLast_name($last_name) {
+ $this->last_name = $last_name;
+ }
+
+ /**
+ * Getter for last_name
+ */
+ public function getLast_name() {
+ return $this->last_name;
+ }
+
+ /**
+ * Setter for payer_id
+ * @param string $payer_id
+ */
+ public function setPayer_id($payer_id) {
+ $this->payer_id = $payer_id;
+ }
+
+ /**
+ * Getter for payer_id
+ */
+ public function getPayer_id() {
+ return $this->payer_id;
+ }
+
+ /**
+ * Setter for shipping_address
+ * @param PayPal\Api\Address $shipping_address
+ */
+ public function setShipping_address($shipping_address) {
+ $this->shipping_address = $shipping_address;
+ }
+
+ /**
+ * Getter for shipping_address
+ */
+ public function getShipping_address() {
+ return $this->shipping_address;
+ }
+
+ /**
+ * Setter for phone
+ * @param string $phone
+ */
+ public function setPhone($phone) {
+ $this->phone = $phone;
+ }
+
+ /**
+ * Getter for phone
+ */
+ public function getPhone() {
+ return $this->phone;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Payment.php b/lib/PayPal/Api/Payment.php
new file mode 100644
index 0000000..a736b59
--- /dev/null
+++ b/lib/PayPal/Api/Payment.php
@@ -0,0 +1,244 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for create_time
+ * @param string $create_time
+ */
+ public function setCreate_time($create_time) {
+ $this->create_time = $create_time;
+ }
+
+ /**
+ * Getter for create_time
+ */
+ public function getCreate_time() {
+ return $this->create_time;
+ }
+
+ /**
+ * Setter for update_time
+ * @param string $update_time
+ */
+ public function setUpdate_time($update_time) {
+ $this->update_time = $update_time;
+ }
+
+ /**
+ * Getter for update_time
+ */
+ public function getUpdate_time() {
+ return $this->update_time;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for intent
+ * @param string $intent
+ */
+ public function setIntent($intent) {
+ $this->intent = $intent;
+ }
+
+ /**
+ * Getter for intent
+ */
+ public function getIntent() {
+ return $this->intent;
+ }
+
+ /**
+ * Setter for payer
+ * @param PayPal\Api\Payer $payer
+ */
+ public function setPayer($payer) {
+ $this->payer = $payer;
+ }
+
+ /**
+ * Getter for payer
+ */
+ public function getPayer() {
+ return $this->payer;
+ }
+
+ /**
+ * Setter for transactions
+ * @param PayPal\Api\Transaction $transactions
+ */
+ public function setTransactions($transactions) {
+ $this->transactions = $transactions;
+ }
+
+ /**
+ * Getter for transactions
+ */
+ public function getTransactions() {
+ return $this->transactions;
+ }
+
+ /**
+ * Setter for redirect_urls
+ * @param PayPal\Api\RedirectUrls $redirect_urls
+ */
+ public function setRedirect_urls($redirect_urls) {
+ $this->redirect_urls = $redirect_urls;
+ }
+
+ /**
+ * Getter for redirect_urls
+ */
+ public function getRedirect_urls() {
+ return $this->redirect_urls;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+
+ /**
+ * @path /v1/payments/payment
+ * @method GET
+ * @param array $params
+ * array containing the query strings with the
+ * following values as keys:
+ * count,
+ * start_id,
+ * start_index,
+ * start_time,
+ * end_time,
+ * payee_id,
+ * sort_by,
+ * sort_order,
+ * All other keys in the map are ignored by the SDK
+ */
+ public static function all($params) {
+ $payLoad = "";
+ $allowedParams = array('count' => 1, 'start_id' => 1, 'start_index' => 1, 'start_time' => 1, 'end_time' => 1, 'payee_id' => 1, 'sort_by' => 1, 'sort_order' => 1, );
+
+ $apiContext = new ApiContext(self::$credential); $call = new Call();
+ $json = $call->execute("/v1/payments/payment?" . http_build_query(array_intersect_key($params, $allowedParams)), "GET", $payLoad, $apiContext);
+ $ret = new PaymentHistory();
+ $ret->fromJson($json);
+ return $ret;
+
+ }
+
+ /**
+ * @path /v1/payments/payment
+ * @method POST
+
+ * @param PayPal\Rest\ApiContext $apiContext optional
+ */
+ public function create( $apiContext=null) {
+ $payLoad = $this->toJSON();
+ if($apiContext == null) {
+ $apiContext = new ApiContext(self::$credential);
+ }
+ $call = new Call();
+ $json = $call->execute("/v1/payments/payment", "POST", $payLoad, $apiContext);
+ $this->fromJson($json);
+ return $this;
+ }
+
+ /**
+ * @path /v1/payments/payment/:payment-id
+ * @method GET
+ * @param string $paymentid
+ */
+ public static function get( $paymentid) {
+ if (($paymentid == null) || (strlen($paymentid) <= 0)) {
+ throw new \InvalidArgumentException("paymentid cannot be null or empty");
+ }
+ $payLoad = "";
+
+ $apiContext = new ApiContext(self::$credential); $call = new Call();
+ $json = $call->execute("/v1/payments/payment/$paymentid", "GET", $payLoad, $apiContext);
+ $ret = new Payment();
+ $ret->fromJson($json);
+ return $ret;
+
+ }
+
+ /**
+ * @path /v1/payments/payment/:payment-id/execute
+ * @method POST
+ * @param PaymentExecution $payment_execution
+ * @param PayPal\Rest\ApiContext $apiContext optional
+ */
+ public function execute( $payment_execution, $apiContext=null) {
+ if ($payment_execution == null) {
+ throw new \InvalidArgumentException("payment_execution cannot be null");
+ }
+ if ($this->getId() == null) {
+ throw new \InvalidArgumentException("Id cannot be null");
+ }
+ $payLoad = $payment_execution->toJSON();
+ if($apiContext == null) {
+ $apiContext = new ApiContext(self::$credential);
+ }
+ $call = new Call();
+ $json = $call->execute("/v1/payments/payment/{$this->getId()}/execute", "POST", $payLoad, $apiContext);
+ $this->fromJson($json);
+ return $this;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/PaymentExecution.php b/lib/PayPal/Api/PaymentExecution.php
new file mode 100644
index 0000000..b095a96
--- /dev/null
+++ b/lib/PayPal/Api/PaymentExecution.php
@@ -0,0 +1,42 @@
+payer_id = $payer_id;
+ }
+
+ /**
+ * Getter for payer_id
+ */
+ public function getPayer_id() {
+ return $this->payer_id;
+ }
+
+ /**
+ * Setter for transactions
+ * @param PayPal\Api\Amount $transactions
+ */
+ public function setTransactions($transactions) {
+ $this->transactions = $transactions;
+ }
+
+ /**
+ * Getter for transactions
+ */
+ public function getTransactions() {
+ return $this->transactions;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/PaymentHistory.php b/lib/PayPal/Api/PaymentHistory.php
new file mode 100644
index 0000000..de232c3
--- /dev/null
+++ b/lib/PayPal/Api/PaymentHistory.php
@@ -0,0 +1,57 @@
+payments = $payments;
+ }
+
+ /**
+ * Getter for payments
+ */
+ public function getPayments() {
+ return $this->payments;
+ }
+
+ /**
+ * Setter for count
+ * @param integer $count
+ */
+ public function setCount($count) {
+ $this->count = $count;
+ }
+
+ /**
+ * Getter for count
+ */
+ public function getCount() {
+ return $this->count;
+ }
+
+ /**
+ * Setter for next_id
+ * @param string $next_id
+ */
+ public function setNext_id($next_id) {
+ $this->next_id = $next_id;
+ }
+
+ /**
+ * Getter for next_id
+ */
+ public function getNext_id() {
+ return $this->next_id;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/RedirectUrls.php b/lib/PayPal/Api/RedirectUrls.php
new file mode 100644
index 0000000..2a92f8c
--- /dev/null
+++ b/lib/PayPal/Api/RedirectUrls.php
@@ -0,0 +1,42 @@
+return_url = $return_url;
+ }
+
+ /**
+ * Getter for return_url
+ */
+ public function getReturn_url() {
+ return $this->return_url;
+ }
+
+ /**
+ * Setter for cancel_url
+ * @param string $cancel_url
+ */
+ public function setCancel_url($cancel_url) {
+ $this->cancel_url = $cancel_url;
+ }
+
+ /**
+ * Getter for cancel_url
+ */
+ public function getCancel_url() {
+ return $this->cancel_url;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Refund.php b/lib/PayPal/Api/Refund.php
new file mode 100644
index 0000000..93b14a2
--- /dev/null
+++ b/lib/PayPal/Api/Refund.php
@@ -0,0 +1,191 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for create_time
+ * @param string $create_time
+ */
+ public function setCreate_time($create_time) {
+ $this->create_time = $create_time;
+ }
+
+ /**
+ * Getter for create_time
+ */
+ public function getCreate_time() {
+ return $this->create_time;
+ }
+
+ /**
+ * Setter for update_time
+ * @param string $update_time
+ */
+ public function setUpdate_time($update_time) {
+ $this->update_time = $update_time;
+ }
+
+ /**
+ * Getter for update_time
+ */
+ public function getUpdate_time() {
+ return $this->update_time;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for amount
+ * @param PayPal\Api\Amount $amount
+ */
+ public function setAmount($amount) {
+ $this->amount = $amount;
+ }
+
+ /**
+ * Getter for amount
+ */
+ public function getAmount() {
+ return $this->amount;
+ }
+
+ /**
+ * Setter for sale_id
+ * @param string $sale_id
+ */
+ public function setSale_id($sale_id) {
+ $this->sale_id = $sale_id;
+ }
+
+ /**
+ * Getter for sale_id
+ */
+ public function getSale_id() {
+ return $this->sale_id;
+ }
+
+ /**
+ * Setter for capture_id
+ * @param string $capture_id
+ */
+ public function setCapture_id($capture_id) {
+ $this->capture_id = $capture_id;
+ }
+
+ /**
+ * Getter for capture_id
+ */
+ public function getCapture_id() {
+ return $this->capture_id;
+ }
+
+ /**
+ * Setter for parent_payment
+ * @param string $parent_payment
+ */
+ public function setParent_payment($parent_payment) {
+ $this->parent_payment = $parent_payment;
+ }
+
+ /**
+ * Getter for parent_payment
+ */
+ public function getParent_payment() {
+ return $this->parent_payment;
+ }
+
+ /**
+ * Setter for description
+ * @param string $description
+ */
+ public function setDescription($description) {
+ $this->description = $description;
+ }
+
+ /**
+ * Getter for description
+ */
+ public function getDescription() {
+ return $this->description;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+
+ /**
+ * @path /v1/payments/refund/:refund-id
+ * @method GET
+ * @param string $refundid
+ */
+ public static function get( $refundid) {
+ if (($refundid == null) || (strlen($refundid) <= 0)) {
+ throw new \InvalidArgumentException("refundid cannot be null or empty");
+ }
+ $payLoad = "";
+
+ $apiContext = new ApiContext(self::$credential); $call = new Call();
+ $json = $call->execute("/v1/payments/refund/$refundid", "GET", $payLoad, $apiContext);
+ $ret = new Refund();
+ $ret->fromJson($json);
+ return $ret;
+
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Resource.php b/lib/PayPal/Api/Resource.php
new file mode 100644
index 0000000..825384a
--- /dev/null
+++ b/lib/PayPal/Api/Resource.php
@@ -0,0 +1,13 @@
+id = $id;
+ }
+
+ /**
+ * Getter for id
+ */
+ public function getId() {
+ return $this->id;
+ }
+
+ /**
+ * Setter for create_time
+ * @param string $create_time
+ */
+ public function setCreate_time($create_time) {
+ $this->create_time = $create_time;
+ }
+
+ /**
+ * Getter for create_time
+ */
+ public function getCreate_time() {
+ return $this->create_time;
+ }
+
+ /**
+ * Setter for update_time
+ * @param string $update_time
+ */
+ public function setUpdate_time($update_time) {
+ $this->update_time = $update_time;
+ }
+
+ /**
+ * Getter for update_time
+ */
+ public function getUpdate_time() {
+ return $this->update_time;
+ }
+
+ /**
+ * Setter for state
+ * @param string $state
+ */
+ public function setState($state) {
+ $this->state = $state;
+ }
+
+ /**
+ * Getter for state
+ */
+ public function getState() {
+ return $this->state;
+ }
+
+ /**
+ * Setter for amount
+ * @param PayPal\Api\Amount $amount
+ */
+ public function setAmount($amount) {
+ $this->amount = $amount;
+ }
+
+ /**
+ * Getter for amount
+ */
+ public function getAmount() {
+ return $this->amount;
+ }
+
+ /**
+ * Setter for parent_payment
+ * @param string $parent_payment
+ */
+ public function setParent_payment($parent_payment) {
+ $this->parent_payment = $parent_payment;
+ }
+
+ /**
+ * Getter for parent_payment
+ */
+ public function getParent_payment() {
+ return $this->parent_payment;
+ }
+
+ /**
+ * Setter for links
+ * @param PayPal\Api\Link $links
+ */
+ public function setLinks($links) {
+ $this->links = $links;
+ }
+
+ /**
+ * Getter for links
+ */
+ public function getLinks() {
+ return $this->links;
+ }
+
+
+
+ /**
+ * @path /v1/payments/sale/:sale-id
+ * @method GET
+ * @param string $saleid
+ */
+ public static function get( $saleid) {
+ if (($saleid == null) || (strlen($saleid) <= 0)) {
+ throw new \InvalidArgumentException("saleid cannot be null or empty");
+ }
+ $payLoad = "";
+
+ $apiContext = new ApiContext(self::$credential); $call = new Call();
+ $json = $call->execute("/v1/payments/sale/$saleid", "GET", $payLoad, $apiContext);
+ $ret = new Sale();
+ $ret->fromJson($json);
+ return $ret;
+
+ }
+
+ /**
+ * @path /v1/payments/sale/:sale-id/refund
+ * @method POST
+ * @param Refund $refund
+ * @param PayPal\Rest\ApiContext $apiContext optional
+ */
+ public function refund( $refund, $apiContext=null) {
+ if ($refund == null) {
+ throw new \InvalidArgumentException("refund cannot be null");
+ }
+ if ($this->getId() == null) {
+ throw new \InvalidArgumentException("Id cannot be null");
+ }
+ $payLoad = $refund->toJSON();
+ if($apiContext == null) {
+ $apiContext = new ApiContext(self::$credential);
+ }
+ $call = new Call();
+ $json = $call->execute("/v1/payments/sale/{$this->getId()}/refund", "POST", $payLoad, $apiContext);
+ $this->fromJson($json);
+ return $this;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/ShippingAddress.php b/lib/PayPal/Api/ShippingAddress.php
new file mode 100644
index 0000000..798df69
--- /dev/null
+++ b/lib/PayPal/Api/ShippingAddress.php
@@ -0,0 +1,27 @@
+recipient_name = $recipient_name;
+ }
+
+ /**
+ * Getter for recipient_name
+ */
+ public function getRecipient_name() {
+ return $this->recipient_name;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/SubTransaction.php b/lib/PayPal/Api/SubTransaction.php
new file mode 100644
index 0000000..4e92a09
--- /dev/null
+++ b/lib/PayPal/Api/SubTransaction.php
@@ -0,0 +1,72 @@
+sale = $sale;
+ }
+
+ /**
+ * Getter for sale
+ */
+ public function getSale() {
+ return $this->sale;
+ }
+
+ /**
+ * Setter for authorization
+ * @param PayPal\Api\Authorization $authorization
+ */
+ public function setAuthorization($authorization) {
+ $this->authorization = $authorization;
+ }
+
+ /**
+ * Getter for authorization
+ */
+ public function getAuthorization() {
+ return $this->authorization;
+ }
+
+ /**
+ * Setter for refund
+ * @param PayPal\Api\Refund $refund
+ */
+ public function setRefund($refund) {
+ $this->refund = $refund;
+ }
+
+ /**
+ * Getter for refund
+ */
+ public function getRefund() {
+ return $this->refund;
+ }
+
+ /**
+ * Setter for capture
+ * @param PayPal\Api\Capture $capture
+ */
+ public function setCapture($capture) {
+ $this->capture = $capture;
+ }
+
+ /**
+ * Getter for capture
+ */
+ public function getCapture() {
+ return $this->capture;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Api/Transaction.php b/lib/PayPal/Api/Transaction.php
new file mode 100644
index 0000000..f5857a5
--- /dev/null
+++ b/lib/PayPal/Api/Transaction.php
@@ -0,0 +1,87 @@
+amount = $amount;
+ }
+
+ /**
+ * Getter for amount
+ */
+ public function getAmount() {
+ return $this->amount;
+ }
+
+ /**
+ * Setter for payee
+ * @param PayPal\Api\Payee $payee
+ */
+ public function setPayee($payee) {
+ $this->payee = $payee;
+ }
+
+ /**
+ * Getter for payee
+ */
+ public function getPayee() {
+ return $this->payee;
+ }
+
+ /**
+ * Setter for description
+ * @param string $description
+ */
+ public function setDescription($description) {
+ $this->description = $description;
+ }
+
+ /**
+ * Getter for description
+ */
+ public function getDescription() {
+ return $this->description;
+ }
+
+ /**
+ * Setter for item_list
+ * @param PayPal\Api\ItemList $item_list
+ */
+ public function setItem_list($item_list) {
+ $this->item_list = $item_list;
+ }
+
+ /**
+ * Getter for item_list
+ */
+ public function getItem_list() {
+ return $this->item_list;
+ }
+
+ /**
+ * Setter for related_resources
+ * @param PayPal\Api\SubTransaction $related_resources
+ */
+ public function setRelated_resources($related_resources) {
+ $this->related_resources = $related_resources;
+ }
+
+ /**
+ * Getter for related_resources
+ */
+ public function getRelated_resources() {
+ return $this->related_resources;
+ }
+
+
+}
\ No newline at end of file
diff --git a/lib/PayPal/Auth/OAuthTokenCredential.php b/lib/PayPal/Auth/OAuthTokenCredential.php
new file mode 100644
index 0000000..cd28348
--- /dev/null
+++ b/lib/PayPal/Auth/OAuthTokenCredential.php
@@ -0,0 +1,118 @@
+clientId = $clientId;
+ $this->clientSecret = $clientSecret;
+ $this->logger = new \PPLoggingManager(__CLASS__);
+ }
+
+ /**
+ * @return the accessToken
+ */
+ public function getAccessToken() {
+ // Check if Access Token is not null and has not expired.
+ // The API returns expiry time as a relative time unit
+ // We use a buffer time when checking for token expiry to account
+ // for API call delays and any delay between the time the token is
+ // retrieved and subsequently used
+ if ($this->accessToken != null &&
+ (time() - $this->tokenCreateTime) > ($this->tokenExpiresIn - self::$expiryBufferTime)) {
+ $this->accessToken = null;
+ }
+ // If accessToken is Null, obtain a new token
+ if ($this->accessToken == null) {
+ $this->generateAccessToken();
+ }
+ return $this->accessToken;
+ }
+
+ /**
+ * Generates a new access token
+ */
+ private function generateAccessToken() {
+ return $this->generateOAuthToken(base64_encode($this->clientId . ":" . $this->clientSecret));
+ }
+
+ /**
+ * Generate OAuth type token from Base64Client ID
+ */
+ private function generateOAuthToken($base64ClientID) {
+
+ $headers = array(
+ "Authorization" => "Basic " . $base64ClientID,
+ "Accept" => "*/*"
+ );
+ $httpConfiguration = $this->getOAuthHttpConfiguration();
+ $httpConfiguration->setHeaders($headers);
+
+ $connection = \PPConnectionManager::getInstance()->getConnection($httpConfiguration);
+ $res = $connection->execute("grant_type=client_credentials");
+ $jsonResponse = json_decode($res, true);
+ if($jsonResponse == NULL ||
+ !isset($jsonResponse["access_token"]) || !isset($jsonResponse["expires_in"]) ) {
+ $this->accessToken = NULL;
+ $this->tokenExpiresIn = NULL;
+ $this->logger->warning("Could not generate new Access token. Invalid response from server: " . $jsonResponse);
+ } else {
+ $this->accessToken = $jsonResponse["access_token"];
+ $this->tokenExpiresIn = $jsonResponse["expires_in"];
+ }
+ $this->tokenCreateTime = time();
+ return $this->accessToken;
+ }
+
+ /*
+ * Get HttpConfiguration object for OAuth API
+ */
+ private function getOAuthHttpConfiguration() {
+ $configMgr = \PPConfigManager::getInstance();
+
+ $baseEndpoint = ($configMgr->get("oauth.EndPoint") != '' && !is_array($configMgr->get("oauth.EndPoint"))) ?
+ $configMgr->get("oauth.EndPoint") : $configMgr->get("service.EndPoint");
+ $baseEndpoint = rtrim(trim($baseEndpoint), '/');
+ return new \PPHttpConfig($baseEndpoint . "/v1/oauth2/token", "POST");
+ }
+}
diff --git a/lib/PayPal/Common/ArrayUtil.php b/lib/PayPal/Common/ArrayUtil.php
new file mode 100644
index 0000000..315a2e4
--- /dev/null
+++ b/lib/PayPal/Common/ArrayUtil.php
@@ -0,0 +1,19 @@
+ $v) {
+ if(is_int($k)) {
+ return false;
+ }
+ }
+ return true;
+ }
+}
\ No newline at end of file
diff --git a/lib/PayPal/Common/Model.php b/lib/PayPal/Common/Model.php
new file mode 100644
index 0000000..ff72c52
--- /dev/null
+++ b/lib/PayPal/Common/Model.php
@@ -0,0 +1,88 @@
+_propMap[$key];
+ }
+
+ public function __set($key, $value) {
+ $this->_propMap[$key] = $value;
+ }
+
+ public function __isset($key) {
+ return isset($this->_propMap[$key]);
+ }
+
+ public function __unset($key) {
+ unset($this->_propMap[$key]);
+ }
+
+
+ private function _convertToArray($param) {
+ $ret = array();
+ foreach($param as $k => $v) {
+ if($v instanceof Model ) {
+ $ret[$k] = $v->toArray();
+ } else if (is_array($v)) {
+ $ret[$k] = $this->_convertToArray($v);
+ } else {
+ $ret[$k] = $v;
+ }
+ }
+ return $ret;
+ }
+
+ public function fromArray($arr) {
+
+ foreach($arr as $k => $v) {
+ if(is_array($v)) {
+ $clazz = ReflectionUtil::getPropertyClass(get_class($this), $k);
+ if(ArrayUtil::isAssocArray($v)) {
+ $o = new $clazz();
+ $o->fromArray($v);
+ $setterFunc = "set".ucfirst($k);
+ $this->$setterFunc($o);
+ } else {
+ $setterFunc = "set".ucfirst($k);
+ $arr = array();
+ foreach($v as $nk => $nv) {
+ if(is_array($nv)) {
+ $o = new $clazz();
+ $o->fromArray($nv);
+ $arr[$nk] = $o;
+ } else {
+ $arr[$nk] = $nv;
+ }
+ }
+ $this->$setterFunc($arr); //TODO: Cleaning up any current values in this case. Should be doing this allways
+ }
+ }else {
+ $this->$k = $v;
+ }
+ }
+ }
+
+ public function fromJson($json) {
+ $this->fromArray(json_decode($json, true));
+ }
+
+ public function toArray() {
+ return $this->_convertToArray($this->_propMap);
+ }
+
+ public function toJSON() {
+ return json_encode($this->toArray());
+ }
+}
\ No newline at end of file
diff --git a/lib/PayPal/Common/ReflectionUtil.php b/lib/PayPal/Common/ReflectionUtil.php
new file mode 100644
index 0000000..3aa0fcd
--- /dev/null
+++ b/lib/PayPal/Common/ReflectionUtil.php
@@ -0,0 +1,73 @@
+getDocComment(), $annots, PREG_PATTERN_ORDER)) {
+ return NULL;
+ }
+ foreach ($annots[1] as $i => $annot) {
+ $annotations[strtolower($annot)] = empty($annots[2][$i]) ? TRUE : rtrim($annots[2][$i], " \t\n\r)");
+ }
+
+ return $annotations;
+ }
+}
\ No newline at end of file
diff --git a/lib/PayPal/Common/UserAgent.php b/lib/PayPal/Common/UserAgent.php
new file mode 100644
index 0000000..2f1e302
--- /dev/null
+++ b/lib/PayPal/Common/UserAgent.php
@@ -0,0 +1,44 @@
+credential;
+ }
+
+ public function getrequestId() {
+ if($this->requestId == null) {
+ $this->requestId = $this->generaterequestId();
+ }
+ return $this->requestId;
+ }
+
+ /**
+ *
+ * @param PayPal/Api/OAuthTokenCredential $credential
+ * @param string $requestId
+ */
+ public function __construct($credential, $requestId=null) {
+ $this->credential = $credential;
+ $this->requestId = $requestId;
+ }
+
+ /**
+ * Generates a unique per request id that
+ * can be used to set the PayPal-Request-Id header
+ * that is used for idemptency
+ * @return string
+ */
+ private function generateRequestId() {
+
+ static $pid = -1;
+ static $addr = -1;
+
+ if ($pid == -1) {
+ $pid = getmypid();
+ }
+ if ($addr == -1) {
+ if(array_key_exists('SERVER_ADDR', $_SERVER)) {
+ $addr = ip2long($_SERVER['SERVER_ADDR']);
+ } else {
+ $addr = php_uname('n');
+ }
+ }
+
+ return $addr . $pid . $_SERVER['REQUEST_TIME'] . mt_rand(0, 0xffff);
+ }
+}
diff --git a/lib/PayPal/Rest/Call.php b/lib/PayPal/Rest/Call.php
new file mode 100644
index 0000000..2a1fceb
--- /dev/null
+++ b/lib/PayPal/Rest/Call.php
@@ -0,0 +1,59 @@
+logger = new \PPLoggingManager(__CLASS__);
+ }
+
+ /**
+ *
+ * @param string $path
+ * @param string $data
+ * @param PayPal/Rest/ApiContext $apiContext
+ * @param array $headers
+ */
+ public function execute($path, $method, $data='', $apiContext, $headers=array()) {
+ $configMgr = \PPConfigManager::getInstance();
+
+ $credential = $apiContext->getCredential();
+ if($credential == NULL) {
+ // Try picking credentials from the config file
+ $credMgr = \PPCredentialManager::getInstance();
+ $credValues = $credMgr->getCredentialObject();
+ if(!is_array($credValues)) {
+ throw new \PPMissingCredentialException("Empty or invalid credentials passed");
+ }
+ $credential = new OAuthTokenCredential($credValues['clientId'], $credValues['clientSecret']);
+ }
+ if($credential == NULL || ! ($credential instanceof OAuthTokenCredential) ) {
+ throw new \PPInvalidCredentialException("Invalid credentials passed");
+ }
+
+ $resourceUrl = rtrim( trim($configMgr->get('service.EndPoint')), '/') . $path;
+ $config = new \PPHttpConfig($resourceUrl, $method);
+ $headers += array(
+ 'Content-Type' => 'application/json',
+ 'User-Agent' => UserAgent::getValue()
+ );
+ if(!is_null($credential) && $credential instanceof OAuthTokenCredential) {
+ $headers['Authorization'] = "Bearer " . $credential->getAccessToken();
+ }
+ if($method == 'POST' || $method == 'PUT') {
+ $headers['PayPal-Request-Id'] = $apiContext->getRequestId();
+ }
+ $config->setHeaders($headers);
+ $connection = new \PPHttpConnection($config);
+ $response = $connection->execute($data);
+ $this->logger->fine($response);
+
+ return $response;
+ }
+}
diff --git a/lib/PayPal/Rest/IResource.php b/lib/PayPal/Rest/IResource.php
new file mode 100644
index 0000000..395586c
--- /dev/null
+++ b/lib/PayPal/Rest/IResource.php
@@ -0,0 +1,7 @@
+
+
+
+
+
+ tests
+
+
+
+
+
+
+
+
+
+ ./lib
+
+
+
+
+
\ No newline at end of file
diff --git a/sample/README.md b/sample/README.md
new file mode 100644
index 0000000..dfffbfe
--- /dev/null
+++ b/sample/README.md
@@ -0,0 +1,14 @@
+Rest API Samples
+===================
+
+
+This sample project is a simple web app that you can explore to understand what the payment APIs can do for you. To try out the sample, run `composer update` from the samples folder and you are all set.
+
+
+The sample comes pre-configured with a test account but in case you need to try them against your account, you must
+
+ * Obtain your client id and client secret from the developer portal
+ * Update the sdk_config.ini file with your new client id and secret.
+
+
+If you are looking for a full fledged application that uses the new RESTful APIs, check out the Pizza store sample app at https://github.com/paypal/rest-api-sample-app-php
diff --git a/sample/bootstrap.php b/sample/bootstrap.php
new file mode 100644
index 0000000..3d8f23c
--- /dev/null
+++ b/sample/bootstrap.php
@@ -0,0 +1,50 @@
+::setCredential($cred) calls that
+// you see in the samples.
+$cred = new OAuthTokenCredential(
+ $configManager->get('acct1.ClientId'),
+ $configManager->get('acct1.ClientSecret'));
+
+
+/**
+ * ### getBaseUrl function
+ * // utility function that returns base url for
+ * // determining return/cancel urls
+ * @return string
+ */
+function getBaseUrl() {
+
+ $protocol = 'http';
+ if ($_SERVER['SERVER_PORT'] == 443 || (!empty($_SERVER['HTTPS']) && strtolower($_SERVER['HTTPS']) == 'on')) {
+ $protocol .= 's';
+ $protocol_port = $_SERVER['SERVER_PORT'];
+ } else {
+ $protocol_port = 80;
+ }
+
+ $host = $_SERVER['HTTP_HOST'];
+ $port = $_SERVER['SERVER_PORT'];
+ $request = $_SERVER['PHP_SELF'];
+ return dirname($protocol . '://' . $host . ($port == $protocol_port ? '' : ':' . $port) . $request);
+}
diff --git a/sample/composer.json b/sample/composer.json
new file mode 100644
index 0000000..f3c60bf
--- /dev/null
+++ b/sample/composer.json
@@ -0,0 +1,14 @@
+{
+ "name": "paypal/rest-api-sdk-sample-php",
+ "description": "Samples using PayPal's REST API SDK for PHP",
+ "homepage": "https://github.com/paypal/rest-api-sdk-php",
+ "config": {
+ "require-all": true
+ },
+ "require": {
+ "php": ">=5.3.0",
+ "ext-curl": "*",
+ "ext-json": "*",
+ "paypal/rest-api-sdk-php" : "0.5.*"
+ }
+}
diff --git a/sample/images/edt-format-source-button.png b/sample/images/edt-format-source-button.png
new file mode 100644
index 0000000..88cc504
Binary files /dev/null and b/sample/images/edt-format-source-button.png differ
diff --git a/sample/images/play_button.png b/sample/images/play_button.png
new file mode 100644
index 0000000..9afac6e
Binary files /dev/null and b/sample/images/play_button.png differ
diff --git a/sample/index.html b/sample/index.html
new file mode 100644
index 0000000..280cc33
--- /dev/null
+++ b/sample/index.html
@@ -0,0 +1,94 @@
+
+
+
+
+PayPal REST API Samples
+
+
+
+
+ PayPal REST API Samples
+
+
+
+
+
\ No newline at end of file
diff --git a/sample/payments/CreatePayment.php b/sample/payments/CreatePayment.php
new file mode 100644
index 0000000..562a70d
--- /dev/null
+++ b/sample/payments/CreatePayment.php
@@ -0,0 +1,111 @@
+setLine1("3909 Witmer Road");
+$addr->setLine2("Niagara Falls");
+$addr->setCity("Niagara Falls");
+$addr->setState("NY");
+$addr->setPostal_code("14305");
+$addr->setCountry_code("US");
+$addr->setPhone("716-298-1822");
+
+// ### CreditCard
+// A resource representing a credit card that can be
+// used to fund a payment.
+$card = new CreditCard();
+$card->setType("visa");
+$card->setNumber("4417119669820331");
+$card->setExpire_month("11");
+$card->setExpire_year("2019");
+$card->setCvv2("012");
+$card->setFirst_name("Joe");
+$card->setLast_name("Shopper");
+$card->setBilling_address($addr);
+
+// ### FundingInstrument
+// A resource representing a Payer's funding instrument.
+// Use a Payer ID (A unique identifier of the payer generated
+// and provided by the facilitator. This is required when
+// creating or using a tokenized funding instrument)
+// and the `CreditCardDetails`
+$fi = new FundingInstrument();
+$fi->setCredit_card($card);
+
+// ### Payer
+// A resource representing a Payer that funds a payment
+// Use the List of `FundingInstrument` and the Payment Method
+// as 'credit_card'
+$payer = new Payer();
+$payer->setPayment_method("credit_card");
+$payer->setFunding_instruments(array($fi));
+
+// ### Amount
+// Let's you specify a payment amount.
+$amount = new Amount();
+$amount->setCurrency("USD");
+$amount->setTotal("1.00");
+
+// ### Transaction
+// A transaction defines the contract of a
+// payment - what is the payment for and who
+// is fulfilling it. Transaction is created with
+// a `Payee` and `Amount` types
+$transaction = new Transaction();
+$transaction->setAmount($amount);
+$transaction->setDescription("This is the payment description.");
+
+// ### Payment
+// A Payment Resource; create one using
+// the above types and intent as 'sale'
+$payment = new Payment();
+$payment->setIntent("sale");
+$payment->setPayer($payer);
+$payment->setTransactions(array($transaction));
+
+// ### Api Context
+// Pass in a `ApiContext` object to authenticate
+// the call and to send a unique request id
+// (that ensures idempotency). The SDK generates
+// a request id if you do not pass one explicitly.
+$apiContext = new ApiContext($cred, 'Request' . time());
+
+// ### Create Payment
+// Create a payment by posting to the APIService
+// using a valid ApiContext
+// The return object contains the status;
+try {
+ $payment->create($apiContext);
+} catch (\PPConnectionException $ex) {
+ echo "Exception: " . $ex->getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+
+ Created payment:
+ getId();?>
+
+ toArray());?>
+ Back
+
+
diff --git a/sample/payments/CreatePaymentUsingPayPal.php b/sample/payments/CreatePaymentUsingPayPal.php
new file mode 100644
index 0000000..8467c15
--- /dev/null
+++ b/sample/payments/CreatePaymentUsingPayPal.php
@@ -0,0 +1,93 @@
+setPayment_method("paypal");
+
+// ### Amount
+// Let's you specify a payment amount.
+$amount = new Amount();
+$amount->setCurrency("USD");
+$amount->setTotal("1.00");
+
+// ### Transaction
+// A transaction defines the contract of a
+// payment - what is the payment for and who
+// is fulfilling it. Transaction is created with
+// a `Payee` and `Amount` types
+$transaction = new Transaction();
+$transaction->setAmount($amount);
+$transaction->setDescription("This is the payment description.");
+
+// ### Redirect urls
+// Set the urls that the buyer must be redirected to after
+// payment approval/ cancellation.
+$baseUrl = getBaseUrl();
+$redirectUrls = new RedirectUrls();
+$redirectUrls->setReturn_url("$baseUrl/ExecutePayment.php?success=true");
+$redirectUrls->setCancel_url("$baseUrl/ExecutePayment.php?success=false");
+
+// ### Payment
+// A Payment Resource; create one using
+// the above types and intent as 'sale'
+$payment = new Payment();
+$payment->setIntent("sale");
+$payment->setPayer($payer);
+$payment->setRedirect_urls($redirectUrls);
+$payment->setTransactions(array($transaction));
+
+// ### Api Context
+// Pass in a `ApiContext` object to authenticate
+// the call and to send a unique request id
+// (that ensures idempotency). The SDK generates
+// a request id if you do not pass one explicitly.
+$apiContext = new ApiContext($cred, 'Request' . time());
+
+// ### Create Payment
+// Create a payment by posting to the APIService
+// using a valid apiContext
+// The return object contains the status and the
+// url to which the buyer must be redirected to
+// for payment approval
+try {
+ $payment->create($apiContext);
+} catch (\PPConnectionException $ex) {
+ echo "Exception: " . $ex->getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+
+// ### Redirect buyer to paypal
+// Retrieve buyer approval url from the `payment` object.
+foreach($payment->getLinks() as $link) {
+ if($link->getRel() == 'approval_url') {
+ $redirectUrl = $link->getHref();
+ }
+}
+// It is not really a great idea to store the payment id
+// in the session. In a real world app, please store the
+// payment id in a database.
+$_SESSION['paymentId'] = $payment->getId();
+if(isset($redirectUrl)) {
+ header("Location: $redirectUrl");
+ exit;
+}
diff --git a/sample/payments/CreatePaymentUsingSavedCard.php b/sample/payments/CreatePaymentUsingSavedCard.php
new file mode 100644
index 0000000..5994c7c
--- /dev/null
+++ b/sample/payments/CreatePaymentUsingSavedCard.php
@@ -0,0 +1,96 @@
+setCredit_card_id($creditCardId);
+
+// ### FundingInstrument
+// A resource representing a Payer's funding instrument.
+// Use a Payer ID (A unique identifier of the payer generated
+// and provided by the facilitator. This is required when
+// creating or using a tokenized funding instrument)
+// and the `CreditCardDetails`
+$fi = new FundingInstrument();
+$fi->setCredit_card_token($creditCardToken);
+
+// ### Payer
+// A resource representing a Payer that funds a payment
+// Use the List of `FundingInstrument` and the Payment Method
+// as 'credit_card'
+$payer = new Payer();
+$payer->setPayment_method("credit_card");
+$payer->setFunding_instruments(array($fi));
+
+// ### Amount
+// Let's you specify a payment amount.
+$amount = new Amount();
+$amount->setCurrency("USD");
+$amount->setTotal("1.00");
+
+// ### Transaction
+// A transaction defines the contract of a
+// payment - what is the payment for and who
+// is fulfilling it. Transaction is created with
+// a `Payee` and `Amount` types
+$transaction = new Transaction();
+$transaction->setAmount($amount);
+$transaction->setDescription("This is the payment description.");
+
+// ### Payment
+// A Payment Resource; create one using
+// the above types and intent as 'sale'
+$payment = new Payment();
+$payment->setIntent("sale");
+$payment->setPayer($payer);
+$payment->setTransactions(array($transaction));
+
+// ### Api Context
+// Pass in a `ApiContext` object to authenticate
+// the call and to send a unique request id
+// (that ensures idempotency). The SDK generates
+// a request id if you do not pass one explicitly.
+$apiContext = new ApiContext($cred, 'Request' . time());
+
+// ###Create Payment
+// Create a payment by posting to the APIService
+// using a valid apiContext
+// The return object contains the status;
+try {
+ $payment->create($apiContext);
+} catch (\PPConnectionException $ex) {
+ echo "Exception: " . $ex->getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+
+ Created payment:
+ getId();?>
+
+ toArray());?>
+ Back
+
+
\ No newline at end of file
diff --git a/sample/payments/ExecutePayment.php b/sample/payments/ExecutePayment.php
new file mode 100644
index 0000000..45224fd
--- /dev/null
+++ b/sample/payments/ExecutePayment.php
@@ -0,0 +1,47 @@
+/execute'.
+
+require __DIR__ . '/../bootstrap.php';
+use PayPal\Api\ExecutePayment;
+use PayPal\Api\Payment;
+use PayPal\Api\PaymentExecution;
+use PayPal\Rest\ApiContext;
+session_start();
+
+if(isset($_GET['success']) && $_GET['success'] == 'true') {
+ // ### Api Context
+ // Pass in a `ApiContext` object to authenticate
+ // the call and to send a unique request id
+ // (that ensures idempotency). The SDK generates
+ // a request id if you do not pass one explicitly.
+ $apiContext = new ApiContext($cred);
+
+ // Get the payment Object by passing paymentId
+ // payment id was previously stored in session in
+ // CreatePaymentUsingPayPal.php
+ $paymentId = $_SESSION['paymentId'];
+ $payment = Payment::get($paymentId);
+
+ // PaymentExecution object includes information necessary
+ // to execute a PayPal account payment.
+ // The payer_id is added to the request query parameters
+ // when the user is redirected from paypal back to your site
+ $execution = new PaymentExecution();
+ $execution->setPayer_id($_GET['PayerID']);
+
+ //Execute the payment
+ $payment->execute($execution, $apiContext);
+
+ echo "";
+ var_dump($payment->toArray());
+ echo " Back ";
+
+} else {
+ echo "User cancelled payment.";
+}
\ No newline at end of file
diff --git a/sample/payments/GetPayment.php b/sample/payments/GetPayment.php
new file mode 100644
index 0000000..97415ca
--- /dev/null
+++ b/sample/payments/GetPayment.php
@@ -0,0 +1,39 @@
+getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+ Retrieving Payment ID:
+ toArray());?>
+ Back
+
+
\ No newline at end of file
diff --git a/sample/payments/ListPayments.php b/sample/payments/ListPayments.php
new file mode 100644
index 0000000..c11396c
--- /dev/null
+++ b/sample/payments/ListPayments.php
@@ -0,0 +1,42 @@
+ 10, 'start_index' => 5));
+} catch (\PPConnectionException $ex) {
+ echo "Exception:" . $ex->getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+ Got getCount(); ?> matching payments
+ toArray());?>
+ Back
+
+
diff --git a/sample/sale/GetSale.php b/sample/sale/GetSale.php
new file mode 100644
index 0000000..9ac1697
--- /dev/null
+++ b/sample/sale/GetSale.php
@@ -0,0 +1,35 @@
+getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+ Retrieving sale id:
+
+ Back
+
+
\ No newline at end of file
diff --git a/sample/sale/RefundSale.php b/sample/sale/RefundSale.php
new file mode 100644
index 0000000..072af6d
--- /dev/null
+++ b/sample/sale/RefundSale.php
@@ -0,0 +1,55 @@
+setCurrency('USD');
+$amt->setTotal('0.01');
+
+$refund = new Refund();
+$refund->setAmount($amt);
+
+$saleId = '3RM92092UW5126232';
+
+// ###Sale
+// A sale transaction.
+// Create a Sale object with the
+// given sale transaction id.
+$sale = new Sale();
+$sale->setId($saleId);
+
+// ### Api Context
+// Pass in a `ApiContext` object to authenticate
+// the call and to send a unique request id
+// (that ensures idempotency). The SDK generates
+// a request id if you do not pass one explicitly.
+$apiContext = new ApiContext($cred, 'Request' . time());
+try {
+ // Refund the sale
+ $sale->refund($refund, $apiContext);
+} catch (\PPConnectionException $ex) {
+ echo "Exception:" . $ex->getMessage() . PHP_EOL;
+ var_dump($ex->getData());
+ exit(1);
+}
+?>
+
+
+ Refunding sale id:
+
+ Back
+
+
\ No newline at end of file
diff --git a/sample/sdk_config.ini b/sample/sdk_config.ini
new file mode 100644
index 0000000..69de99f
--- /dev/null
+++ b/sample/sdk_config.ini
@@ -0,0 +1,35 @@
+;Account credentials from developer portal
+[Account]
+acct1.ClientId = EBWKjlELKMYqRNQ6sYvFo64FtaRLRR5BdHEESmha49TM
+acct1.ClientSecret = EO422dn3gQLgDbuwqTjzrFgFtaRLRR5BdHEESmha49TM
+
+
+;Connection Information
+[Http]
+http.ConnectionTimeOut = 30
+http.Retry = 1
+;http.Proxy=http://[username:password]@hostname[:port][/path]
+
+
+;Service Configuration
+[Service]
+service.EndPoint="https://api.sandbox.paypal.com"
+; Uncomment this line for integrating with the live endpoint
+; service.EndPoint="https://api.paypal.com"
+
+
+;Logging Information
+[Log]
+
+log.LogEnabled=true
+
+# When using a relative path, the log file is created
+# relative to the .php file that is the entry point
+# for this request. You can also provide an absolute
+# path here
+log.FileName=../PayPal.log
+
+# Logging level can be one of FINE, INFO, WARN or ERROR
+# Logging is most verbose in the 'FINE' level and
+# decreases as you proceed towards ERROR
+log.LogLevel=FINE
\ No newline at end of file
diff --git a/sample/source/CreateCreditCard.html b/sample/source/CreateCreditCard.html
new file mode 100644
index 0000000..86eaa6f
--- /dev/null
+++ b/sample/source/CreateCreditCard.html
@@ -0,0 +1,48 @@
+CreateCreditCard use PayPal\Rest\ApiContext ;
+
+require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\CreditCard ;
+use PayPal\Api\Address ;
$card = new CreditCard ();
+$card -> setType ( "visa" );
+$card -> setNumber ( "4417119669820331" );
+$card -> setExpire_month ( "11" );
+$card -> setExpire_year ( "2019" );
+$card -> setCvv2 ( "012" );
+$card -> setFirst_name ( "Joe" );
+$card -> setLast_name ( "Shopper" );
$apiContext = new ApiContext ( $cred , 'Request' . time ());
try {
+ $card -> create ();
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception:" . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Saved a new credit card with id: <?php echo $card -> getId (); ?> </div>
+ <pre> <?php var_dump ( $card ); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/CreatePayment.html b/sample/source/CreatePayment.html
new file mode 100644
index 0000000..284662e
--- /dev/null
+++ b/sample/source/CreatePayment.html
@@ -0,0 +1,90 @@
+CreatePayment require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Address ;
+use PayPal\Api\Amount ;
+use PayPal\Api\CreditCard ;
+use PayPal\Api\Payer ;
+use PayPal\Api\Payment ;
+use PayPal\Api\FundingInstrument ;
+use PayPal\Api\Transaction ;
+use PayPal\Rest\ApiContext ;
$addr = new Address ();
+$addr -> setLine1 ( "3909 Witmer Road" );
+$addr -> setLine2 ( "Niagara Falls" );
+$addr -> setCity ( "Niagara Falls" );
+$addr -> setState ( "NY" );
+$addr -> setPostal_code ( "14305" );
+$addr -> setCountry_code ( "US" );
+$addr -> setPhone ( "716-298-1822" );
$card = new CreditCard ();
+$card -> setType ( "visa" );
+$card -> setNumber ( "4417119669820331" );
+$card -> setExpire_month ( "11" );
+$card -> setExpire_year ( "2019" );
+$card -> setCvv2 ( "012" );
+$card -> setFirst_name ( "Joe" );
+$card -> setLast_name ( "Shopper" );
+$card -> setBilling_address ( $addr );
$fi = new FundingInstrument ();
+$fi -> setCredit_card ( $card );
$payer = new Payer ();
+$payer -> setPayment_method ( "credit_card" );
+$payer -> setFunding_instruments ( array ( $fi ));
$amount = new Amount ();
+$amount -> setCurrency ( "USD" );
+$amount -> setTotal ( "1.00" );
$transaction = new Transaction ();
+$transaction -> setAmount ( $amount );
+$transaction -> setDescription ( "This is the payment description." );
$payment = new Payment ();
+$payment -> setIntent ( "sale" );
+$payment -> setPayer ( $payer );
+$payment -> setTransactions ( array ( $transaction ));
$apiContext = new ApiContext ( $cred , 'Request' . time ());
try {
+ $payment -> create ( $apiContext );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception: " . $ex -> getMessage () . PHP_EOL ;
+ <pre> <?php var_dump ( $card ); ?> </pre>
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>
+ Created payment:
+ <?php echo $payment -> getId (); ?>
+ </div>
+ <pre> <?php var_dump ( $payment -> toArray ()); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
diff --git a/sample/source/CreatePaymentUsingPayPal.html b/sample/source/CreatePaymentUsingPayPal.html
new file mode 100644
index 0000000..7a03153
--- /dev/null
+++ b/sample/source/CreatePaymentUsingPayPal.html
@@ -0,0 +1,72 @@
+CreatePaymentUsingPayPal require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Address ;
+use PayPal\Api\Amount ;
+use PayPal\Api\Payer ;
+use PayPal\Api\Payment ;
+use PayPal\Api\FundingInstrument ;
+use PayPal\Api\RedirectUrls ;
+use PayPal\Api\Transaction ;
+use PayPal\Rest\ApiContext ;
+session_start ();
$payer = new Payer ();
+$payer -> setPayment_method ( "paypal" );
$amount = new Amount ();
+$amount -> setCurrency ( "USD" );
+$amount -> setTotal ( "1.00" );
$transaction = new Transaction ();
+$transaction -> setAmount ( $amount );
+$transaction -> setDescription ( "This is the payment description." );
$baseUrl = getBaseUrl ();
+$redirectUrls = new RedirectUrls ();
+$redirectUrls -> setReturn_url ( " $baseUrl /ExecutePayment.php?success=true" );
+$redirectUrls -> setCancel_url ( " $baseUrl /ExecutePayment.php?success=false" );
$payment = new Payment ();
+$payment -> setIntent ( "sale" );
+$payment -> setPayer ( $payer );
+$payment -> setRedirect_urls ( $redirectUrls );
+$payment -> setTransactions ( array ( $transaction ));
$apiContext = new ApiContext ( $cred , 'Request' . time ());
try {
+ $payment -> create ( $apiContext );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception: " . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
foreach ( $payment -> getLinks () as $link ) {
+ if ( $link -> getRel () == 'approval_url' ) {
+ $redirectUrl = $link -> getHref ();
+ }
+}
$_SESSION [ 'paymentId' ] = $payment -> getId ();
+if ( isset ( $redirectUrl )) {
+ header ( "Location: $redirectUrl " );
+ exit ;
+}
\ No newline at end of file
diff --git a/sample/source/CreatePaymentUsingSavedCard.html b/sample/source/CreatePaymentUsingSavedCard.html
new file mode 100644
index 0000000..b4d90d0
--- /dev/null
+++ b/sample/source/CreatePaymentUsingSavedCard.html
@@ -0,0 +1,77 @@
+CreatePaymentUsingSavedCard require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Address ;
+use PayPal\Api\Amount ;
+use PayPal\Api\CreditCard ;
+use PayPal\Api\CreditCardToken ;
+use PayPal\Api\Payer ;
+use PayPal\Api\Payment ;
+use PayPal\Api\FundingInstrument ;
+use PayPal\Api\RedirectUrls ;
+use PayPal\Api\Transaction ;
+use PayPal\Auth\OAuthTokenCredential ;
+use PayPal\Rest\ApiContext ;
$creditCardId = 'CARD-5BT058015C739554AKE2GCEI' ;
+$creditCardToken = new CreditCardToken ();
+$creditCardToken -> setCredit_card_id ( $creditCardId );
$fi = new FundingInstrument ();
+$fi -> setCredit_card_token ( $creditCardToken );
$payer = new Payer ();
+$payer -> setPayment_method ( "credit_card" );
+$payer -> setFunding_instruments ( array ( $fi ));
$amount = new Amount ();
+$amount -> setCurrency ( "USD" );
+$amount -> setTotal ( "1.00" );
$transaction = new Transaction ();
+$transaction -> setAmount ( $amount );
+$transaction -> setDescription ( "This is the payment description." );
$payment = new Payment ();
+$payment -> setIntent ( "sale" );
+$payment -> setPayer ( $payer );
+$payment -> setTransactions ( array ( $transaction ));
$apiContext = new ApiContext ( $cred , 'Request' . time ());
try {
+ $payment -> create ( $apiContext );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception: " . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>
+ Created payment:
+ <?php echo $payment -> getId (); ?>
+ </div>
+ <pre> <?php var_dump ( $payment -> toArray ()); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/ExecutePayment.html b/sample/source/ExecutePayment.html
new file mode 100644
index 0000000..5f007b7
--- /dev/null
+++ b/sample/source/ExecutePayment.html
@@ -0,0 +1,40 @@
+ExecutePayment require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\ExecutePayment ;
+use PayPal\Api\Payment ;
+use PayPal\Api\PaymentExecution ;
+use PayPal\Rest\ApiContext ;
+session_start ();
+
+if ( isset ( $_GET [ 'success' ]) && $_GET [ 'success' ] == 'true' ) {
$apiContext = new ApiContext ( $cred );
+
$paymentId = $_SESSION [ 'paymentId' ];
+ $payment = Payment :: get ( $paymentId );
+
$execution = new PaymentExecution ();
+ $execution -> setPayer_id ( $_GET [ 'PayerID' ]);
+
+ //Execute the payment
+ $payment -> execute ( $execution , $apiContext );
+
+ echo "<html><body><pre>" ;
+ var_dump ( $payment -> toArray ());
+ echo "</pre><a href='../index.html'>Back</a></body></html>" ;
+
+} else {
+ echo "User cancelled payment." ;
+}
\ No newline at end of file
diff --git a/sample/source/GetCreditCard.html b/sample/source/GetCreditCard.html
new file mode 100644
index 0000000..b22c75d
--- /dev/null
+++ b/sample/source/GetCreditCard.html
@@ -0,0 +1,31 @@
+GetCreditCard require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\CreditCard ;
$cardId = "CARD-5BT058015C739554AKE2GCEI" ;
CreditCard :: setCredential ( $cred );
+/// ### Retrieve card
+try {
+ $card = CreditCard :: get ( $cardId );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception: " . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Retrieving credit card: <?php echo $cardId ; ?> </div>
+ <pre> <?php var_dump ( $card ); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/GetPayment.html b/sample/source/GetPayment.html
new file mode 100644
index 0000000..4805cee
--- /dev/null
+++ b/sample/source/GetPayment.html
@@ -0,0 +1,34 @@
+GetPayment require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Payment ;
+
+$paymentId = "PAY-0XL713371A312273YKE2GCNI" ;
Payment :: setCredential ( $cred );
try {
+ $payment = Payment :: get ( $paymentId );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception:" . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Retrieving Payment ID: <?php echo $paymentId ; ?> </div>
+ <pre> <?php var_dump ( $payment -> toArray ()); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/GetSale.html b/sample/source/GetSale.html
new file mode 100644
index 0000000..0c02368
--- /dev/null
+++ b/sample/source/GetSale.html
@@ -0,0 +1,30 @@
+GetSale require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Sale ;
+
+$saleId = '3RM92092UW5126232' ;
Sale :: setCredential ( $cred );
+try {
$sale = Sale :: get ( $saleId );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception:" . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Retrieving sale id: <?php echo $saleId ; ?> </div>
+ <pre> <?php var_dump ( $sale ); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/ListPayments.html b/sample/source/ListPayments.html
new file mode 100644
index 0000000..d6ac87c
--- /dev/null
+++ b/sample/source/ListPayments.html
@@ -0,0 +1,35 @@
+ListPayments require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Payment ;
Payment :: setCredential ( $cred );
try {
+ $payments = Payment :: all ( array ( 'count' => 10 , 'start_index' => 5 ));
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception:" . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Got <?php echo $payments -> getCount (); ?> matching payments </div>
+ <pre> <?php var_dump ( $payments -> toArray ()); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/RefundSale.html b/sample/source/RefundSale.html
new file mode 100644
index 0000000..87c2455
--- /dev/null
+++ b/sample/source/RefundSale.html
@@ -0,0 +1,44 @@
+RefundSale require __DIR__ . '/../bootstrap.php' ;
+use PayPal\Api\Amount ;
+use PayPal\Api\Refund ;
+use PayPal\Api\Sale ;
+use PayPal\Rest\ApiContext ;
$amt = new Amount ();
+$amt -> setCurrency ( 'USD' );
+$amt -> setTotal ( '0.01' );
+
+$refund = new Refund ();
+$refund -> setAmount ( $amt );
+
+$saleId = '3RM92092UW5126232' ;
$sale = new Sale ();
+$sale -> setId ( $saleId );
$apiContext = new ApiContext ( $cred , 'Request' . time ());
+try {
$sale -> refund ( $refund , $apiContext );
+} catch ( \PPConnectionException $ex ) {
+ echo "Exception:" . $ex -> getMessage () . PHP_EOL ;
+ var_dump ( $ex -> getData ());
+ exit ( 1 );
+}
+?>
+<html>
+<body>
+ <div>Refunding sale id: <?php echo $saleId ; ?> </div>
+ <pre> <?php var_dump ( $sale ); ?> </pre>
+ <a href='../index.html'>Back</a>
+</body>
+</html>
\ No newline at end of file
diff --git a/sample/source/assets/behavior.js b/sample/source/assets/behavior.js
new file mode 100644
index 0000000..c76f978
--- /dev/null
+++ b/sample/source/assets/behavior.js
@@ -0,0 +1,459 @@
+/*! jQuery v1.7.1 jquery.com | jquery.org/license */
+(function(a,b){function cy(a){return f.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function cv(a){if(!ck[a]){var b=c.body,d=f("<"+a+">").appendTo(b),e=d.css("display");d.remove();if(e==="none"||e===""){cl||(cl=c.createElement("iframe"),cl.frameBorder=cl.width=cl.height=0),b.appendChild(cl);if(!cm||!cl.createElement)cm=(cl.contentWindow||cl.contentDocument).document,cm.write((c.compatMode==="CSS1Compat"?"":"")+""),cm.close();d=cm.createElement(a),cm.body.appendChild(d),e=f.css(d,"display"),b.removeChild(cl)}ck[a]=e}return ck[a]}function cu(a,b){var c={};f.each(cq.concat.apply([],cq.slice(0,b)),function(){c[this]=a});return c}function ct(){cr=b}function cs(){setTimeout(ct,0);return cr=f.now()}function cj(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function ci(){try{return new a.XMLHttpRequest}catch(b){}}function cc(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var d=a.dataTypes,e={},g,h,i=d.length,j,k=d[0],l,m,n,o,p;for(g=1;g0){if(c!=="border")for(;g=0===c})}function S(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function K(){return!0}function J(){return!1}function n(a,b,c){var d=b+"defer",e=b+"queue",g=b+"mark",h=f._data(a,d);h&&(c==="queue"||!f._data(a,e))&&(c==="mark"||!f._data(a,g))&&setTimeout(function(){!f._data(a,e)&&!f._data(a,g)&&(f.removeData(a,d,!0),h.fire())},0)}function m(a){for(var b in a){if(b==="data"&&f.isEmptyObject(a[b]))continue;if(b!=="toJSON")return!1}return!0}function l(a,c,d){if(d===b&&a.nodeType===1){var e="data-"+c.replace(k,"-$1").toLowerCase();d=a.getAttribute(e);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:f.isNumeric(d)?parseFloat(d):j.test(d)?f.parseJSON(d):d}catch(g){}f.data(a,c,d)}else d=b}return d}function h(a){var b=g[a]={},c,d;a=a.split(/\s+/);for(c=0,d=a.length;c)[^>]*$|#([\w\-]*)$)/,j=/\S/,k=/^\s+/,l=/\s+$/,m=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,n=/^[\],:{}\s]*$/,o=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,p=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,q=/(?:^|:|,)(?:\s*\[)+/g,r=/(webkit)[ \/]([\w.]+)/,s=/(opera)(?:.*version)?[ \/]([\w.]+)/,t=/(msie) ([\w.]+)/,u=/(mozilla)(?:.*? rv:([\w.]+))?/,v=/-([a-z]|[0-9])/ig,w=/^-ms-/,x=function(a,b){return(b+"").toUpperCase()},y=d.userAgent,z,A,B,C=Object.prototype.toString,D=Object.prototype.hasOwnProperty,E=Array.prototype.push,F=Array.prototype.slice,G=String.prototype.trim,H=Array.prototype.indexOf,I={};e.fn=e.prototype={constructor:e,init:function(a,d,f){var g,h,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!d&&c.body){this.context=c,this[0]=c.body,this.selector=a,this.length=1;return this}if(typeof a=="string"){a.charAt(0)!=="<"||a.charAt(a.length-1)!==">"||a.length<3?g=i.exec(a):g=[null,a,null];if(g&&(g[1]||!d)){if(g[1]){d=d instanceof e?d[0]:d,k=d?d.ownerDocument||d:c,j=m.exec(a),j?e.isPlainObject(d)?(a=[c.createElement(j[1])],e.fn.attr.call(a,d,!0)):a=[k.createElement(j[1])]:(j=e.buildFragment([g[1]],[k]),a=(j.cacheable?e.clone(j.fragment):j.fragment).childNodes);return e.merge(this,a)}h=c.getElementById(g[2]);if(h&&h.parentNode){if(h.id!==g[2])return f.find(a);this.length=1,this[0]=h}this.context=c,this.selector=a;return this}return!d||d.jquery?(d||f).find(a):this.constructor(d).find(a)}if(e.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return e.makeArray(a,this)},selector:"",jquery:"1.7.1",length:0,size:function(){return this.length},toArray:function(){return F.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=this.constructor();e.isArray(a)?E.apply(d,a):e.merge(d,a),d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")");return d},each:function(a,b){return e.each(this,a,b)},ready:function(a){e.bindReady(),A.add(a);return this},eq:function(a){a=+a;return a===-1?this.slice(a):this.slice(a,a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(F.apply(this,arguments),"slice",F.call(arguments).join(","))},map:function(a){return this.pushStack(e.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:E,sort:[].sort,splice:[].splice},e.fn.init.prototype=e.fn,e.extend=e.fn.extend=function(){var a,c,d,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i=="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!="object"&&!e.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j0)return;A.fireWith(c,[e]),e.fn.trigger&&e(c).trigger("ready").off("ready")}},bindReady:function(){if(!A){A=e.Callbacks("once memory");if(c.readyState==="complete")return setTimeout(e.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",B,!1),a.addEventListener("load",e.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",B),a.attachEvent("onload",e.ready);var b=!1;try{b=a.frameElement==null}catch(d){}c.documentElement.doScroll&&b&&J()}}},isFunction:function(a){return e.type(a)==="function"},isArray:Array.isArray||function(a){return e.type(a)==="array"},isWindow:function(a){return a&&typeof a=="object"&&"setInterval"in a},isNumeric:function(a){return!isNaN(parseFloat(a))&&isFinite(a)},type:function(a){return a==null?String(a):I[C.call(a)]||"object"},isPlainObject:function(a){if(!a||e.type(a)!=="object"||a.nodeType||e.isWindow(a))return!1;try{if(a.constructor&&!D.call(a,"constructor")&&!D.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}var d;for(d in a);return d===b||D.call(a,d)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw new Error(a)},parseJSON:function(b){if(typeof b!="string"||!b)return null;b=e.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(n.test(b.replace(o,"@").replace(p,"]").replace(q,"")))return(new Function("return "+b))();e.error("Invalid JSON: "+b)},parseXML:function(c){var d,f;try{a.DOMParser?(f=new DOMParser,d=f.parseFromString(c,"text/xml")):(d=new ActiveXObject("Microsoft.XMLDOM"),d.async="false",d.loadXML(c))}catch(g){d=b}(!d||!d.documentElement||d.getElementsByTagName("parsererror").length)&&e.error("Invalid XML: "+c);return d},noop:function(){},globalEval:function(b){b&&j.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(w,"ms-").replace(v,x)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,d){var f,g=0,h=a.length,i=h===b||e.isFunction(a);if(d){if(i){for(f in a)if(c.apply(a[f],d)===!1)break}else for(;g0&&a[0]&&a[j-1]||j===0||e.isArray(a));if(k)for(;i1?i.call(arguments,0):b,j.notifyWith(k,e)}}function l(a){return function(c){b[a]=arguments.length>1?i.call(arguments,0):c,--g||j.resolveWith(j,b)}}var b=i.call(arguments,0),c=0,d=b.length,e=Array(d),g=d,h=d,j=d<=1&&a&&f.isFunction(a.promise)?a:f.Deferred(),k=j.promise();if(d>1){for(;ca ",d=q.getElementsByTagName("*"),e=q.getElementsByTagName("a")[0];if(!d||!d.length||!e)return{};g=c.createElement("select"),h=g.appendChild(c.createElement("option")),i=q.getElementsByTagName("input")[0],b={leadingWhitespace:q.firstChild.nodeType===3,tbody:!q.getElementsByTagName("tbody").length,htmlSerialize:!!q.getElementsByTagName("link").length,style:/top/.test(e.getAttribute("style")),hrefNormalized:e.getAttribute("href")==="/a",opacity:/^0.55/.test(e.style.opacity),cssFloat:!!e.style.cssFloat,checkOn:i.value==="on",optSelected:h.selected,getSetAttribute:q.className!=="t",enctype:!!c.createElement("form").enctype,html5Clone:c.createElement("nav").cloneNode(!0).outerHTML!=="<:nav>",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0},i.checked=!0,b.noCloneChecked=i.cloneNode(!0).checked,g.disabled=!0,b.optDisabled=!h.disabled;try{delete q.test}catch(s){b.deleteExpando=!1}!q.addEventListener&&q.attachEvent&&q.fireEvent&&(q.attachEvent("onclick",function(){b.noCloneEvent=!1}),q.cloneNode(!0).fireEvent("onclick")),i=c.createElement("input"),i.value="t",i.setAttribute("type","radio"),b.radioValue=i.value==="t",i.setAttribute("checked","checked"),q.appendChild(i),k=c.createDocumentFragment(),k.appendChild(q.lastChild),b.checkClone=k.cloneNode(!0).cloneNode(!0).lastChild.checked,b.appendChecked=i.checked,k.removeChild(i),k.appendChild(q),q.innerHTML="",a.getComputedStyle&&(j=c.createElement("div"),j.style.width="0",j.style.marginRight="0",q.style.width="2px",q.appendChild(j),b.reliableMarginRight=(parseInt((a.getComputedStyle(j,null)||{marginRight:0}).marginRight,10)||0)===0);if(q.attachEvent)for(o in{submit:1,change:1,focusin:1})n="on"+o,p=n in q,p||(q.setAttribute(n,"return;"),p=typeof q[n]=="function"),b[o+"Bubbles"]=p;k.removeChild(q),k=g=h=j=q=i=null,f(function(){var a,d,e,g,h,i,j,k,m,n,o,r=c.getElementsByTagName("body")[0];!r||(j=1,k="position:absolute;top:0;left:0;width:1px;height:1px;margin:0;",m="visibility:hidden;border:0;",n="style='"+k+"border:5px solid #000;padding:0;'",o=""+"",a=c.createElement("div"),a.style.cssText=m+"width:0;height:0;position:static;top:0;margin-top:"+j+"px",r.insertBefore(a,r.firstChild),q=c.createElement("div"),a.appendChild(q),q.innerHTML="",l=q.getElementsByTagName("td"),p=l[0].offsetHeight===0,l[0].style.display="",l[1].style.display="none",b.reliableHiddenOffsets=p&&l[0].offsetHeight===0,q.innerHTML="",q.style.width=q.style.paddingLeft="1px",f.boxModel=b.boxModel=q.offsetWidth===2,typeof q.style.zoom!="undefined"&&(q.style.display="inline",q.style.zoom=1,b.inlineBlockNeedsLayout=q.offsetWidth===2,q.style.display="",q.innerHTML="
",b.shrinkWrapBlocks=q.offsetWidth!==2),q.style.cssText=k+m,q.innerHTML=o,d=q.firstChild,e=d.firstChild,h=d.nextSibling.firstChild.firstChild,i={doesNotAddBorder:e.offsetTop!==5,doesAddBorderForTableAndCells:h.offsetTop===5},e.style.position="fixed",e.style.top="20px",i.fixedPosition=e.offsetTop===20||e.offsetTop===15,e.style.position=e.style.top="",d.style.overflow="hidden",d.style.position="relative",i.subtractsBorderForOverflowNotVisible=e.offsetTop===-5,i.doesNotIncludeMarginInBodyOffset=r.offsetTop!==j,r.removeChild(a),q=a=null,f.extend(b,i))});return b}();var j=/^(?:\{.*\}|\[.*\])$/,k=/([A-Z])/g;f.extend({cache:{},uuid:0,expando:"jQuery"+(f.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?f.cache[a[f.expando]]:a[f.expando];return!!a&&!m(a)},data:function(a,c,d,e){if(!!f.acceptData(a)){var g,h,i,j=f.expando,k=typeof c=="string",l=a.nodeType,m=l?f.cache:a,n=l?a[j]:a[j]&&j,o=c==="events";if((!n||!m[n]||!o&&!e&&!m[n].data)&&k&&d===b)return;n||(l?a[j]=n=++f.uuid:n=j),m[n]||(m[n]={},l||(m[n].toJSON=f.noop));if(typeof c=="object"||typeof c=="function")e?m[n]=f.extend(m[n],c):m[n].data=f.extend(m[n].data,c);g=h=m[n],e||(h.data||(h.data={}),h=h.data),d!==b&&(h[f.camelCase(c)]=d);if(o&&!h[c])return g.events;k?(i=h[c],i==null&&(i=h[f.camelCase(c)])):i=h;return i}},removeData:function(a,b,c){if(!!f.acceptData(a)){var d,e,g,h=f.expando,i=a.nodeType,j=i?f.cache:a,k=i?a[h]:h;if(!j[k])return;if(b){d=c?j[k]:j[k].data;if(d){f.isArray(b)||(b in d?b=[b]:(b=f.camelCase(b),b in d?b=[b]:b=b.split(" ")));for(e=0,g=b.length;e-1)return!0;return!1},val:function(a){var c,d,e,g=this[0];{if(!!arguments.length){e=f.isFunction(a);return this.each(function(d){var g=f(this),h;if(this.nodeType===1){e?h=a.call(this,d,g.val()):h=a,h==null?h="":typeof h=="number"?h+="":f.isArray(h)&&(h=f.map(h,function(a){return a==null?"":a+""})),c=f.valHooks[this.nodeName.toLowerCase()]||f.valHooks[this.type];if(!c||!("set"in c)||c.set(this,h,"value")===b)this.value=h}})}if(g){c=f.valHooks[g.nodeName.toLowerCase()]||f.valHooks[g.type];if(c&&"get"in c&&(d=c.get(g,"value"))!==b)return d;d=g.value;return typeof d=="string"?d.replace(q,""):d==null?"":d}}}}),f.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b,c,d,e,g=a.selectedIndex,h=[],i=a.options,j=a.type==="select-one";if(g<0)return null;c=j?g:0,d=j?g+1:i.length;for(;c=0}),c.length||(a.selectedIndex=-1);return c}}},attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attr:function(a,c,d,e){var g,h,i,j=a.nodeType;if(!!a&&j!==3&&j!==8&&j!==2){if(e&&c in f.attrFn)return f(a)[c](d);if(typeof a.getAttribute=="undefined")return f.prop(a,c,d);i=j!==1||!f.isXMLDoc(a),i&&(c=c.toLowerCase(),h=f.attrHooks[c]||(u.test(c)?x:w));if(d!==b){if(d===null){f.removeAttr(a,c);return}if(h&&"set"in h&&i&&(g=h.set(a,d,c))!==b)return g;a.setAttribute(c,""+d);return d}if(h&&"get"in h&&i&&(g=h.get(a,c))!==null)return g;g=a.getAttribute(c);return g===null?b:g}},removeAttr:function(a,b){var c,d,e,g,h=0;if(b&&a.nodeType===1){d=b.toLowerCase().split(p),g=d.length;for(;h=0}})});var z=/^(?:textarea|input|select)$/i,A=/^([^\.]*)?(?:\.(.+))?$/,B=/\bhover(\.\S+)?\b/,C=/^key/,D=/^(?:mouse|contextmenu)|click/,E=/^(?:focusinfocus|focusoutblur)$/,F=/^(\w*)(?:#([\w\-]+))?(?:\.([\w\-]+))?$/,G=function(a){var b=F.exec(a);b&&(b[1]=(b[1]||"").toLowerCase(),b[3]=b[3]&&new RegExp("(?:^|\\s)"+b[3]+"(?:\\s|$)"));return b},H=function(a,b){var c=a.attributes||{};return(!b[1]||a.nodeName.toLowerCase()===b[1])&&(!b[2]||(c.id||{}).value===b[2])&&(!b[3]||b[3].test((c["class"]||{}).value))},I=function(a){return f.event.special.hover?a:a.replace(B,"mouseenter$1 mouseleave$1")};
+f.event={add:function(a,c,d,e,g){var h,i,j,k,l,m,n,o,p,q,r,s;if(!(a.nodeType===3||a.nodeType===8||!c||!d||!(h=f._data(a)))){d.handler&&(p=d,d=p.handler),d.guid||(d.guid=f.guid++),j=h.events,j||(h.events=j={}),i=h.handle,i||(h.handle=i=function(a){return typeof f!="undefined"&&(!a||f.event.triggered!==a.type)?f.event.dispatch.apply(i.elem,arguments):b},i.elem=a),c=f.trim(I(c)).split(" ");for(k=0;k=0&&(h=h.slice(0,-1),k=!0),h.indexOf(".")>=0&&(i=h.split("."),h=i.shift(),i.sort());if((!e||f.event.customEvent[h])&&!f.event.global[h])return;c=typeof c=="object"?c[f.expando]?c:new f.Event(h,c):new f.Event(h),c.type=h,c.isTrigger=!0,c.exclusive=k,c.namespace=i.join("."),c.namespace_re=c.namespace?new RegExp("(^|\\.)"+i.join("\\.(?:.*\\.)?")+"(\\.|$)"):null,o=h.indexOf(":")<0?"on"+h:"";if(!e){j=f.cache;for(l in j)j[l].events&&j[l].events[h]&&f.event.trigger(c,d,j[l].handle.elem,!0);return}c.result=b,c.target||(c.target=e),d=d!=null?f.makeArray(d):[],d.unshift(c),p=f.event.special[h]||{};if(p.trigger&&p.trigger.apply(e,d)===!1)return;r=[[e,p.bindType||h]];if(!g&&!p.noBubble&&!f.isWindow(e)){s=p.delegateType||h,m=E.test(s+h)?e:e.parentNode,n=null;for(;m;m=m.parentNode)r.push([m,s]),n=m;n&&n===e.ownerDocument&&r.push([n.defaultView||n.parentWindow||a,s])}for(l=0;le&&i.push({elem:this,matches:d.slice(e)});for(j=0;j0?this.on(b,null,a,c):this.trigger(b)},f.attrFn&&(f.attrFn[b]=!0),C.test(b)&&(f.event.fixHooks[b]=f.event.keyHooks),D.test(b)&&(f.event.fixHooks[b]=f.event.mouseHooks)}),function(){function x(a,b,c,e,f,g){for(var h=0,i=e.length;h0){k=j;break}}j=j[a]}e[h]=k}}}function w(a,b,c,e,f,g){for(var h=0,i=e.length;h+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,d="sizcache"+(Math.random()+"").replace(".",""),e=0,g=Object.prototype.toString,h=!1,i=!0,j=/\\/g,k=/\r\n/g,l=/\W/;[0,0].sort(function(){i=!1;return 0});var m=function(b,d,e,f){e=e||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!="string")return e;var i,j,k,l,n,q,r,t,u=!0,v=m.isXML(d),w=[],x=b;do{a.exec(""),i=a.exec(x);if(i){x=i[3],w.push(i[1]);if(i[2]){l=i[3];break}}}while(i);if(w.length>1&&p.exec(b))if(w.length===2&&o.relative[w[0]])j=y(w[0]+w[1],d,f);else{j=o.relative[w[0]]?[d]:m(w.shift(),d);while(w.length)b=w.shift(),o.relative[b]&&(b+=w.shift()),j=y(b,j,f)}else{!f&&w.length>1&&d.nodeType===9&&!v&&o.match.ID.test(w[0])&&!o.match.ID.test(w[w.length-1])&&(n=m.find(w.shift(),d,v),d=n.expr?m.filter(n.expr,n.set)[0]:n.set[0]);if(d){n=f?{expr:w.pop(),set:s(f)}:m.find(w.pop(),w.length===1&&(w[0]==="~"||w[0]==="+")&&d.parentNode?d.parentNode:d,v),j=n.expr?m.filter(n.expr,n.set):n.set,w.length>0?k=s(j):u=!1;while(w.length)q=w.pop(),r=q,o.relative[q]?r=w.pop():q="",r==null&&(r=d),o.relative[q](k,r,v)}else k=w=[]}k||(k=j),k||m.error(q||b);if(g.call(k)==="[object Array]")if(!u)e.push.apply(e,k);else if(d&&d.nodeType===1)for(t=0;k[t]!=null;t++)k[t]&&(k[t]===!0||k[t].nodeType===1&&m.contains(d,k[t]))&&e.push(j[t]);else for(t=0;k[t]!=null;t++)k[t]&&k[t].nodeType===1&&e.push(j[t]);else s(k,e);l&&(m(l,h,e,f),m.uniqueSort(e));return e};m.uniqueSort=function(a){if(u){h=i,a.sort(u);if(h)for(var b=1;b0},m.find=function(a,b,c){var d,e,f,g,h,i;if(!a)return[];for(e=0,f=o.order.length;e":function(a,b){var c,d=typeof b=="string",e=0,f=a.length;if(d&&!l.test(b)){b=b.toLowerCase();for(;e=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(j,"")},TAG:function(a,b){return a[1].replace(j,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||m.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&m.error(a[0]);a[0]=e++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(j,"");!f&&o.attrMap[g]&&(a[1]=o.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(j,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=m(b[3],null,null,c);else{var g=m.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(o.match.POS.test(b[0])||o.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!m(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){var b=a.getAttribute("type"),c=a.type;return a.nodeName.toLowerCase()==="input"&&"text"===c&&(b===c||b===null)},radio:function(a){return a.nodeName.toLowerCase()==="input"&&"radio"===a.type},checkbox:function(a){return a.nodeName.toLowerCase()==="input"&&"checkbox"===a.type},file:function(a){return a.nodeName.toLowerCase()==="input"&&"file"===a.type},password:function(a){return a.nodeName.toLowerCase()==="input"&&"password"===a.type},submit:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"submit"===a.type},image:function(a){return a.nodeName.toLowerCase()==="input"&&"image"===a.type},reset:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"reset"===a.type},button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&"button"===a.type||b==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)},focus:function(a){return a===a.ownerDocument.activeElement}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return bc[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=o.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||n([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||!!a.nodeName&&a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=m.attr?m.attr(a,c):o.attrHandle[c]?o.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":!f&&m.attr?d!=null:f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=o.setFilters[e];if(f)return f(a,c,b,d)}}},p=o.match.POS,q=function(a,b){return"\\"+(b-0+1)};for(var r in o.match)o.match[r]=new RegExp(o.match[r].source+/(?![^\[]*\])(?![^\(]*\))/.source),o.leftMatch[r]=new RegExp(/(^(?:.|\r|\n)*?)/.source+o.match[r].source.replace(/\\(\d+)/g,q));var s=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(t){s=function(a,b){var c=0,d=b||[];if(g.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length=="number")for(var e=a.length;c ",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(o.find.ID=function(a,c,d){if(typeof c.getElementById!="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},o.filter.ID=function(a,b){var c=typeof a.getAttributeNode!="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(o.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML=" ",a.firstChild&&typeof a.firstChild.getAttribute!="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(o.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=m,b=c.createElement("div"),d="__sizzle__";b.innerHTML="
";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){m=function(b,e,f,g){e=e||c;if(!g&&!m.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return s(e.getElementsByTagName(b),f);if(h[2]&&o.find.CLASS&&e.getElementsByClassName)return s(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return s([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return s([],f);if(i.id===h[3])return s([i],f)}try{return s(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var k=e,l=e.getAttribute("id"),n=l||d,p=e.parentNode,q=/^\s*[+~]/.test(b);l?n=n.replace(/'/g,"\\$&"):e.setAttribute("id",n),q&&p&&(e=e.parentNode);try{if(!q||p)return s(e.querySelectorAll("[id='"+n+"'] "+b),f)}catch(r){}finally{l||k.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)m[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector;if(b){var d=!b.call(c.createElement("div"),"div"),e=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(f){e=!0}m.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!m.isXML(a))try{if(e||!o.match.PSEUDO.test(c)&&!/!=/.test(c)){var f=b.call(a,c);if(f||!d||a.document&&a.document.nodeType!==11)return f}}catch(g){}return m(c,null,null,[a]).length>0}}}(),function(){var a=c.createElement("div");a.innerHTML="
";if(!!a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;o.order.splice(1,0,"CLASS"),o.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?m.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?m.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:m.contains=function(){return!1},m.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var y=function(a,b,c){var d,e=[],f="",g=b.nodeType?[b]:b;while(d=o.match.PSEUDO.exec(a))f+=d[0],a=a.replace(o.match.PSEUDO,"");a=o.relative[a]?a+"*":a;for(var h=0,i=g.length;h0)for(h=g;h=0:f.filter(a,this).length>0:this.filter(a).length>0)},closest:function(a,b){var c=[],d,e,g=this[0];if(f.isArray(a)){var h=1;while(g&&g.ownerDocument&&g!==b){for(d=0;d-1:f.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b||g.nodeType===11)break}}c=c.length>1?f.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a)return this[0]&&this[0].parentNode?this.prevAll().length:-1;if(typeof a=="string")return f.inArray(this[0],f(a));return f.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a=="string"?f(a,b):f.makeArray(a&&a.nodeType?[a]:a),d=f.merge(this.get(),c);return this.pushStack(S(c[0])||S(d[0])?d:f.unique(d))},andSelf:function(){return this.add(this.prevObject)}}),f.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return f.dir(a,"parentNode")},parentsUntil:function(a,b,c){return f.dir(a,"parentNode",c)},next:function(a){return f.nth(a,2,"nextSibling")},prev:function(a){return f.nth(a,2,"previousSibling")},nextAll:function(a){return f.dir(a,"nextSibling")},prevAll:function(a){return f.dir(a,"previousSibling")},nextUntil:function(a,b,c){return f.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return f.dir(a,"previousSibling",c)},siblings:function(a){return f.sibling(a.parentNode.firstChild,a)},children:function(a){return f.sibling(a.firstChild)},contents:function(a){return f.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:f.makeArray(a.childNodes)}},function(a,b){f.fn[a]=function(c,d){var e=f.map(this,b,c);L.test(a)||(d=c),d&&typeof d=="string"&&(e=f.filter(d,e)),e=this.length>1&&!R[a]?f.unique(e):e,(this.length>1||N.test(d))&&M.test(a)&&(e=e.reverse());return this.pushStack(e,a,P.call(arguments).join(","))}}),f.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?f.find.matchesSelector(b[0],a)?[b[0]]:[]:f.find.matches(a,b)},dir:function(a,c,d){var e=[],g=a[c];while(g&&g.nodeType!==9&&(d===b||g.nodeType!==1||!f(g).is(d)))g.nodeType===1&&e.push(g),g=g[c];return e},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var V="abbr|article|aside|audio|canvas|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",W=/ jQuery\d+="(?:\d+|null)"/g,X=/^\s+/,Y=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,Z=/<([\w:]+)/,$=/",""],legend:[1,""," "],thead:[1,""],tr:[2,""],td:[3,""],col:[2,""],area:[1,""," "],_default:[0,"",""]},bh=U(c);bg.optgroup=bg.option,bg.tbody=bg.tfoot=bg.colgroup=bg.caption=bg.thead,bg.th=bg.td,f.support.htmlSerialize||(bg._default=[1,"div","
"]),f.fn.extend({text:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.text(a.call(this,b,c.text()))});if(typeof a!="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return f.text(this)},wrapAll:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapAll(a.call(this,b))});if(this[0]){var b=f(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapInner(a.call(this,b))});return this.each(function(){var b=f(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=f.isFunction(a);return this.each(function(c){f(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){f.nodeName(this,"body")||f(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=f.clean(arguments);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,f.clean(arguments));return a}},remove:function(a,b){for(var c=0,d;(d=this[c])!=null;c++)if(!a||f.filter(a,[d]).length)!b&&d.nodeType===1&&(f.cleanData(d.getElementsByTagName("*")),f.cleanData([d])),d.parentNode&&d.parentNode.removeChild(d);return this},empty:function()
+{for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&f.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return f.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(W,""):null;if(typeof a=="string"&&!ba.test(a)&&(f.support.leadingWhitespace||!X.test(a))&&!bg[(Z.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Y,"<$1>$2>");try{for(var c=0,d=this.length;c1&&l0?this.clone(!0):this).get();f(e[h])[b](j),d=d.concat(j)}return this.pushStack(d,a,e.selector)}}),f.extend({clone:function(a,b,c){var d,e,g,h=f.support.html5Clone||!bc.test("<"+a.nodeName)?a.cloneNode(!0):bo(a);if((!f.support.noCloneEvent||!f.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!f.isXMLDoc(a)){bk(a,h),d=bl(a),e=bl(h);for(g=0;d[g];++g)e[g]&&bk(d[g],e[g])}if(b){bj(a,h);if(c){d=bl(a),e=bl(h);for(g=0;d[g];++g)bj(d[g],e[g])}}d=e=null;return h},clean:function(a,b,d,e){var g;b=b||c,typeof b.createElement=="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var h=[],i;for(var j=0,k;(k=a[j])!=null;j++){typeof k=="number"&&(k+="");if(!k)continue;if(typeof k=="string")if(!_.test(k))k=b.createTextNode(k);else{k=k.replace(Y,"<$1>$2>");var l=(Z.exec(k)||["",""])[1].toLowerCase(),m=bg[l]||bg._default,n=m[0],o=b.createElement("div");b===c?bh.appendChild(o):U(b).appendChild(o),o.innerHTML=m[1]+k+m[2];while(n--)o=o.lastChild;if(!f.support.tbody){var p=$.test(k),q=l==="table"&&!p?o.firstChild&&o.firstChild.childNodes:m[1]===""&&!p?o.childNodes:[];for(i=q.length-1;i>=0;--i)f.nodeName(q[i],"tbody")&&!q[i].childNodes.length&&q[i].parentNode.removeChild(q[i])}!f.support.leadingWhitespace&&X.test(k)&&o.insertBefore(b.createTextNode(X.exec(k)[0]),o.firstChild),k=o.childNodes}var r;if(!f.support.appendChecked)if(k[0]&&typeof (r=k.length)=="number")for(i=0;i=0)return b+"px"}}}),f.support.opacity||(f.cssHooks.opacity={get:function(a,b){return br.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=f.isNumeric(b)?"alpha(opacity="+b*100+")":"",g=d&&d.filter||c.filter||"";c.zoom=1;if(b>=1&&f.trim(g.replace(bq,""))===""){c.removeAttribute("filter");if(d&&!d.filter)return}c.filter=bq.test(g)?g.replace(bq,e):g+" "+e}}),f(function(){f.support.reliableMarginRight||(f.cssHooks.marginRight={get:function(a,b){var c;f.swap(a,{display:"inline-block"},function(){b?c=bz(a,"margin-right","marginRight"):c=a.style.marginRight});return c}})}),c.defaultView&&c.defaultView.getComputedStyle&&(bA=function(a,b){var c,d,e;b=b.replace(bs,"-$1").toLowerCase(),(d=a.ownerDocument.defaultView)&&(e=d.getComputedStyle(a,null))&&(c=e.getPropertyValue(b),c===""&&!f.contains(a.ownerDocument.documentElement,a)&&(c=f.style(a,b)));return c}),c.documentElement.currentStyle&&(bB=function(a,b){var c,d,e,f=a.currentStyle&&a.currentStyle[b],g=a.style;f===null&&g&&(e=g[b])&&(f=e),!bt.test(f)&&bu.test(f)&&(c=g.left,d=a.runtimeStyle&&a.runtimeStyle.left,d&&(a.runtimeStyle.left=a.currentStyle.left),g.left=b==="fontSize"?"1em":f||0,f=g.pixelLeft+"px",g.left=c,d&&(a.runtimeStyle.left=d));return f===""?"auto":f}),bz=bA||bB,f.expr&&f.expr.filters&&(f.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!f.support.reliableHiddenOffsets&&(a.style&&a.style.display||f.css(a,"display"))==="none"},f.expr.filters.visible=function(a){return!f.expr.filters.hidden(a)});var bD=/%20/g,bE=/\[\]$/,bF=/\r?\n/g,bG=/#.*$/,bH=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bI=/^(?:color|date|datetime|datetime-local|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bJ=/^(?:about|app|app\-storage|.+\-extension|file|res|widget):$/,bK=/^(?:GET|HEAD)$/,bL=/^\/\//,bM=/\?/,bN=/
Create Credit Card Sample
+ +Using the 'vault' API, you can store a +Credit Card securely on PayPal. You can +use a saved Credit Card to process +a payment in the future. +The following code demonstrates how +can save a Credit Card on PayPal using +the Vault API. +API used: POST /v1/vault/credit-card