Billiecart API

<back to all web services

CreateBookingRequest

Requires Authentication
Requires the role:manager
The following routes are available for this service:
POST/bookings
namespace Application.Interfaces.Resources

open System
open System.Collections
open System.Collections.Generic
open System.Runtime.Serialization
open ServiceStack
open ServiceStack.DataAnnotations

    [<AllowNullLiteral>]
    type Booking() = 
        member val StartUtc:DateTime = new DateTime() with get,set
        member val EndUtc:DateTime = new DateTime() with get,set
        member val BorrowerId:String = null with get,set
        member val CarId:String = null with get,set
        member val Id:String = null with get,set

    [<AllowNullLiteral>]
    type CreateBookingResponse() = 
        member val ResponseStatus:ResponseStatus = null with get,set
        member val Booking:Booking = null with get,set

    [<AllowNullLiteral>]
    type CreateBookingRequest() = 
        inherit PostOperationTenanted<CreateBookingResponse>()
        member val CarId:String = null with get,set
        member val StartUtc:DateTime = new DateTime() with get,set
        member val EndUtc:Nullable<DateTime> = new Nullable<DateTime>() with get,set

    [<AllowNullLiteral>]
    type PostOperationTenanted<'TResponse>() = 
        inherit PostOperationUnTenanted<TResponse>()
        member val OrganisationId:String = null with get,set

    [<AllowNullLiteral>]
    type PostOperationUnTenanted<'TResponse>() = 
        interface IPost

F# CreateBookingRequest 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: staging-api.billiecart.com.au 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"carId":"String","endUtc":null,"organisationId":"String"}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}},"booking":{"borrowerId":"String","carId":"String","id":"String"}}