Skip to content

vippsas/vipps-recurring-drupal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Vipps Recurring Payments

Support and development by Frontkom Support and development by Frontkom

null Only available for Vipps.

This plugin is built and maintained by Frontkom and is hosted on GitHub. For support, submit an issue at drupal.org: Vipps Recurring Payments.

💥 Please use the plugin pages on https://developer.vippsmobilepay.com. 💥

Features

Basic authentication

In order to be able to send API requests to the module, you need to activate Basic auth module which is a part of the core and use Basic auth with all your API calls:

{
  "Content-type": "application/json",
  "Authorization": "Basic ZnJvbnRrb206R29vZCBsdWNrIHRyeWluZw=="

}

Test auth

  • Endpoint: /vipps-recurring-payments/test/auth
  • Method: GET
  • Content-Type: application/json
  • Response example:
eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIs <truncated>

Get status of an agreement

  • Endpoint: /vipps-recurring-payments/agreement/get
  • Method: POST
  • Content-Type: application/json
  • Request content example:
"agr_UVUFcx31"
  • Response example:
{
    "id": "agr_CUfJvfx",
    "start": "2020-02-06T10:10:07Z",
    "stop": null,
    "status": "ACTIVE",
    "productName": "Vipps product",
    "price": 87600,
    "productDescription": "Testing Vipps recurring payment",
    "interval": "MONTH",
    "intervalCount": 1,
    "currency": "NOK",
    "campaign": null
}

Cancel an agreement

  • Endpoint: /vipps-recurring-payments/agreement/cancel
  • Method: POST
  • Content-Type: application/json
  • Request content example:
[
  "agr_UVUFcx31",
  "agr_CUfJvfx"
]
  • Response example:
{
    "successes": [
        "agr_UVUFcx31"
    ],
    "errors": [
      "agr_CUfJvfx: Client error: `PATCH https://apitest.vipps.no/recurring/v2/agreements/agr_CUfJvfx` resulted in a `400 Bad Request` response:\n[{\"field\":\"status\",\"message\":\"Missing message for error: status.notActive\",\"code\":\"status.notActive\",\"contextId\":\"a47463 (truncated...)\n"
    ]
}

Make charges

  • Endpoint: /vipps-recurring-payments/charge/make
  • Method: POST
  • Content-Type: application/json
  • Request content example:
[{
 "agreement_id": "agr_UVUFcx3",
 "price": "250",
 "description": "Custom description"
},{
 "agreement_id": "agr_UVUFcx3",
 "price": "25000",
 "description": "Custom description"
},{
 "agreement_id": "agr_UVUFcx31",
 "price": "25000",
 "description": "Custom description"
}]
  • Response example:
{
    "successes": [
        "chr_hFZSqV6"
    ],
    "errors": [
        "agr_UVUFcx3: Client error: `POST amount.exceeds.expected.chargelimit ...",
        "agr_UVUFcx31: Client error: `POST This agreement does not exist"
    ]
}

Get charges for an agreement

  • Endpoint: /vipps-recurring-payments/charge/get
  • Method: POST
  • Content-Type: application/json
  • Request content example:
[
  {
    "agreement_id": "agr_UVUFcx3"
  },
  {
    "agreement_id": "agr_UVUFcx3"
  }
]
  • Response example:
{
    "successes": [
        "[{\"id\":\"chr_Ntsak6z\",\"status\":\"PARTIALLY_REFUNDED\",\"due\":\"2020-02-06T10:09:54Z\",\"amount\":87600,\"amountRefunded\":26640,\"transactionId\":\"5001630551\",\"description\":\"Testing Vipps recurring payment\",\"type\":\"INITIAL\"},{\"id\":\"chr_dxWPD5n\",\"status\":\"CANCELLED\",\"due\":\"2020-03-01T10:00:00Z\",\"amount\":123,\"amountRefunded\":0,\"transactionId\":null,\"description\":\"This is description\",\"type\":\"RECURRING\"},{\"id\":\"chr_xTsRNrg\",\"status\":\"DUE\",\"due\":\"2020-03-01T10:00:00Z\",\"amount\":123,\"amountRefunded\":0,\"transactionId\":\"5001659055\",\"description\":\"This is description\",\"type\":\"RECURRING\"}]"
    ],
    "errors": [
        "agr_UVUFcx3: Client error: `GET https://apitest.vipps.no/recurring/v2/agreements/agr_knvVufdj/charges` resulted in a `400 Bad Request` response:\n[{\"field\":\"agreementId\",\"message\":\"Missing message for error: invalid.agreementId\",\"code\":\"invalid.agreementId\",\"context (truncated...)\n"
    ]
}

Cancel charges for an agreement

  • Endpoint: /vipps-recurring-payments/charge/cancel
  • Method: POST
  • Content-Type: application/json
  • Request content example:
[
 {
  "agreement_id": "agr_CUfJvfx",
  "price": 123,
     "description": "This is description",
     "charge_id": "chr_ptqHYWG"
 }
]
  • Response example:
{
    "successes": [
        "chr_ptqHYWG"
    ],
    "errors": []
}

Refund charges for an agreement

  • Endpoint: /vipps-recurring-payments/charge/refund
  • Method: POST
  • Content-Type: application/json
  • Request content example:
[
 {
  "agreement_id": "agr_CUfJvfx",
  "price": 123,
     "description": "This is description",
     "charge_id": "chr_ptqHYWG"
 }
]
  • Response example:
{
    "successes": [
        "chr_ptqHYWG"
    ],
    "errors": []
}

Support

For problems with your plugin, submit an issue at drupal.org: Vipps Recurring Payments.

About

Vipps Recurring payments for Drupal

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published