2
0
Files
gitcaddy-server/modules/monetize/manager.go
logikonline d1f20f6b46
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
feat(ci): add repository subscription monetization system
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
2026-01-31 13:37:07 -05:00

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,
))
}
}