| Requires any of the roles: | bookingsupplier-administrator-write, superadmin | 
| POST | /news | Add a news item | Add a news item to the company of the currently logged in user, only administrators are allowed to add news items. | 
|---|
import 'package:servicestack/servicestack.dart';
class NewsItemQueryResponse implements IConvertible
{
    /**
    * The news item id
    */
    // @ApiMember(Description="The news item id")
    int? Id;
    /**
    * Heading of the news item
    */
    // @ApiMember(Description="Heading of the news item")
    String? Heading;
    /**
    * Body of the news item
    */
    // @ApiMember(Description="Body of the news item")
    String? Body;
    /**
    * Url to a image associated with the news
    */
    // @ApiMember(Description="Url to a image associated with the news")
    Uri? ImageUrl;
    /**
    * The timestamp from which the newsitem should be visible from
    */
    // @ApiMember(Description="The timestamp from which the newsitem should be visible from", IsRequired=true)
    DateTime? From;
    /**
    * The timestamp to which the newsitem should be visible to
    */
    // @ApiMember(Description="The timestamp to which the newsitem should be visible to", IsRequired=true)
    DateTime? To;
    /**
    * The timestamp when news was created
    */
    // @ApiMember(Description="The timestamp when news was created", IsRequired=true)
    DateTime? Created;
    ResponseStatus? ResponseStatus;
    NewsItemQueryResponse({this.Id,this.Heading,this.Body,this.ImageUrl,this.From,this.To,this.Created,this.ResponseStatus});
    NewsItemQueryResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
    fromMap(Map<String, dynamic> json) {
        Id = json['Id'];
        Heading = json['Heading'];
        Body = json['Body'];
        ImageUrl = JsonConverters.fromJson(json['ImageUrl'],'Uri',context!);
        From = JsonConverters.fromJson(json['From'],'DateTime',context!);
        To = JsonConverters.fromJson(json['To'],'DateTime',context!);
        Created = JsonConverters.fromJson(json['Created'],'DateTime',context!);
        ResponseStatus = JsonConverters.fromJson(json['ResponseStatus'],'ResponseStatus',context!);
        return this;
    }
    Map<String, dynamic> toJson() => {
        'Id': Id,
        'Heading': Heading,
        'Body': Body,
        'ImageUrl': JsonConverters.toJson(ImageUrl,'Uri',context!),
        'From': JsonConverters.toJson(From,'DateTime',context!),
        'To': JsonConverters.toJson(To,'DateTime',context!),
        'Created': JsonConverters.toJson(Created,'DateTime',context!),
        'ResponseStatus': JsonConverters.toJson(ResponseStatus,'ResponseStatus',context!)
    };
    getTypeName() => "NewsItemQueryResponse";
    TypeContext? context = _ctx;
}
// @ValidateRequest(Validator="IsAuthenticated")
class CreateNewsItem implements ICompany, IConvertible
{
    /**
    * The company id, if empty will use the company id for the user you are logged in with.
    */
    // @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.")
    String? CompanyId;
    /**
    * The news item header, keep this short and concise
    */
    // @ApiMember(Description="The news item header, keep this short and concise", IsRequired=true)
    String? Heading;
    /**
    * The news body text
    */
    // @ApiMember(Description="The news body text", IsRequired=true)
    String? Body;
    /**
    * Valid url to a image associated with the news
    */
    // @ApiMember(Description="Valid url to a image associated with the news")
    Uri? ImageUrl;
    /**
    * The timestamp from which the newsitem should be visible from
    */
    // @ApiMember(Description="The timestamp from which the newsitem should be visible from", IsRequired=true)
    DateTime? From;
    /**
    * The timestamp to which the newsitem should be visible to
    */
    // @ApiMember(Description="The timestamp to which the newsitem should be visible to", IsRequired=true)
    DateTime? To;
    CreateNewsItem({this.CompanyId,this.Heading,this.Body,this.ImageUrl,this.From,this.To});
    CreateNewsItem.fromJson(Map<String, dynamic> json) { fromMap(json); }
    fromMap(Map<String, dynamic> json) {
        CompanyId = json['CompanyId'];
        Heading = json['Heading'];
        Body = json['Body'];
        ImageUrl = JsonConverters.fromJson(json['ImageUrl'],'Uri',context!);
        From = JsonConverters.fromJson(json['From'],'DateTime',context!);
        To = JsonConverters.fromJson(json['To'],'DateTime',context!);
        return this;
    }
    Map<String, dynamic> toJson() => {
        'CompanyId': CompanyId,
        'Heading': Heading,
        'Body': Body,
        'ImageUrl': JsonConverters.toJson(ImageUrl,'Uri',context!),
        'From': JsonConverters.toJson(From,'DateTime',context!),
        'To': JsonConverters.toJson(To,'DateTime',context!)
    };
    getTypeName() => "CreateNewsItem";
    TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'testapi.bokamera.se', types: <String, TypeInfo> {
    'NewsItemQueryResponse': TypeInfo(TypeOf.Class, create:() => NewsItemQueryResponse()),
    'Uri': TypeInfo(TypeOf.Class, create:() => Uri()),
    'CreateNewsItem': TypeInfo(TypeOf.Class, create:() => CreateNewsItem()),
});
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /news HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"CompanyId":"00000000-0000-0000-0000-000000000000","Heading":"String","Body":"String"}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length
{"Id":0,"Heading":"String","Body":"String","ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}