@cohostvip/cohost-node 0.0.12 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.mts CHANGED
@@ -340,7 +340,7 @@ interface CalculatedCostComponent extends Omit<CostComponent, "ops" | "cap" | "r
340
340
  /**
341
341
  * @zod .string()
342
342
  */
343
- type OfferingType = "admission" | "package" | "skip" | "drink" | "ticket" | "tc-ticket" | "merch" | "donation" | "membership" | "voucher" | "service" | "other";
343
+ type OfferingType = "admission" | "admission.tableCommitment" | "package" | "skip" | "drink" | "ticket" | "tc-ticket" | "merch" | "donation" | "membership" | "voucher" | "service" | "other";
344
344
  type ActiveOfferingStatus = "live" | "hidden" | "sold-out";
345
345
  type OfferingStatus = ActiveOfferingStatus | "draft" | "deleted" | "unavailable";
346
346
  type PriceCategory = "donation" | "free" | "paid" | "other";
@@ -403,6 +403,12 @@ interface Offering extends DataRecord {
403
403
  hidden: boolean;
404
404
  order_confirmation_message?: string | null;
405
405
  costs: OfferingCosts;
406
+ /**
407
+ * @description The group this offering belongs to.
408
+ *
409
+ * @example "General Admission" (ticket) | "T-shirt" (merch) | "Donation" (donation) | "Membership" (membership) | "Gift Card" (voucher) | "Service Fee" (service) | "Other" (other)
410
+ */
411
+ options?: OfferingOptionsGroup[];
406
412
  /**
407
413
  * Describe fees and other costs associated with purchasing tickets
408
414
  * to this offering
@@ -411,6 +417,18 @@ interface Offering extends DataRecord {
411
417
  */
412
418
  costComponents?: CostComponent[];
413
419
  }
420
+ interface OfferingOptionsGroup {
421
+ id: string;
422
+ name: string;
423
+ hash?: string;
424
+ options: OfferingOption[];
425
+ }
426
+ interface OfferingOption {
427
+ key: string;
428
+ description: string;
429
+ value: string | number;
430
+ meta?: any;
431
+ }
414
432
  interface PackageInclude {
415
433
  id: string;
416
434
  quantity: number;
@@ -853,6 +871,13 @@ interface OrderItem {
853
871
  * @example "item_abc123"
854
872
  */
855
873
  id: string;
874
+ tableCommitmentId: string | null;
875
+ tableCommitment?: {
876
+ id: string;
877
+ groupSize: number;
878
+ ticketsPurchased: number;
879
+ completed: boolean;
880
+ };
856
881
  /**
857
882
  * Type of offering (e.g., ticket, package, merch).
858
883
  * @example "ticket"
@@ -888,15 +913,18 @@ interface OrderItem {
888
913
  * @example { "customField": "value" }
889
914
  */
890
915
  meta: any;
916
+ details: string | null;
917
+ options: any | null;
891
918
  offering: OrderItemOffering;
892
919
  }
893
- interface OrderItemOffering extends Pick<Offering, "name" | "costs" | "type" | "includes"> {
920
+ interface OrderItemOffering extends Pick<Offering, "id" | "name" | "type" | "includes" | "maximumQuantity" | "minimumQuantity"> {
921
+ costs?: OfferingCosts;
894
922
  /**
895
923
  * doc assicated with this offering in the DB.
896
924
  *
897
925
  * @example "events/1234567890/tickets/0987654321"
898
926
  */
899
- docPath: string;
927
+ refPath: string;
900
928
  }
901
929
  /**
902
930
  * Represents the resolved context associated with a cart session.
@@ -1148,6 +1176,9 @@ interface OrderContext$1 {
1148
1176
  */
1149
1177
  [custom: string]: unknown;
1150
1178
  }
1179
+ type CartSessionItem = Pick<OrderItem, "id" | "details" | "offeringId" | "quantity" | "options" | "offering"> & {
1180
+ costs?: OrderItemCosts;
1181
+ };
1151
1182
  /**
1152
1183
  * Represents a temporary or persisted cart before order placement.
1153
1184
  * Focuses on user intent and checkout prep, not post-purchase records.
@@ -1175,7 +1206,7 @@ interface CartSession extends DataRecord, Pick<Order, "currency" | "contextId" |
1175
1206
  /**
1176
1207
  * Items the user has added to their cart.
1177
1208
  */
1178
- items: Partial<OrderItem>[];
1209
+ items: CartSessionItem[];
1179
1210
  /**
1180
1211
  * Estimated totals based on current cart state.
1181
1212
  * These values are subject to recalculation before checkout.
@@ -1228,7 +1259,7 @@ type RequestMethod = "GET" | "POST" | "PUT" | "DELETE" | "PATCH";
1228
1259
  type RequestOptions = {
1229
1260
  method?: RequestMethod;
1230
1261
  data?: any;
1231
- query?: Record<string, string | number | boolean | undefined>;
1262
+ query?: Record<string, string | number | boolean | string[] | undefined>;
1232
1263
  headers?: Record<string, string>;
1233
1264
  pagination?: Pagination;
1234
1265
  };
@@ -1356,6 +1387,24 @@ interface StartCartSessionInput {
1356
1387
  referrer?: string;
1357
1388
  ipAddresses?: string[];
1358
1389
  }
1390
+ interface FindTablesProps {
1391
+ /**
1392
+ * min group size
1393
+ */
1394
+ min: number;
1395
+ /**
1396
+ * max group size
1397
+ */
1398
+ max: number;
1399
+ /**
1400
+ * eligible table sectionss
1401
+ */
1402
+ sections: string[];
1403
+ }
1404
+ interface ViableTableOption {
1405
+ id: string;
1406
+ groupSize: number;
1407
+ }
1359
1408
 
1360
1409
  /**
1361
1410
  * Provides methods to interact with cart sessions in the Cohost API.
@@ -1400,6 +1449,7 @@ declare class SessionsAPI extends CohostEndpoint {
1400
1449
  *
1401
1450
  * @param id - The ID of the session to cancel
1402
1451
  * @returns Nothing if successful
1452
+ *
1403
1453
  * @throws Will throw an error if the cancel operation fails
1404
1454
  */
1405
1455
  cancel(id: string): Promise<void>;
@@ -1413,12 +1463,20 @@ declare class SessionsAPI extends CohostEndpoint {
1413
1463
  * @throws Will throw an error if the update fails
1414
1464
  */
1415
1465
  updateItem(sessionId: string, props: {
1416
- offeringId: string;
1466
+ itemId: string;
1417
1467
  quantity: number;
1468
+ options?: {
1469
+ [key: string]: any;
1470
+ };
1418
1471
  }): Promise<CartSession>;
1419
1472
  /**
1420
- * Pre-validate and prepare the cart session for checkout.
1421
- * @param sessionId
1473
+ * Pre-validate the cart session for payment and checkout.
1474
+ *
1475
+ * @param sessionId - The ID of the cart session
1476
+ * @param data - Data required for validation
1477
+ * @returns {CartSession} The validated cart session
1478
+ *
1479
+ * @throws Will throw an error if validation fails
1422
1480
  */
1423
1481
  preValidate(sessionId: string, data: any): Promise<CartSession>;
1424
1482
  /**
@@ -1435,11 +1493,31 @@ declare class SessionsAPI extends CohostEndpoint {
1435
1493
  * Remove an item from the cart session.
1436
1494
  * The same as setting the quantity to 0.
1437
1495
  *
1438
- * @param sessionId
1439
- * @param offeringId
1496
+ * @param sessionId - The ID of the cart session
1497
+ * @param itemId - The ID of the item to remove
1440
1498
  * @returns {CartSession} The latest cart session
1441
1499
  */
1442
- deleteItem(sessionId: string, offeringId: string): Promise<CartSession>;
1500
+ deleteItem(sessionId: string, itemId: string): Promise<CartSession>;
1501
+ /**
1502
+ * Find available table options for a given cart session.
1503
+ *
1504
+ * @param id - The ID of the cart session
1505
+ * @param props - Filter parameters for finding tables
1506
+ * @returns {ViableTableOption[]} List of valid table options
1507
+ *
1508
+ * @throws Will throw an error if the request fails
1509
+ */
1510
+ findTables(id: string, props: FindTablesProps): Promise<ViableTableOption[]>;
1511
+ /**
1512
+ * Join a table commitment within an active cart session.
1513
+ *
1514
+ * @param id - The ID of the cart session
1515
+ * @param tableCommitmentId - The table commitment ID to join
1516
+ * @returns {CartSession} Updated cart session with joined table
1517
+ *
1518
+ * @throws Will throw an error if the join operation fails
1519
+ */
1520
+ joinTableCommitment(id: string, tableCommitmentId: string): Promise<CartSession>;
1443
1521
  }
1444
1522
 
1445
1523
  /**
@@ -1480,4 +1558,4 @@ declare class CohostClient {
1480
1558
  */
1481
1559
  declare function createCohostClient(options: CohostClientOptions): CohostClient;
1482
1560
 
1483
- export { type ActiveOfferingStatus, type Address, type ApiVersion, type Attendee3, type AttendeeStatus, type BuzzBuilder, type CalculatedCostComponent, type CartSession, CohostClient, type CohostClientSettings, type ContextId, type CostBase, type CostBucket, type CostComponent, type CostComponentCap, type CostComponentRule, type CostComponentRuleCondition, type CostOp, type Coupon, type CouponSummary, type CurrencyAmount, type Customer, type DataRecord, type EqualOperator, type EventBase, type EventFeature, type EventProfile, type EventStatus, type GeometryPoint, type Location, type LocationGeometry, type MultipartText, type Offering, type OfferingCosts, type OfferingStatus, type OfferingType, type Order, type OrderContext, type OrderCosts, type OrderItem, type OrderItemCosts, type OrderItemOffering, type OrderStatus, type PackageInclude, type PaginatedRequest, type PaginatedResponse, type Pagination$1 as Pagination, type PaginationResponse, type Person, type PersonContact, type Photo, type PriceCategory, type ResolvedCartContext, type ResolvedCartContextOffering, type Schedule, type Ticket, type TimeOrOffset, type UpdatableCartSession, type VCDataRecord, type Venue, type VenueBase, type VersionedDataRecord, createCohostClient };
1561
+ export { type ActiveOfferingStatus, type Address, type ApiVersion, type Attendee3, type AttendeeStatus, type BuzzBuilder, type CalculatedCostComponent, type CartSession, type CartSessionItem, CohostClient, type CohostClientSettings, type ContextId, type CostBase, type CostBucket, type CostComponent, type CostComponentCap, type CostComponentRule, type CostComponentRuleCondition, type CostOp, type Coupon, type CouponSummary, type CurrencyAmount, type Customer, type DataRecord, type EqualOperator, type EventBase, type EventFeature, type EventProfile, type EventStatus, type GeometryPoint, type Location, type LocationGeometry, type MultipartText, type Offering, type OfferingCosts, type OfferingOption, type OfferingOptionsGroup, type OfferingStatus, type OfferingType, type Order, type OrderContext, type OrderCosts, type OrderItem, type OrderItemCosts, type OrderItemOffering, type OrderStatus, type PackageInclude, type PaginatedRequest, type PaginatedResponse, type Pagination$1 as Pagination, type PaginationResponse, type Person, type PersonContact, type Photo, type PriceCategory, type ResolvedCartContext, type ResolvedCartContextOffering, type Schedule, type Ticket, type TimeOrOffset, type UpdatableCartSession, type VCDataRecord, type Venue, type VenueBase, type VersionedDataRecord, createCohostClient };
package/dist/index.d.ts CHANGED
@@ -340,7 +340,7 @@ interface CalculatedCostComponent extends Omit<CostComponent, "ops" | "cap" | "r
340
340
  /**
341
341
  * @zod .string()
342
342
  */
343
- type OfferingType = "admission" | "package" | "skip" | "drink" | "ticket" | "tc-ticket" | "merch" | "donation" | "membership" | "voucher" | "service" | "other";
343
+ type OfferingType = "admission" | "admission.tableCommitment" | "package" | "skip" | "drink" | "ticket" | "tc-ticket" | "merch" | "donation" | "membership" | "voucher" | "service" | "other";
344
344
  type ActiveOfferingStatus = "live" | "hidden" | "sold-out";
345
345
  type OfferingStatus = ActiveOfferingStatus | "draft" | "deleted" | "unavailable";
346
346
  type PriceCategory = "donation" | "free" | "paid" | "other";
@@ -403,6 +403,12 @@ interface Offering extends DataRecord {
403
403
  hidden: boolean;
404
404
  order_confirmation_message?: string | null;
405
405
  costs: OfferingCosts;
406
+ /**
407
+ * @description The group this offering belongs to.
408
+ *
409
+ * @example "General Admission" (ticket) | "T-shirt" (merch) | "Donation" (donation) | "Membership" (membership) | "Gift Card" (voucher) | "Service Fee" (service) | "Other" (other)
410
+ */
411
+ options?: OfferingOptionsGroup[];
406
412
  /**
407
413
  * Describe fees and other costs associated with purchasing tickets
408
414
  * to this offering
@@ -411,6 +417,18 @@ interface Offering extends DataRecord {
411
417
  */
412
418
  costComponents?: CostComponent[];
413
419
  }
420
+ interface OfferingOptionsGroup {
421
+ id: string;
422
+ name: string;
423
+ hash?: string;
424
+ options: OfferingOption[];
425
+ }
426
+ interface OfferingOption {
427
+ key: string;
428
+ description: string;
429
+ value: string | number;
430
+ meta?: any;
431
+ }
414
432
  interface PackageInclude {
415
433
  id: string;
416
434
  quantity: number;
@@ -853,6 +871,13 @@ interface OrderItem {
853
871
  * @example "item_abc123"
854
872
  */
855
873
  id: string;
874
+ tableCommitmentId: string | null;
875
+ tableCommitment?: {
876
+ id: string;
877
+ groupSize: number;
878
+ ticketsPurchased: number;
879
+ completed: boolean;
880
+ };
856
881
  /**
857
882
  * Type of offering (e.g., ticket, package, merch).
858
883
  * @example "ticket"
@@ -888,15 +913,18 @@ interface OrderItem {
888
913
  * @example { "customField": "value" }
889
914
  */
890
915
  meta: any;
916
+ details: string | null;
917
+ options: any | null;
891
918
  offering: OrderItemOffering;
892
919
  }
893
- interface OrderItemOffering extends Pick<Offering, "name" | "costs" | "type" | "includes"> {
920
+ interface OrderItemOffering extends Pick<Offering, "id" | "name" | "type" | "includes" | "maximumQuantity" | "minimumQuantity"> {
921
+ costs?: OfferingCosts;
894
922
  /**
895
923
  * doc assicated with this offering in the DB.
896
924
  *
897
925
  * @example "events/1234567890/tickets/0987654321"
898
926
  */
899
- docPath: string;
927
+ refPath: string;
900
928
  }
901
929
  /**
902
930
  * Represents the resolved context associated with a cart session.
@@ -1148,6 +1176,9 @@ interface OrderContext$1 {
1148
1176
  */
1149
1177
  [custom: string]: unknown;
1150
1178
  }
1179
+ type CartSessionItem = Pick<OrderItem, "id" | "details" | "offeringId" | "quantity" | "options" | "offering"> & {
1180
+ costs?: OrderItemCosts;
1181
+ };
1151
1182
  /**
1152
1183
  * Represents a temporary or persisted cart before order placement.
1153
1184
  * Focuses on user intent and checkout prep, not post-purchase records.
@@ -1175,7 +1206,7 @@ interface CartSession extends DataRecord, Pick<Order, "currency" | "contextId" |
1175
1206
  /**
1176
1207
  * Items the user has added to their cart.
1177
1208
  */
1178
- items: Partial<OrderItem>[];
1209
+ items: CartSessionItem[];
1179
1210
  /**
1180
1211
  * Estimated totals based on current cart state.
1181
1212
  * These values are subject to recalculation before checkout.
@@ -1228,7 +1259,7 @@ type RequestMethod = "GET" | "POST" | "PUT" | "DELETE" | "PATCH";
1228
1259
  type RequestOptions = {
1229
1260
  method?: RequestMethod;
1230
1261
  data?: any;
1231
- query?: Record<string, string | number | boolean | undefined>;
1262
+ query?: Record<string, string | number | boolean | string[] | undefined>;
1232
1263
  headers?: Record<string, string>;
1233
1264
  pagination?: Pagination;
1234
1265
  };
@@ -1356,6 +1387,24 @@ interface StartCartSessionInput {
1356
1387
  referrer?: string;
1357
1388
  ipAddresses?: string[];
1358
1389
  }
1390
+ interface FindTablesProps {
1391
+ /**
1392
+ * min group size
1393
+ */
1394
+ min: number;
1395
+ /**
1396
+ * max group size
1397
+ */
1398
+ max: number;
1399
+ /**
1400
+ * eligible table sectionss
1401
+ */
1402
+ sections: string[];
1403
+ }
1404
+ interface ViableTableOption {
1405
+ id: string;
1406
+ groupSize: number;
1407
+ }
1359
1408
 
1360
1409
  /**
1361
1410
  * Provides methods to interact with cart sessions in the Cohost API.
@@ -1400,6 +1449,7 @@ declare class SessionsAPI extends CohostEndpoint {
1400
1449
  *
1401
1450
  * @param id - The ID of the session to cancel
1402
1451
  * @returns Nothing if successful
1452
+ *
1403
1453
  * @throws Will throw an error if the cancel operation fails
1404
1454
  */
1405
1455
  cancel(id: string): Promise<void>;
@@ -1413,12 +1463,20 @@ declare class SessionsAPI extends CohostEndpoint {
1413
1463
  * @throws Will throw an error if the update fails
1414
1464
  */
1415
1465
  updateItem(sessionId: string, props: {
1416
- offeringId: string;
1466
+ itemId: string;
1417
1467
  quantity: number;
1468
+ options?: {
1469
+ [key: string]: any;
1470
+ };
1418
1471
  }): Promise<CartSession>;
1419
1472
  /**
1420
- * Pre-validate and prepare the cart session for checkout.
1421
- * @param sessionId
1473
+ * Pre-validate the cart session for payment and checkout.
1474
+ *
1475
+ * @param sessionId - The ID of the cart session
1476
+ * @param data - Data required for validation
1477
+ * @returns {CartSession} The validated cart session
1478
+ *
1479
+ * @throws Will throw an error if validation fails
1422
1480
  */
1423
1481
  preValidate(sessionId: string, data: any): Promise<CartSession>;
1424
1482
  /**
@@ -1435,11 +1493,31 @@ declare class SessionsAPI extends CohostEndpoint {
1435
1493
  * Remove an item from the cart session.
1436
1494
  * The same as setting the quantity to 0.
1437
1495
  *
1438
- * @param sessionId
1439
- * @param offeringId
1496
+ * @param sessionId - The ID of the cart session
1497
+ * @param itemId - The ID of the item to remove
1440
1498
  * @returns {CartSession} The latest cart session
1441
1499
  */
1442
- deleteItem(sessionId: string, offeringId: string): Promise<CartSession>;
1500
+ deleteItem(sessionId: string, itemId: string): Promise<CartSession>;
1501
+ /**
1502
+ * Find available table options for a given cart session.
1503
+ *
1504
+ * @param id - The ID of the cart session
1505
+ * @param props - Filter parameters for finding tables
1506
+ * @returns {ViableTableOption[]} List of valid table options
1507
+ *
1508
+ * @throws Will throw an error if the request fails
1509
+ */
1510
+ findTables(id: string, props: FindTablesProps): Promise<ViableTableOption[]>;
1511
+ /**
1512
+ * Join a table commitment within an active cart session.
1513
+ *
1514
+ * @param id - The ID of the cart session
1515
+ * @param tableCommitmentId - The table commitment ID to join
1516
+ * @returns {CartSession} Updated cart session with joined table
1517
+ *
1518
+ * @throws Will throw an error if the join operation fails
1519
+ */
1520
+ joinTableCommitment(id: string, tableCommitmentId: string): Promise<CartSession>;
1443
1521
  }
1444
1522
 
1445
1523
  /**
@@ -1480,4 +1558,4 @@ declare class CohostClient {
1480
1558
  */
1481
1559
  declare function createCohostClient(options: CohostClientOptions): CohostClient;
1482
1560
 
1483
- export { type ActiveOfferingStatus, type Address, type ApiVersion, type Attendee3, type AttendeeStatus, type BuzzBuilder, type CalculatedCostComponent, type CartSession, CohostClient, type CohostClientSettings, type ContextId, type CostBase, type CostBucket, type CostComponent, type CostComponentCap, type CostComponentRule, type CostComponentRuleCondition, type CostOp, type Coupon, type CouponSummary, type CurrencyAmount, type Customer, type DataRecord, type EqualOperator, type EventBase, type EventFeature, type EventProfile, type EventStatus, type GeometryPoint, type Location, type LocationGeometry, type MultipartText, type Offering, type OfferingCosts, type OfferingStatus, type OfferingType, type Order, type OrderContext, type OrderCosts, type OrderItem, type OrderItemCosts, type OrderItemOffering, type OrderStatus, type PackageInclude, type PaginatedRequest, type PaginatedResponse, type Pagination$1 as Pagination, type PaginationResponse, type Person, type PersonContact, type Photo, type PriceCategory, type ResolvedCartContext, type ResolvedCartContextOffering, type Schedule, type Ticket, type TimeOrOffset, type UpdatableCartSession, type VCDataRecord, type Venue, type VenueBase, type VersionedDataRecord, createCohostClient };
1561
+ export { type ActiveOfferingStatus, type Address, type ApiVersion, type Attendee3, type AttendeeStatus, type BuzzBuilder, type CalculatedCostComponent, type CartSession, type CartSessionItem, CohostClient, type CohostClientSettings, type ContextId, type CostBase, type CostBucket, type CostComponent, type CostComponentCap, type CostComponentRule, type CostComponentRuleCondition, type CostOp, type Coupon, type CouponSummary, type CurrencyAmount, type Customer, type DataRecord, type EqualOperator, type EventBase, type EventFeature, type EventProfile, type EventStatus, type GeometryPoint, type Location, type LocationGeometry, type MultipartText, type Offering, type OfferingCosts, type OfferingOption, type OfferingOptionsGroup, type OfferingStatus, type OfferingType, type Order, type OrderContext, type OrderCosts, type OrderItem, type OrderItemCosts, type OrderItemOffering, type OrderStatus, type PackageInclude, type PaginatedRequest, type PaginatedResponse, type Pagination$1 as Pagination, type PaginationResponse, type Person, type PersonContact, type Photo, type PriceCategory, type ResolvedCartContext, type ResolvedCartContextOffering, type Schedule, type Ticket, type TimeOrOffset, type UpdatableCartSession, type VCDataRecord, type Venue, type VenueBase, type VersionedDataRecord, createCohostClient };
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var m=Object.defineProperty;var B=Object.getOwnPropertyDescriptor;var D=Object.getOwnPropertyNames;var w=Object.prototype.hasOwnProperty;var z=(r,e,t)=>e in r?m(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t;var $=(r,e)=>{for(var t in e)m(r,t,{get:e[t],enumerable:!0})},V=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of D(e))!w.call(r,s)&&s!==t&&m(r,s,{get:()=>e[s],enumerable:!(n=B(e,s))||n.enumerable});return r};var _=r=>V(m({},"__esModule",{value:!0}),r);var o=(r,e,t)=>z(r,typeof e!="symbol"?e+"":e,t);var F={};$(F,{CohostClient:()=>l,createCohostClient:()=>L});module.exports=_(F);var d=class{constructor(e,t){o(this,"request");o(this,"settings");this.request=e,this.settings=t}};var p="https://api.cohost.com/v1";var f=class r extends Error{constructor(t,n){super(t);o(this,"errorCode");o(this,"statusCode");this.name="CohostError",this.errorCode=n?.errorCode,this.statusCode=n?.statusCode}static fromError(t,n){return new r(t.message,{...n,errorCode:n?.errorCode||t.name})}};var q={baseUrl:"https://api.cohost.vip",headers:{"Content-Type":"application/json"}},P={};var I=(r,e)=>{let{pagination:t,...n}=r;return{query:n,pagination:t,...e}},v=({token:r,baseUrl:e=p,debug:t=!1})=>async function(n,s={}){let{method:i="GET",data:c,query:A,pagination:k,headers:T={}}=s,S={...A,...k},E=S?"?"+new URLSearchParams(Object.entries(S).reduce((g,[U,R])=>(R!==void 0&&(g[U]=String(R)),g),{})).toString():"",h=`${P.baseUrl??e}${n}${E}`,b={...q.headers,...P.headers,...T};r&&(b.Authorization=`Bearer ${r}`);let O=c&&i!=="GET"?JSON.stringify(c):void 0;t&&(console.log(`[Cohost SDK] Request: ${i} ${h}`),O&&console.log("[Cohost SDK] Body:",O),console.log("[Cohost SDK] Headers:",b));let u=await fetch(h,{method:i,headers:b,body:O}),a=u.headers.get("content-type")?.includes("application/json")?await u.json():await u.text();if(!u.ok){let g=typeof a=="string"?a:JSON.stringify(a);throw console.error(`[Cohost SDK] Error: ${g}`,{url:h}),new f(g||u.statusText,{errorCode:u.statusText||"API_ERROR",statusCode:u.status})}return typeof a=="object"&&a!==null&&a.status==="ok"&&"data"in a?a.data:a};var y=class extends d{async list(){return this.request("/events")}async fetch(e){return this.request(`/events/${e}`)}async tickets(e){return this.request(`/events/${e}/tickets`)}async attendees(e,t){return this.request(`/events/${e}/attendees`,I(t))}};var C=class extends d{async fetch(e,t){return this.request(`/orders/${e}?uid=${t}`)}async list(e){let t=new URLSearchParams(e).toString();return this.request(`/orders${t?`?${t}`:""}`)}};var x=class extends d{async start(e){return this.request("/cart/sessions",{method:"POST",data:e})}async get(e){return this.request(`/cart/sessions/${e}`)}async update(e,t){return this.request(`/cart/sessions/${e}`,{method:"PATCH",data:t})}async cancel(e){return this.request(`/cart/sessions/${e}`,{method:"DELETE"})}async updateItem(e,t){return this.request(`/cart/sessions/${e}/item`,{method:"POST",data:t})}async preValidate(e,t){return this.request(`/cart/sessions/${e}/payment/pre-validate`,{method:"POST",data:t})}async placeOrder(e,t){return this.request(`/cart/sessions/${e}/place-order`,{method:"POST",data:t})}async deleteItem(e,t){return this.updateItem(e,{offeringId:t,quantity:0})}};var l=class r{constructor(e,t){o(this,"events");o(this,"orders");o(this,"cart");o(this,"baseOptions");this.baseOptions=e;let{token:n,settings:s={}}=e,i=t??v({token:n,baseUrl:s.apiUrl||p,debug:s.debug});this.events=new y(i,s),this.orders=new C(i,s),this.cart=new x(i,s)}requestWithOverrides(e){let{token:t,settings:n={}}=this.baseOptions,s=(i,c={})=>v({token:e.token??t,baseUrl:e.baseUrl??n.apiUrl??p,debug:n.debug})(i,{...c,headers:{...e.headers||{},...c.headers||{}}});return new r({token:e.token??t,settings:{...n,apiUrl:e.baseUrl??n.apiUrl}},s)}};function L(r){return new l(r)}0&&(module.exports={CohostClient,createCohostClient});
1
+ "use strict";var l=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var U=Object.getOwnPropertyNames;var B=Object.prototype.hasOwnProperty;var D=(n,e,t)=>e in n?l(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var $=(n,e)=>{for(var t in e)l(n,t,{get:e[t],enumerable:!0})},w=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of U(e))!B.call(n,s)&&s!==t&&l(n,s,{get:()=>e[s],enumerable:!(r=E(e,s))||r.enumerable});return n};var z=n=>w(l({},"__esModule",{value:!0}),n);var o=(n,e,t)=>D(n,typeof e!="symbol"?e+"":e,t);var L={};$(L,{CohostClient:()=>p,createCohostClient:()=>_});module.exports=z(L);var d=class{constructor(e,t){o(this,"request");o(this,"settings");this.request=e,this.settings=t}};var g="https://api.cohost.com/v1";var m=class n extends Error{constructor(t,r){super(t);o(this,"errorCode");o(this,"statusCode");this.name="CohostError",this.errorCode=r?.errorCode,this.statusCode=r?.statusCode}static fromError(t,r){return new n(t.message,{...r,errorCode:r?.errorCode||t.name})}};var v={baseUrl:"https://api.cohost.vip",headers:{"Content-Type":"application/json"}},O={};var R=(n,e)=>{let{pagination:t,...r}=n;return{query:r,pagination:t,...e}},V=n=>{if(!n)return"";let e=new URLSearchParams;for(let[t,r]of Object.entries(n))r!==void 0&&(Array.isArray(r)?r.forEach(s=>e.append(t,String(s))):e.set(t,String(r)));return e.toString()?`?${e.toString()}`:""},P=({token:n,baseUrl:e=g,debug:t=!1})=>async function(r,s={}){let{method:i="GET",data:c,query:q,pagination:I,headers:A={}}=s,T={...q,...I},k=V(T),x=`${O.baseUrl??e}${r}${k}`,h={...v.headers,...O.headers,...A};n&&(h.Authorization=`Bearer ${n}`);let b=c&&i!=="GET"?JSON.stringify(c):void 0;t&&(console.log(`[Cohost SDK] Request: ${i} ${x}`),b&&console.log("[Cohost SDK] Body:",b),console.log("[Cohost SDK] Headers:",h));let u=await fetch(x,{method:i,headers:h,body:b}),a=u.headers.get("content-type")?.includes("application/json")?await u.json():await u.text();if(!u.ok){let S=typeof a=="string"?a:JSON.stringify(a);throw console.error(`[Cohost SDK] Error: ${S}`,{url:x}),new m(S||u.statusText,{errorCode:u.statusText||"API_ERROR",statusCode:u.status})}return typeof a=="object"&&a!==null&&a.status==="ok"&&"data"in a?a.data:a};var f=class extends d{async list(){return this.request("/events")}async fetch(e){return this.request(`/events/${e}`)}async tickets(e){return this.request(`/events/${e}/tickets`)}async attendees(e,t){return this.request(`/events/${e}/attendees`,R(t))}};var y=class extends d{async fetch(e,t){return this.request(`/orders/${e}?uid=${t}`)}async list(e){let t=new URLSearchParams(e).toString();return this.request(`/orders${t?`?${t}`:""}`)}};var C=class extends d{async start(e){return this.request("/cart/sessions",{method:"POST",data:e})}async get(e){return this.request(`/cart/sessions/${e}`)}async update(e,t){return this.request(`/cart/sessions/${e}`,{method:"PATCH",data:t})}async cancel(e){return this.request(`/cart/sessions/${e}`,{method:"DELETE"})}async updateItem(e,t){return this.request(`/cart/sessions/${e}/item`,{method:"POST",data:t})}async preValidate(e,t){return this.request(`/cart/sessions/${e}/payment/pre-validate`,{method:"POST",data:t})}async placeOrder(e,t){return this.request(`/cart/sessions/${e}/place-order`,{method:"POST",data:t})}async deleteItem(e,t){return this.updateItem(e,{itemId:t,quantity:0})}async findTables(e,t){return this.request(`/cart/tables/find-tables/${e}`,{query:{...t}})}async joinTableCommitment(e,t){return this.request(`/cart/sessions/${e}/join-table`,{method:"POST",data:{tableCommitmentId:t}})}};var p=class n{constructor(e,t){o(this,"events");o(this,"orders");o(this,"cart");o(this,"baseOptions");this.baseOptions=e;let{token:r,settings:s={}}=e,i=t??P({token:r,baseUrl:s.apiUrl||g,debug:s.debug});this.events=new f(i,s),this.orders=new y(i,s),this.cart=new C(i,s)}requestWithOverrides(e){let{token:t,settings:r={}}=this.baseOptions,s=(i,c={})=>P({token:e.token??t,baseUrl:e.baseUrl??r.apiUrl??g,debug:r.debug})(i,{...c,headers:{...e.headers||{},...c.headers||{}}});return new n({token:e.token??t,settings:{...r,apiUrl:e.baseUrl??r.apiUrl}},s)}};function _(n){return new p(n)}0&&(module.exports={CohostClient,createCohostClient});
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/endpoint.ts","../src/apiVersion.ts","../src/error/CohostError.ts","../src/settings.ts","../src/http/request.ts","../src/api/events.ts","../src/api/orders.ts","../src/api/sessions.ts","../src/client.ts"],"sourcesContent":["import { CohostClient, CohostClientOptions } from './client';\nexport { type CohostClientSettings } from './settings';\n\n/**\n * Factory method for creating a CohostClient instance.\n * \n * Example:\n * ```ts\n * const client = createCohostClient({ token: 'your-token' });\n * ```\n */\nexport function createCohostClient(options: CohostClientOptions): CohostClient {\n return new CohostClient(options);\n}\n\n\nexport { CohostClient }\n\nexport * from '../types';","import { RequestFn } from \"./http/request\";\nimport { CohostClientSettings } from \"./settings\";\n\n/**\n * Base class for all API endpoint groups within the Cohost SDK.\n * Provides shared access to the configured request function and settings.\n */\nexport class CohostEndpoint {\n /** Shared request function injected from the client */\n protected request: RequestFn;\n\n /** Client settings passed during instantiation */\n protected settings: CohostClientSettings;\n\n /**\n * Constructs a new endpoint group.\n *\n * @param request - The shared request function for performing API calls\n * @param settings - The client-wide settings passed from the parent client\n */\n constructor(request: RequestFn, settings: CohostClientSettings) {\n this.request = request;\n this.settings = settings;\n }\n}\n","export const apiVersion = '0.1.0';\nexport const apiVersionDate = '2025-04-15';\nexport const apiBaseUrl = 'https://api.cohost.com/v1'","\nexport interface CohostErrorProps {\n /**\n * Optional error code.\n * @default undefined\n */\n errorCode?: string;\n\n /**\n * Optional status code.\n * @default undefined\n */\n statusCode?: number;\n};\n\nexport class CohostError extends Error {\n errorCode: string | undefined;\n statusCode: number | undefined;\n\n /**\n * Custom error class for Cohost SDK errors.\n * @param message - The error message.\n */\n constructor(message: string, props?: CohostErrorProps) {\n // Call the parent constructor with the message\n super(message);\n\n // Set the name of the error to \"CohostError\"\n this.name = \"CohostError\";\n\n // Set the error code if provided\n this.errorCode = props?.errorCode;\n // Set the status code if provided\n this.statusCode = props?.statusCode;\n }\n\n static fromError(err: Error, props?: CohostErrorProps): CohostError {\n // Create a new CohostError instance from an existing error\n return new CohostError(err.message, {\n ...props,\n errorCode: props?.errorCode || err.name,\n });\n }\n\n}\n\n\n\n\n","/**\n * Optional settings for customizing the behavior of the CohostClient.\n */\nexport interface CohostClientSettings {\n /** Enable verbose debug output for all API requests. */\n debug?: boolean;\n\n /** Override the default API base URL (defaults to apiBaseUrl). */\n apiUrl?: string;\n}\n\n// settings.ts\nexport const defaultSettings = {\n baseUrl: 'https://api.cohost.vip',\n headers: {\n 'Content-Type': 'application/json',\n },\n};\n\n// In dev or testing, you can override this in the browser or Node\nexport let runtimeOverrides: {\n baseUrl?: string;\n headers?: Record<string, string>;\n} = {};\n\nexport function setSdkOverrides(overrides: typeof runtimeOverrides) {\n runtimeOverrides = overrides;\n}\n\n","import { PaginatedRequest } from \"../../types\";\nimport { apiBaseUrl } from \"../apiVersion\";\nimport { CohostError } from \"../error/CohostError\";\nimport { defaultSettings, runtimeOverrides } from \"../settings\";\nimport { Pagination } from \"../types/pagination\";\n\n/**\n * Options for configuring the request handler.\n */\ninterface RequestProps {\n /** API token for authentication (Bearer token). */\n token: string | null;\n\n /** Base URL of the API (defaults to versioned `apiBaseUrl`). */\n baseUrl?: string;\n\n /** Enable debug logging of requests/responses. */\n debug?: boolean;\n}\n\n/**\n * Supported HTTP methods.\n */\ntype RequestMethod = \"GET\" | \"POST\" | \"PUT\" | \"DELETE\" | \"PATCH\";\n\n\ntype RequestOptions = {\n method?: RequestMethod;\n data?: any;\n query?: Record<string, string | number | boolean | undefined>;\n headers?: Record<string, string>;\n pagination?: Pagination;\n};\n\n\nexport const paginatedOptions = (req: PaginatedRequest<any>, options?: Partial<RequestOptions>): RequestOptions => {\n const { pagination, ...rest } = req;\n\n\n return {\n query: rest,\n pagination,\n ...options,\n };\n}\n\n/**\n * A function that performs a request to the Cohost API.\n * The generic <T> allows you to specify the expected response type.\n */\ntype RequestFn = <T = any>(\n path: string,\n options?: RequestOptions\n) => Promise<T>;\n\n/**\n * Creates a request function configured with authentication and client defaults.\n * The returned function supports generic return typing via <T>.\n */\nconst request = ({ token, baseUrl = apiBaseUrl, debug = false }: RequestProps): RequestFn => {\n return async function <T = any>(\n path: string,\n options: RequestOptions = {}\n ): Promise<T> {\n const { method = \"GET\", data, query, pagination, headers = {} } = options;\n\n let _query = {\n ...query,\n ...pagination,\n };\n\n\n // Construct query string from `query` object\n const queryString = _query\n ? \"?\" +\n new URLSearchParams(\n Object.entries(_query).reduce((acc, [key, value]) => {\n if (value !== undefined) acc[key] = String(value);\n return acc;\n }, {} as Record<string, string>)\n ).toString()\n : \"\";\n\n\n\n const finalBaseUrl = runtimeOverrides.baseUrl ?? baseUrl;\n const url = `${finalBaseUrl}${path}${queryString}`;\n\n // Merge default, runtime, and per-request headers\n const reqHeaders: Record<string, string> = {\n ...defaultSettings.headers,\n ...runtimeOverrides.headers,\n ...headers,\n };\n\n // Add Authorization header if token is present\n if (token) {\n reqHeaders[\"Authorization\"] = `Bearer ${token}`;\n }\n\n // Only send body if method allows it\n const body = data && method !== \"GET\" ? JSON.stringify(data) : undefined;\n\n // Optional debug logging\n if (debug) {\n console.log(`[Cohost SDK] Request: ${method} ${url}`);\n if (body) console.log(`[Cohost SDK] Body:`, body);\n console.log(`[Cohost SDK] Headers:`, reqHeaders);\n }\n\n const res = await fetch(url, {\n method,\n headers: reqHeaders,\n body,\n });\n\n // Parse the response based on content type\n const isJson = res.headers.get(\"content-type\")?.includes(\"application/json\");\n const responseBody = isJson ? await res.json() : await res.text();\n\n // Handle error responses\n if (!res.ok) {\n const message = typeof responseBody === \"string\" ? responseBody : JSON.stringify(responseBody);\n console.error(`[Cohost SDK] Error: ${message}`, {\n url\n });\n\n\n throw new CohostError(message || res.statusText, {\n errorCode: res.statusText || \"API_ERROR\",\n statusCode: res.status,\n });\n\n }\n\n // If wrapped response structure with { status: 'ok', data }, return `data`\n if (\n typeof responseBody === \"object\" &&\n responseBody !== null &&\n (responseBody as any).status === \"ok\" &&\n \"data\" in responseBody\n ) {\n return (responseBody as { data: T }).data;\n }\n\n // Fallback for raw/unwrapped responses\n return responseBody as T;\n };\n};\n\nexport { type RequestProps, type RequestFn };\nexport { request };\n","// src/api/EventsAPI.ts\n\nimport { CohostEndpoint } from '../endpoint';\nimport { Attendee3, EventProfile, PaginatedRequest, PaginatedResponse, Ticket } from '../../types/index';\nimport { paginatedOptions } from '../http/request';\n\n/**\n * Provides methods to interact with the Cohost Events API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const list = await client.events.list();\n * const event = await client.events.fetch('event-id');\n * const tickets = await client.events.tickets('event-id');\n * ```\n */\nexport class EventsAPI extends CohostEndpoint {\n\n /**\n * Fetch a list of all events.\n * \n * @returns A Promise resolving to an array of event objects\n * @throws Will throw an error if the request fails\n * \n * @todo Implement pagination and filtering options\n */\n async list() {\n return this.request<EventProfile[]>('/events');\n }\n\n\n /**\n * Fetch a single event by ID.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to the event object\n * @throws Will throw an error if the request fails or the event is not found\n */\n async fetch(id: string) {\n return this.request<EventProfile>(`/events/${id}`);\n }\n\n\n\n /**\n * List all tickets associated with a specific event.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to an array of ticket objects\n * @throws Will throw an error if the request fails or the event does not exist\n */\n async tickets(id: string) {\n return this.request<Ticket[]>(`/events/${id}/tickets`);\n }\n\n /**\n * List attendees in the event.\n *\n * Requires: valid authentication token. This endpoint is not public.\n * \n * @param id - The ID of the event.\n * @returns List of tickets (attendees) for the event.\n */\n async attendees(id: string, filters?: PaginatedRequest<any>) {\n return this.request<PaginatedResponse<Attendee3>>(`/events/${id}/attendees`, paginatedOptions(filters));\n }\n\n}\n","import { CohostEndpoint } from '../endpoint';\n\n/**\n * Provides methods to interact with the Cohost Orders API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const order = await client.orders.fetch('order-id', 'user-id');\n * const list = await client.orders.list({ status: 'completed' });\n * ```\n */\nexport class OrdersAPI extends CohostEndpoint {\n\n /**\n * Fetch a single order by ID.\n * \n * @param id - The unique identifier of the order\n * @param uid - The unique user ID associated with the order (currently unused but reserved for future auth context)\n * @returns A Promise resolving to the order object\n * @throws Will throw an error if the request fails or the order is not found\n */\n async fetch(id: string, uid: string) {\n // uid is reserved for future scoped access/auth features\n return this.request(`/orders/${id}?uid=${uid}`);\n }\n\n /**\n * List orders with optional filters.\n * \n * @param filters - Optional filters to apply when retrieving orders\n * @returns A Promise resolving to an array of order summaries\n * @throws Will throw an error if the request fails\n */\n async list(filters?: {\n status?: string;\n startDate?: string;\n endDate?: string;\n page?: number;\n pageSize?: number;\n }) {\n const query = new URLSearchParams(filters as Record<string, string>).toString();\n return this.request(`/orders${query ? `?${query}` : ''}`);\n }\n}\n","import { CartSession, UpdatableCartSession } from '../../types';\nimport { CohostEndpoint } from '../endpoint';\nimport { StartCartSessionInput } from '../types/sessions';\n\n/**\n * Provides methods to interact with cart sessions in the Cohost API.\n *\n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const session = await client.sessions.start({ contextId: 'evt_abc123' });\n * ```\n */\nexport class SessionsAPI extends CohostEndpoint {\n\n\n /**\n * Start a new cart session.\n *\n * @param input - Data to start the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the request fails\n */\n async start(input: StartCartSessionInput) {\n return this.request<CartSession>('/cart/sessions', {\n method: 'POST',\n data: input,\n });\n }\n\n /**\n * Get a cart session by its ID.\n *\n * @param id - The unique session ID\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the session is not found or request fails\n */\n async get(id: string) {\n return this.request<CartSession>(`/cart/sessions/${id}`);\n }\n\n /**\n * Update a cart session.\n *\n * @param id - The ID of the session to update\n * @param input - Data to update the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async update(id: string, input: Partial<UpdatableCartSession>) {\n return this.request<CartSession>(`/cart/sessions/${id}`, {\n method: 'PATCH',\n data: input,\n });\n }\n\n /**\n * Cancel (soft delete) a cart session.\n *\n * @param id - The ID of the session to cancel\n * @returns Nothing if successful\n * @throws Will throw an error if the cancel operation fails\n */\n async cancel(id: string) {\n return this.request<void>(`/cart/sessions/${id}`, {\n method: 'DELETE',\n });\n }\n\n\n\n /**\n * Update an item in the cart session.\n *\n * @param sessionId - The ID of the session\n * @param props - Properties to update\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async updateItem(sessionId: string, props: {\n offeringId: string;\n quantity: number;\n }) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/item`, {\n method: 'POST',\n data: props,\n });\n }\n\n\n /**\n * Pre-validate and prepare the cart session for checkout.\n * @param sessionId \n */\n async preValidate(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/payment/pre-validate`, {\n method: 'POST',\n data: data,\n });\n }\n\n\n /**\n * Close the cart session, and place the order.\n * \n * @param sessionId - The ID of the session\n * @param data - Data to place the order\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the order placement fails\n */\n async placeOrder(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/place-order`, {\n method: 'POST',\n data: data,\n });\n }\n\n\n /**\n * Remove an item from the cart session.\n * The same as setting the quantity to 0.\n * \n * @param sessionId \n * @param offeringId \n * @returns {CartSession} The latest cart session\n */\n async deleteItem(sessionId: string, offeringId: string) {\n return this.updateItem(sessionId, {\n offeringId,\n quantity: 0,\n });\n }\n\n}\n","import { EventsAPI } from './api/events';\nimport { OrdersAPI } from './api/orders';\nimport { SessionsAPI } from './api/sessions';\nimport { apiBaseUrl } from './apiVersion';\nimport { request, RequestFn } from './http/request';\nimport { CohostClientSettings } from './settings';\n\n/**\n * Configuration options for instantiating a CohostClient.\n */\nexport interface CohostClientOptions {\n /** API token used for authenticated requests. */\n token: string;\n\n /** Optional client settings such as debug mode or custom API URL. */\n settings?: CohostClientSettings;\n}\n\n/**\n * CohostClient provides grouped access to various API modules such as Events and Orders.\n */\nexport class CohostClient {\n public readonly events: EventsAPI;\n public readonly orders: OrdersAPI;\n public readonly cart: SessionsAPI;\n\n private readonly baseOptions: CohostClientOptions;\n\n constructor(options: CohostClientOptions, customRequestFn?: RequestFn) {\n this.baseOptions = options;\n\n const { token, settings = {} } = options;\n\n const sharedRequest = customRequestFn ?? request({\n token,\n baseUrl: settings.apiUrl || apiBaseUrl,\n debug: settings.debug,\n });\n\n this.events = new EventsAPI(sharedRequest, settings);\n this.orders = new OrdersAPI(sharedRequest, settings);\n this.cart = new SessionsAPI(sharedRequest, settings);\n }\n\n /**\n * Returns a new CohostClient instance with overridden request behavior\n */\n public requestWithOverrides(overrides: {\n token?: string;\n baseUrl?: string;\n headers?: Record<string, string>;\n }): CohostClient {\n const { token, settings = {} } = this.baseOptions;\n\n const overriddenRequest: RequestFn = (path, options = {}) =>\n request({\n token: overrides.token ?? token,\n baseUrl: overrides.baseUrl ?? settings.apiUrl ?? apiBaseUrl,\n debug: settings.debug,\n })(path, {\n ...options,\n headers: {\n ...(overrides.headers || {}),\n ...(options.headers || {}),\n },\n });\n\n return new CohostClient(\n {\n token: overrides.token ?? token,\n settings: {\n ...settings,\n apiUrl: overrides.baseUrl ?? settings.apiUrl,\n },\n },\n overriddenRequest\n );\n }\n}\n"],"mappings":"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","names":["index_exports","__export","CohostClient","createCohostClient","__toCommonJS","CohostEndpoint","request","settings","__publicField","apiBaseUrl","CohostError","_CohostError","message","props","__publicField","err","defaultSettings","runtimeOverrides","paginatedOptions","req","options","pagination","rest","request","token","baseUrl","apiBaseUrl","debug","path","method","data","query","headers","_query","queryString","acc","key","value","url","runtimeOverrides","reqHeaders","defaultSettings","body","res","responseBody","message","CohostError","EventsAPI","CohostEndpoint","id","filters","paginatedOptions","OrdersAPI","CohostEndpoint","id","uid","filters","query","SessionsAPI","CohostEndpoint","input","id","sessionId","props","data","offeringId","CohostClient","_CohostClient","options","customRequestFn","__publicField","token","settings","sharedRequest","request","apiBaseUrl","EventsAPI","OrdersAPI","SessionsAPI","overrides","overriddenRequest","path","createCohostClient","options","CohostClient"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/endpoint.ts","../src/apiVersion.ts","../src/error/CohostError.ts","../src/settings.ts","../src/http/request.ts","../src/api/events.ts","../src/api/orders.ts","../src/api/sessions.ts","../src/client.ts"],"sourcesContent":["import { CohostClient, CohostClientOptions } from './client';\nexport { type CohostClientSettings } from './settings';\n\n/**\n * Factory method for creating a CohostClient instance.\n * \n * Example:\n * ```ts\n * const client = createCohostClient({ token: 'your-token' });\n * ```\n */\nexport function createCohostClient(options: CohostClientOptions): CohostClient {\n return new CohostClient(options);\n}\n\n\nexport { CohostClient }\n\nexport * from '../types';","import { RequestFn } from \"./http/request\";\nimport { CohostClientSettings } from \"./settings\";\n\n/**\n * Base class for all API endpoint groups within the Cohost SDK.\n * Provides shared access to the configured request function and settings.\n */\nexport class CohostEndpoint {\n /** Shared request function injected from the client */\n protected request: RequestFn;\n\n /** Client settings passed during instantiation */\n protected settings: CohostClientSettings;\n\n /**\n * Constructs a new endpoint group.\n *\n * @param request - The shared request function for performing API calls\n * @param settings - The client-wide settings passed from the parent client\n */\n constructor(request: RequestFn, settings: CohostClientSettings) {\n this.request = request;\n this.settings = settings;\n }\n}\n","export const apiVersion = '0.1.0';\nexport const apiVersionDate = '2025-04-15';\nexport const apiBaseUrl = 'https://api.cohost.com/v1'","\nexport interface CohostErrorProps {\n /**\n * Optional error code.\n * @default undefined\n */\n errorCode?: string;\n\n /**\n * Optional status code.\n * @default undefined\n */\n statusCode?: number;\n};\n\nexport class CohostError extends Error {\n errorCode: string | undefined;\n statusCode: number | undefined;\n\n /**\n * Custom error class for Cohost SDK errors.\n * @param message - The error message.\n */\n constructor(message: string, props?: CohostErrorProps) {\n // Call the parent constructor with the message\n super(message);\n\n // Set the name of the error to \"CohostError\"\n this.name = \"CohostError\";\n\n // Set the error code if provided\n this.errorCode = props?.errorCode;\n // Set the status code if provided\n this.statusCode = props?.statusCode;\n }\n\n static fromError(err: Error, props?: CohostErrorProps): CohostError {\n // Create a new CohostError instance from an existing error\n return new CohostError(err.message, {\n ...props,\n errorCode: props?.errorCode || err.name,\n });\n }\n\n}\n\n\n\n\n","/**\n * Optional settings for customizing the behavior of the CohostClient.\n */\nexport interface CohostClientSettings {\n /** Enable verbose debug output for all API requests. */\n debug?: boolean;\n\n /** Override the default API base URL (defaults to apiBaseUrl). */\n apiUrl?: string;\n}\n\n// settings.ts\nexport const defaultSettings = {\n baseUrl: 'https://api.cohost.vip',\n headers: {\n 'Content-Type': 'application/json',\n },\n};\n\n// In dev or testing, you can override this in the browser or Node\nexport let runtimeOverrides: {\n baseUrl?: string;\n headers?: Record<string, string>;\n} = {};\n\nexport function setSdkOverrides(overrides: typeof runtimeOverrides) {\n runtimeOverrides = overrides;\n}\n\n","import { PaginatedRequest } from \"../../types\";\nimport { apiBaseUrl } from \"../apiVersion\";\nimport { CohostError } from \"../error/CohostError\";\nimport { defaultSettings, runtimeOverrides } from \"../settings\";\nimport { Pagination } from \"../types/pagination\";\n\n/**\n * Options for configuring the request handler.\n */\ninterface RequestProps {\n /** API token for authentication (Bearer token). */\n token: string | null;\n\n /** Base URL of the API (defaults to versioned `apiBaseUrl`). */\n baseUrl?: string;\n\n /** Enable debug logging of requests/responses. */\n debug?: boolean;\n}\n\n/**\n * Supported HTTP methods.\n */\ntype RequestMethod = \"GET\" | \"POST\" | \"PUT\" | \"DELETE\" | \"PATCH\";\n\ntype RequestOptions = {\n method?: RequestMethod;\n data?: any;\n query?: Record<string, string | number | boolean | string[] | undefined>;\n headers?: Record<string, string>;\n pagination?: Pagination;\n};\n\nexport const paginatedOptions = (req: PaginatedRequest<any>, options?: Partial<RequestOptions>): RequestOptions => {\n const { pagination, ...rest } = req;\n return {\n query: rest,\n pagination,\n ...options,\n };\n};\n\n/**\n * Builds a query string from a flat object, supporting array values via repeated keys.\n */\nconst buildQueryString = (\n input?: Record<string, string | number | boolean | string[] | undefined>\n): string => {\n if (!input) return \"\";\n\n const params = new URLSearchParams();\n for (const [key, value] of Object.entries(input)) {\n if (value === undefined) continue;\n if (Array.isArray(value)) {\n value.forEach((v) => params.append(key, String(v)));\n } else {\n params.set(key, String(value));\n }\n }\n return params.toString() ? `?${params.toString()}` : \"\";\n};\n\n/**\n * A function that performs a request to the Cohost API.\n * The generic <T> allows you to specify the expected response type.\n */\ntype RequestFn = <T = any>(\n path: string,\n options?: RequestOptions\n) => Promise<T>;\n\n/**\n * Creates a request function configured with authentication and client defaults.\n * The returned function supports generic return typing via <T>.\n */\nconst request = ({ token, baseUrl = apiBaseUrl, debug = false }: RequestProps): RequestFn => {\n return async function <T = any>(\n path: string,\n options: RequestOptions = {}\n ): Promise<T> {\n const { method = \"GET\", data, query, pagination, headers = {} } = options;\n\n const _query = {\n ...query,\n ...pagination,\n };\n\n const queryString = buildQueryString(_query);\n const finalBaseUrl = runtimeOverrides.baseUrl ?? baseUrl;\n const url = `${finalBaseUrl}${path}${queryString}`;\n\n const reqHeaders: Record<string, string> = {\n ...defaultSettings.headers,\n ...runtimeOverrides.headers,\n ...headers,\n };\n\n if (token) {\n reqHeaders[\"Authorization\"] = `Bearer ${token}`;\n }\n\n const body = data && method !== \"GET\" ? JSON.stringify(data) : undefined;\n\n if (debug) {\n console.log(`[Cohost SDK] Request: ${method} ${url}`);\n if (body) console.log(`[Cohost SDK] Body:`, body);\n console.log(`[Cohost SDK] Headers:`, reqHeaders);\n }\n\n const res = await fetch(url, {\n method,\n headers: reqHeaders,\n body,\n });\n\n const isJson = res.headers.get(\"content-type\")?.includes(\"application/json\");\n const responseBody = isJson ? await res.json() : await res.text();\n\n if (!res.ok) {\n const message = typeof responseBody === \"string\" ? responseBody : JSON.stringify(responseBody);\n console.error(`[Cohost SDK] Error: ${message}`, { url });\n throw new CohostError(message || res.statusText, {\n errorCode: res.statusText || \"API_ERROR\",\n statusCode: res.status,\n });\n }\n\n if (\n typeof responseBody === \"object\" &&\n responseBody !== null &&\n (responseBody as any).status === \"ok\" &&\n \"data\" in responseBody\n ) {\n return (responseBody as { data: T }).data;\n }\n\n return responseBody as T;\n };\n};\n\nexport { type RequestProps, type RequestFn };\nexport { request };\n","// src/api/EventsAPI.ts\n\nimport { CohostEndpoint } from '../endpoint';\nimport { Attendee3, EventProfile, PaginatedRequest, PaginatedResponse, Ticket } from '../../types/index';\nimport { paginatedOptions } from '../http/request';\n\n/**\n * Provides methods to interact with the Cohost Events API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const list = await client.events.list();\n * const event = await client.events.fetch('event-id');\n * const tickets = await client.events.tickets('event-id');\n * ```\n */\nexport class EventsAPI extends CohostEndpoint {\n\n /**\n * Fetch a list of all events.\n * \n * @returns A Promise resolving to an array of event objects\n * @throws Will throw an error if the request fails\n * \n * @todo Implement pagination and filtering options\n */\n async list() {\n return this.request<EventProfile[]>('/events');\n }\n\n\n /**\n * Fetch a single event by ID.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to the event object\n * @throws Will throw an error if the request fails or the event is not found\n */\n async fetch(id: string) {\n return this.request<EventProfile>(`/events/${id}`);\n }\n\n\n\n /**\n * List all tickets associated with a specific event.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to an array of ticket objects\n * @throws Will throw an error if the request fails or the event does not exist\n */\n async tickets(id: string) {\n return this.request<Ticket[]>(`/events/${id}/tickets`);\n }\n\n /**\n * List attendees in the event.\n *\n * Requires: valid authentication token. This endpoint is not public.\n * \n * @param id - The ID of the event.\n * @returns List of tickets (attendees) for the event.\n */\n async attendees(id: string, filters?: PaginatedRequest<any>) {\n return this.request<PaginatedResponse<Attendee3>>(`/events/${id}/attendees`, paginatedOptions(filters));\n }\n\n \n\n}\n","import { CohostEndpoint } from '../endpoint';\n\n/**\n * Provides methods to interact with the Cohost Orders API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const order = await client.orders.fetch('order-id', 'user-id');\n * const list = await client.orders.list({ status: 'completed' });\n * ```\n */\nexport class OrdersAPI extends CohostEndpoint {\n\n /**\n * Fetch a single order by ID.\n * \n * @param id - The unique identifier of the order\n * @param uid - The unique user ID associated with the order (currently unused but reserved for future auth context)\n * @returns A Promise resolving to the order object\n * @throws Will throw an error if the request fails or the order is not found\n */\n async fetch(id: string, uid: string) {\n // uid is reserved for future scoped access/auth features\n return this.request(`/orders/${id}?uid=${uid}`);\n }\n\n /**\n * List orders with optional filters.\n * \n * @param filters - Optional filters to apply when retrieving orders\n * @returns A Promise resolving to an array of order summaries\n * @throws Will throw an error if the request fails\n */\n async list(filters?: {\n status?: string;\n startDate?: string;\n endDate?: string;\n page?: number;\n pageSize?: number;\n }) {\n const query = new URLSearchParams(filters as Record<string, string>).toString();\n return this.request(`/orders${query ? `?${query}` : ''}`);\n }\n}\n","import { CartSession, UpdatableCartSession } from '../../types';\nimport { CohostEndpoint } from '../endpoint';\nimport { FindTablesProps, StartCartSessionInput, ViableTableOption } from '../types/sessions';\n\n/**\n * Provides methods to interact with cart sessions in the Cohost API.\n *\n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const session = await client.sessions.start({ contextId: 'evt_abc123' });\n * ```\n */\nexport class SessionsAPI extends CohostEndpoint {\n\n /**\n * Start a new cart session.\n *\n * @param input - Data to start the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the request fails\n */\n async start(input: StartCartSessionInput) {\n return this.request<CartSession>('/cart/sessions', {\n method: 'POST',\n data: input,\n });\n }\n\n /**\n * Get a cart session by its ID.\n *\n * @param id - The unique session ID\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the session is not found or request fails\n */\n async get(id: string) {\n return this.request<CartSession>(`/cart/sessions/${id}`);\n }\n\n /**\n * Update a cart session.\n *\n * @param id - The ID of the session to update\n * @param input - Data to update the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async update(id: string, input: Partial<UpdatableCartSession>) {\n return this.request<CartSession>(`/cart/sessions/${id}`, {\n method: 'PATCH',\n data: input,\n });\n }\n\n /**\n * Cancel (soft delete) a cart session.\n *\n * @param id - The ID of the session to cancel\n * @returns Nothing if successful\n * \n * @throws Will throw an error if the cancel operation fails\n */\n async cancel(id: string) {\n return this.request<void>(`/cart/sessions/${id}`, {\n method: 'DELETE',\n });\n }\n\n /**\n * Update an item in the cart session.\n *\n * @param sessionId - The ID of the session\n * @param props - Properties to update\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async updateItem(sessionId: string, props: {\n itemId: string;\n quantity: number;\n options?: {\n [key: string]: any;\n };\n }) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/item`, {\n method: 'POST',\n data: props,\n });\n }\n\n /**\n * Pre-validate the cart session for payment and checkout.\n *\n * @param sessionId - The ID of the cart session\n * @param data - Data required for validation\n * @returns {CartSession} The validated cart session\n * \n * @throws Will throw an error if validation fails\n */\n async preValidate(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/payment/pre-validate`, {\n method: 'POST',\n data: data,\n });\n }\n\n /**\n * Close the cart session, and place the order.\n * \n * @param sessionId - The ID of the session\n * @param data - Data to place the order\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the order placement fails\n */\n async placeOrder(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/place-order`, {\n method: 'POST',\n data: data,\n });\n }\n\n /**\n * Remove an item from the cart session.\n * The same as setting the quantity to 0.\n * \n * @param sessionId - The ID of the cart session\n * @param itemId - The ID of the item to remove\n * @returns {CartSession} The latest cart session\n */\n async deleteItem(sessionId: string, itemId: string) {\n return this.updateItem(sessionId, {\n itemId,\n quantity: 0,\n });\n }\n\n /**\n * Find available table options for a given cart session.\n *\n * @param id - The ID of the cart session\n * @param props - Filter parameters for finding tables\n * @returns {ViableTableOption[]} List of valid table options\n * \n * @throws Will throw an error if the request fails\n */\n async findTables(id: string, props: FindTablesProps): Promise<ViableTableOption[]> {\n return this.request<ViableTableOption[]>(`/cart/tables/find-tables/${id}`, {\n query: {\n ...props,\n }\n });\n }\n\n /**\n * Join a table commitment within an active cart session.\n *\n * @param id - The ID of the cart session\n * @param tableCommitmentId - The table commitment ID to join\n * @returns {CartSession} Updated cart session with joined table\n * \n * @throws Will throw an error if the join operation fails\n */\n async joinTableCommitment(id: string, tableCommitmentId: string): Promise<CartSession> {\n return this.request<CartSession>(`/cart/sessions/${id}/join-table`, {\n method: 'POST',\n data: {\n tableCommitmentId,\n }\n });\n }\n}\n","import { EventsAPI } from './api/events';\nimport { OrdersAPI } from './api/orders';\nimport { SessionsAPI } from './api/sessions';\nimport { apiBaseUrl } from './apiVersion';\nimport { request, RequestFn } from './http/request';\nimport { CohostClientSettings } from './settings';\n\n/**\n * Configuration options for instantiating a CohostClient.\n */\nexport interface CohostClientOptions {\n /** API token used for authenticated requests. */\n token: string;\n\n /** Optional client settings such as debug mode or custom API URL. */\n settings?: CohostClientSettings;\n}\n\n/**\n * CohostClient provides grouped access to various API modules such as Events and Orders.\n */\nexport class CohostClient {\n public readonly events: EventsAPI;\n public readonly orders: OrdersAPI;\n public readonly cart: SessionsAPI;\n\n private readonly baseOptions: CohostClientOptions;\n\n constructor(options: CohostClientOptions, customRequestFn?: RequestFn) {\n this.baseOptions = options;\n\n const { token, settings = {} } = options;\n\n const sharedRequest = customRequestFn ?? request({\n token,\n baseUrl: settings.apiUrl || apiBaseUrl,\n debug: settings.debug,\n });\n\n this.events = new EventsAPI(sharedRequest, settings);\n this.orders = new OrdersAPI(sharedRequest, settings);\n this.cart = new SessionsAPI(sharedRequest, settings);\n }\n\n /**\n * Returns a new CohostClient instance with overridden request behavior\n */\n public requestWithOverrides(overrides: {\n token?: string;\n baseUrl?: string;\n headers?: Record<string, string>;\n }): CohostClient {\n const { token, settings = {} } = this.baseOptions;\n\n const overriddenRequest: RequestFn = (path, options = {}) =>\n request({\n token: overrides.token ?? token,\n baseUrl: overrides.baseUrl ?? settings.apiUrl ?? apiBaseUrl,\n debug: settings.debug,\n })(path, {\n ...options,\n headers: {\n ...(overrides.headers || {}),\n ...(options.headers || {}),\n },\n });\n\n return new CohostClient(\n {\n token: overrides.token ?? token,\n settings: {\n ...settings,\n apiUrl: overrides.baseUrl ?? settings.apiUrl,\n },\n },\n overriddenRequest\n );\n }\n}\n"],"mappings":"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","names":["index_exports","__export","CohostClient","createCohostClient","__toCommonJS","CohostEndpoint","request","settings","__publicField","apiBaseUrl","CohostError","_CohostError","message","props","__publicField","err","defaultSettings","runtimeOverrides","paginatedOptions","req","options","pagination","rest","buildQueryString","input","params","key","value","v","request","token","baseUrl","apiBaseUrl","debug","path","method","data","query","headers","_query","queryString","url","runtimeOverrides","reqHeaders","defaultSettings","body","res","responseBody","message","CohostError","EventsAPI","CohostEndpoint","id","filters","paginatedOptions","OrdersAPI","CohostEndpoint","id","uid","filters","query","SessionsAPI","CohostEndpoint","input","id","sessionId","props","data","itemId","tableCommitmentId","CohostClient","_CohostClient","options","customRequestFn","__publicField","token","settings","sharedRequest","request","apiBaseUrl","EventsAPI","OrdersAPI","SessionsAPI","overrides","overriddenRequest","path","createCohostClient","options","CohostClient"]}
package/dist/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- var U=Object.defineProperty;var B=(r,e,t)=>e in r?U(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t;var s=(r,e,t)=>B(r,typeof e!="symbol"?e+"":e,t);var d=class{constructor(e,t){s(this,"request");s(this,"settings");this.request=e,this.settings=t}};var p="https://api.cohost.com/v1";var l=class r extends Error{constructor(t,n){super(t);s(this,"errorCode");s(this,"statusCode");this.name="CohostError",this.errorCode=n?.errorCode,this.statusCode=n?.statusCode}static fromError(t,n){return new r(t.message,{...n,errorCode:n?.errorCode||t.name})}};var R={baseUrl:"https://api.cohost.vip",headers:{"Content-Type":"application/json"}},O={};var q=(r,e)=>{let{pagination:t,...n}=r;return{query:n,pagination:t,...e}},P=({token:r,baseUrl:e=p,debug:t=!1})=>async function(n,o={}){let{method:i="GET",data:c,query:I,pagination:A,headers:k={}}=o,v={...I,...A},T=v?"?"+new URLSearchParams(Object.entries(v).reduce((g,[E,S])=>(S!==void 0&&(g[E]=String(S)),g),{})).toString():"",x=`${O.baseUrl??e}${n}${T}`,h={...R.headers,...O.headers,...k};r&&(h.Authorization=`Bearer ${r}`);let b=c&&i!=="GET"?JSON.stringify(c):void 0;t&&(console.log(`[Cohost SDK] Request: ${i} ${x}`),b&&console.log("[Cohost SDK] Body:",b),console.log("[Cohost SDK] Headers:",h));let u=await fetch(x,{method:i,headers:h,body:b}),a=u.headers.get("content-type")?.includes("application/json")?await u.json():await u.text();if(!u.ok){let g=typeof a=="string"?a:JSON.stringify(a);throw console.error(`[Cohost SDK] Error: ${g}`,{url:x}),new l(g||u.statusText,{errorCode:u.statusText||"API_ERROR",statusCode:u.status})}return typeof a=="object"&&a!==null&&a.status==="ok"&&"data"in a?a.data:a};var m=class extends d{async list(){return this.request("/events")}async fetch(e){return this.request(`/events/${e}`)}async tickets(e){return this.request(`/events/${e}/tickets`)}async attendees(e,t){return this.request(`/events/${e}/attendees`,q(t))}};var f=class extends d{async fetch(e,t){return this.request(`/orders/${e}?uid=${t}`)}async list(e){let t=new URLSearchParams(e).toString();return this.request(`/orders${t?`?${t}`:""}`)}};var y=class extends d{async start(e){return this.request("/cart/sessions",{method:"POST",data:e})}async get(e){return this.request(`/cart/sessions/${e}`)}async update(e,t){return this.request(`/cart/sessions/${e}`,{method:"PATCH",data:t})}async cancel(e){return this.request(`/cart/sessions/${e}`,{method:"DELETE"})}async updateItem(e,t){return this.request(`/cart/sessions/${e}/item`,{method:"POST",data:t})}async preValidate(e,t){return this.request(`/cart/sessions/${e}/payment/pre-validate`,{method:"POST",data:t})}async placeOrder(e,t){return this.request(`/cart/sessions/${e}/place-order`,{method:"POST",data:t})}async deleteItem(e,t){return this.updateItem(e,{offeringId:t,quantity:0})}};var C=class r{constructor(e,t){s(this,"events");s(this,"orders");s(this,"cart");s(this,"baseOptions");this.baseOptions=e;let{token:n,settings:o={}}=e,i=t??P({token:n,baseUrl:o.apiUrl||p,debug:o.debug});this.events=new m(i,o),this.orders=new f(i,o),this.cart=new y(i,o)}requestWithOverrides(e){let{token:t,settings:n={}}=this.baseOptions,o=(i,c={})=>P({token:e.token??t,baseUrl:e.baseUrl??n.apiUrl??p,debug:n.debug})(i,{...c,headers:{...e.headers||{},...c.headers||{}}});return new r({token:e.token??t,settings:{...n,apiUrl:e.baseUrl??n.apiUrl}},o)}};function ce(r){return new C(r)}export{C as CohostClient,ce as createCohostClient};
1
+ var k=Object.defineProperty;var E=(n,e,t)=>e in n?k(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var o=(n,e,t)=>E(n,typeof e!="symbol"?e+"":e,t);var d=class{constructor(e,t){o(this,"request");o(this,"settings");this.request=e,this.settings=t}};var g="https://api.cohost.com/v1";var p=class n extends Error{constructor(t,r){super(t);o(this,"errorCode");o(this,"statusCode");this.name="CohostError",this.errorCode=r?.errorCode,this.statusCode=r?.statusCode}static fromError(t,r){return new n(t.message,{...r,errorCode:r?.errorCode||t.name})}};var S={baseUrl:"https://api.cohost.vip",headers:{"Content-Type":"application/json"}},b={};var v=(n,e)=>{let{pagination:t,...r}=n;return{query:r,pagination:t,...e}},U=n=>{if(!n)return"";let e=new URLSearchParams;for(let[t,r]of Object.entries(n))r!==void 0&&(Array.isArray(r)?r.forEach(s=>e.append(t,String(s))):e.set(t,String(r)));return e.toString()?`?${e.toString()}`:""},O=({token:n,baseUrl:e=g,debug:t=!1})=>async function(r,s={}){let{method:i="GET",data:c,query:R,pagination:q,headers:I={}}=s,A={...R,...q},T=U(A),C=`${b.baseUrl??e}${r}${T}`,x={...S.headers,...b.headers,...I};n&&(x.Authorization=`Bearer ${n}`);let h=c&&i!=="GET"?JSON.stringify(c):void 0;t&&(console.log(`[Cohost SDK] Request: ${i} ${C}`),h&&console.log("[Cohost SDK] Body:",h),console.log("[Cohost SDK] Headers:",x));let u=await fetch(C,{method:i,headers:x,body:h}),a=u.headers.get("content-type")?.includes("application/json")?await u.json():await u.text();if(!u.ok){let P=typeof a=="string"?a:JSON.stringify(a);throw console.error(`[Cohost SDK] Error: ${P}`,{url:C}),new p(P||u.statusText,{errorCode:u.statusText||"API_ERROR",statusCode:u.status})}return typeof a=="object"&&a!==null&&a.status==="ok"&&"data"in a?a.data:a};var l=class extends d{async list(){return this.request("/events")}async fetch(e){return this.request(`/events/${e}`)}async tickets(e){return this.request(`/events/${e}/tickets`)}async attendees(e,t){return this.request(`/events/${e}/attendees`,v(t))}};var m=class extends d{async fetch(e,t){return this.request(`/orders/${e}?uid=${t}`)}async list(e){let t=new URLSearchParams(e).toString();return this.request(`/orders${t?`?${t}`:""}`)}};var f=class extends d{async start(e){return this.request("/cart/sessions",{method:"POST",data:e})}async get(e){return this.request(`/cart/sessions/${e}`)}async update(e,t){return this.request(`/cart/sessions/${e}`,{method:"PATCH",data:t})}async cancel(e){return this.request(`/cart/sessions/${e}`,{method:"DELETE"})}async updateItem(e,t){return this.request(`/cart/sessions/${e}/item`,{method:"POST",data:t})}async preValidate(e,t){return this.request(`/cart/sessions/${e}/payment/pre-validate`,{method:"POST",data:t})}async placeOrder(e,t){return this.request(`/cart/sessions/${e}/place-order`,{method:"POST",data:t})}async deleteItem(e,t){return this.updateItem(e,{itemId:t,quantity:0})}async findTables(e,t){return this.request(`/cart/tables/find-tables/${e}`,{query:{...t}})}async joinTableCommitment(e,t){return this.request(`/cart/sessions/${e}/join-table`,{method:"POST",data:{tableCommitmentId:t}})}};var y=class n{constructor(e,t){o(this,"events");o(this,"orders");o(this,"cart");o(this,"baseOptions");this.baseOptions=e;let{token:r,settings:s={}}=e,i=t??O({token:r,baseUrl:s.apiUrl||g,debug:s.debug});this.events=new l(i,s),this.orders=new m(i,s),this.cart=new f(i,s)}requestWithOverrides(e){let{token:t,settings:r={}}=this.baseOptions,s=(i,c={})=>O({token:e.token??t,baseUrl:e.baseUrl??r.apiUrl??g,debug:r.debug})(i,{...c,headers:{...e.headers||{},...c.headers||{}}});return new n({token:e.token??t,settings:{...r,apiUrl:e.baseUrl??r.apiUrl}},s)}};function ue(n){return new y(n)}export{y as CohostClient,ue as createCohostClient};
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/endpoint.ts","../src/apiVersion.ts","../src/error/CohostError.ts","../src/settings.ts","../src/http/request.ts","../src/api/events.ts","../src/api/orders.ts","../src/api/sessions.ts","../src/client.ts","../src/index.ts"],"sourcesContent":["import { RequestFn } from \"./http/request\";\nimport { CohostClientSettings } from \"./settings\";\n\n/**\n * Base class for all API endpoint groups within the Cohost SDK.\n * Provides shared access to the configured request function and settings.\n */\nexport class CohostEndpoint {\n /** Shared request function injected from the client */\n protected request: RequestFn;\n\n /** Client settings passed during instantiation */\n protected settings: CohostClientSettings;\n\n /**\n * Constructs a new endpoint group.\n *\n * @param request - The shared request function for performing API calls\n * @param settings - The client-wide settings passed from the parent client\n */\n constructor(request: RequestFn, settings: CohostClientSettings) {\n this.request = request;\n this.settings = settings;\n }\n}\n","export const apiVersion = '0.1.0';\nexport const apiVersionDate = '2025-04-15';\nexport const apiBaseUrl = 'https://api.cohost.com/v1'","\nexport interface CohostErrorProps {\n /**\n * Optional error code.\n * @default undefined\n */\n errorCode?: string;\n\n /**\n * Optional status code.\n * @default undefined\n */\n statusCode?: number;\n};\n\nexport class CohostError extends Error {\n errorCode: string | undefined;\n statusCode: number | undefined;\n\n /**\n * Custom error class for Cohost SDK errors.\n * @param message - The error message.\n */\n constructor(message: string, props?: CohostErrorProps) {\n // Call the parent constructor with the message\n super(message);\n\n // Set the name of the error to \"CohostError\"\n this.name = \"CohostError\";\n\n // Set the error code if provided\n this.errorCode = props?.errorCode;\n // Set the status code if provided\n this.statusCode = props?.statusCode;\n }\n\n static fromError(err: Error, props?: CohostErrorProps): CohostError {\n // Create a new CohostError instance from an existing error\n return new CohostError(err.message, {\n ...props,\n errorCode: props?.errorCode || err.name,\n });\n }\n\n}\n\n\n\n\n","/**\n * Optional settings for customizing the behavior of the CohostClient.\n */\nexport interface CohostClientSettings {\n /** Enable verbose debug output for all API requests. */\n debug?: boolean;\n\n /** Override the default API base URL (defaults to apiBaseUrl). */\n apiUrl?: string;\n}\n\n// settings.ts\nexport const defaultSettings = {\n baseUrl: 'https://api.cohost.vip',\n headers: {\n 'Content-Type': 'application/json',\n },\n};\n\n// In dev or testing, you can override this in the browser or Node\nexport let runtimeOverrides: {\n baseUrl?: string;\n headers?: Record<string, string>;\n} = {};\n\nexport function setSdkOverrides(overrides: typeof runtimeOverrides) {\n runtimeOverrides = overrides;\n}\n\n","import { PaginatedRequest } from \"../../types\";\nimport { apiBaseUrl } from \"../apiVersion\";\nimport { CohostError } from \"../error/CohostError\";\nimport { defaultSettings, runtimeOverrides } from \"../settings\";\nimport { Pagination } from \"../types/pagination\";\n\n/**\n * Options for configuring the request handler.\n */\ninterface RequestProps {\n /** API token for authentication (Bearer token). */\n token: string | null;\n\n /** Base URL of the API (defaults to versioned `apiBaseUrl`). */\n baseUrl?: string;\n\n /** Enable debug logging of requests/responses. */\n debug?: boolean;\n}\n\n/**\n * Supported HTTP methods.\n */\ntype RequestMethod = \"GET\" | \"POST\" | \"PUT\" | \"DELETE\" | \"PATCH\";\n\n\ntype RequestOptions = {\n method?: RequestMethod;\n data?: any;\n query?: Record<string, string | number | boolean | undefined>;\n headers?: Record<string, string>;\n pagination?: Pagination;\n};\n\n\nexport const paginatedOptions = (req: PaginatedRequest<any>, options?: Partial<RequestOptions>): RequestOptions => {\n const { pagination, ...rest } = req;\n\n\n return {\n query: rest,\n pagination,\n ...options,\n };\n}\n\n/**\n * A function that performs a request to the Cohost API.\n * The generic <T> allows you to specify the expected response type.\n */\ntype RequestFn = <T = any>(\n path: string,\n options?: RequestOptions\n) => Promise<T>;\n\n/**\n * Creates a request function configured with authentication and client defaults.\n * The returned function supports generic return typing via <T>.\n */\nconst request = ({ token, baseUrl = apiBaseUrl, debug = false }: RequestProps): RequestFn => {\n return async function <T = any>(\n path: string,\n options: RequestOptions = {}\n ): Promise<T> {\n const { method = \"GET\", data, query, pagination, headers = {} } = options;\n\n let _query = {\n ...query,\n ...pagination,\n };\n\n\n // Construct query string from `query` object\n const queryString = _query\n ? \"?\" +\n new URLSearchParams(\n Object.entries(_query).reduce((acc, [key, value]) => {\n if (value !== undefined) acc[key] = String(value);\n return acc;\n }, {} as Record<string, string>)\n ).toString()\n : \"\";\n\n\n\n const finalBaseUrl = runtimeOverrides.baseUrl ?? baseUrl;\n const url = `${finalBaseUrl}${path}${queryString}`;\n\n // Merge default, runtime, and per-request headers\n const reqHeaders: Record<string, string> = {\n ...defaultSettings.headers,\n ...runtimeOverrides.headers,\n ...headers,\n };\n\n // Add Authorization header if token is present\n if (token) {\n reqHeaders[\"Authorization\"] = `Bearer ${token}`;\n }\n\n // Only send body if method allows it\n const body = data && method !== \"GET\" ? JSON.stringify(data) : undefined;\n\n // Optional debug logging\n if (debug) {\n console.log(`[Cohost SDK] Request: ${method} ${url}`);\n if (body) console.log(`[Cohost SDK] Body:`, body);\n console.log(`[Cohost SDK] Headers:`, reqHeaders);\n }\n\n const res = await fetch(url, {\n method,\n headers: reqHeaders,\n body,\n });\n\n // Parse the response based on content type\n const isJson = res.headers.get(\"content-type\")?.includes(\"application/json\");\n const responseBody = isJson ? await res.json() : await res.text();\n\n // Handle error responses\n if (!res.ok) {\n const message = typeof responseBody === \"string\" ? responseBody : JSON.stringify(responseBody);\n console.error(`[Cohost SDK] Error: ${message}`, {\n url\n });\n\n\n throw new CohostError(message || res.statusText, {\n errorCode: res.statusText || \"API_ERROR\",\n statusCode: res.status,\n });\n\n }\n\n // If wrapped response structure with { status: 'ok', data }, return `data`\n if (\n typeof responseBody === \"object\" &&\n responseBody !== null &&\n (responseBody as any).status === \"ok\" &&\n \"data\" in responseBody\n ) {\n return (responseBody as { data: T }).data;\n }\n\n // Fallback for raw/unwrapped responses\n return responseBody as T;\n };\n};\n\nexport { type RequestProps, type RequestFn };\nexport { request };\n","// src/api/EventsAPI.ts\n\nimport { CohostEndpoint } from '../endpoint';\nimport { Attendee3, EventProfile, PaginatedRequest, PaginatedResponse, Ticket } from '../../types/index';\nimport { paginatedOptions } from '../http/request';\n\n/**\n * Provides methods to interact with the Cohost Events API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const list = await client.events.list();\n * const event = await client.events.fetch('event-id');\n * const tickets = await client.events.tickets('event-id');\n * ```\n */\nexport class EventsAPI extends CohostEndpoint {\n\n /**\n * Fetch a list of all events.\n * \n * @returns A Promise resolving to an array of event objects\n * @throws Will throw an error if the request fails\n * \n * @todo Implement pagination and filtering options\n */\n async list() {\n return this.request<EventProfile[]>('/events');\n }\n\n\n /**\n * Fetch a single event by ID.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to the event object\n * @throws Will throw an error if the request fails or the event is not found\n */\n async fetch(id: string) {\n return this.request<EventProfile>(`/events/${id}`);\n }\n\n\n\n /**\n * List all tickets associated with a specific event.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to an array of ticket objects\n * @throws Will throw an error if the request fails or the event does not exist\n */\n async tickets(id: string) {\n return this.request<Ticket[]>(`/events/${id}/tickets`);\n }\n\n /**\n * List attendees in the event.\n *\n * Requires: valid authentication token. This endpoint is not public.\n * \n * @param id - The ID of the event.\n * @returns List of tickets (attendees) for the event.\n */\n async attendees(id: string, filters?: PaginatedRequest<any>) {\n return this.request<PaginatedResponse<Attendee3>>(`/events/${id}/attendees`, paginatedOptions(filters));\n }\n\n}\n","import { CohostEndpoint } from '../endpoint';\n\n/**\n * Provides methods to interact with the Cohost Orders API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const order = await client.orders.fetch('order-id', 'user-id');\n * const list = await client.orders.list({ status: 'completed' });\n * ```\n */\nexport class OrdersAPI extends CohostEndpoint {\n\n /**\n * Fetch a single order by ID.\n * \n * @param id - The unique identifier of the order\n * @param uid - The unique user ID associated with the order (currently unused but reserved for future auth context)\n * @returns A Promise resolving to the order object\n * @throws Will throw an error if the request fails or the order is not found\n */\n async fetch(id: string, uid: string) {\n // uid is reserved for future scoped access/auth features\n return this.request(`/orders/${id}?uid=${uid}`);\n }\n\n /**\n * List orders with optional filters.\n * \n * @param filters - Optional filters to apply when retrieving orders\n * @returns A Promise resolving to an array of order summaries\n * @throws Will throw an error if the request fails\n */\n async list(filters?: {\n status?: string;\n startDate?: string;\n endDate?: string;\n page?: number;\n pageSize?: number;\n }) {\n const query = new URLSearchParams(filters as Record<string, string>).toString();\n return this.request(`/orders${query ? `?${query}` : ''}`);\n }\n}\n","import { CartSession, UpdatableCartSession } from '../../types';\nimport { CohostEndpoint } from '../endpoint';\nimport { StartCartSessionInput } from '../types/sessions';\n\n/**\n * Provides methods to interact with cart sessions in the Cohost API.\n *\n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const session = await client.sessions.start({ contextId: 'evt_abc123' });\n * ```\n */\nexport class SessionsAPI extends CohostEndpoint {\n\n\n /**\n * Start a new cart session.\n *\n * @param input - Data to start the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the request fails\n */\n async start(input: StartCartSessionInput) {\n return this.request<CartSession>('/cart/sessions', {\n method: 'POST',\n data: input,\n });\n }\n\n /**\n * Get a cart session by its ID.\n *\n * @param id - The unique session ID\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the session is not found or request fails\n */\n async get(id: string) {\n return this.request<CartSession>(`/cart/sessions/${id}`);\n }\n\n /**\n * Update a cart session.\n *\n * @param id - The ID of the session to update\n * @param input - Data to update the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async update(id: string, input: Partial<UpdatableCartSession>) {\n return this.request<CartSession>(`/cart/sessions/${id}`, {\n method: 'PATCH',\n data: input,\n });\n }\n\n /**\n * Cancel (soft delete) a cart session.\n *\n * @param id - The ID of the session to cancel\n * @returns Nothing if successful\n * @throws Will throw an error if the cancel operation fails\n */\n async cancel(id: string) {\n return this.request<void>(`/cart/sessions/${id}`, {\n method: 'DELETE',\n });\n }\n\n\n\n /**\n * Update an item in the cart session.\n *\n * @param sessionId - The ID of the session\n * @param props - Properties to update\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async updateItem(sessionId: string, props: {\n offeringId: string;\n quantity: number;\n }) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/item`, {\n method: 'POST',\n data: props,\n });\n }\n\n\n /**\n * Pre-validate and prepare the cart session for checkout.\n * @param sessionId \n */\n async preValidate(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/payment/pre-validate`, {\n method: 'POST',\n data: data,\n });\n }\n\n\n /**\n * Close the cart session, and place the order.\n * \n * @param sessionId - The ID of the session\n * @param data - Data to place the order\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the order placement fails\n */\n async placeOrder(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/place-order`, {\n method: 'POST',\n data: data,\n });\n }\n\n\n /**\n * Remove an item from the cart session.\n * The same as setting the quantity to 0.\n * \n * @param sessionId \n * @param offeringId \n * @returns {CartSession} The latest cart session\n */\n async deleteItem(sessionId: string, offeringId: string) {\n return this.updateItem(sessionId, {\n offeringId,\n quantity: 0,\n });\n }\n\n}\n","import { EventsAPI } from './api/events';\nimport { OrdersAPI } from './api/orders';\nimport { SessionsAPI } from './api/sessions';\nimport { apiBaseUrl } from './apiVersion';\nimport { request, RequestFn } from './http/request';\nimport { CohostClientSettings } from './settings';\n\n/**\n * Configuration options for instantiating a CohostClient.\n */\nexport interface CohostClientOptions {\n /** API token used for authenticated requests. */\n token: string;\n\n /** Optional client settings such as debug mode or custom API URL. */\n settings?: CohostClientSettings;\n}\n\n/**\n * CohostClient provides grouped access to various API modules such as Events and Orders.\n */\nexport class CohostClient {\n public readonly events: EventsAPI;\n public readonly orders: OrdersAPI;\n public readonly cart: SessionsAPI;\n\n private readonly baseOptions: CohostClientOptions;\n\n constructor(options: CohostClientOptions, customRequestFn?: RequestFn) {\n this.baseOptions = options;\n\n const { token, settings = {} } = options;\n\n const sharedRequest = customRequestFn ?? request({\n token,\n baseUrl: settings.apiUrl || apiBaseUrl,\n debug: settings.debug,\n });\n\n this.events = new EventsAPI(sharedRequest, settings);\n this.orders = new OrdersAPI(sharedRequest, settings);\n this.cart = new SessionsAPI(sharedRequest, settings);\n }\n\n /**\n * Returns a new CohostClient instance with overridden request behavior\n */\n public requestWithOverrides(overrides: {\n token?: string;\n baseUrl?: string;\n headers?: Record<string, string>;\n }): CohostClient {\n const { token, settings = {} } = this.baseOptions;\n\n const overriddenRequest: RequestFn = (path, options = {}) =>\n request({\n token: overrides.token ?? token,\n baseUrl: overrides.baseUrl ?? settings.apiUrl ?? apiBaseUrl,\n debug: settings.debug,\n })(path, {\n ...options,\n headers: {\n ...(overrides.headers || {}),\n ...(options.headers || {}),\n },\n });\n\n return new CohostClient(\n {\n token: overrides.token ?? token,\n settings: {\n ...settings,\n apiUrl: overrides.baseUrl ?? settings.apiUrl,\n },\n },\n overriddenRequest\n );\n }\n}\n","import { CohostClient, CohostClientOptions } from './client';\nexport { type CohostClientSettings } from './settings';\n\n/**\n * Factory method for creating a CohostClient instance.\n * \n * Example:\n * ```ts\n * const client = createCohostClient({ token: 'your-token' });\n * ```\n */\nexport function createCohostClient(options: CohostClientOptions): CohostClient {\n return new CohostClient(options);\n}\n\n\nexport { CohostClient }\n\nexport * from '../types';"],"mappings":"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","names":["CohostEndpoint","request","settings","__publicField","apiBaseUrl","CohostError","_CohostError","message","props","__publicField","err","defaultSettings","runtimeOverrides","paginatedOptions","req","options","pagination","rest","request","token","baseUrl","apiBaseUrl","debug","path","method","data","query","headers","_query","queryString","acc","key","value","url","runtimeOverrides","reqHeaders","defaultSettings","body","res","responseBody","message","CohostError","EventsAPI","CohostEndpoint","id","filters","paginatedOptions","OrdersAPI","CohostEndpoint","id","uid","filters","query","SessionsAPI","CohostEndpoint","input","id","sessionId","props","data","offeringId","CohostClient","_CohostClient","options","customRequestFn","__publicField","token","settings","sharedRequest","request","apiBaseUrl","EventsAPI","OrdersAPI","SessionsAPI","overrides","overriddenRequest","path","createCohostClient","options","CohostClient"]}
1
+ {"version":3,"sources":["../src/endpoint.ts","../src/apiVersion.ts","../src/error/CohostError.ts","../src/settings.ts","../src/http/request.ts","../src/api/events.ts","../src/api/orders.ts","../src/api/sessions.ts","../src/client.ts","../src/index.ts"],"sourcesContent":["import { RequestFn } from \"./http/request\";\nimport { CohostClientSettings } from \"./settings\";\n\n/**\n * Base class for all API endpoint groups within the Cohost SDK.\n * Provides shared access to the configured request function and settings.\n */\nexport class CohostEndpoint {\n /** Shared request function injected from the client */\n protected request: RequestFn;\n\n /** Client settings passed during instantiation */\n protected settings: CohostClientSettings;\n\n /**\n * Constructs a new endpoint group.\n *\n * @param request - The shared request function for performing API calls\n * @param settings - The client-wide settings passed from the parent client\n */\n constructor(request: RequestFn, settings: CohostClientSettings) {\n this.request = request;\n this.settings = settings;\n }\n}\n","export const apiVersion = '0.1.0';\nexport const apiVersionDate = '2025-04-15';\nexport const apiBaseUrl = 'https://api.cohost.com/v1'","\nexport interface CohostErrorProps {\n /**\n * Optional error code.\n * @default undefined\n */\n errorCode?: string;\n\n /**\n * Optional status code.\n * @default undefined\n */\n statusCode?: number;\n};\n\nexport class CohostError extends Error {\n errorCode: string | undefined;\n statusCode: number | undefined;\n\n /**\n * Custom error class for Cohost SDK errors.\n * @param message - The error message.\n */\n constructor(message: string, props?: CohostErrorProps) {\n // Call the parent constructor with the message\n super(message);\n\n // Set the name of the error to \"CohostError\"\n this.name = \"CohostError\";\n\n // Set the error code if provided\n this.errorCode = props?.errorCode;\n // Set the status code if provided\n this.statusCode = props?.statusCode;\n }\n\n static fromError(err: Error, props?: CohostErrorProps): CohostError {\n // Create a new CohostError instance from an existing error\n return new CohostError(err.message, {\n ...props,\n errorCode: props?.errorCode || err.name,\n });\n }\n\n}\n\n\n\n\n","/**\n * Optional settings for customizing the behavior of the CohostClient.\n */\nexport interface CohostClientSettings {\n /** Enable verbose debug output for all API requests. */\n debug?: boolean;\n\n /** Override the default API base URL (defaults to apiBaseUrl). */\n apiUrl?: string;\n}\n\n// settings.ts\nexport const defaultSettings = {\n baseUrl: 'https://api.cohost.vip',\n headers: {\n 'Content-Type': 'application/json',\n },\n};\n\n// In dev or testing, you can override this in the browser or Node\nexport let runtimeOverrides: {\n baseUrl?: string;\n headers?: Record<string, string>;\n} = {};\n\nexport function setSdkOverrides(overrides: typeof runtimeOverrides) {\n runtimeOverrides = overrides;\n}\n\n","import { PaginatedRequest } from \"../../types\";\nimport { apiBaseUrl } from \"../apiVersion\";\nimport { CohostError } from \"../error/CohostError\";\nimport { defaultSettings, runtimeOverrides } from \"../settings\";\nimport { Pagination } from \"../types/pagination\";\n\n/**\n * Options for configuring the request handler.\n */\ninterface RequestProps {\n /** API token for authentication (Bearer token). */\n token: string | null;\n\n /** Base URL of the API (defaults to versioned `apiBaseUrl`). */\n baseUrl?: string;\n\n /** Enable debug logging of requests/responses. */\n debug?: boolean;\n}\n\n/**\n * Supported HTTP methods.\n */\ntype RequestMethod = \"GET\" | \"POST\" | \"PUT\" | \"DELETE\" | \"PATCH\";\n\ntype RequestOptions = {\n method?: RequestMethod;\n data?: any;\n query?: Record<string, string | number | boolean | string[] | undefined>;\n headers?: Record<string, string>;\n pagination?: Pagination;\n};\n\nexport const paginatedOptions = (req: PaginatedRequest<any>, options?: Partial<RequestOptions>): RequestOptions => {\n const { pagination, ...rest } = req;\n return {\n query: rest,\n pagination,\n ...options,\n };\n};\n\n/**\n * Builds a query string from a flat object, supporting array values via repeated keys.\n */\nconst buildQueryString = (\n input?: Record<string, string | number | boolean | string[] | undefined>\n): string => {\n if (!input) return \"\";\n\n const params = new URLSearchParams();\n for (const [key, value] of Object.entries(input)) {\n if (value === undefined) continue;\n if (Array.isArray(value)) {\n value.forEach((v) => params.append(key, String(v)));\n } else {\n params.set(key, String(value));\n }\n }\n return params.toString() ? `?${params.toString()}` : \"\";\n};\n\n/**\n * A function that performs a request to the Cohost API.\n * The generic <T> allows you to specify the expected response type.\n */\ntype RequestFn = <T = any>(\n path: string,\n options?: RequestOptions\n) => Promise<T>;\n\n/**\n * Creates a request function configured with authentication and client defaults.\n * The returned function supports generic return typing via <T>.\n */\nconst request = ({ token, baseUrl = apiBaseUrl, debug = false }: RequestProps): RequestFn => {\n return async function <T = any>(\n path: string,\n options: RequestOptions = {}\n ): Promise<T> {\n const { method = \"GET\", data, query, pagination, headers = {} } = options;\n\n const _query = {\n ...query,\n ...pagination,\n };\n\n const queryString = buildQueryString(_query);\n const finalBaseUrl = runtimeOverrides.baseUrl ?? baseUrl;\n const url = `${finalBaseUrl}${path}${queryString}`;\n\n const reqHeaders: Record<string, string> = {\n ...defaultSettings.headers,\n ...runtimeOverrides.headers,\n ...headers,\n };\n\n if (token) {\n reqHeaders[\"Authorization\"] = `Bearer ${token}`;\n }\n\n const body = data && method !== \"GET\" ? JSON.stringify(data) : undefined;\n\n if (debug) {\n console.log(`[Cohost SDK] Request: ${method} ${url}`);\n if (body) console.log(`[Cohost SDK] Body:`, body);\n console.log(`[Cohost SDK] Headers:`, reqHeaders);\n }\n\n const res = await fetch(url, {\n method,\n headers: reqHeaders,\n body,\n });\n\n const isJson = res.headers.get(\"content-type\")?.includes(\"application/json\");\n const responseBody = isJson ? await res.json() : await res.text();\n\n if (!res.ok) {\n const message = typeof responseBody === \"string\" ? responseBody : JSON.stringify(responseBody);\n console.error(`[Cohost SDK] Error: ${message}`, { url });\n throw new CohostError(message || res.statusText, {\n errorCode: res.statusText || \"API_ERROR\",\n statusCode: res.status,\n });\n }\n\n if (\n typeof responseBody === \"object\" &&\n responseBody !== null &&\n (responseBody as any).status === \"ok\" &&\n \"data\" in responseBody\n ) {\n return (responseBody as { data: T }).data;\n }\n\n return responseBody as T;\n };\n};\n\nexport { type RequestProps, type RequestFn };\nexport { request };\n","// src/api/EventsAPI.ts\n\nimport { CohostEndpoint } from '../endpoint';\nimport { Attendee3, EventProfile, PaginatedRequest, PaginatedResponse, Ticket } from '../../types/index';\nimport { paginatedOptions } from '../http/request';\n\n/**\n * Provides methods to interact with the Cohost Events API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const list = await client.events.list();\n * const event = await client.events.fetch('event-id');\n * const tickets = await client.events.tickets('event-id');\n * ```\n */\nexport class EventsAPI extends CohostEndpoint {\n\n /**\n * Fetch a list of all events.\n * \n * @returns A Promise resolving to an array of event objects\n * @throws Will throw an error if the request fails\n * \n * @todo Implement pagination and filtering options\n */\n async list() {\n return this.request<EventProfile[]>('/events');\n }\n\n\n /**\n * Fetch a single event by ID.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to the event object\n * @throws Will throw an error if the request fails or the event is not found\n */\n async fetch(id: string) {\n return this.request<EventProfile>(`/events/${id}`);\n }\n\n\n\n /**\n * List all tickets associated with a specific event.\n * \n * @param id - The unique identifier of the event\n * @returns A Promise resolving to an array of ticket objects\n * @throws Will throw an error if the request fails or the event does not exist\n */\n async tickets(id: string) {\n return this.request<Ticket[]>(`/events/${id}/tickets`);\n }\n\n /**\n * List attendees in the event.\n *\n * Requires: valid authentication token. This endpoint is not public.\n * \n * @param id - The ID of the event.\n * @returns List of tickets (attendees) for the event.\n */\n async attendees(id: string, filters?: PaginatedRequest<any>) {\n return this.request<PaginatedResponse<Attendee3>>(`/events/${id}/attendees`, paginatedOptions(filters));\n }\n\n \n\n}\n","import { CohostEndpoint } from '../endpoint';\n\n/**\n * Provides methods to interact with the Cohost Orders API.\n * \n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const order = await client.orders.fetch('order-id', 'user-id');\n * const list = await client.orders.list({ status: 'completed' });\n * ```\n */\nexport class OrdersAPI extends CohostEndpoint {\n\n /**\n * Fetch a single order by ID.\n * \n * @param id - The unique identifier of the order\n * @param uid - The unique user ID associated with the order (currently unused but reserved for future auth context)\n * @returns A Promise resolving to the order object\n * @throws Will throw an error if the request fails or the order is not found\n */\n async fetch(id: string, uid: string) {\n // uid is reserved for future scoped access/auth features\n return this.request(`/orders/${id}?uid=${uid}`);\n }\n\n /**\n * List orders with optional filters.\n * \n * @param filters - Optional filters to apply when retrieving orders\n * @returns A Promise resolving to an array of order summaries\n * @throws Will throw an error if the request fails\n */\n async list(filters?: {\n status?: string;\n startDate?: string;\n endDate?: string;\n page?: number;\n pageSize?: number;\n }) {\n const query = new URLSearchParams(filters as Record<string, string>).toString();\n return this.request(`/orders${query ? `?${query}` : ''}`);\n }\n}\n","import { CartSession, UpdatableCartSession } from '../../types';\nimport { CohostEndpoint } from '../endpoint';\nimport { FindTablesProps, StartCartSessionInput, ViableTableOption } from '../types/sessions';\n\n/**\n * Provides methods to interact with cart sessions in the Cohost API.\n *\n * Usage:\n * ```ts\n * const client = new CohostClient({ token: 'your-token' });\n * const session = await client.sessions.start({ contextId: 'evt_abc123' });\n * ```\n */\nexport class SessionsAPI extends CohostEndpoint {\n\n /**\n * Start a new cart session.\n *\n * @param input - Data to start the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the request fails\n */\n async start(input: StartCartSessionInput) {\n return this.request<CartSession>('/cart/sessions', {\n method: 'POST',\n data: input,\n });\n }\n\n /**\n * Get a cart session by its ID.\n *\n * @param id - The unique session ID\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the session is not found or request fails\n */\n async get(id: string) {\n return this.request<CartSession>(`/cart/sessions/${id}`);\n }\n\n /**\n * Update a cart session.\n *\n * @param id - The ID of the session to update\n * @param input - Data to update the session\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async update(id: string, input: Partial<UpdatableCartSession>) {\n return this.request<CartSession>(`/cart/sessions/${id}`, {\n method: 'PATCH',\n data: input,\n });\n }\n\n /**\n * Cancel (soft delete) a cart session.\n *\n * @param id - The ID of the session to cancel\n * @returns Nothing if successful\n * \n * @throws Will throw an error if the cancel operation fails\n */\n async cancel(id: string) {\n return this.request<void>(`/cart/sessions/${id}`, {\n method: 'DELETE',\n });\n }\n\n /**\n * Update an item in the cart session.\n *\n * @param sessionId - The ID of the session\n * @param props - Properties to update\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the update fails\n */\n async updateItem(sessionId: string, props: {\n itemId: string;\n quantity: number;\n options?: {\n [key: string]: any;\n };\n }) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/item`, {\n method: 'POST',\n data: props,\n });\n }\n\n /**\n * Pre-validate the cart session for payment and checkout.\n *\n * @param sessionId - The ID of the cart session\n * @param data - Data required for validation\n * @returns {CartSession} The validated cart session\n * \n * @throws Will throw an error if validation fails\n */\n async preValidate(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/payment/pre-validate`, {\n method: 'POST',\n data: data,\n });\n }\n\n /**\n * Close the cart session, and place the order.\n * \n * @param sessionId - The ID of the session\n * @param data - Data to place the order\n * @returns {CartSession} The latest cart session\n * \n * @throws Will throw an error if the order placement fails\n */\n async placeOrder(sessionId: string, data: any) {\n return this.request<CartSession>(`/cart/sessions/${sessionId}/place-order`, {\n method: 'POST',\n data: data,\n });\n }\n\n /**\n * Remove an item from the cart session.\n * The same as setting the quantity to 0.\n * \n * @param sessionId - The ID of the cart session\n * @param itemId - The ID of the item to remove\n * @returns {CartSession} The latest cart session\n */\n async deleteItem(sessionId: string, itemId: string) {\n return this.updateItem(sessionId, {\n itemId,\n quantity: 0,\n });\n }\n\n /**\n * Find available table options for a given cart session.\n *\n * @param id - The ID of the cart session\n * @param props - Filter parameters for finding tables\n * @returns {ViableTableOption[]} List of valid table options\n * \n * @throws Will throw an error if the request fails\n */\n async findTables(id: string, props: FindTablesProps): Promise<ViableTableOption[]> {\n return this.request<ViableTableOption[]>(`/cart/tables/find-tables/${id}`, {\n query: {\n ...props,\n }\n });\n }\n\n /**\n * Join a table commitment within an active cart session.\n *\n * @param id - The ID of the cart session\n * @param tableCommitmentId - The table commitment ID to join\n * @returns {CartSession} Updated cart session with joined table\n * \n * @throws Will throw an error if the join operation fails\n */\n async joinTableCommitment(id: string, tableCommitmentId: string): Promise<CartSession> {\n return this.request<CartSession>(`/cart/sessions/${id}/join-table`, {\n method: 'POST',\n data: {\n tableCommitmentId,\n }\n });\n }\n}\n","import { EventsAPI } from './api/events';\nimport { OrdersAPI } from './api/orders';\nimport { SessionsAPI } from './api/sessions';\nimport { apiBaseUrl } from './apiVersion';\nimport { request, RequestFn } from './http/request';\nimport { CohostClientSettings } from './settings';\n\n/**\n * Configuration options for instantiating a CohostClient.\n */\nexport interface CohostClientOptions {\n /** API token used for authenticated requests. */\n token: string;\n\n /** Optional client settings such as debug mode or custom API URL. */\n settings?: CohostClientSettings;\n}\n\n/**\n * CohostClient provides grouped access to various API modules such as Events and Orders.\n */\nexport class CohostClient {\n public readonly events: EventsAPI;\n public readonly orders: OrdersAPI;\n public readonly cart: SessionsAPI;\n\n private readonly baseOptions: CohostClientOptions;\n\n constructor(options: CohostClientOptions, customRequestFn?: RequestFn) {\n this.baseOptions = options;\n\n const { token, settings = {} } = options;\n\n const sharedRequest = customRequestFn ?? request({\n token,\n baseUrl: settings.apiUrl || apiBaseUrl,\n debug: settings.debug,\n });\n\n this.events = new EventsAPI(sharedRequest, settings);\n this.orders = new OrdersAPI(sharedRequest, settings);\n this.cart = new SessionsAPI(sharedRequest, settings);\n }\n\n /**\n * Returns a new CohostClient instance with overridden request behavior\n */\n public requestWithOverrides(overrides: {\n token?: string;\n baseUrl?: string;\n headers?: Record<string, string>;\n }): CohostClient {\n const { token, settings = {} } = this.baseOptions;\n\n const overriddenRequest: RequestFn = (path, options = {}) =>\n request({\n token: overrides.token ?? token,\n baseUrl: overrides.baseUrl ?? settings.apiUrl ?? apiBaseUrl,\n debug: settings.debug,\n })(path, {\n ...options,\n headers: {\n ...(overrides.headers || {}),\n ...(options.headers || {}),\n },\n });\n\n return new CohostClient(\n {\n token: overrides.token ?? token,\n settings: {\n ...settings,\n apiUrl: overrides.baseUrl ?? settings.apiUrl,\n },\n },\n overriddenRequest\n );\n }\n}\n","import { CohostClient, CohostClientOptions } from './client';\nexport { type CohostClientSettings } from './settings';\n\n/**\n * Factory method for creating a CohostClient instance.\n * \n * Example:\n * ```ts\n * const client = createCohostClient({ token: 'your-token' });\n * ```\n */\nexport function createCohostClient(options: CohostClientOptions): CohostClient {\n return new CohostClient(options);\n}\n\n\nexport { CohostClient }\n\nexport * from '../types';"],"mappings":"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","names":["CohostEndpoint","request","settings","__publicField","apiBaseUrl","CohostError","_CohostError","message","props","__publicField","err","defaultSettings","runtimeOverrides","paginatedOptions","req","options","pagination","rest","buildQueryString","input","params","key","value","v","request","token","baseUrl","apiBaseUrl","debug","path","method","data","query","headers","_query","queryString","url","runtimeOverrides","reqHeaders","defaultSettings","body","res","responseBody","message","CohostError","EventsAPI","CohostEndpoint","id","filters","paginatedOptions","OrdersAPI","CohostEndpoint","id","uid","filters","query","SessionsAPI","CohostEndpoint","input","id","sessionId","props","data","itemId","tableCommitmentId","CohostClient","_CohostClient","options","customRequestFn","__publicField","token","settings","sharedRequest","request","apiBaseUrl","EventsAPI","OrdersAPI","SessionsAPI","overrides","overriddenRequest","path","createCohostClient","options","CohostClient"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cohostvip/cohost-node",
3
- "version": "0.0.12",
3
+ "version": "0.1.1",
4
4
  "description": "Cohost API wrapper",
5
5
  "main": "dist/index.mjs",
6
6
  "module": "dist/index.mjs",