Pages

Friday, 10 January 2014

ASP.Net 4.0 - Chart Control

ASP.Net 4.0 - Chart Control: Getting Started

Note Microsoft introduced a new control (chart) from ASP.Net 4.0 version.

You can download full source code of a chart application.


Chart control can be of following types:
1. Line
2. Bar
3. Pie etc and a lot more......
In this section we will only concentrate on the above mentioned 3 chart types.
This guide presents the following to quickly get you up and running with the Chart Diagram (Bar, Line and Pie):

Overview

A chart control have 2 most important attributes:
1. Series: The Series collection contains the data-points for one or more data-series. Basically for each line in the chart
(consisting of multiple data-points), one series of data is required. Each series can have its own ChartType.
2. ChartAreas: The ChartArea collection can have one or more configurations which controls the rendering of a chart.
A chart must have a chart area.

Our System

We will going to generate the following charts today:



Key Concept

You can create a chart diagram by following the below steps:
  1. First of all Drag a Chart control on the default page from toolbox.
    It will perform the following changes:
    
     a. It will add some handlers, appkeys and axd file in web.config:
        
    
    
    
        b. Now your web page will have the chart control :
    
    
        
    
  2. Now declare the chart type and bind the chart control with a datatable or dataset from the code behind:
            
    
  3. By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com
    

Thursday, 9 January 2014

Screenshot Capturing Appliction

C# - Capture screenshot of active window

This guide presents the following to quickly get you up and running with the Screenshot Capturing Application using C#.
You can download full source code of a Screenshot Capturing Application

Overview

A software or Application capable of Capturing screens will allow you to take screenshots of your screen iteratively
after a certain period of time (i.e. Here 10 seconds).

The base thing about this software is, all of these events occured from background. So you can keep yourself busy in other works, while the
application will still capture the screenshots..

It is also possible, that the application or software will upload all of those screenshots to the server..
I'm not going to introduce the above today....We will learn it another day surely....

Key Concepts

You can create a Screenshot Capture software by following the below mentioned steps:
  1. First of all put 2 button namely: "Start Capturing" and "Stop Capturing" on the Form.
  2. Now add a Timer control on the Form.
  3. Now Click on the Timer Control twice to generate an timer1_Tick event on the code behind.
).
Put the following code on your code behind:
private void timer1_Tick(object sender, EventArgs e)
{
Image screenShot = CaptureScreenShot();
string filename = "screenshot" + DateTime.Now.Day.ToString() + "_" + DateTime.Now.Month.ToString() + "_" +

DateTime.Now.Year.ToString() + "_" + DateTime.Now.Hour.ToString() + "_" + DateTime.Now.Minute.ToString() + "_"

+ DateTime.Now.Second.ToString() + ".jpg";
screenShot.Save("d:/Screens/" + filename);
}


private Image CaptureScreenShot()
{
Bitmap bmpScreenshot = new Bitmap(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height,

PixelFormat.Format32bppArgb);
Graphics gfxScreenshot = Graphics.FromImage(bmpScreenshot);
gfxScreenshot.CopyFromScreen(Screen.PrimaryScreen.Bounds.X, Screen.PrimaryScreen.Bounds.Y, 0, 0,

Screen.PrimaryScreen.Bounds.Size, CopyPixelOperation.SourceCopy);
return bmpScreenshot;
}




  • Now Click on the "Button Controls" twice to generate an Click event on the code behind.
  • Put the following code on your code behind:
    Put the following code on your code behind:
    private void btnCapture_Click(object sender, EventArgs e)
    {
    btnCapture.Enabled = false;
    btnStopCapture.Enabled = true;
    timer1.Tick += new EventHandler(timer1_Tick); // Everytime timer ticks, timer_Tick will be called
    timer1.Interval = (1000) * (10);             // Timer will tick evert 10 seconds
    timer1.Enabled = true;                       // Enable the timer
    timer1.Start();                              // Start the timer
    }
    
    
    private void btnStopCapture_Click(object sender, EventArgs e)
    {
    timer1.Enabled = false;
    btnCapture.Enabled = true;
    btnStopCapture.Enabled = false;
    }
    
    Now run the application and Start getting the screenshots in the directory "D:\Screens"

  • By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com
    

    Wednesday, 8 January 2014

    Tournaments brackets Generating: Single Elimination

    Tournaments Brckets Generating: Single Elimination

    Download a dummy implementation of single elimination  


    This guide presents the following sections to quickly get you up and running with the Single Elimination algorithms and implementations:

    Overview

    There are various elimination algorithm exist in the system:

    1. Single Elimination
    2. Double Elimination
    3. Round Robin
    4. Seeding etc

    Here we will discuss only on Single Elimination scheme.

    Key Concepts

    Single EliminationAdaptive Payments has operations that enable the sending and receiving of payments involving two or more parties. Each Adaptive Payments API transaction includes a sender and one or more receivers of the payment. Each transaction also includes the application owner, called the "API Caller," who is an invisible third party that provides the transaction flow and is the entity that makes the API calls. In most scenarios, payment transactions are initiated by the buyer (in asend type of payment arrangement) or by the seller (in a pay type of payment arrangement).

       Figure 1. Single Elimination Graph
    A single-elimination tournament — also called an Olympic system tournament, a knockout, cup, or sudden death tournament
    is a type of elimination tournament where the loser of each bracket is immediately eliminated from winning the championship
    or first prize in the event.

    Formula

    To calculate the number of rounds we need to consider the following:
    int rounds = (int)Math.Log(Convert.ToInt32(txtNoofPlayers.Text), 2) + 1;
    Where, txtNoofPlayers.Text providing the no of participants in a tournament.
    No of player need to be power of 2 (i.e. 2, 4, 8, 16, 32, 128 etc)

    After getting number of rounds, we can calculate number of matches should be occured on each round:
    int noOfPlayers = Convert.ToInt32(txtNoofPlayers.Text);
    #region calculating No of matches each round
    for (int i = 1; i <= rounds; i++)
    {
    GroupMatches[i - 1] = noOfPlayers / 2;
    noOfPlayers /= 2;
    }
    #endregion
    By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com
    

    Tuesday, 7 January 2014

    PayPal MASS pay API Integration

    PayPal MASS PAY: Getting Started

    Downlodable Mass Pay Integration demo Project

    Overview

    PayPal MASS PAY API lets allow you to pay multiple clients / users at a single click.
    The sender can pay at most 250 users at a time.

    Key Concepts

    To sending the amount using MASS PAY API you need to provide the followings:

    1. e-mail addresses of your payees.
    2. Each and Every payees amount.
    3. Transaction Currency.

    Note You need to get API details (APIUsername, APIPassword and APISignature) from your paypal account and set those to the application.

    Note When setting up a MassPay call, you can specify a customized subject line for the e-mail that PayPal distributes. You can also add a note
    for PayPal to include in the body of e-mail. Included in the e-mail is a link that provides an easy way for payees to log into their PayPal
    accounts. Once logged in, payees can can manage the payments they've received.

    Making Your First Call

    The following example calls MASS Payment API in the Sandbox to make a MASS payout.
    1. Obtain the endpoint for the service and environment you are addressing.
      https://api-3t.sandbox.paypal.com/nvp
      
      This is the endpoint for making calls in name/value pair style in the Sandbox. For the SOAP endpoint, see API endpoints.
    2. Provide the authentication. For the sample DoDirectPayment call below, these are set via parameters you pass to the call.
      // Sandbox API credentials for the API Caller account
      USER : // user id
      PWD : // password
      SIGNATURE : // signature
      VERSION : // the release version of the API
      
    3. Provide parameters needed by the specific call being made .
      METHOD : MassPay
      RECEIVERTYPE : EmailAddress(other options are Mobile No or Paypal User ID)
      CURRENCYCODE : USD (any three digit corrency code)
      
    4. Now provide each and every payees email id and payable amount.
      L_EMAIL0=payee0@example.com
      L_AMT0=15.95 
      L_EMAIL1=payee1@example.com
      L_AMT1=21.50
      
      You are now ready to make a call..
    5. Evaluate the response.

    Check Normal Paypal Integration.
    Check Adaptive Payment Integration.
    Check PayPal Pro Integration.

    By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com
    

    Digital Signature: SuperSignature Integration

    Digital Signature in ASP.Net: Super Signature

    You can Download Supersignature Integration demo project.
    This guide presents the following sections to quickly get you up and running with the Super Signature Integration in ASP.Net:

    Overview

    The Super Signature / Digital Signature enables users to sign online sing their Iphones, Ipads, Fingertips or stylus.
    We can integrate this Control very easily into our websites and allow the website to capture the signatures online.

    Integration Steps:

    1. First of all we need to download SuperSignature Dll.

    2. Now we need to ADD that DLL to our website by Right clicking the solution explorer and clicking on
       'Add Reference' and then browse through the Dll.

    3. Now copy the following and put in your Default.aspx page:



    4. Now copoy the followings and replace your Default.aspx.cs page:



    5. Now build and Run the website...

    Notes

    The providing codes and the demo website will only work from localhost.
    To get in work on the server, you need to purchase SuperSignature dll license.
    By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com
    

    Monday, 6 January 2014

    PayPal Adaptive Payments Integration

    Adaptive Payments API: Getting Started

    Full source code is available here

    This guide presents the following sections to quickly get you up and running with the Adaptive Payments API:

    Overview

    The Adaptive Payments API enables merchants and developers to select the payment scenario most suitable to their needs. Merchants and developers can create applications that manage payments, payment preapprovals, and refunds. Merchants and developers can also send money peer-to-peer, split payments in both parallel and chained models, accept guest payments, , and schedule disbursements. It works on multiple platforms including the web and mobile environments.

    Key Concepts

    Adaptive Payments has operations that enable the sending and receiving of payments involving two or more parties. Each Adaptive Payments API transaction includes a sender and one or more receivers of the payment. Each transaction also includes the application owner, called the "API Caller," who is an invisible third party that provides the transaction flow and is the entity that makes the API calls. In most scenarios, payment transactions are initiated by the buyer (in asend type of payment arrangement) or by the seller (in a pay type of payment arrangement).
    Adaptive Payments Overview
       Figure 1. Overview of Adaptive Payments
    The Adaptive Payments API uses the Pay operation to make payments between a sender and one or more receivers of that payment. Payments can be split between receivers (in either "chained" or "parallel" modes) and additional operations in the API lets senders authorize and preapprove an application to make payments on their behalf. The flexibility of the operations in the API make for an "adaptive" set of functions that addresses a wide range of payment scenarios.

    Payment Approvals

    As with any payment, the payments made via the Adaptive Payments API must be authorized and approved by the payment sender. To provide the best possible user experience for senders, the Adaptive Payments API provides the following payment approval methods:
    Web Redirect
    The default method where applications redirect the sender of the payment to PayPal for approval.
    Embedded Process
    Applications embed the payment authorization process into the application itself.
    Implicit
    Applications act as the sender of the payment and implicitly authorize the payment.
    Preapproved
    Applications obtain a preapproval from the sender.

    Making Your First Call

    To make a call to the Adaptive Payments Pay operation, supply the necessary HTTP headers and call payload to the service endpoint.
    A call to the Pay operation involves three users:
    • API Caller, represents your application and the account whose credentials the application uses to make the call
    • Sender, the account making the payment
    • Receiver, the account receiving the payment
    The following steps outline the inputs needed to make the call and shows how to authorize the payment after the Pay operation succeeds:
    1. Obtain the endpoint for the service and environment you are addressing.

      The Sandbox endpoint for the Adaptive Payments Pay operation is:
        https://svcs.sandbox.paypal.com/AdaptivePayments/Pay
    2. Format the HTTP headers needed to make the call.

      You need to supply the following headers to call the Pay operation:
      // Sandbox API credentials for the API Caller account
      X-PAYPAL-SECURITY-USERID : Sandbox-Caller-User-Id
      X-PAYPAL-SECURITY-PASSWORD : Sandbox-Caller-Password
      X-PAYPAL-SECURITY-SIGNATURE : Sandbox-Caller-Security-Signature
      
      // Global Sandbox Application ID
      X-PAYPAL-APPLICATION-ID : APP-80W284485P519543T
      
      // Input and output formats
      X-PAYPAL-REQUEST-DATA-FORMAT : JSON
      X-PAYPAL-RESPONSE-DATA-FORMAT : JSON
      
    3. Format the call payload.

      The Pay operation requires several payload input fields, shown here as a JSON object:
    4. {
      "actionType":"PAY",    // Specify the payment
          action
      "currencyCode":"USD",  // The currency of the
          payment
      "receiverList":{"receiver":[{
      "amount":"1.00",                    // The payment
          amount
      "email":"Sandbox-Receiver-eMail"}]  //
          The payment Receiver's email address
      },
      
      // Where the Sender is redirected to after approving a successful
          payment
      "returnUrl":"http://Payment-Success-URL",
      
      // Where the Sender is redirected to upon a canceled payment
      "cancelUrl":"http://Payment-Cancel-URL",
      "requestEnvelope":{
      "errorLanguage":"en_US",    // Language used
          to display errors
      "detailLevel":"ReturnAll"   // Error detail
          level
      }
      }
      
      That's it, you're now set to make the call.
    5. Make the call.
    6. If your Pay call is successful (the ack field in the response contains Success), redirect the Sender to PayPal so they can authorize the payment:
      1. Retrieve the payKey value from the response of the Pay call.
        Here is an example of a successful Pay response with the payKey highlighted:
        {
        "responseEnvelope": {
        "timestamp": "2011-08-20T15:12:20.833-07:00",   
            // GMT time that the server issued the response
        "ack": "Success",                               //
            Status of the response
        "correlationId": "nnnnnnnnnnnn",                // ID identifying the response
        "build": "nnnnnnn"                              // Version of the server
        },
        "payKey": "Your-payKey",                          // Key used to authorize payment
        "paymentExecStatus": "CREATED"                    //
            Current status of payment
        }
        
      2. Use the payKey value in an authorization redirect to PayPal using the following Sandbox URI:
        https://www.sandbox.paypal.com/cgi-bin/webscr?cmd=_ap-payment&paykey=
            Your-payKey
        
        When redirected to PayPal, the Sender is presented with a PayPal Authorization window where they can login to their account and approve the payment.
        Adaptive Payments: Authorizing Payment
           Figure 2. Authorizing the Payment
    Once the buyer authorizes the payment, the transaction is complete and they are redirected to the URL specified by the returnUrl input field in your Payrequest.

    Try It!

    The following cURL command contains a call to the Pay operation. Run the command by copying and pasting it into a code window. (If cURL is not installed on your system, you can download the free cURL executable from http://curl.haxx.se/download.html.)
    curl -s --insecure -H "X-PAYPAL-SECURITY-USERID: caller_1312486258_biz_api1.gmail.com" -H "X-PAYPAL-SECURITY-PASSWORD: 1312486294" -H "X-PAYPAL-SECURITY-SIGNATURE: AbtI7HV1xB428VygBUcIhARzxch4AL65.T18CTeylixNNxDZUu0iO87e" -H "X-PAYPAL-REQUEST-DATA-FORMAT: JSON" -H "X-PAYPAL-RESPONSE-DATA-FORMAT: JSON" -H "X-PAYPAL-APPLICATION-ID: APP-80W284485P519543T" https://svcs.sandbox.paypal.com/AdaptivePayments/Pay -d "{\"actionType\":\"PAY\", \"currencyCode\":\"USD\", \"receiverList\":{\"receiver\":[{\"amount\":\"1.00\",\"email\":\"rec1_1312486368_biz@gmail.com\"}]}, \"returnUrl\":\"http://www.example.com/success.html\", \"cancelUrl\":\"http://www.example.com/failure.html\", \"requestEnvelope\":{\"errorLanguage\":\"en_US\", \"detailLevel\":\"ReturnAll\"}}"
    
    Voilà! You have made your first call to the Adaptive Payments API.
    After issuing the command, the Adaptive Payments service should return a successful response that includes a valid Sandbox payKey.
    The above call is made possible by the use of a publicly-available set of Sandbox credentials (highlighted in the call). While you can extract the payKey from the response and use it in an authorization redirect, you will be unable to authorize the Sandbox transaction. However, if you substitute the credentials and e-mail address from your Sandbox test accounts into the above command, you will be able to complete the entire transaction flow in the Sandbox.
    If, after using your own Sandbox credentials, your Pay call is not successful, review the call response for the error details and address the problem before resubmitting the call. If your call is successful, insert the returned payKey value into the following URL:
    https://www.sandbox.paypal.com/cgi-bin/webscr?cmd=_ap-payment&paykey=payKey
    
    Log in to the resulting PayPal window with your Sandbox Buyer account to complete the transaction. Once complete, log into your Sandbox account and review the test account balances and e-mail to see the transaction results.


    Introducing Adaptive Payments

    The Adaptive Payments API enables you to send money in many different scenarios, from simple to complex. For example, you might build a small send money application for a social networking site or a robust payroll system.

    Adaptive Payments Actors and Objects

    Adaptive payments handles payments between a sender of a payment and one or more receivers of the payment. You are an application owner, such as a merchant that owns a website, the owner of a widget on a social networking site, the provider of a payment application on mobile phones, and so on. Your application is the caller of Adaptive Payments API operations.
    Note: The application owner must have a PayPal Business account. Senders and receivers can have any PayPal account type. Senders and receivers are not required to have PayPal accounts initially. PayPal prompts a sender to create an account before a payment can be completed. A receiver must create an account to receive the funds after the payment completes.
    With many applications, you may be both the application owner and a receiver. For example, as the owner of a website, you are the receiver of payments from the senders who are your customers. The following diagram shows the relationship between a sender, you as a receiver, and PayPal:


    You are not required to be a receiver. For example, if you own a shopping cart, you are not required to receive payments directly. You can facilitate payments between the sender and receivers that provide the actual goods. The following diagram shows the relationship between a sender, you as an application owner that directs payments to receivers, and PayPal:


    This diagram shows a payment in which the sender pays multiple receivers in a parallel payment. With parallel payments, the sender can see the transaction to each receiver.
    The following diagram shows the relationship between a sender, you as an application owner that directs payments to receivers, and PayPal in a chained payment:


    In a chained payment, the sender pays the primary receiver an amount, from which the primary receiver pays secondary receivers. The sender only knows about the primary receiver, not the secondary receivers. The secondary receivers only know about the primary receiver, not the sender.
    The following diagram shows the relationship between you as both the sender and the application owner that directs payments to receivers:


    For example, you might use this configuration in a sales commission application that transfers funds owed for commissions from your account to the accounts of your sales force.

    Simple, Parallel, and Chained Payments

    Adaptive Payments provides several kinds of payment: simple, parallel, and chained payments. You create each kind of payment with the Pay API.
    • Simple payments enable a sender to send a single payment to a single receiver. For example, your website can use an Adaptive Payments payment flow to transfer money resulting from a sale from your customer's PayPal account to your own account. This is the traditional kind of payment.
    • Parallel payments enable a sender to send a single payment to multiple receivers. For example, your application might be a shopping cart that enables a buyer to pay for items from several merchants with one payment. Your shopping cart allocates the payment to merchants that actually provided the items. PayPal then deducts money from the sender's account and deposits it in the receivers' accounts.
    • Chained payments enable a sender to send a single payment to a primary receiver. The primary receiver keeps part of the payment and pays secondary receivers the remainder. For example, your application could be an online travel agency that handles bookings for airfare, hotel reservations, and car rentals. The sender sees only you as the primary receiver. You allocate the payment for your commission and the actual cost of services provided by other receivers. PayPal then deducts money from the sender's account and deposits it in both your account and the secondary receivers' accounts.
      Note: Chained payments also include delayed chained payments, in which payments to secondary receivers can be delayed for up to 90 days.

    Simple Payments

    Simple payments enable a sender to send a single payment to a single receiver. This is sometimes considered a traditional payment, such as a payment from a buyer to a seller.
    Scenarios involving simple payments might include the following scenarios:
    • Buyer makes a payment on a merchant's website.
    • Buyer makes a single payment for a cart of items from the same merchant.
    • Person on a social networking site makes a payment for a purchase to the receiver. For example, a sender sends money to pay for lunch at a restaurant.
    In these cases, the sender sends a payment to a single receiver. The following example shows a sender making a simple payment:


    Parallel Payments

    A parallel payment is a payment from a sender that is split directly among 2-6 receivers. Technically, a parallel payment is a set of multiple payments made in a single Pay request.
    Parallel payments are useful in cases when a buyer intends to make a single payment for items from multiple sellers. Examples include the following scenarios:
    • a single payment for multiple items from different merchants, such as a combination of items in your inventory and items that partners drop ship for you.
    • purchases of items related to an event, such as a trip that requires airfare, car rental, and a hotel booking.
    In these cases, the sender knows the receivers and the amount paid to each one. The following example shows a sender paying 3 receivers in a single parallel payment:


    Note: This scenario is an example only and does not take PayPal fees into account.

    Chained Payments

    A chained payment is a payment from a sender that is indirectly split among multiple receivers. It is an extension of a typical payment from a sender to a receiver, in which a receiver, known as the primary receiver, passes part of the payment to other receivers, who are called secondary receivers.
    Note: The API caller must get permission from PayPal to use chained payments.
    You can have at most one primary receiver and 1-5 secondary receivers. Chained payments are useful in cases when the primary receiver acts as an agent for other receivers. The sender deals only with the primary receiver and does not know about the secondary receivers, including how a payment is split among receivers. The following example shows a sender making a payment of $100:


    In this example, the primary receiver receives $100 from the sender's perspective. The primary receiver actually receives only $10 and passes a total of $90 to secondary receivers, Receiver 2 and Receiver 3.
    Note: This scenario is an example only and does not take PayPal fees into account.

    Delayed Chained Payments

    By default, payments to all receivers in a chained payment are immediate. However, you can choose to delay a payment to a secondary receiver. For example, as primary receiver, you may require secondary receivers to perform some action, such as shipping goods or waiting for expiration of a return period, before making payment. To complete the payment, you must explicitly execute a payment to secondary receivers after the sender pays you. The payment must occur within 90 days, after which you cannot complete the payment as part of the original chained payment.

    Payment Approval

    The sender of a payment must approve the transfer. The sender can log in to paypal.com to approve each payment, preapprove payments, or when the sender is your application, be implicitly approved to make payments.
    Note: Preapproval requests require permission from PayPal.
    There are 3 kinds of payment approvals:
    • Explicit approval payments, in which the sender logs in to paypal.com to approve each payment. Explicitly approving payments is the traditional way to pay with PayPal. This method is the only option unless the sender has set up a preapproval agreement or you, the API caller, are also the sender.
    • Preapproved payments, in which a sender logs in to PayPal and sets up preapprovals that approve future payments or set up a preapproval during the embedded payment flow. The sender logs in to paypal.com once to set up the preapproval. After the sender agrees to the preapproval, specific approval is unnecessary.
    • Implicit approval payments, in which your application is both the sender of a payment and the caller of the Adaptive Payments Pay API. In this case, PayPal makes the payment from your own account, which eliminates the need for approval.

    Adaptive Payments Service Permissions

    Adaptive Payments services are divided into 2 categories: standard services that do not require specific permission to use and advanced services that require permission from PayPal to use. You obtain permission to use a service when you submit an application to PayPal.
    You can use the following standard services without requesting specific permission:
    • Making simple or parallel payments that require explicit approval of the sender
    • Getting payment details
    • Making refunds
    • Performing currency conversions
    To use any other service, you must receive permission from PayPal to use the service when you submit your application. For example, if your application makes chained payments, which is an advanced service, you request permission when you submit your application. Later, if you modify your application to support preapprovals, which is also an advanced service, you must resubmit your application to obtain permission from PayPal to use the service.
    Important: If you allow a third party to PayPal to execute an application on your behalf, the third party becomes the API caller because the party is now calling the Adaptive Payments API. The third party must also have permission from PayPal to use the advanced service. For example, if an application supports chained payments, both you and the third party must have permission to use the service.

    Explicit Approval Payment Flow

    Explicit approval payments require the sender to log in to paypal.com to approve the payment. You control the interaction between your application and PayPal by specifying URLs for redirection in various situations.
    The following diagram shows the basic flow of control for a payment (such as payment for items in a shopping cart at a web store) that requires the sender to log in to paypal.com to approve the payment:


    The following items correspond to the circled numbers in the diagram:
    1. Your site or device sends a Pay request to PayPal on behalf of a sender.
    2. PayPal responds with a key that you use when you direct the sender to PayPal.
    3. You redirect your sender's browser to paypal.com.
    4. After the sender authorizes the transfer of funds, PayPal redirects your sender's browser to the location you specify.
    Note: The cancel operation is not shown in the diagram. Cancellation is handled by a separate cancellation URL to which PayPal redirects the sender's browser any time the sender cancels while on paypal.com.
    In addition to these steps, PayPal notifies you and the sender of the payment.

    Preapproved Payments Flow

    Preapproved payments require the sender to log in to paypal.com to set up the payment agreement with a particular vendor. You control the interaction between your application and PayPal by specifying URLs for redirection in various situations.
    The sender logs in to paypal.com and sets up the preapproval, which includes setting the following information:
    • duration of the preapproval, from the start date to the end date, inclusive
    • the maximum amount being preapproved
    • the maximum number of payments
    The following diagram shows the basic flow of control during a preapproval operation:


    The following items correspond to the circled numbers in the diagram:
    1. Your site or device sends a Preapproval request to PayPal on behalf of a sender.
    2. PayPal responds with a key, called a preapproval key, that you use when you direct the sender to PayPal, and once the preapproval has been established, whenever you automatically complete a payment on behalf of the sender.
    3. You redirect your sender's browser to PayPal.
    4. After the sender logs in to paypal.com and sets up the preapproval, PayPal redirects the sender's browser to a location you specify.
    Note: The cancel operation is not shown in the above diagram. Cancellation is handled by a separate cancellation URL to which PayPal redirects the sender's browser any time the sender cancels while on paypal.com.
    In addition to the steps shown above, PayPal sends an email notifying you and the sender that the preapproval has been created.
    After the sender sets up the approval, you can make payments on the sender's behalf directly. The sender is no longer required to log in to PayPal to complete the payment. The following diagram shows the basic flow of control during a Pay operation:


    The following items correspond to the circled numbers in the diagram:
    1. Your site or device sends a Pay request to PayPal on behalf of a sender. You can require the sender to provide a personal identification number (PIN); however, logging in to paypal.com is no longer required.
      Note: You must provide a preapproval key that identifies the agreement.
    2. PayPal still responds with a payment key that you can use for other API operations, such as for obtaining details of the payment or for issuing a refund.

    Implicit Approval Payments Flow

    Implicit approval payments are payments where the sender and the API caller are using the same account. Because PayPal draws the funds for the payment from your own account, there is no approval necessary, and as such there is no visible flow for implicit approval payments.
    The following diagram shows the basic flow of control during an implicitly approved payment operation:


    The following items correspond to the circled numbers in the diagram:
    1. Your site or device sends a Pay request to PayPal.
      Note: A web flow is not required.
    2. PayPal responds with a key that you use for other API operations.

    Embedded Payments

    An embedded payment is a payment that initiates a visual presentation of the Adaptive Payments payment flow in which the sender appears to never leave your checkout or payment page. Embedded payments make it easier for a sender to make a payment because PayPal may allow the sender to bypass the PayPal login step.
    The ability to bypass the login relies on a remember me cookie, which is stored in the sender's browser when the sender chooses to take advantage of being remembered. Opting in reduces the number of steps to purchase goods or services without significantly increasing the risk that the sender's account might be misused. After the initial login, PayPal bypasses the login step if subsequent payments meet specific criteria, such as a subsequent payment for a small amount.

    Embedded Payment Flow Presentations

    PayPal provides the following kinds of visual presentations for the embedded payment flow:
    • The payment flow can be embedded as a lightbox on your web page, which gives the impression that the payment is handled completely within your website:
    • The payment flow can appear in a minibrowser window that appears in front of your web page, which does not require an IFRAME:
    • The payment flow can be embedded as a lightbox in an IFRAME on your web page, which gives the impression that the payment is handled completely within your website:
    You choose your preferred visual presentation when you invoke the embedded payment flow. In some cases, PayPal may override your choice to use a lightbox; for example, when the sender is required to log into PayPal for the initial payment.

    Kinds of Embedded Payments

    Embedded payments can include
    • simple payments
    • parallel payments
    • chained payments
    You can also enable preapprovals for future payments or enable shipping addresses to be associated with embedded payments.
    Important: Payments for digital goods must use the embedded payment flow. You cannot associate a preapproval for future payments or enable shipping addresses in a payment for digital goods.

    Embedded Payments Implementation Basics

    To implement the embedded payment flow, you must
    • include JavaScript code from PayPal on your checkout or payment web pages
    • use the functions provided in the JavaScript to coordinate the PayPal flow with the appearance of your web pages
    • launch your preferred embedded payment flow, which is either the lightbox or minibrowser, and redirect the sender's browser to the PayPal URL that supports embedded payments, which is https://www.paypal.com/webapps/adaptivepayment/flow/pay?paykey=...
    You must call the Pay API operation to obtain a payment key before launching the embedded payment flow. If the payment is specifically for digital goods, modify your Pay API operation to specify that each receiver is receiving payment for digital goods.

    Embedded Payment Experience

    To the sender of a payment, the embedded payment experience appears to be built into your website. The PayPal-supplied JavaScript provides all the code needed to set up the flow as an IFRAME within the sender's browser and as a pop-up mini-browser that appears in front of your website. Typically, the sender initiates a payment by clicking a button:


    PayPal responds to the JavaScript that initiates the flow. If it is the first payment, or if PayPal determines that the payment requires the sender to log in, PayPal displays a Log In button in the IFRAME created by the JavaScript: 

    The IFRAME also allows the sender to sign up for a PayPal account or pay as a guest without logging in.
    Note: Guest checkout only provides the visual benefits of an embedded payment. It does not reduce the payment steps.
    After clicking Log In, PayPal displays a Log in to your PayPal account page in the minibrowser. The sender enters an email address and password and can also check a box, which allows the sender to skip this step for subsequent purchases:


    The checkbox controls the remember me behavior for log in. This behavior allows the sender to skip the log in step in cases where there is little risk of the account being misused.
    TipImportant: Opting in to the remember me behavior does not guarantee that the sender will not be asked to provide log in credentials.
    After logging in, PayPal displays the You are about to pay page, sometimes called the review your payment page in the minibrowser:


    If the sender chooses Cancel, PayPal redirects the sender's browser to the cancel URL specified in the Pay API operation's request message. If the sender chooses Pay, the Thank you for using PayPal page appears in the minibrowser:


    When the sender clicks Close, PayPal redirects the sender's browser to the return URL specified in the Pay API operation's request message.
    Note: You are responsible for closing the minibrowser after PayPal redirects to the page specified in either the return or cancel URL. PayPal provides a JavaScript function that you call to close a PayPal minibrowser or lightbox.
    For subsequent payments in which PayPal does not require the account holder to log in again and the account holder has chosen to be remembered, the PayPal payment pages appear in a lightbox rather than in a minibrowser and PayPal bypasses the log in steps. For these payments, the actions you take to launch the flow and close the lightbox, remain the same. For example, the lightbox for reviewing a payment would appear in your page as follows:


    The lightbox containing the confirmation would appear in your page as follows:


    Preapprove Future Payments Checkbox

    You can add a Preapprove future payments checkbox to the sender's embedded payment experience, which enables the sender to preapprove subsequent payments. If you specify both a payment key and a preapproval key when you call the Pay API operation, PayPal displays the checkbox on the payment page in the minibrowser:


    If the payment sender checks the preapproval box, the confirmation page provides details about the preapproval:
    Note: Unless there is an error with the payment itself, PayPal transfers the money regardless of whether the preapproval for future payments was successful.

    Shipping Address Information

    You can display and collect shipping address information. PayPal displays the default shipping address when you setsenderOptions.requireShippingAddressSelection to true in your request to SetPaymentOptions:


    The sender of a payment can select one of the available shipping addresses or add a new shipping address by selecting Add new shipping address from the Ship to: drop-down menu:

    Embedded Payment Experience

    To the sender of a payment, the embedded payment experience appears to be built into your website. The PayPal-supplied JavaScript provides all the code needed to set up the flow as an IFRAME within the sender's browser and as a pop-up mini-browser that appears in front of your website.
    Typically, the sender initiates a payment by clicking a button:


    PayPal responds to the JavaScript that initiates the flow. If it is the first payment, or if PayPal determines that the payment requires the sender to log in, PayPal displays a Log In button in the IFRAME created by the JavaScript:


    The IFRAME also allows the sender to sign up for a PayPal account or pay as a guest without logging in.
    Note: Guest checkout only provides the visual benefits of an embedded payment. It does not reduce the payment steps.
    After clicking Log In, PayPal displays a Log in to your PayPal account page in the minibrowser. The sender enters an email address and password and can also check a box, which allows the sender to skip this step for subsequent purchases:


    The checkbox controls the remember me behavior for log in. This behavior allows the sender to skip the log in step in cases where there is little risk of the account being misused.
    TipImportant: Opting in to the remember me behavior does not guarantee that the sender will not be asked to provide log in credentials.
    After logging in, PayPal displays the You are about to pay page, sometimes called the review your payment page in the minibrowser:


    If the sender chooses Cancel, PayPal redirects the sender's browser to the cancel URL specified in the Pay API operation's request message. If the sender chooses Pay, the Thank you for using PayPal page appears in the minibrowser:


    When the sender clicks Close, PayPal redirects the sender's browser to the return URL specified in the Pay API operation's request message.
    Note: You are responsible for closing the minibrowser after PayPal redirects to the page specified in either the return or cancel URL. PayPal provides a JavaScript function that you call to close a PayPal minibrowser or lightbox.
    For subsequent payments in which PayPal does not require the account holder to log in again and the account holder has chosen to be remembered, PayPal bypasses the log in steps.
    For example, the lightbox for reviewing a payment would appear in your page as follows:


    The lightbox containing the confirmation would appear in your page as follows:


    The actions you take to launch the flow and close the lightbox are the same steps you take for the minibrowser.

    Preapprove Future Payments Checkbox

    You can add a Preapprove future payments checkbox to the sender's embedded payment experience, which enables the sender to preapprove subsequent payments. If you invoke the embedded payment flow, passing both a payment key obtained by calling Pay and a preapproval key obtained by callingPreapproval, PayPal displays the checkbox on the payment page:


    If the payment sender checks the preapproval box, the confirmation page provides details about the preapproval:


    Note: Unless there is an error with the payment itself, PayPal transfers the money regardless of whether the preapproval for future payments was successful.

    Embedded Preapproval Experience

    Adaptive Payments provides a preapproval experience using a mini-browser.You can invoke the embedded preapproval flow by passing the preapproval key. Here is an example :
    https://www.paypal.com/webapps/adaptivepayment/flow/preapproval?preapprovalKey

    =PA-xxxxxxxxxxxx&expType=mini
    PayPal first asks the user to log into their PayPal account:


    After signing in, the user is presented with a consent form that the user must agree to:


    If the seller has enabled PIN code entry, after consenting to the agreement,
     the user is prompted to enter a PIN code by the seller:


    Finally, the user is presented with a confirmation screen:


    Shipping Address Selection

    You can display and collect shipping address information for a transaction with the embedded payment flow. PayPal displays the default shipping address when you set senderOptions.requireShippingAddressSelection to true in your request to SetPaymentOptions:


    The sender of a payment can select one of the available shipping addresses or add a new shipping address by selecting Add new shipping address from the Ship to: drop-down menu:


    After the sender of the payment clicks Pay, PayPal displays the selected shipping address on the Thank you for using PayPal page:


    You can call the GetShippingAddresses API operation to obtain the selected shipping address for the transaction using the key assoicated with the payment.

    Setting Up Web Pages to Invoke the Embedded Payment Flow Using a Lightbox

    Use the JavaScript functions in https://www.paypalobjects.com/js/external/dg.js to set up and control the embedded payment flow. This example shows how to initiate the embedded payment flow after obtaining a payment key.
    This example assumes that you obtain a payment key before initiating the flow and that the key does not change or expire before the sender completes the flow.
    To set up a web page to invoke the embedded payment flow:
    1. Call the Pay API operation to obtain a valid pay key.
    2. Create your form or button.
      • You must include the pay key and redirect to https://www.paypal.com/webapps/adaptivepayment/flow/pay.
      • Optionally, include a preapproval key if you want to enable the selection of Preapproval for future payments
      • Specify that a lightbox opens in the PayPal-created IFRAMEPPDGFrame.
      • Set the expType parameter to indicate your preference for the context in which the PayPal payment flow is displayed. You must specify light for lightbox.
      <form action=
      "https://www.paypal.com/webapps/adaptivepayment/flow/pay"
      target="PPDGFrame">
      <input id="type" type="hidden" name="expType" value="light">
      <input id="paykey" type="hidden" name="paykey" value="
          AP-...">   <input id="preapprovalkey"     type="hidden" name="preapprovalkey" value="PA-...">   <input type="submit" id="submitBtn" value="Pay with PayPal">  </form>
      
      Note: To modify an existing application to use the embedded payment flow, change the redirect fromhttps://www.paypal.com/cgi-bin/webscr?cmd=_ap-payment&paykey=... to
    3. https://www.paypal.com/webapps/adaptivepayment/flow/pay? paykey=... after obtaining the pay key.
    4. Include the PayPal JavaScript functions from dg.js.
      <script src="https://www.paypalobjects.com/js/external/dg.js">
      </script>
      
    5. Create an embedded flow object and associate it with your payment form or button.
      <script>
      var dgFlow = new PAYPAL.apps.DGFlow({ trigger: 'submitBtn' });
      </script>
      
    On the pages you identify as the return and cancel URLs in the Pay API operation, you must include the PayPal JavaScript functions from dg.js and close the PayPal window, as in the following example:
    dgFlow = top.dgFlow || top.opener.top.dgFlow;
    dgFlow.closeFlow();
    top.close();
    

    Setting Up Web Pages to Invoke the Embedded Payment Flow Using a Minibrowser

    Use the JavaScript functions in https://www.paypalobjects.com/js/external/apdg.js to set up and control the embedded payment flow. This example shows how to initiate the embedded payment flow after obtaining a payment key.
    This example assumes that you obtain a payment key before initiating the flow and that the key does not change or expire before the sender completes the flow.
    To set up a web page to invoke the embedded payment flow:
    1. Call the Pay API operation to obtain a valid pay key.
    2. Create your form or button.
      • You must include the pay key and redirect to https://www.paypal.com/webapps/adaptivepayment/flow/pay.
      • Optionally, include a preapproval key if you want to enable the selection of Preapproval for future payments
      • Set the expType parameter to mini to indicate your preference for the context in which the PayPal payment flow is displayed.
      <form action=
      "https://www.paypal.com/webapps/adaptivepayment/flow/pay"
      target="PPDGFrame">
      <input id="type" type="hidden" name="expType" value="mini">
      <input id="paykey" type="hidden" name="paykey" value="
          AP-...">   <input id="preapprovalkey"     type="hidden" name="preapprovalkey" value="PA-...">   <input type="submit" id="submitBtn" value="Pay with PayPal">  </form>
      
      Note: To modify an existing application to use the embedded payment flow, change the redirect fromhttps://www.paypal.com/cgi-bin/webscr?cmd=_ap-payment&paykey=... to
    3. https://www.paypal.com/webapps/adaptivepayment/flow/pay? paykey=... after obtaining the pay key.
    4. Include the PayPal JavaScript functions from apdg.js.
      <script src="https://www.paypalobjects.com/js/external/apdg.js">
      </script>
      
    5. Create an embedded flow object and associate it with your payment form or button.
      <script>
      function <<returnFunctionName>>() {
      <<Your code goes here.>>
      }
      </script>
      
    The following minibrowser return script can be used to determine whether the payment successfully completed:
    PAYMENTDETAILS=$(wget --output-document=- \
    --quiet \
    --header="X-PAYPAL-SERVICE-VERSION: 1.0.0" \
    --header="X-PAYPAL-SECURITY-USERID: $APIUSER" \
    --header="X-PAYPAL-SECURITY-PASSWORD: $APIPASS" \
    --header="X-PAYPAL-SECURITY-SIGNATURE: $APISIG" \
    --header="X-PAYPAL-REQUEST-DATA-FORMAT: NV" \
    --header="X-PAYPAL-RESPONSE-DATA-FORMAT: NV" \
    --header="X-PAYPAL-APPLICATION-ID:  $APPLICATIONID" \
    --post-data="payKey=$PAYKEY&requestEnvelope.errorLanguage=en_US" \
    https://www.paypal.com/AdaptivePayments/PaymentDetails)
    if echo $PAYMENTDETAILS | grep -q "\&status=COMPLETED"
    then  echo "Thank you for approving pay key $PAYKEY"
    else  echo "Sorry, you were unable to approve pay key $PAYKEY.  Please try another transaction!"
    fi
    

    Displaying and Collecting Shipping Addresses

    PayPal displays the default shipping address and allows the payment sender to change the address when you setsenderOptions.requireShippingAddressSelection to true in your request to the SetPaymentOptions API operation. You call theGetShippingAddresses API operation to obtain the selected shipping address after invoking the embedded payment flow.
    The steps in this example assume that you have implemented the JavaScript for invoking the embedded payment flow, that you have set up your button or form to invoke the flow, and that you have included the code to close the window associated with the flow.
    To display and collect the selected shipping address
    1. Call the Pay API operation with actionType set to CREATE to obtain a payment key.
    2. Set senderOptions.requireShippingAddressSelection to true in your request to SetPaymentOptions and call the API operation.
    3. Redirect the payment sender's browser to the embedded payment flow at https://www.paypal.com/webapps/adaptivepayment/flow/pay?paykey=...after obtaining the pay key.
    4. After returning from the flow, call the GetShippingAddresses API operation to obtain the selected shipping address.

    Guest Payments

    Adaptive payments supports guest payments, which are payments using a sender's credit card without logging into PayPal to complete the transaction.The sender is not explicitly identified as a PayPal account holder during the transaction and is not required to have a PayPal account.
    Each receiver of a guest payment must be a verified PayPal Business Verified or Premier Verified account holder.
    PayPal handles guest payments in the same way that it handles explicitly approved payments. Instead of logging into PayPal to complete transaction, the sender provides credit card information on the PayPal payment screen:


    Note: For European Union countries, only 10 guest payments are allowed per card.

    Fee Payment Configuration

    You can set up a payment transaction so that either the sender of a payment pays the fee or the receivers of a payment pay the fee. If receivers pay the fee, you can specify whether the primary receiver in a chained payment pays the entire fee or whether all receivers pay a portion of the fee.
    You can specify who pays these fees. Fee payment configurations include:
    Note: Fees are determined by PayPal and are based on criteria, such as the transaction volume of the receiver. In the examples that follow, the fees shown are representative only and not actual fees.

    Sender Pays the Fee

    The sender can pay a fee for a simple payment, parallel payment, or a chained payment. The following example shows fees being paid by the sender of a parallel payment, based on the assessment for each receiver:


    In this example, the sender pays a total of $510.83, which includes all fees.
    Note: The scenario above is an example only and is not representative of actual PayPal fees.

    Receiver Pays the Fee in a Parallel Payment

    If the receivers pay the fee in a parallel payment, each receiver pays a portion of the fee, based on their assessment. The following example shows the receivers paying the fees:


    Note: The scenario above is an example only and is not representative of actual PayPal fees.

    Each Receiver Pays the Fee in a Chained Payment

    If the receivers pay the fee in a chained payment, each receiver pays a portion of the fee, based on their assessment. The following example shows the receivers paying the fees:


    In this example, the primary receiver, identified as the merchant, pays a fee for $20 received. Each of the other receivers also pay a fee on the amount each receives.
    Note: The scenario above is an example only and is not representative of actual PayPal fees.

    Primary Receiver Pays the Fee in a Chained Payment

    If only the primary receiver pays the fee in a chained payment, other receivers pay no fees. The fees paid by the primary receiver, however, are based upon the total fees assigned to all receivers. The following example shows only the primary receiver, identified as the merchant, paying all fees:


    Note: The scenario above is an example only and is not representative of actual PayPal fees.

    Click here to view normal PayPal integration
    Click here to view normal PayPal Pro integration

    By,
    Akash Roy,
    CEO, JPR Infoserve,
    http://jprinfoserve.com