All Downloads are FREE. Search and download functionalities are using the official Maven repository.

features-extras.opensocial-payment.payment.js Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

/**
 * @class
 * Representation of a payment.
 ?
 * @name opensocial.Payment
 */


/**
 * Base interface for all payment objects.
 *
 * @param {Object.} params
 *    Parameters defining the payment.
 * @private
 * @constructor
 */
opensocial.Payment = function(params) {
  this.fields_ = params || {};
  this.fields_[opensocial.Payment.Field.PAYMENT_TYPE] = 
      this.fields_[opensocial.Payment.Field.PAYMENT_TYPE] || 
      opensocial.Payment.PaymentType.PAYMENT;
};


opensocial.Payment.prototype.isPayment = function() {
  return this.fields_[opensocial.Payment.Field.PAYMENT_TYPE] == 
      opensocial.Payment.PaymentType.PAYMENT;
};

opensocial.Payment.prototype.isCredit = function() {
  return this.fields_[opensocial.Payment.Field.PAYMENT_TYPE] == 
      opensocial.Payment.PaymentType.CREDIT;
};

opensocial.Payment.prototype.isComplete = function() {
  return !!this.fields_[opensocial.Payment.Field.PAYMENT_COMPLETE];
};


/**
 * @static
 * @class
 * All of the fields that a payment object can have.
 *
 * 

The ITEMS, AMOUNT, MESSAGE, PARAMETERS are required for the request.

* *

And the ORDER_ID, ORDERED_TIME, SUBMITTED_TIME, EXECUTED_TIME fields * will be filled during the procedure and return to the app.

*

* See also: * opensocial.Payment.getField() *

* * @name opensocial.Payment.Field */ opensocial.Payment.Field = { /** * @member opensocial.Payment.Field */ SANDBOX : 'sandbox', /** * @member opensocial.Payment.Field */ ITEMS : 'items', /** * @member opensocial.Payment.Field */ AMOUNT : 'amount', /** * @member opensocial.Payment.Field */ MESSAGE : 'message', /** * @member opensocial.Payment.Field */ PARAMETERS : 'parameters', /** * @member opensocial.Payment.Field */ PAYMENT_TYPE : 'paymentType', /** * @member opensocial.Payment.Field */ ORDER_ID : 'orderId', /** * @member opensocial.Payment.Field */ ORDERED_TIME : 'orderedTime', /** * @member opensocial.Payment.Field */ SUBMITTED_TIME : 'submittedTime', /** * @member opensocial.Payment.Field */ EXECUTED_TIME : 'executedTime', /** * @member opensocial.Payment.Field */ RESPONSE_CODE : 'responseCode', /** * @member opensocial.Payment.Field */ RESPONSE_MESSAGE : 'responseMessage', /** * @member opensocial.Payment.Field */ PAYMENT_COMPLETE : 'paymentComplete' }; /** * Gets the payment field data that's associated with the specified key. * * @param {string} key The key to get data for; * see the Field class * for possible values * @param {Object.=} * opt_params Additional * params * to pass to the request. * @return {string} The data * @member opensocial.Payment */ opensocial.Payment.prototype.getField = function(key, opt_params) { return opensocial.Container.getField(this.fields_, key, opt_params); }; /** * Sets data for this payment associated with the given key. * * @param {string} key The key to set data for * @param {string} data The data to set */ opensocial.Payment.prototype.setField = function(key, data) { return this.fields_[key] = data; }; /** * @static * @class * Types for a payment. * * @name opensocial.Payment.PaymentType */ opensocial.Payment.PaymentType = { /** * @member opensocial.Payment.PaymentType */ PAYMENT : 'payment', /** * @member opensocial.Payment.PaymentType */ CREDIT : 'credit' }; /** * @static * @class * Possible response codes for the whole payment process. * * @name opensocial.Payment.ResponseCode */ opensocial.Payment.ResponseCode = { /** * @member opensocial.Payment.ResponseCode */ APP_LOGIC_ERROR : 'appLogicError', /** * @member opensocial.Payment.ResponseCode */ APP_NETWORK_FAILURE : 'appNetworkFailure', /** * @member opensocial.Payment.ResponseCode */ INSUFFICIENT_MONEY : 'insufficientMoney', /** * @member opensocial.Payment.ResponseCode */ INVALID_TOKEN : 'invalidToken', /** * @member opensocial.Payment.ResponseCode */ MALFORMED_REQUEST : 'malformedRequest', /** * @member opensocial.Payment.ResponseCode */ NOT_IMPLEMENTED : 'notImplemented', /** * @member opensocial.Payment.ResponseCode */ OK : 'ok', /** * @member opensocial.Payment.ResponseCode */ PAYMENT_ERROR : 'paymentError', /** * @member opensocial.Payment.ResponseCode */ PAYMENT_PROCESSOR_ALREADY_OPENED : 'paymentProcessorAlreadyOpened', /** * @member opensocial.Payment.ResponseCode */ UNKNOWN_ERROR : 'unknownError', /** * @member opensocial.Payment.ResponseCode */ USER_CANCELLED : 'userCancelled' }; /** * @static * @class * Request fields for requesting payment records. * * @name opensocial.Payment.RecordsRequestFields */ opensocial.Payment.RecordsRequestFields = { /** * @member opensocial.Payment.RecordsRequestFields */ SANDBOX : 'sandbox', /** * @member opensocial.Payment.RecordsRequestFields */ MAX : 'max', /** * @member opensocial.Payment.RecordsRequestFields */ INCOMPLETE_ONLY : 'incompleteOnly' };




© 2015 - 2025 Weber Informatics LLC | Privacy Policy