From 90dc24c17a07591114eb147b438fab00657a936b Mon Sep 17 00:00:00 2001 From: Robert Lesser Date: Thu, 29 Aug 2024 16:45:26 -0400 Subject: [PATCH] refactor: use openAPI types for user info (#68) real user types --- src/type-gen/openapi.ts | 182 ++++++++++++++++++++++++++++++---------- src/user.ts | 25 +----- 2 files changed, 143 insertions(+), 64 deletions(-) diff --git a/src/type-gen/openapi.ts b/src/type-gen/openapi.ts index b972632..4148d7c 100644 --- a/src/type-gen/openapi.ts +++ b/src/type-gen/openapi.ts @@ -842,6 +842,13 @@ export interface paths { */ post: operations['update_dataset_member_v1_dataset__dataset_id__members_update_post']; }; + '/v1/stripe/promo-code/validate': { + /** + * Validate Promo Code + * @description Validate a promo code against a plan type using Stripe API + */ + get: operations['validate_promo_code_v1_stripe_promo_code_validate_get']; + }; '/v1/stripe/subscribe': { /** * Stripe Subscription @@ -2397,6 +2404,58 @@ export interface components { }; /** Organization */ Organization: { + /** @description The plan type this organization is on. */ + plan_type: components['schemas']['OrganizationPlan']; + /** Max Datums Per Project */ + max_datums_per_project: number; + /** Max Members */ + max_members: number; + /** Max Projects */ + max_projects: number; + /** Max External Collaborators */ + max_external_collaborators: number; + /** Max Datums Across All Projects */ + max_datums_across_all_projects?: number; + /** + * Private Projects + * @default false + */ + private_projects?: boolean; + /** Max Text Tokens */ + max_text_tokens?: number; + /** Max Image Embeddings */ + max_image_embeddings?: number; + /** Max Storage */ + max_storage?: number; + /** Max Premium Api Calls */ + max_premium_api_calls?: number; + /** Max Non Embedding Projects */ + max_non_embedding_projects?: number; + /** + * Features + * @description The features this organization is allowed to utilize. + */ + features: string[]; + /** + * Free Text Tokens Per Seat + * @default 0 + */ + free_text_tokens_per_seat?: number; + /** + * Free Image Embeddings Per Seat + * @default 0 + */ + free_image_embeddings_per_seat?: number; + /** + * Free Storage Per Seat + * @default 0 + */ + free_storage_per_seat?: number; + /** + * Free Seats + * @default 0 + */ + free_seats?: number; /** * Id * Format: uuid @@ -2410,11 +2469,6 @@ export interface components { * @example nomicai */ nickname: string; - /** - * Plan Type - * @description The plan type this organization is on. - */ - plan_type: string; /** * Time Created * Format: date-time @@ -2478,26 +2532,6 @@ export interface components { * @description The url of the organization website. */ website?: string; - /** - * Features - * @description The features this organization is allowed to utilize. - */ - features: string[]; - /** - * Max Datums Per Project - * @description The maximum number of datums per project this organization is allowed. - */ - max_datums_per_project: string; - /** - * Max Members - * @description The maximum number of members this organization is allowed. - */ - max_members: string; - /** - * Max Projects - * @description The maximum number of projects this organization can create. - */ - max_projects: number; /** * Stripe Subscription Id * @description Stripe subscription id @@ -2522,21 +2556,11 @@ export interface components { * @description The timestamp the stripe subscription billing period ends */ stripe_subscription_end_timestamp: string; - /** - * Max External Collaborators - * @description The maximum number of external collaborators. - */ - max_external_collaborators: number; /** * Project Count * @description The total number of projects of this organization */ project_count: number; - /** - * Max Datums Across All Projects - * @description Max datums across all projects - */ - max_datums_across_all_projects: number; }; /** OrganizationAccessRequestApproveRequest */ OrganizationAccessRequestApproveRequest: { @@ -2643,11 +2667,10 @@ export interface components { */ access_role: string; /** - * Plan Type * @description Plan type * @example enterprise */ - plan_type: string; + plan_type: components['schemas']['OrganizationPlan']; /** * Permissions * @description User permissions in organization @@ -2730,6 +2753,24 @@ export interface components { /** Organization:Billing:Write */ 'organization:billing:write': boolean; }; + /** + * OrganizationPlan + * @description The list of available plans for organizations. + * @enum {string} + */ + OrganizationPlan: + | 'atlas_demo' + | 'atlas_enterprise' + | 'atlas_research' + | 'atlas_starter' + | 'atlas_startup' + | 'atlas_pro' + | 'mock' + | 'free_test_user' + | 'pro' + | 'enterprise' + | 'free' + | 'research'; /** PagedEmbeddingRequest */ PagedEmbeddingRequest: { /** @@ -3375,11 +3416,8 @@ export interface components { * @example nomicai */ nickname: string; - /** - * Plan Type - * @description The plan type this organization is on. - */ - plan_type: string; + /** @description The plan type this organization is on. */ + plan_type: components['schemas']['OrganizationPlan']; /** * Time Created * Format: date-time @@ -3559,6 +3597,16 @@ export interface components { */ max_datums: number; }; + /** StripeSubscriptionCancelRequest */ + StripeSubscriptionCancelRequest: { + /** + * Organization Id + * Format: uuid + * @description Organization ID + * @example 33adcf85-84ed-4e3a-9519-17c72682f905 + */ + organization_id: string; + }; /** StripeSubscriptionCreateRequest */ StripeSubscriptionCreateRequest: { /** @@ -3568,6 +3616,16 @@ export interface components { * @example 33adcf85-84ed-4e3a-9519-17c72682f905 */ organization_id: string; + /** + * @description Subscription plan + * @default pro + */ + plan_type?: components['schemas']['OrganizationPlan']; + /** + * Promo Code + * @description Promotion code + */ + promo_code?: string; }; /** StripeSubscriptionCreateResponse */ StripeSubscriptionCreateResponse: { @@ -3877,6 +3935,19 @@ export interface components { */ topic_geojson: components['schemas']['FeatureCollection']; }; + /** ValidatePromoCodeRequest */ + ValidatePromoCodeRequest: { + /** + * Promo Code + * @description The promo code to validate + */ + promo_code: string; + /** + * Plan Type + * @description The plan type to validate the promo code against + */ + plan_type: string; + }; /** ValidationError */ ValidationError: { /** Location */ @@ -7233,6 +7304,31 @@ export interface operations { }; }; }; + /** + * Validate Promo Code + * @description Validate a promo code against a plan type using Stripe API + */ + validate_promo_code_v1_stripe_promo_code_validate_get: { + requestBody: { + content: { + 'application/json': components['schemas']['ValidatePromoCodeRequest']; + }; + }; + responses: { + /** @description Successful Response */ + 200: { + content: { + 'application/json': components['schemas']['SuccessResponse']; + }; + }; + /** @description Validation Error */ + 422: { + content: { + 'application/json': components['schemas']['HTTPValidationError']; + }; + }; + }; + }; /** * Stripe Subscription * @description Create stripe subscription checkout session url and send it to front end @@ -7290,7 +7386,7 @@ export interface operations { cancel_stripe_subscription_v1_stripe_cancel_post: { requestBody: { content: { - 'application/json': components['schemas']['StripeSubscriptionCreateRequest']; + 'application/json': components['schemas']['StripeSubscriptionCancelRequest']; }; }; responses: { diff --git a/src/user.ts b/src/user.ts index 1265bb7..5e0c7bf 100644 --- a/src/user.ts +++ b/src/user.ts @@ -115,28 +115,11 @@ export function getEnvViewer(): AtlasViewer { return viewer; } -type UUID = string; - -type OrganizationUserInfo = { - organization_id: UUID; - nickname: string; - user_id: string; - access_role: 'OWNER' | 'MEMBER'; -}; - -export type UserInfo = { - sub: string; - nickname: string; - name: string; - picture: string; - updated_at: string; - default_organization?: UUID; - organizations: OrganizationUserInfo[]; -}; - type ViewMakerArgs = ConstructorParameters; -export class AtlasUser extends BaseAtlasClass { +export class AtlasUser extends BaseAtlasClass< + components['schemas']['PrivateUser'] +> { /* An AtlasUser is a registered user. The class contains both information about the user and the credentials @@ -180,7 +163,7 @@ export class AtlasUser extends BaseAtlasClass { * @returns A list of organizations where the user has the specified role */ async organizations(role: 'OWNER' | 'MEMBER' | null = null) { - let organizations = (await this.fetchAttributes()).organizations; + let organizations = (await this.fetchAttributes()).organizations || []; if (role !== null) { organizations = organizations.filter((org) => org.access_role === role); }