Requires any of the roles: | bookingsupplier-administrator-write, superadmin |
POST | /support/cases/{Id}/comments | Add a new support case comment | Add a new support case comment to the support case with the prvoided id for the currently logged in user, only administrators are allowed to add support cases. |
---|
import 'package:servicestack/servicestack.dart';
class SupportCaseCommentsResponse implements IConvertible
{
/**
* The case id
*/
// @ApiMember(Description="The case id")
int? SupportCaseId;
/**
* The comments id
*/
// @ApiMember(Description="The comments id")
int? Id;
/**
* The case comment
*/
// @ApiMember(Description="The case comment")
String? Comment;
/**
* The case comment created by
*/
// @ApiMember(Description="The case comment created by")
String? CreatedBy;
/**
* The case comment created date
*/
// @ApiMember(Description="The case comment created date")
DateTime? Created;
SupportCaseCommentsResponse({this.SupportCaseId,this.Id,this.Comment,this.CreatedBy,this.Created});
SupportCaseCommentsResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
SupportCaseId = json['SupportCaseId'];
Id = json['Id'];
Comment = json['Comment'];
CreatedBy = json['CreatedBy'];
Created = JsonConverters.fromJson(json['Created'],'DateTime',context!);
return this;
}
Map<String, dynamic> toJson() => {
'SupportCaseId': SupportCaseId,
'Id': Id,
'Comment': Comment,
'CreatedBy': CreatedBy,
'Created': JsonConverters.toJson(Created,'DateTime',context!)
};
getTypeName() => "SupportCaseCommentsResponse";
TypeContext? context = _ctx;
}
// @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401)
// @ApiResponse(Description="You have too low privilegies to call this service", StatusCode=403)
// @ValidateRequest(Validator="IsAuthenticated")
class AddSupportCaseComment implements ISupportCase, IConvertible
{
/**
* Enter the company id, if blank company id and you are an admin, your company id will be used.
*/
// @ApiMember(Description="Enter the company id, if blank company id and you are an admin, your company id will be used.")
String? CompanyId;
/**
* The support case id
*/
// @ApiMember(Description="The support case id", IsRequired=true, ParameterType="path")
int? Id;
/**
* The case comment.
*/
// @ApiMember(Description="The case comment.")
String? Comment;
AddSupportCaseComment({this.CompanyId,this.Id,this.Comment});
AddSupportCaseComment.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
CompanyId = json['CompanyId'];
Id = json['Id'];
Comment = json['Comment'];
return this;
}
Map<String, dynamic> toJson() => {
'CompanyId': CompanyId,
'Id': Id,
'Comment': Comment
};
getTypeName() => "AddSupportCaseComment";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'api.bokamera.se', types: <String, TypeInfo> {
'SupportCaseCommentsResponse': TypeInfo(TypeOf.Class, create:() => SupportCaseCommentsResponse()),
'AddSupportCaseComment': TypeInfo(TypeOf.Class, create:() => AddSupportCaseComment()),
});
Dart AddSupportCaseComment 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
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /support/cases/{Id}/comments HTTP/1.1
Host: api.bokamera.se
Accept: application/json
Content-Type: application/json
Content-Length: length
{"CompanyId":"00000000-0000-0000-0000-000000000000","Id":0,"Comment":"String"}
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"SupportCaseId":0,"Id":0,"Comment":"String","CreatedBy":"String"}