Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/plutov/paypal
Golang client for PayPal REST API
https://github.com/plutov/paypal
hacktoberfest
Last synced: 4 days ago
JSON representation
Golang client for PayPal REST API
- Host: GitHub
- URL: https://github.com/plutov/paypal
- Owner: plutov
- License: mit
- Created: 2015-10-14T04:57:49.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-09-24T09:51:27.000Z (4 months ago)
- Last Synced: 2024-10-29T15:49:08.113Z (3 months ago)
- Topics: hacktoberfest
- Language: Go
- Homepage:
- Size: 359 KB
- Stars: 689
- Watchers: 31
- Forks: 269
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-go - paypal - Wrapper for PayPal payment API. (Third-party APIs / Utility/Miscellaneous)
- awesome-go-extra - paypal - 10-14T04:57:49Z|2022-07-22T08:48:53Z| (Third-party APIs / Fail injection)
README
[Docs](https://pkg.go.dev/github.com/plutov/paypal)
# Go client for PayPal REST API
## Paypal REST API Docs
[Get started with PayPal REST APIs](https://developer.paypal.com/api/rest/)
## Missing endpoints
It is possible that some endpoints are missing in this client, but you can use built-in `paypal` functions to perform a request: `NewClient -> NewRequest -> SendWithAuth`
## Usage
```go
import "github.com/plutov/paypal/v4"// Create a client instance
c, err := paypal.NewClient("clientID", "secretID", paypal.APIBaseSandBox)
c.SetLog(os.Stdout) // Set log to terminal stdout
```## Get authorization by ID
```go
auth, err := c.GetAuthorization("2DC87612EK520411B")
```### Capture authorization
```go
capture, err := c.CaptureAuthorization(authID, &paypal.Amount{Total: "7.00", Currency: "USD"}, true)
```### Void authorization
```go
auth, err := c.VoidAuthorization(authID)
```### Reauthorize authorization
```go
auth, err := c.ReauthorizeAuthorization(authID, &paypal.Amount{Total: "7.00", Currency: "USD"})
```### Get Refund by ID
```go
refund, err := c.GetRefund("O-4J082351X3132253H")
```### Get Order by ID
```go
order, err := c.GetOrder("O-4J082351X3132253H")
```### Create an Order
```go
ctx := context.Background()
units := []paypal.PurchaseUnitRequest{}
source := &paypal.PaymentSource{}
appCtx := &paypal.ApplicationContext{}
order, err := c.CreateOrder(ctx, paypal.OrderIntentCapture, units, ource, appCtx)
```### Update Order by ID
```go
order, err := c.UpdateOrder("O-4J082351X3132253H", []paypal.PurchaseUnitRequest{})
```### Authorize Order
```go
auth, err := c.AuthorizeOrder(orderID, paypal.AuthorizeOrderRequest{})
```### Capture Order
```go
capture, err := c.CaptureOrder(orderID, paypal.CaptureOrderRequest{})
```### Identity
```go
token, err := c.GrantNewAccessTokenFromAuthCode("", "http://example.com/myapp/return.php")
// ... or by refresh token
token, err := c.GrantNewAccessTokenFromRefreshToken("")
```### Retreive user information
```go
userInfo, err := c.GetUserInfo("openid")
```### Create single payout to email
```go
payout := paypal.Payout{
SenderBatchHeader: &paypal.SenderBatchHeader{
EmailSubject: "Subject will be displayed on PayPal",
},
Items: []paypal.PayoutItem{
paypal.PayoutItem{
RecipientType: "EMAIL",
Receiver: "[email protected]",
Amount: &paypal.AmountPayout{
Value: "15.11",
Currency: "USD",
},
Note: "Optional note",
SenderItemID: "Optional Item ID",
},
},
}payoutResp, err := c.CreatePayout(payout)
```### Get payout by ID
```go
payout, err := c.GetPayout("PayoutBatchID")
```### Get payout item by ID
```go
payoutItem, err := c.GetPayoutItem("PayoutItemID")
```### Cancel unclaimed payout item by ID
```go
payoutItem, err := c.CancelPayoutItem("PayoutItemID")
```### Create web experience profile
```go
webprofile := WebProfile{
Name: "YeowZa! T-Shirt Shop",
Presentation: Presentation{
BrandName: "YeowZa! Paypal",
LogoImage: "http://www.yeowza.com",
LocaleCode: "US",
},InputFields: InputFields{
AllowNote: true,
NoShipping: NoShippingDisplay,
AddressOverride: AddrOverrideFromCall,
},FlowConfig: FlowConfig{
LandingPageType: LandingPageTypeBilling,
BankTXNPendingURL: "http://www.yeowza.com",
},
}result, err := c.CreateWebProfile(webprofile)
```### Get web experience profile
```go
webprofile, err := c.GetWebProfile("XP-CP6S-W9DY-96H8-MVN2")
```### List web experience profile
```go
webprofiles, err := c.GetWebProfiles()
```### Update web experience profile
```go
webprofile := WebProfile{
ID: "XP-CP6S-W9DY-96H8-MVN2",
Name: "Shop YeowZa! YeowZa! ",
}
err := c.SetWebProfile(webprofile)
```### Delete web experience profile
```go
err := c.DeleteWebProfile("XP-CP6S-W9DY-96H8-MVN2")
```### Vault
```go
// Store CC
c.StoreCreditCard(paypal.CreditCard{
Number: "4417119669820331",
Type: "visa",
ExpireMonth: "11",
ExpireYear: "2020",
CVV2: "874",
FirstName: "Foo",
LastName: "Bar",
})// Delete it
c.DeleteCreditCard("CARD-ID-123")// Edit it
c.PatchCreditCard("CARD-ID-123", []paypal.CreditCardField{
paypal.CreditCardField{
Operation: "replace",
Path: "/billing_address/line1",
Value: "New value",
},
})// Get it
c.GetCreditCard("CARD-ID-123")// Get all stored credit cards
c.GetCreditCards(nil)
```### Webhooks
```go
// Create a webhook
c.CreateWebhook(paypal.CreateWebhookRequest{
URL: "webhook URL",
EventTypes: []paypal.WebhookEventType{
paypal.WebhookEventType{
Name: "PAYMENT.AUTHORIZATION.CREATED",
},
},
})// Update a registered webhook
c.UpdateWebhook("WebhookID", []paypal.WebhookField{
paypal.WebhookField{
Operation: "replace",
Path: "/event_types",
Value: []interface{}{
map[string]interface{}{
"name": "PAYMENT.SALE.REFUNDED",
},
},
},
})// Get a registered webhook
c.GetWebhook("WebhookID")// Delete a webhook
c.DeleteWebhook("WebhookID")// List registered webhooks
c.ListWebhooks(paypal.AncorTypeApplication)
```### Generate Next Invoice Number
```go
// GenerateInvoiceNumber: generates the next invoice number that is available to the merchant.
c.GenerateInvoiceNumber(ctx) // might return something like "0001" or "0010".
```### Get Invoice Details by ID
```go
// the second argument is an ID, it should be valid
invoice, err := c.GetInvoiceDetails(ctx, "INV2-XFXV-YW42-ZANU-4F33")
```- for now, we are yet to implement the ShowAllInvoices endpoint, so use the following cURL request for the same(this gives you the list of invoice-IDs for this customer)
```bash
curl -v -X GET https://api-m.sandbox.paypal.com/v2/invoicing/invoices?total_required=true \
-H "Content-Type: application/json" \
-H "Authorization: Bearer "
```- refer to the beginning of this Usage section for obtaining a Token.
## How to Contribute
- Fork a repository
- Add/Fix something
- Check that tests are passing
- Create PRMain contributors:
- [Alex Pliutau](https://github.com/plutov)
- [Roopak Venkatakrishnan](https://github.com/roopakv)## Tests
```
go test -v ./...
```