Pecuario.Backend

<back to all web services

CreateFarm

Requires Authentication
The following routes are available for this service:
POST/api/v1/farms
import 'package:servicestack/servicestack.dart';

class Status implements IConvertible
{
    String? message;
    int? statusCode;

    Status({this.message,this.statusCode});
    Status.fromJson(Map<String, dynamic> json) { fromMap(json); }

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

    Map<String, dynamic> toJson() => {
        'message': message,
        'statusCode': statusCode
    };

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

class BaseResponse implements IConvertible
{
    Status? status;

    BaseResponse({this.status});
    BaseResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        status = JsonConverters.fromJson(json['status'],'Status',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'status': JsonConverters.toJson(status,'Status',context!)
    };

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

class CreateFarmResponse extends BaseResponse implements IConvertible
{
    CreateFarmResponse();
    CreateFarmResponse.fromJson(Map<String, dynamic> json) : super.fromJson(json);
    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson();
    getTypeName() => "CreateFarmResponse";
    TypeContext? context = _ctx;
}

class CreateFarm implements IPost, IConvertible
{
    String? name;
    int? regionId;
    int? measurementUnitId;
    double? area;

    CreateFarm({this.name,this.regionId,this.measurementUnitId,this.area});
    CreateFarm.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        name = json['name'];
        regionId = json['regionId'];
        measurementUnitId = json['measurementUnitId'];
        area = JsonConverters.toDouble(json['area']);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'name': name,
        'regionId': regionId,
        'measurementUnitId': measurementUnitId,
        'area': area
    };

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

TypeContext _ctx = TypeContext(library: 'pecuario_backend.develsystems.com', types: <String, TypeInfo> {
    'Status': TypeInfo(TypeOf.Class, create:() => Status()),
    'BaseResponse': TypeInfo(TypeOf.Class, create:() => BaseResponse()),
    'CreateFarmResponse': TypeInfo(TypeOf.Class, create:() => CreateFarmResponse()),
    'CreateFarm': TypeInfo(TypeOf.Class, create:() => CreateFarm()),
});

Dart CreateFarm DTOs

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

HTTP + CSV

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

POST /api/v1/farms HTTP/1.1 
Host: pecuario-backend.develsystems.com 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"name":"String","regionId":0,"measurementUnitId":0,"area":0}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length

{}