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 java.math.*
import java.util.*
import net.servicestack.client.*


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

    var roomType:RoomType? = null
    @Validate(Validator="GreaterThan(0)")
    var roomNumber:Int? = null

    @Validate(Validator="GreaterThan(0)")
    var cost:BigDecimal? = null

    var bookingStartDate:Date? = null
    var bookingEndDate:Date? = null
    var notes:String? = null
}

enum class RoomType
{
    Single,
    Double,
    Queen,
    Twin,
    Suite,
}

@DataContract
open class IdResponse
{
    @DataMember(Order=1)
    var id:String? = null

    @DataMember(Order=2)
    var responseStatus:ResponseStatus? = null
}

Kotlin CreateBooking 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.

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

{"name":"String","roomType":"Single","roomNumber":0,"cost":0,"bookingStartDate":"\/Date(-62135596800000-0000)\/","bookingEndDate":"\/Date(-62135596800000-0000)\/","notes":"String"}
HTTP/1.1 200 OK
Content-Type: application/json
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"}}}