MyApp

<back to all web services

CreateBooking

bookings

Create a new Booking

Requires Authentication
Required role:Employee
The following routes are available for this service:
POST/bookings
import Foundation
import ServiceStack

/**
* Create a new Booking
*/
// @ValidateRequest(Validator="HasRole(`Employee`)")
public class CreateBooking : ICreateDb<Booking>, Codable
{
    /**
    * Name this Booking is for
    */
    // @Validate(Validator="NotEmpty")
    public var name:String

    public var roomType:RoomType
    // @Validate(Validator="GreaterThan(0)")
    public var roomNumber:Int

    // @Validate(Validator="GreaterThan(0)")
    public var cost:Double

    public var bookingStartDate:Date
    public var bookingEndDate:Date?
    public var notes:String

    required public init(){}
}

public enum RoomType : String, Codable
{
    case Single
    case Double
    case Queen
    case Twin
    case Suite
}

// @DataContract
public class IdResponse : Codable
{
    // @DataMember(Order=1)
    public var id:String

    // @DataMember(Order=2)
    public var responseStatus:ResponseStatus

    required public init(){}
}


Swift CreateBooking DTOs

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

HTTP + JSV

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

POST /bookings HTTP/1.1 
Host: vue-vite-api.jamstacks.net 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	name: String,
	roomType: Single,
	roomNumber: 0,
	cost: 0,
	bookingStartDate: 0001-01-01,
	bookingEndDate: 0001-01-01,
	notes: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	id: String,
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}