zoukankan      html  css  js  c++  java
  • Announcing Mobile SDK V2.0

    As you might have read over at our PayPal Forward Blog it’s time to celebrate for PayPal | Developer. One year ago we relaunched our Developer Platform with way clearer documentation, new REST APIs and our CardIO-enhanced Mobile SDK that allows for frictionless payments on Android and iOS.

    Today I want to quickly elaborate on an amazing new feature of our mSDK version 2.0 called Future Payments that allows for great use-cases like subscription payments without requiring the user to re-authorize each payment by logging in again. Great experiences like the ones that you can find when using Uber can be created by using this kind of payment. By authorizing the application once to handle future transaction the user grants the application a revokable token that will be passed in all future transactions and therefore skips the login step.

    Implementing this step is actually very easy as our SDK got even easier with version 2. First of all we need to change the configuration of the SDK slightly. In the following examples I will showcase how to do so when working on Android apps – bear in mind that implementing this feature in iOS is equally easy to handle:

      private static PayPalConfiguration config = new PayPalConfiguration()
      .environment(CONFIG_ENVIRONMENT)
      .clientId(CONFIG_CLIENT_ID)
      // The following are only used in PayPalFuturePaymentActivity.
      .merchantName("Innovative cab app")
      .merchantPrivacyPolicyUri(Uri.parse("https://www.example.com/privacy"))
      .merchantUserAgreementUri(Uri.parse("https://www.example.com/legal"));

    If you’ve worked with our SDK prior this version you will see that the configuration got much easier by removing all Intent Extras and adding dedicated methods for initializing the SDK.

    After the user logged in an OAuth 2.0 authorize token is being returned which can be exchanged against a short-lived access token. Furthermore a refresh token is being returned which we will need to acquire a new access token once the previous one becomes invalid.

      Intent intent = new Intent(MyActivity.this, PayPalFuturePaymentActivity.class);
      startActivityForResult(intent, REQUEST_CODE_FUTURE_PAYMENT);
    view rawintent.java hosted with ❤ by GitHub

    By using the startActivityForResult mechanism we receive the PayPalAuthorization in onActivityForResult:

      @Override
      protected void onActivityResult(int requestCode, int resultCode, Intent data) {
      if (requestCode == REQUEST_CODE_FUTURE_PAYMENT) {
      if (resultCode == Activity.RESULT_OK) {
      PayPalAuthorization auth = data
      .getParcelableExtra(PayPalFuturePaymentActivity.EXTRA_RESULT_AUTHORIZATION);
      if (auth != null) {
      String authorization_code = auth.getAuthorizationCode();
      // send authorization code to server to receive the access & refresh code
      }
      }
      }
      }

    The payment is being handled on server-side – to do so we hand over the app’s correlation ID and payment details to the backend. To acquire the correlation ID we leverage a method that we introduced with version 2.0 of the SDK:

      String correlationId = PayPalConfiguration.getApplicationCorrelationId(this);

    It is required that the application provides a way to revoke the token on client-side to ensure a user-friendly experience.

    We are looking forward to bringing even more great features to the SDK and are as always keen for your feedback!

    Best regards,
    Tim

  • 相关阅读:
    几何+点与线段的位置关系+二分(POJ2318)
    二维凸包模板(凸包重心,周长,面积,直径,最大三角形,最小环绕矩形)
    边的双联通+缩点+LCA(HDU3686)
    三维凸包(两个没有公共点)经过旋转平移后使其重心相距最近(POJ3862)
    三维凸包求凸包表面的个数(HDU3662)
    三维凸包求其表面积(POJ3528)
    三维凸包求重心到面的最短距离(HDU4273)
    三维凸包求内部一点到表面的最近距离(HDU4266)
    三维凸包模板
    判断点与多边形的位置关系
  • 原文地址:https://www.cnblogs.com/android-blogs/p/6409212.html
Copyright © 2011-2022 走看看