BokaMera.API.Host

<back to all web services

AddResource

Requires Authentication
Requires any of the roles:bookingsupplier-administrator-write, superadmin
The following routes are available for this service:
POST/resourcetypes/{Id}/addresourceAdd resource(s) to ResourceTypeAdd resource(s) to ResourceType for the currently logged in user, only administrators are allowed to add resources to ResourceTypes.
import 'package:servicestack/servicestack.dart';

class AddResourceTypeResource implements IConvertible
{
    /**
    * The resource id
    */
    // @ApiMember(Description="The resource id")
    int? Id;

    /**
    * The priority of the resource. If no priority is set it will take random resource when booking a time.
    */
    // @ApiMember(Description="The priority of the resource. If no priority is set it will take random resource when booking a time.")
    int? Priority;

    AddResourceTypeResource({this.Id,this.Priority});
    AddResourceTypeResource.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        Id = json['Id'];
        Priority = json['Priority'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'Id': Id,
        'Priority': Priority
    };

    getTypeName() => "AddResourceTypeResource";
    TypeContext? context = _ctx;
}

// @ValidateRequest(Validator="IsAuthenticated")
class AddResource implements IConvertible
{
    /**
    * The company id
    */
    // @ApiMember(Description="The company id", IsRequired=true)
    String? CompanyId;

    /**
    * The ResourceType id
    */
    // @ApiMember(Description="The ResourceType id", IsRequired=true, ParameterType="path")
    int? Id;

    /**
    * The resources to be included
    */
    // @ApiMember(Description="The resources to be included")
    List<AddResourceTypeResource>? Resources;

    AddResource({this.CompanyId,this.Id,this.Resources});
    AddResource.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        CompanyId = json['CompanyId'];
        Id = json['Id'];
        Resources = JsonConverters.fromJson(json['Resources'],'List<AddResourceTypeResource>',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'CompanyId': CompanyId,
        'Id': Id,
        'Resources': JsonConverters.toJson(Resources,'List<AddResourceTypeResource>',context!)
    };

    getTypeName() => "AddResource";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'api.bokamera.se', types: <String, TypeInfo> {
    'AddResourceTypeResource': TypeInfo(TypeOf.Class, create:() => AddResourceTypeResource()),
    'AddResource': TypeInfo(TypeOf.Class, create:() => AddResource()),
    'List<AddResourceTypeResource>': TypeInfo(TypeOf.Class, create:() => <AddResourceTypeResource>[]),
});

Dart AddResource DTOs

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

HTTP + XML

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

POST /resourcetypes/{Id}/addresource HTTP/1.1 
Host: api.bokamera.se 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<AddResource xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/BokaMera.API.ServiceModel.Dtos">
  <CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
  <Id>0</Id>
  <Resources>
    <AddResourceTypeResource>
      <Id>0</Id>
      <Priority>0</Priority>
    </AddResourceTypeResource>
  </Resources>
</AddResource>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<z:anyType xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:z="http://schemas.microsoft.com/2003/10/Serialization/" />