ClubReady Api

<back to all web services

ClassRosterRequest

The following routes are available for this service:
GET/scheduling/class-rosterGet booked and waitlisted users for a class.

export class ApiDtoBase
{
    public ApiKey: string;
    public StoreId?: number;
    public ChainId?: number;

    public constructor(init?: Partial<ApiDtoBase>) { (Object as any).assign(this, init); }
}

export class ClassRosterRequestDto extends ApiDtoBase
{
    public ClassScheduleId: number;

    public constructor(init?: Partial<ClassRosterRequestDto>) { super(init); (Object as any).assign(this, init); }
}

export enum RestrictedResourceType
{
    Store = 'Store',
    Chain = 'Chain',
    User = 'User',
    Undefined = 'Undefined',
}

export class ClassRosterRequest extends ClassRosterRequestDto implements IRestrictedApiRequest
{
    /**
    * Api Key - grants access to resources
    */
    // @ApiMember(DataType="string", Description="Api Key - grants access to resources", IsRequired=true, Name="ApiKey", ParameterType="query")
    public ApiKey: string;

    /**
    * Store Id or Chain Id is required
    */
    // @ApiMember(DataType="integer", Description="Store Id or Chain Id is required", Name="StoreId", ParameterType="query")
    public StoreId?: number;

    /**
    * Store Id or Chain Id is required
    */
    // @ApiMember(DataType="integer", Description="Store Id or Chain Id is required", Name="ChainId", ParameterType="query")
    public ChainId?: number;

    /**
    * Class Schedule ID
    */
    // @ApiMember(DataType="integer", Description="Class Schedule ID", IsRequired=true, Name="ClassScheduleId", ParameterType="query")
    public ClassScheduleId: number;

    public RestrictedId?: number;
    public RestrictedResourceType: RestrictedResourceType;

    public constructor(init?: Partial<ClassRosterRequest>) { super(init); (Object as any).assign(this, init); }
}

export class ApiResponseBase
{
    public Success: boolean;
    public Message: string;

    public constructor(init?: Partial<ApiResponseBase>) { (Object as any).assign(this, init); }
}

export enum ClassRosterCreditType
{
    Uninitialized = 0,
    PaidCredit = 1,
    FreeCredit = 2,
    AmenityCredit = 3,
    MembershipTypeCredit = 4,
    ClassPassCredit = 5,
    Error = -1,
}

export class ClassRosterItem
{
    public BookingId: number;
    public UserId: number;
    public FirstName: string;
    public LastName: string;
    public Email: string;
    public Phone: string;
    public BookingMade: string;
    public FirstTimeBooking: boolean;
    public PackageName: string;
    public PackageId?: number;
    public LeadTypeName: string;
    public LeadTypeId?: number;
    public IsMember: boolean;
    public MemberExpiration?: string;
    public CreditType: ClassRosterCreditType;
    public CreditsRemaining: number;
    public NextCreditExpiration?: string;
    public BookingStatusId?: number;
    public BookingStatusDescription: string;

    public constructor(init?: Partial<ClassRosterItem>) { (Object as any).assign(this, init); }
}

export class ClassRosterResponseDto extends ApiResponseBase
{
    public ClassRoster: ClassRosterItem[];
    public WaitList: ClassRosterItem[];

    public constructor(init?: Partial<ClassRosterResponseDto>) { super(init); (Object as any).assign(this, init); }
}

export class ClassRosterResponse extends ClassRosterResponseDto
{
    public Success: boolean;
    public Message: string;
    public ClassDate: string;
    public FreeSpots: number;
    public MaxSpots: number;
    public TotalBooked: number;
    public LocationType: string;
    public VirtualLink: string;
    public ClassRoster: ClassRosterItem[];
    public WaitList: ClassRosterItem[];

    public constructor(init?: Partial<ClassRosterResponse>) { super(init); (Object as any).assign(this, init); }
}

TypeScript ClassRosterRequest DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json

To embed the response in a jsonp callback, append ?callback=myCallback

HTTP + JSON

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

GET /scheduling/class-roster HTTP/1.1 
Host: clubready.com 
Accept: application/json
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"Success":false,"Message":"String","ClassDate":"0001-01-01T00:00:00.0000000","FreeSpots":0,"MaxSpots":0,"TotalBooked":0,"LocationType":"String","VirtualLink":"String","ClassRoster":[{"BookingId":0,"UserId":0,"FirstName":"String","LastName":"String","Email":"String","Phone":"String","BookingMade":"0001-01-01T00:00:00.0000000","FirstTimeBooking":false,"PackageName":"String","PackageId":0,"LeadTypeName":"String","LeadTypeId":0,"IsMember":false,"MemberExpiration":"0001-01-01T00:00:00.0000000","CreditType":"Uninitialized","CreditsRemaining":0,"NextCreditExpiration":"0001-01-01T00:00:00.0000000","BookingStatusId":0,"BookingStatusDescription":"String"}],"WaitList":[{"BookingId":0,"UserId":0,"FirstName":"String","LastName":"String","Email":"String","Phone":"String","BookingMade":"0001-01-01T00:00:00.0000000","FirstTimeBooking":false,"PackageName":"String","PackageId":0,"LeadTypeName":"String","LeadTypeId":0,"IsMember":false,"MemberExpiration":"0001-01-01T00:00:00.0000000","CreditType":"Uninitialized","CreditsRemaining":0,"NextCreditExpiration":"0001-01-01T00:00:00.0000000","BookingStatusId":0,"BookingStatusDescription":"String"}]}