2015-10-15 10:47:36 +02:00
|
|
|
package paypalsdk
|
|
|
|
|
|
|
|
import (
|
2015-10-30 08:02:32 +01:00
|
|
|
"bytes"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2015-10-15 10:47:36 +02:00
|
|
|
)
|
|
|
|
|
2015-10-30 08:02:32 +01:00
|
|
|
// GetAccessToken returns struct of TokenResponse
|
2015-12-29 10:21:11 +01:00
|
|
|
// No need to call SetAccessToken to apply new access token for current Client
|
|
|
|
// Endpoint: POST /v1/oauth2/token
|
2015-11-20 07:38:40 +01:00
|
|
|
func (c *Client) GetAccessToken() (*TokenResponse, error) {
|
|
|
|
buf := bytes.NewBuffer([]byte("grant_type=client_credentials"))
|
|
|
|
req, err := http.NewRequest("POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/oauth2/token"), buf)
|
2015-10-30 08:02:32 +01:00
|
|
|
if err != nil {
|
|
|
|
return &TokenResponse{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
req.SetBasicAuth(c.ClientID, c.Secret)
|
2015-11-20 08:40:47 +01:00
|
|
|
req.Header.Set("Content-type", "application/x-www-form-urlencoded")
|
2015-10-30 08:02:32 +01:00
|
|
|
|
|
|
|
t := TokenResponse{}
|
|
|
|
err = c.Send(req, &t)
|
|
|
|
|
|
|
|
// Set Token fur current Client
|
|
|
|
if t.Token != "" {
|
|
|
|
c.Token = &t
|
|
|
|
}
|
|
|
|
|
|
|
|
return &t, err
|
2015-10-16 12:00:57 +02:00
|
|
|
}
|
2015-12-01 05:35:25 +01:00
|
|
|
|
|
|
|
// GetAuthorization returns an authorization by ID
|
2015-12-29 10:21:11 +01:00
|
|
|
// Endpoint: GET /v1/payments/authorization/ID
|
2015-12-01 05:35:25 +01:00
|
|
|
func (c *Client) GetAuthorization(authID string) (*Authorization, error) {
|
|
|
|
buf := bytes.NewBuffer([]byte(""))
|
|
|
|
req, err := http.NewRequest("GET", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/authorization/"+authID), buf)
|
|
|
|
if err != nil {
|
|
|
|
return &Authorization{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
auth := &Authorization{}
|
|
|
|
|
|
|
|
err = c.SendWithAuth(req, auth)
|
|
|
|
if err != nil {
|
|
|
|
return auth, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return auth, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CaptureAuthorization captures and process an existing authorization.
|
|
|
|
// To use this method, the original payment must have Intent set to "authorize"
|
2015-12-29 10:21:11 +01:00
|
|
|
// Endpoint: POST /v1/payments/authorization/ID/capture
|
2015-12-01 05:35:25 +01:00
|
|
|
func (c *Client) CaptureAuthorization(authID string, a *Amount, isFinalCapture bool) (*Capture, error) {
|
|
|
|
isFinalStr := "false"
|
|
|
|
if isFinalCapture {
|
|
|
|
isFinalStr = "true"
|
|
|
|
}
|
|
|
|
buf := bytes.NewBuffer([]byte("{\"amount\":{\"currency\":\"" + a.Currency + "\",\"total\":\"" + a.Total + "\"},\"is_final_capture\":" + isFinalStr + "}"))
|
|
|
|
req, err := http.NewRequest("POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/authorization/"+authID+"/capture"), buf)
|
|
|
|
if err != nil {
|
|
|
|
return &Capture{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
capture := &Capture{}
|
|
|
|
|
|
|
|
err = c.SendWithAuth(req, capture)
|
|
|
|
if err != nil {
|
|
|
|
return capture, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return capture, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// VoidAuthorization voids a previously authorized payment
|
2015-12-29 10:21:11 +01:00
|
|
|
// Endpoint: POST /v1/payments/authorization/ID/void
|
2015-12-01 05:35:25 +01:00
|
|
|
func (c *Client) VoidAuthorization(authID string) (*Authorization, error) {
|
|
|
|
buf := bytes.NewBuffer([]byte(""))
|
|
|
|
req, err := http.NewRequest("POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/authorization/"+authID+"/void"), buf)
|
|
|
|
if err != nil {
|
|
|
|
return &Authorization{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
auth := &Authorization{}
|
|
|
|
|
|
|
|
err = c.SendWithAuth(req, auth)
|
|
|
|
if err != nil {
|
|
|
|
return auth, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return auth, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ReauthorizeAuthorization reauthorize a Paypal account payment.
|
|
|
|
// PayPal recommends to reauthorize payment after ~3 days
|
2015-12-29 10:21:11 +01:00
|
|
|
// Endpoint: POST /v1/payments/authorization/ID/reauthorize
|
2015-12-01 05:35:25 +01:00
|
|
|
func (c *Client) ReauthorizeAuthorization(authID string, a *Amount) (*Authorization, error) {
|
|
|
|
buf := bytes.NewBuffer([]byte("{\"amount\":{\"currency\":\"" + a.Currency + "\",\"total\":\"" + a.Total + "\"}}"))
|
|
|
|
req, err := http.NewRequest("POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/authorization/"+authID+"/reauthorize"), buf)
|
|
|
|
if err != nil {
|
|
|
|
return &Authorization{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
auth := &Authorization{}
|
|
|
|
|
|
|
|
err = c.SendWithAuth(req, auth)
|
|
|
|
if err != nil {
|
|
|
|
return auth, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return auth, nil
|
|
|
|
}
|