mirror of
https://github.com/plutov/paypal.git
synced 2025-01-22 18:01:04 +01:00
79 lines
2.6 KiB
Go
79 lines
2.6 KiB
Go
package paypal
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
)
|
|
|
|
// CreatePayout submits a payout with an asynchronous API call, which immediately returns the results of a PayPal payment.
|
|
// For email payout set RecipientType: "EMAIL" and receiver email into Receiver
|
|
// Endpoint: POST /v1/payments/payouts
|
|
func (c *Client) CreatePayout(ctx context.Context, p Payout) (*PayoutResponse, error) {
|
|
req, err := c.NewRequest(ctx, "POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/payouts"), p)
|
|
response := &PayoutResponse{}
|
|
|
|
if err != nil {
|
|
return response, err
|
|
}
|
|
|
|
if err = c.SendWithAuth(req, response); err != nil {
|
|
return response, err
|
|
}
|
|
|
|
return response, nil
|
|
}
|
|
|
|
// GetPayout shows the latest status of a batch payout along with the transaction status and other data for individual items.
|
|
// Also, returns IDs for the individual payout items. You can use these item IDs in other calls.
|
|
// Endpoint: GET /v1/payments/payouts/ID
|
|
func (c *Client) GetPayout(ctx context.Context, payoutBatchID string) (*PayoutResponse, error) {
|
|
req, err := c.NewRequest(ctx, "GET", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/payouts/"+payoutBatchID), nil)
|
|
response := &PayoutResponse{}
|
|
|
|
if err != nil {
|
|
return response, err
|
|
}
|
|
|
|
if err = c.SendWithAuth(req, response); err != nil {
|
|
return response, err
|
|
}
|
|
|
|
return response, nil
|
|
}
|
|
|
|
// GetPayoutItem shows the details for a payout item.
|
|
// Use this call to review the current status of a previously unclaimed, or pending, payout item.
|
|
// Endpoint: GET /v1/payments/payouts-item/ID
|
|
func (c *Client) GetPayoutItem(ctx context.Context, payoutItemID string) (*PayoutItemResponse, error) {
|
|
req, err := c.NewRequest(ctx, "GET", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/payouts-item/"+payoutItemID), nil)
|
|
response := &PayoutItemResponse{}
|
|
|
|
if err != nil {
|
|
return response, err
|
|
}
|
|
|
|
if err = c.SendWithAuth(req, response); err != nil {
|
|
return response, err
|
|
}
|
|
|
|
return response, nil
|
|
}
|
|
|
|
// CancelPayoutItem cancels an unclaimed Payout Item. If no one claims the unclaimed item within 30 days,
|
|
// the funds are automatically returned to the sender. Use this call to cancel the unclaimed item before the automatic 30-day refund.
|
|
// Endpoint: POST /v1/payments/payouts-item/ID/cancel
|
|
func (c *Client) CancelPayoutItem(ctx context.Context, payoutItemID string) (*PayoutItemResponse, error) {
|
|
req, err := c.NewRequest(ctx, "POST", fmt.Sprintf("%s%s", c.APIBase, "/v1/payments/payouts-item/"+payoutItemID+"/cancel"), nil)
|
|
response := &PayoutItemResponse{}
|
|
|
|
if err != nil {
|
|
return response, err
|
|
}
|
|
|
|
if err = c.SendWithAuth(req, response); err != nil {
|
|
return response, err
|
|
}
|
|
|
|
return response, nil
|
|
}
|