All checks were successful
Build and Release / Create Release (push) Successful in 0s
Build and Release / Unit Tests (push) Successful in 3m10s
Build and Release / Integration Tests (PostgreSQL) (push) Successful in 5m13s
Build and Release / Lint (push) Successful in 5m25s
Build and Release / Build Binaries (amd64, linux, linux-latest) (push) Successful in 3m13s
Build and Release / Build Binaries (amd64, windows, windows-latest) (push) Successful in 8h5m42s
Build and Release / Build Binaries (amd64, darwin, macos) (push) Successful in 7m30s
Build and Release / Build Binaries (arm64, darwin, macos) (push) Successful in 7m55s
Build and Release / Build Binary (linux/arm64) (push) Successful in 7m36s
Implement complete subscription monetization system for repositories with Stripe and PayPal integration. Includes: - Database models and migrations for monetization settings, subscription products, and user subscriptions - Payment provider abstraction layer with Stripe and PayPal implementations - Admin UI for configuring payment providers and viewing subscriptions - Repository settings UI for managing subscription products and tiers - Subscription checkout flow and webhook handlers for payment events - Access control to gate repository code behind active subscriptions
50 lines
1.2 KiB
Go
50 lines
1.2 KiB
Go
// Copyright 2026 MarketAlly. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package monetize
|
|
|
|
import (
|
|
"fmt"
|
|
"sync"
|
|
|
|
monetize_model "code.gitcaddy.com/server/v3/models/monetize"
|
|
)
|
|
|
|
var (
|
|
mu sync.RWMutex
|
|
providers = make(map[ProviderType]PaymentProvider)
|
|
)
|
|
|
|
// RegisterProvider registers a payment provider.
|
|
func RegisterProvider(p PaymentProvider) {
|
|
mu.Lock()
|
|
defer mu.Unlock()
|
|
providers[p.Type()] = p
|
|
}
|
|
|
|
// GetProvider returns the registered provider of the given type.
|
|
func GetProvider(t ProviderType) (PaymentProvider, error) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
p, ok := providers[t]
|
|
if !ok {
|
|
return nil, fmt.Errorf("payment provider %q not registered", t)
|
|
}
|
|
return p, nil
|
|
}
|
|
|
|
// InitProviders initialises payment providers from the stored admin settings.
|
|
func InitProviders(settings *monetize_model.Setting) {
|
|
if settings.StripeEnabled && settings.StripeSecretKey != "" {
|
|
RegisterProvider(NewStripeProvider(settings.StripeSecretKey, settings.StripeWebhookSecret))
|
|
}
|
|
if settings.PayPalEnabled && settings.PayPalClientID != "" {
|
|
RegisterProvider(NewPayPalProvider(
|
|
settings.PayPalClientID,
|
|
settings.PayPalClientSecret,
|
|
settings.PayPalWebhookID,
|
|
settings.PayPalSandbox,
|
|
))
|
|
}
|
|
}
|