BokaMera.API.Host

<back to all web services

CreateWidgetConfigurationSchema

Requires Authentication
Requires the role:superadmin
The following routes are available for this service:
POST/widget/configurationschemaCreate a widget configuration schemaCreates a new schema. SuperAdmin only. Schemas are global and immutable: there is no PUT or DELETE.
namespace BokaMera.API.ServiceModel.Dtos

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

    [<AllowNullLiteral>]
    type WidgetConfigurationSchemaResponse() = 
        member val Id:Int32 = new Int32() with get,set
        member val Version:Int32 = new Int32() with get,set
        member val Schema:Dictionary<String, Object> = null with get,set
        member val CreatedDate:DateTime = new DateTime() with get,set
        member val ResponseStatus:ResponseStatus = null with get,set

    [<ApiResponse(Description="Returned if there is a validation error or the schema is invalid JSON Schema", StatusCode=400)>]
    [<ApiResponse(Description="Returned if a schema with this Version already exists", StatusCode=409)>]
    [<ApiResponse(Description="Returned if the current user is not a SuperAdmin", StatusCode=401)>]
    [<ValidateRequest(Validator="IsAuthenticated")>]
    [<AllowNullLiteral>]
    type CreateWidgetConfigurationSchema() = 
        ///<summary>
        ///The schema version. Must be unique.
        ///</summary>
        [<ApiMember(Description="The schema version. Must be unique.", IsRequired=true)>]
        member val Version:Int32 = new Int32() with get,set

        ///<summary>
        ///The JSON Schema document.
        ///</summary>
        [<ApiMember(Description="The JSON Schema document.", IsRequired=true)>]
        member val Schema:Dictionary<String, Object> = null with get,set

F# CreateWidgetConfigurationSchema DTOs

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

HTTP + OTHER

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

POST /widget/configurationschema HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length

{"Version":0,"Schema":{"String":{}}}
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"Id":0,"Version":0,"Schema":{"String":{}},"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}