Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add self serve billing management UI #5431

Merged
merged 80 commits into from
Oct 28, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
2440f32
Add basic plan info
AdityaHegde Aug 12, 2024
acb2da5
Add actions for switching plans
AdityaHegde Aug 19, 2024
44a38ab
Add payment section
AdityaHegde Aug 19, 2024
475dbd0
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Aug 21, 2024
441e0bf
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Aug 26, 2024
662bfee
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Sep 19, 2024
418e180
Use new APIs
AdityaHegde Sep 19, 2024
376cbaa
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Sep 23, 2024
96d26a0
Add banners for trial and billing issues
AdityaHegde Sep 23, 2024
72e6508
Improve trial end math
AdityaHegde Sep 24, 2024
1f71f66
Add TRIAL_ENDING_SOON state
AdityaHegde Sep 24, 2024
fade30f
Remove TRIAL_ENDING_SOON
AdityaHegde Sep 30, 2024
83ae354
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Sep 30, 2024
e5af9dd
Add plan pill
AdityaHegde Sep 30, 2024
c337e64
Add start team plan variants
AdityaHegde Sep 30, 2024
a16c1f7
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 1, 2024
6ba3913
Handle payment issues
AdityaHegde Oct 1, 2024
b60caca
Handle some edge cases
AdityaHegde Oct 1, 2024
368dd77
Open stripe page before plan upgrade
AdityaHegde Oct 2, 2024
ebc8e6e
Use billing issue to show trial dates
AdityaHegde Oct 3, 2024
7730520
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 3, 2024
5a3105c
Avoid using ListPlans API
AdityaHegde Oct 3, 2024
c4ea1c3
Add null checks
AdityaHegde Oct 3, 2024
8310b96
Fix trial grace period end check
AdityaHegde Oct 4, 2024
df1f20b
Handle cancelled subscriptions
AdityaHegde Oct 4, 2024
9752b05
UXQA fixes - pass 1
AdityaHegde Oct 5, 2024
fc7e934
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 7, 2024
3dabb6a
Use RenewBillingSubscription
AdityaHegde Oct 7, 2024
1d61d74
Handle no subscription case
AdityaHegde Oct 8, 2024
e993973
Always fetch stripe page
AdityaHegde Oct 8, 2024
1e5f1dd
Embed Orb customer portal
AdityaHegde Oct 8, 2024
d4b790c
Open upgrader in same page
AdityaHegde Oct 8, 2024
79f4874
Tweaks
AdityaHegde Oct 8, 2024
883738d
Fix misc issues
AdityaHegde Oct 8, 2024
2198ea1
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 9, 2024
599d568
UXQA - Pass 2
AdityaHegde Oct 9, 2024
7560fa8
Handle viewer cases
AdityaHegde Oct 9, 2024
3613cc3
Refactor to use billing issues message in hibernating message
AdityaHegde Oct 10, 2024
9c2b883
Support PAYMENT_FAILED_ISSUE
AdityaHegde Oct 10, 2024
cfe2460
Add wake all projects
AdityaHegde Oct 10, 2024
98e75c8
UXQA - Pass 3
AdityaHegde Oct 11, 2024
187bb17
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 11, 2024
d2148b1
Hibernating message improvements
AdityaHegde Oct 14, 2024
c4d546b
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 14, 2024
e382acc
Fix hibernate sub cancel check
AdityaHegde Oct 14, 2024
c6389c2
minor changes (#5890)
pjain1 Oct 14, 2024
e49a3d8
Revert asset deletion
AdityaHegde Oct 15, 2024
24acbb9
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 16, 2024
d65af0d
UXQA - Pass 4
AdityaHegde Oct 16, 2024
3d0718c
Add back quotas
AdityaHegde Oct 16, 2024
de504fe
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 17, 2024
f6fc368
Hardcode plan names
AdityaHegde Oct 17, 2024
ab7e0f1
Add CTAs to existing email formats
AdityaHegde Oct 17, 2024
323699b
UI Review comments
AdityaHegde Oct 18, 2024
472e5de
PR comments pass 2
AdityaHegde Oct 21, 2024
dfd796b
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 22, 2024
1be4252
Fix upgrade callback url to stripe
AdityaHegde Oct 22, 2024
4c04d87
PR comments pass 3
AdityaHegde Oct 23, 2024
a671dd4
Styling updates
AdityaHegde Oct 24, 2024
5674229
Add spinner to iframe loading
AdityaHegde Oct 24, 2024
8ec01f5
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 24, 2024
6d57a5c
Add POC plan support
AdityaHegde Oct 24, 2024
4b87ed9
Tweaks
AdityaHegde Oct 24, 2024
8dcd55b
PR comments pass 4
AdityaHegde Oct 25, 2024
f4301e5
fix start trial race condition (#5971)
pjain1 Oct 25, 2024
a8e41c2
web-auth: use svelte and vite-plugin-singlefile (#5965)
briangregoryholmes Oct 24, 2024
d6ce8c4
Share Project Popover (#5887)
lovincyrus Oct 24, 2024
0d774ea
disable preview button when explore resource is reconciling (#5962)
briangregoryholmes Oct 24, 2024
06c444c
fix: display null values with italics in TDD (#5945)
briangregoryholmes Oct 25, 2024
c535b01
completely remove org from orb and stripe (#5955)
pjain1 Oct 25, 2024
035155b
Don't log request cancellation as internal errors in the Github APIs …
begelundmuller Oct 25, 2024
87b95ae
trigger org repair manually (#5936)
pjain1 Oct 25, 2024
2af7c7d
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 28, 2024
4b14bf3
Fix public URLs
AdityaHegde Oct 28, 2024
7c5ba24
Fix upgrade emails
AdityaHegde Oct 28, 2024
52df6b5
Merge branch 'main' into adityahegde/billing-ui
AdityaHegde Oct 28, 2024
0dc2a39
Fix lint
AdityaHegde Oct 28, 2024
691c99a
PR comments pass 5
AdityaHegde Oct 28, 2024
1deb7fb
check org billing init in start trial job (#5983)
pjain1 Oct 28, 2024
15132a4
Add back commented email
AdityaHegde Oct 28, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix upgrade emails
  • Loading branch information
AdityaHegde committed Oct 28, 2024
commit 7c5ba24615cdbabe4d0024c5701b9cd84965ee37
2 changes: 1 addition & 1 deletion admin/urls.go
Original file line number Diff line number Diff line change
Expand Up @@ -339,7 +339,7 @@ func (u *URLs) AlertEdit(org, project, alert string) string {

// UpgradePlan returns the landing page URL to either upgrade to plan or redirect to payment portal if there are any issues.
func (u *URLs) UpgradePlan(org string) string {
return urlutil.MustJoinURL(u.Frontend(), org, "-", "settings", "billing", "upgrade")
return urlutil.MustWithQuery(urlutil.MustJoinURL(u.Frontend(), org, "-", "settings", "billing"), map[string]string{"upgrade": "true"})
}

// PaymentPortal returns the landing page url that redirects user to payment portal
Expand Down
13 changes: 10 additions & 3 deletions web-admin/src/routes/+layout.ts
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The calls to redirectToLoginIfNotLoggedIn break Public URLs. We have two options:

  1. For now, remove them in favor of the call in the global error callback in error-utils.ts where we handle the Public URL case.
  2. Handle the Public URL case here. With a refactor, we might actually be able to migrate away from the global error callback & instead rely on throwing errors in the relevant +layout.ts files, like you've done here.

1 might be safer & easier, but 2 is probably better long-term.

Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,10 @@ import {
type V1OrganizationPermissions,
type V1ProjectPermissions,
} from "@rilldata/web-admin/client";
import { redirectToLoginOrRequestAccess } from "@rilldata/web-admin/features/authentication/checkUserAccess";
import {
redirectToLoginIfNotLoggedIn,
redirectToLoginOrRequestAccess,
} from "@rilldata/web-admin/features/authentication/checkUserAccess";
import { fetchOrganizationPermissions } from "@rilldata/web-admin/features/organizations/selectors";
import { queryClient } from "@rilldata/web-common/lib/svelte-query/globalQueryClient.js";
import { error, type Page } from "@sveltejs/kit";
Expand Down Expand Up @@ -44,9 +47,13 @@ export const load = async ({ params, url, route }) => {
if (e.response?.status !== 403) {
throw error(e.response.status, "Error fetching organization");
}
const didRedirect = await redirectToLoginOrRequestAccess(pageState);
// Use without access to anything withing the org will hit this, so redirect to access page here.
const didRedirect = await redirectToLoginIfNotLoggedIn();
if (!didRedirect) {
throw error(e.response.status, "Error fetching organization");
return {
organizationPermissions,
projectPermissions: <V1ProjectPermissions>{},
};
}
}
}
Expand Down
11 changes: 0 additions & 11 deletions web-admin/src/routes/[organization]/+layout.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import type { V1BillingIssue } from "@rilldata/web-admin/client";
import { redirectToLoginIfNotLoggedIn } from "@rilldata/web-admin/features/authentication/checkUserAccess";
import { fetchOrganizationBillingIssues } from "@rilldata/web-admin/features/billing/selectors";
import { error } from "@sveltejs/kit";

Expand All @@ -15,16 +14,6 @@ export const load = async ({ params: { organization }, parent }) => {
if (e.response?.status !== 403) {
throw error(e.response.status, "Error fetching billing issues");
}
const didRedirect = await redirectToLoginIfNotLoggedIn();
if (!didRedirect) {
throw error(e.response.status, "Error fetching billing issues");
}
if (
e.response?.status !== 403 ||
(await redirectToLoginIfNotLoggedIn())
) {
throw error(e.response.status, "Error fetching billing issues");
}
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { redirectToLoginIfNotLoggedIn } from "@rilldata/web-admin/features/authentication/checkUserAccess";
import { fetchPaymentsPortalURL } from "@rilldata/web-admin/features/billing/plans/selectors";
import { error, redirect } from "@sveltejs/kit";
import type { PageLoad } from "./$types";
Expand All @@ -14,10 +13,6 @@ export const load: PageLoad = async ({ params: { organization }, url }) => {
if (e.response?.status !== 403) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should throw the error when it's a 403 too

throw error(e.response.status, "Error redirecting to payment portal");
}
const didRedirect = await redirectToLoginIfNotLoggedIn();
if (!didRedirect) {
throw error(e.response.status, "Error redirecting to payment portal");
}
}
throw redirect(307, redirectUrl);
};
AdityaHegde marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@ export const load: PageLoad = async ({
307,
await fetchPaymentsPortalURL(
organization,
`${url.protocol}//${url.host}/${organization}`,
`${url.protocol}//${url.host}/${organization}/-/upgrade-callback`,
),
);
} else {
throw redirect(307, `/${organization}/-/settings/billing/callback`);
throw redirect(307, `/${organization}/-/upgrade-callback`);
}
};
5 changes: 3 additions & 2 deletions web-admin/src/routes/[organization]/[project]/+layout.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,9 @@ export const load = async ({ params: { organization }, parent }) => {
shouldRedirectToProjectsList = true;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It doesn't look like we need to keep this shouldRedirectToProjectsList state & we can just fire the redirect right here

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need this because of the try catch. throw redirect... will end up getting caught there.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh I see. That's a little confusing, so we could only do the data fetching within the try, and move the conditional to the bottom?

}
} catch (e) {
console.error(e);
throw error(e.response.status, "Error fetching billing issues");
if (e.response?.status !== 403) {
throw error(e.response?.status, "Error fetching billing issues");
}
}

if (shouldRedirectToProjectsList) {
Expand Down