#Script Pages

<back to all web services

QueryCustomers

import java.math.*;
import java.util.*;
import net.servicestack.client.*;
import com.google.gson.annotations.*;
import com.google.gson.reflect.*;

public class dtos
{

    public static class QueryCustomers extends QueryDb<Customer>
    {
        public String customerId = null;
        public String companyNameContains = null;
        public ArrayList<String> countryIn = null;
        
        public String getCustomerId() { return customerId; }
        public QueryCustomers setCustomerId(String value) { this.customerId = value; return this; }
        public String getCompanyNameContains() { return companyNameContains; }
        public QueryCustomers setCompanyNameContains(String value) { this.companyNameContains = value; return this; }
        public ArrayList<String> getCountryIn() { return countryIn; }
        public QueryCustomers setCountryIn(ArrayList<String> value) { this.countryIn = value; return this; }
    }

    public static class QueryDb<T> extends QueryBase
    {
        
    }

    @DataContract
    public static class QueryBase
    {
        @DataMember(Order=1)
        public Integer skip = null;

        @DataMember(Order=2)
        public Integer take = null;

        @DataMember(Order=3)
        public String orderBy = null;

        @DataMember(Order=4)
        public String orderByDesc = null;

        @DataMember(Order=5)
        public String include = null;

        @DataMember(Order=6)
        public String fields = null;

        @DataMember(Order=7)
        public HashMap<String,String> meta = null;
        
        public Integer getSkip() { return skip; }
        public QueryBase setSkip(Integer value) { this.skip = value; return this; }
        public Integer getTake() { return take; }
        public QueryBase setTake(Integer value) { this.take = value; return this; }
        public String getOrderBy() { return orderBy; }
        public QueryBase setOrderBy(String value) { this.orderBy = value; return this; }
        public String getOrderByDesc() { return orderByDesc; }
        public QueryBase setOrderByDesc(String value) { this.orderByDesc = value; return this; }
        public String getInclude() { return include; }
        public QueryBase setInclude(String value) { this.include = value; return this; }
        public String getFields() { return fields; }
        public QueryBase setFields(String value) { this.fields = value; return this; }
        public HashMap<String,String> getMeta() { return meta; }
        public QueryBase setMeta(HashMap<String,String> value) { this.meta = value; return this; }
    }

    public static class Customer
    {
        public String customerId = null;
        public String companyName = null;
        public String address = null;
        public String city = null;
        public String region = null;
        public String postalCode = null;
        public String country = null;
        public String phone = null;
        public String fax = null;
        public ArrayList<Order> orders = null;
        
        public String getCustomerId() { return customerId; }
        public Customer setCustomerId(String value) { this.customerId = value; return this; }
        public String getCompanyName() { return companyName; }
        public Customer setCompanyName(String value) { this.companyName = value; return this; }
        public String getAddress() { return address; }
        public Customer setAddress(String value) { this.address = value; return this; }
        public String getCity() { return city; }
        public Customer setCity(String value) { this.city = value; return this; }
        public String getRegion() { return region; }
        public Customer setRegion(String value) { this.region = value; return this; }
        public String getPostalCode() { return postalCode; }
        public Customer setPostalCode(String value) { this.postalCode = value; return this; }
        public String getCountry() { return country; }
        public Customer setCountry(String value) { this.country = value; return this; }
        public String getPhone() { return phone; }
        public Customer setPhone(String value) { this.phone = value; return this; }
        public String getFax() { return fax; }
        public Customer setFax(String value) { this.fax = value; return this; }
        public ArrayList<Order> getOrders() { return orders; }
        public Customer setOrders(ArrayList<Order> value) { this.orders = value; return this; }
    }

    public static class Order
    {
        public Integer orderId = null;
        public String customerId = null;
        public Date orderDate = null;
        public Double total = null;
        
        public Integer getOrderId() { return orderId; }
        public Order setOrderId(Integer value) { this.orderId = value; return this; }
        public String getCustomerId() { return customerId; }
        public Order setCustomerId(String value) { this.customerId = value; return this; }
        public Date getOrderDate() { return orderDate; }
        public Order setOrderDate(Date value) { this.orderDate = value; return this; }
        public Double getTotal() { return total; }
        public Order setTotal(Double value) { this.total = value; return this; }
    }

    @DataContract
    public static class QueryResponse<Customer>
    {
        @DataMember(Order=1)
        public Integer offset = null;

        @DataMember(Order=2)
        public Integer total = null;

        @DataMember(Order=3)
        public ArrayList<Customer> results = null;

        @DataMember(Order=4)
        public HashMap<String,String> meta = null;

        @DataMember(Order=5)
        public ResponseStatus responseStatus = null;
        
        public Integer getOffset() { return offset; }
        public QueryResponse<Customer> setOffset(Integer value) { this.offset = value; return this; }
        public Integer getTotal() { return total; }
        public QueryResponse<Customer> setTotal(Integer value) { this.total = value; return this; }
        public ArrayList<Customer> getResults() { return results; }
        public QueryResponse<Customer> setResults(ArrayList<Customer> value) { this.results = value; return this; }
        public HashMap<String,String> getMeta() { return meta; }
        public QueryResponse<Customer> setMeta(HashMap<String,String> value) { this.meta = value; return this; }
        public ResponseStatus getResponseStatus() { return responseStatus; }
        public QueryResponse<Customer> setResponseStatus(ResponseStatus value) { this.responseStatus = value; return this; }
    }

}

Java QueryCustomers 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 /csv/reply/QueryCustomers HTTP/1.1 
Host: sharpscript.net 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"customerId":"String","companyNameContains":"String","countryIn":["String"],"skip":0,"take":0,"orderBy":"String","orderByDesc":"String","include":"String","fields":"String","meta":{"String":"String"}}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length

{"offset":0,"total":0,"results":[{"customerId":"String","companyName":"String","address":"String","city":"String","region":"String","postalCode":"String","country":"String","phone":"String","fax":"String","orders":[{"orderId":0,"customerId":"String","orderDate":"\/Date(-62135596800000-0000)\/","total":0}]}],"meta":{"String":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}