Skip to content

Commit

Permalink
* Update stripe plan retrieval from procuts instead of price
Browse files Browse the repository at this point in the history
* Adds new features
  • Loading branch information
emmdim committed Dec 12, 2024
1 parent 449d51e commit 888bb37
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 18 deletions.
2 changes: 1 addition & 1 deletion api/organizations.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ func (a *API) createOrganizationHandler(w http.ResponseWriter, r *http.Request)
PlanID: defaultPlan.ID,
StartDate: time.Now(),
Active: true,
MaxCensusSize: defaultPlan.Organization.CensusSize,
MaxCensusSize: defaultPlan.Organization.MaxCensus,
}
// create the organization
if err := a.db.SetOrganization(&db.Organization{
Expand Down
25 changes: 19 additions & 6 deletions db/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,21 +62,34 @@ type Organization struct {
}

type PlanLimits struct {
Memberships int `json:"memberships" bson:"memberships"`
SubOrgs int `json:"subOrgs" bson:"subOrgs"`
CensusSize int `json:"censusSize" bson:"censusSize"`
Members int `json:"members" bson:"members"`
SubOrgs int `json:"subOrgs" bson:"subOrgs"`
CensusSize int `json:"censusSize" bson:"censusSize"`
MaxProcesses int `json:"maxProcesses" bson:"maxProcesses"`
MaxCensus int `json:"maxCensus" bson:"maxCensus"`
MaxDuration string `json:"maxDuration" bson:"maxDuration"`
CustomURL bool `json:"customURL" bson:"customURL"`
Drafts int `json:"drafts" bson:"drafts"`
}

type VotingTypes struct {
Approval bool `json:"approval" bson:"approval"`
Ranked bool `json:"ranked" bson:"ranked"`
Weighted bool `json:"weighted" bson:"weighted"`
Single bool `json:"single" bson:"single"`
Multiple bool `json:"multiple" bson:"multiple"`
Approval bool `json:"approval" bson:"approval"`
Cumulative bool `json:"cumulative" bson:"cumulative"`
Ranked bool `json:"ranked" bson:"ranked"`
Weighted bool `json:"weighted" bson:"weighted"`
}

type Features struct {
Anonymous bool `json:"anonymous" bson:"anonymous"`
Overwrite bool `json:"overwrite" bson:"overwrite"`
LiveResults bool `json:"liveResults" bson:"liveResults"`
Personalization bool `json:"personalization" bson:"personalization"`
EmailReminder bool `json:"emailReminder" bson:"emailReminder"`
SmsNotification bool `json:"smsNotification" bson:"smsNotification"`
WhiteLabel bool `json:"whiteLabel" bson:"whiteLabel"`
LiveStreaming bool `json:"liveStreaming" bson:"liveStreaming"`
}

type Plan struct {
Expand Down
37 changes: 26 additions & 11 deletions stripe/stripe.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,17 @@ import (
"github.com/stripe/stripe-go/v81"
"github.com/stripe/stripe-go/v81/customer"
"github.com/stripe/stripe-go/v81/price"
"github.com/stripe/stripe-go/v81/product"
"github.com/stripe/stripe-go/v81/webhook"
"github.com/vocdoni/saas-backend/db"
"go.vocdoni.io/dvote/log"
)

var PricesLookupKeys = []string{
"essential_annual_plan",
"premium_annual_plan",
"free_plan",
"custom_annual_plan",
var ProductsIDs = []string{
"prod_R3LTVsjklmuQAL", // Essential
"prod_R0kTryoMNl8I19", // Premium
"prod_RFObcbvED7MYbz", // Free
"prod_RHurAb3OjkgJRy", // Custom
}

// StripeClient is a client for interacting with the Stripe API.
Expand Down Expand Up @@ -81,6 +82,17 @@ func (s *StripeClient) GetPriceByID(priceID string) *stripe.Price {
return nil
}

func (s *StripeClient) GetProductByID(productID string) (*stripe.Product, error) {
params := &stripe.ProductParams{}
params.AddExpand("default_price")
params.AddExpand("default_price.tiers")
product, err := product.Get(productID, params)
if err != nil {
return nil, err
}
return product, nil
}

func (s *StripeClient) GetPrices(priceIDs []string) []*stripe.Price {
var prices []*stripe.Price
for _, priceID := range priceIDs {
Expand All @@ -93,20 +105,21 @@ func (s *StripeClient) GetPrices(priceIDs []string) []*stripe.Price {

func (s *StripeClient) GetPlans() ([]*db.Plan, error) {
var plans []*db.Plan
for i, priceID := range PricesLookupKeys {
if price := s.GetPriceByID(priceID); price != nil {
for i, productID := range ProductsIDs {
if product, err := s.GetProductByID(productID); product != nil && err == nil {
var organizationData db.PlanLimits
if err := json.Unmarshal([]byte(price.Metadata["Organization"]), &organizationData); err != nil {
if err := json.Unmarshal([]byte(product.Metadata["organization"]), &organizationData); err != nil {
return nil, fmt.Errorf("error parsing plan organization metadata JSON: %s\n", err.Error())
}
var votingTypesData db.VotingTypes
if err := json.Unmarshal([]byte(price.Metadata["VotingTypes"]), &votingTypesData); err != nil {
if err := json.Unmarshal([]byte(product.Metadata["votingTypes"]), &votingTypesData); err != nil {
return nil, fmt.Errorf("error parsing plan voting types metadata JSON: %s\n", err.Error())
}
var featuresData db.Features
if err := json.Unmarshal([]byte(price.Metadata["Features"]), &featuresData); err != nil {
if err := json.Unmarshal([]byte(product.Metadata["features"]), &featuresData); err != nil {
return nil, fmt.Errorf("error parsing plan features metadata JSON: %s\n", err.Error())
}
price := product.DefaultPrice
startingPrice := price.UnitAmount
if len(price.Tiers) > 0 {
startingPrice = price.Tiers[0].FlatAmount
Expand All @@ -123,7 +136,7 @@ func (s *StripeClient) GetPlans() ([]*db.Plan, error) {
}
plans = append(plans, &db.Plan{
ID: uint64(i),
Name: price.Nickname,
Name: product.Name,
StartingPrice: startingPrice,
StripeID: price.ID,
Default: price.Metadata["Default"] == "true",
Expand All @@ -132,6 +145,8 @@ func (s *StripeClient) GetPlans() ([]*db.Plan, error) {
Features: featuresData,
CensusSizeTiers: tiers,
})
} else {
return nil, fmt.Errorf("error getting product %s: %s", productID, err.Error())
}
}
return plans, nil
Expand Down

0 comments on commit 888bb37

Please sign in to comment.