インストール
Goモジュールを使用してSDKをインストールします:コピー
go get github.com/dodopayments/dodopayments-go
SDKはGo 1.18以降のバージョンをサポートしており、最適なパフォーマンスのために最新のGo機能を活用しています。
クイックスタート
クライアントを初期化し、最初のチェックアウトセッションを作成します:コピー
package main
import (
"context"
"fmt"
"log"
"github.com/dodopayments/dodopayments-go"
"github.com/dodopayments/dodopayments-go/option"
)
func main() {
client := dodopayments.NewClient(
option.WithBearerToken("My Bearer Token"), // defaults to os.LookupEnv("DODO_PAYMENTS_API_KEY")
option.WithEnvironmentTestMode(), // defaults to option.WithEnvironmentLiveMode()
)
checkoutSessionResponse, err := client.CheckoutSessions.New(context.TODO(), dodopayments.CheckoutSessionNewParams{
CheckoutSessionRequest: dodopayments.CheckoutSessionRequestParam{
ProductCart: dodopayments.F([]dodopayments.CheckoutSessionRequestProductCartParam{{
ProductID: dodopayments.F("product_id"),
Quantity: dodopayments.F(int64(1)),
}}),
},
})
if err != nil {
log.Fatal(err)
}
fmt.Printf("Session ID: %s\n", checkoutSessionResponse.SessionID)
}
APIキーは常に環境変数を使用して安全に保管してください。ソースコードにハードコーディングしないでください。
コア機能
コンテキストサポート
キャンセルとタイムアウトのためのcontext.Contextの完全サポート
強い型付け
コンパイル時の安全性のための強く型付けされたリクエストとレスポンス
ミドルウェア
ロギング、メトリクス、カスタムロジックのための拡張可能なミドルウェアサポート
ゴルーチン安全
同時操作のために設計されたスレッドセーフなクライアント
設定
コンテキストとタイムアウト
Goのコンテキストを利用してタイムアウトとキャンセルを行います:コピー
import (
"context"
"time"
"github.com/dodopayments/dodopayments-go"
"github.com/dodopayments/dodopayments-go/option"
)
// Create a context with timeout
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
payment, err := client.Payments.Create(ctx, dodopayments.PaymentCreateParams{
Amount: 5000,
Currency: "USD",
CustomerID: "cus_123",
})
if err != nil {
if ctx.Err() == context.DeadlineExceeded {
log.Println("Request timed out")
} else {
log.Fatal(err)
}
}
リトライ設定
自動リトライの動作を設定します:コピー
// Configure default for all requests (default is 2)
client := dodopayments.NewClient(
option.WithMaxRetries(0), // disable retries
)
// Override per-request
client.CheckoutSessions.New(
context.TODO(),
dodopayments.CheckoutSessionNewParams{
CheckoutSessionRequest: dodopayments.CheckoutSessionRequestParam{
ProductCart: dodopayments.F([]dodopayments.CheckoutSessionRequestProductCartParam{{
ProductID: dodopayments.F("product_id"),
Quantity: dodopayments.F(int64(0)),
}}),
},
},
option.WithMaxRetries(5),
)
一般的な操作
チェックアウトセッションの作成
チェックアウトセッションを生成します:コピー
session, err := client.CheckoutSessions.New(ctx, dodopayments.CheckoutSessionNewParams{
CheckoutSessionRequest: dodopayments.CheckoutSessionRequestParam{
ProductCart: dodopayments.F([]dodopayments.CheckoutSessionRequestProductCartParam{{
ProductID: dodopayments.F("prod_123"),
Quantity: dodopayments.F(int64(1)),
}}),
ReturnURL: dodopayments.F("https://yourdomain.com/return"),
},
})
if err != nil {
log.Fatal(err)
}
fmt.Printf("Checkout URL: %s\n", session.URL)
顧客の管理
顧客情報を作成および取得します:コピー
// Create a customer
customer, err := client.Customers.New(ctx, dodopayments.CustomerNewParams{
Email: dodopayments.F("[email protected]"),
Name: dodopayments.F("John Doe"),
Metadata: dodopayments.F(map[string]string{
"user_id": "12345",
}),
})
if err != nil {
log.Fatal(err)
}
// Retrieve customer
customer, err = client.Customers.Get(ctx, "cus_123")
if err != nil {
log.Fatal(err)
}
fmt.Printf("Customer: %s (%s)\n", customer.Name, customer.Email)
サブスクリプションの管理
定期的なサブスクリプションを作成および管理します:コピー
// Create a subscription
subscription, err := client.Subscriptions.New(ctx, dodopayments.SubscriptionNewParams{
CustomerID: dodopayments.F("cus_123"),
ProductID: dodopayments.F("prod_456"),
PriceID: dodopayments.F("price_789"),
})
if err != nil {
log.Fatal(err)
}
// Get usage history
usageHistory, err := client.Subscriptions.GetUsageHistory(
ctx,
subscription.ID,
dodopayments.SubscriptionGetUsageHistoryParams{
StartDate: dodopayments.F("2024-01-01T00:00:00Z"),
EndDate: dodopayments.F("2024-03-31T23:59:59Z"),
},
)
if err != nil {
log.Fatal(err)
}
使用量ベースの請求
使用量イベントの取り込み
カスタムイベントを追跡します:コピー
import "github.com/dodopayments/dodopayments-go"
response, err := client.UsageEvents.Ingest(ctx, dodopayments.UsageEventIngestParams{
Events: dodopayments.F([]dodopayments.UsageEventIngestParamsEvent{{
EventID: dodopayments.F("api_call_12345"),
CustomerID: dodopayments.F("cus_abc123"),
EventName: dodopayments.F("api_request"),
Timestamp: dodopayments.F("2024-01-15T10:30:00Z"),
Metadata: dodopayments.F(map[string]string{
"endpoint": "/api/v1/users",
"method": "GET",
"tokens_used": "150",
}),
}}),
})
if err != nil {
log.Fatal(err)
}
使用量イベントの一覧
コピー
// List events with filters
params := dodopayments.UsageEventListParams{
CustomerID: dodopayments.F("cus_abc123"),
EventName: dodopayments.F("api_request"),
}
events, err := client.UsageEvents.List(ctx, params)
if err != nil {
log.Fatal(err)
}
for _, event := range events.Data {
fmt.Printf("Event %s: %s at %s\n", event.EventID, event.EventName, event.Timestamp)
}
エラーハンドリング
特定のエラータイプを処理します:コピー
payment, err := client.Payments.Create(ctx, dodopayments.PaymentCreateParams{
Amount: 5000,
Currency: "USD",
})
if err != nil {
if apiErr, ok := err.(*dodopayments.APIError); ok {
fmt.Printf("API Error: %s\n", apiErr.Message)
fmt.Printf("Status Code: %d\n", apiErr.StatusCode)
fmt.Printf("Request ID: %s\n", apiErr.RequestID)
// Handle specific error types
switch apiErr.Type {
case dodopayments.ErrorTypeAuthentication:
log.Println("Authentication failed")
case dodopayments.ErrorTypeInvalidRequest:
log.Println("Invalid request parameters")
case dodopayments.ErrorTypeRateLimit:
log.Println("Rate limit exceeded")
default:
log.Printf("API error: %s\n", apiErr.Message)
}
} else {
log.Fatal(err)
}
}
ミドルウェア
ロギングやメトリクスのためのカスタムミドルウェアを追加します:コピー
func Logger(req *http.Request, next option.MiddlewareNext) (res *http.Response, err error) {
// Before the request
start := time.Now()
log.Printf("Request: %s %s\n", req.Method, req.URL)
// Forward the request to the next handler
res, err = next(req)
// After the request
end := time.Now()
log.Printf("Response: %d in %v\n", res.StatusCode, end.Sub(start))
return res, err
}
client := dodopayments.NewClient(
option.WithMiddleware(Logger),
)
同時処理
クライアントは同時使用に安全です:コピー
package main
import (
"context"
"sync"
"log"
"github.com/dodopayments/dodopayments-go"
)
func main() {
client := dodopayments.NewClient()
var wg sync.WaitGroup
for i := 0; i < 10; i++ {
wg.Add(1)
go func(idx int) {
defer wg.Done()
payment, err := client.Payments.Create(context.Background(), dodopayments.PaymentCreateParams{
Amount: 1000,
Currency: "USD",
CustomerID: "cus_123",
})
if err != nil {
log.Printf("Failed to create payment %d: %v", idx, err)
return
}
log.Printf("Created payment %d: %s", idx, payment.ID)
}(i)
}
wg.Wait()
}
リソース
GitHubリポジトリ
ソースコードを表示し、貢献してください
APIリファレンス
完全なAPIドキュメント
Discordコミュニティ
ヘルプを得て開発者とつながる
問題の報告
バグを報告したり機能をリクエストする
サポート
Go SDKに関して助けが必要ですか?- Discord: リアルタイムサポートのためにコミュニティサーバーに参加してください
- Email: [email protected]までご連絡ください
- GitHub: リポジトリに問題をオープンしてください