diff --git a/internal/controllers/users.go b/internal/controllers/users.go index 3696f83..2bc2284 100644 --- a/internal/controllers/users.go +++ b/internal/controllers/users.go @@ -355,8 +355,8 @@ func (s Server) UpdateSubscription(ctx echo.Context) error { } log.Debugf("periods from request is %d", periods) - defaultEndDate := time.Now().AddDate(1, 0, 0) - endDate, err := query.ValidateDateQueryParam(ctx, "end_date", &defaultEndDate) + defaultEndDate := time.Now().AddDate(int(periods), 0, 0) + endDate, err := query.ValidateDateQueryParam(ctx, "end-date", &defaultEndDate) if err != nil { return model.Error(ctx, err.Error(), http.StatusBadRequest) } @@ -404,7 +404,9 @@ func (s Server) UpdateSubscription(ctx echo.Context) error { // Define the subscription options. opts := &model.SubscriptionOptions{ - Paid: &paid, + Paid: &paid, + Periods: &periods, + EndDate: &endDate, } // Subscribe the user to the plan. diff --git a/internal/query/main.go b/internal/query/main.go index 393c401..ca8b458 100644 --- a/internal/query/main.go +++ b/internal/query/main.go @@ -72,7 +72,7 @@ func ValidateDateQueryParam(ctx echo.Context, name string, defaultValue *time.Ti } // Parse the parameter value and return the result. - timeValue, err := time.Parse(time.DateOnly, value) + timeValue, err := time.ParseInLocation(time.DateOnly, value, time.Now().Location()) if err != nil { return timeValue, errors.Wrap(err, errMsg) }