Refactoring
This commit is contained in:
parent
c344742c70
commit
3136586bd0
|
@ -3,7 +3,7 @@ package org.gcube.grsf.publisher.ckan.record;
|
|||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
public class Fishery extends Record {
|
||||
public class FisheryRecord extends Record {
|
||||
|
||||
@Override
|
||||
public String getType() {
|
|
@ -3,7 +3,7 @@ package org.gcube.grsf.publisher.ckan.record;
|
|||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
public class Stock extends Record {
|
||||
public class StockRecord extends Record {
|
||||
|
||||
@Override
|
||||
public String getType() {
|
|
@ -3,7 +3,7 @@ package org.gcube.grsf.publisher.ckan.record;
|
|||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
public class TraceabilityUnit extends Record {
|
||||
public class TraceabilityUnitRecord extends Record {
|
||||
|
||||
@Override
|
||||
public String getType() {
|
|
@ -15,7 +15,7 @@ import javax.ws.rs.core.Response;
|
|||
import org.gcube.gcat.api.GCatConstants;
|
||||
import org.gcube.grsf.publisher.annotation.PATCH;
|
||||
import org.gcube.grsf.publisher.annotation.PURGE;
|
||||
import org.gcube.grsf.publisher.ckan.record.Fishery;
|
||||
import org.gcube.grsf.publisher.ckan.record.FisheryRecord;
|
||||
|
||||
import com.webcohesion.enunciate.metadata.rs.ResponseCode;
|
||||
import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
||||
|
@ -23,14 +23,14 @@ import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
|||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
@Path(FisheryRESTAPIs.COLLECTION_PATH)
|
||||
public class FisheryRESTAPIs extends BaseRESTAPIs<Fishery> {
|
||||
@Path(Fishery.COLLECTION_PATH)
|
||||
public class Fishery extends BaseRESTAPIs<FisheryRecord> {
|
||||
|
||||
public static final String COLLECTION_PATH = "fishery";
|
||||
public static final String GRSF_RECORD_UUID_PARAMETER = "fishery_record_id";
|
||||
|
||||
public FisheryRESTAPIs() {
|
||||
super(COLLECTION_PATH, GRSF_RECORD_UUID_PARAMETER, Fishery.class);
|
||||
public Fishery() {
|
||||
super(COLLECTION_PATH, GRSF_RECORD_UUID_PARAMETER, FisheryRecord.class);
|
||||
}
|
||||
|
||||
/**
|
|
@ -0,0 +1,267 @@
|
|||
package org.gcube.grsf.publisher.rest;
|
||||
|
||||
import javax.ws.rs.Consumes;
|
||||
import javax.ws.rs.DELETE;
|
||||
import javax.ws.rs.DefaultValue;
|
||||
import javax.ws.rs.GET;
|
||||
import javax.ws.rs.POST;
|
||||
import javax.ws.rs.PUT;
|
||||
import javax.ws.rs.Path;
|
||||
import javax.ws.rs.PathParam;
|
||||
import javax.ws.rs.Produces;
|
||||
import javax.ws.rs.QueryParam;
|
||||
import javax.ws.rs.core.Response;
|
||||
|
||||
import org.gcube.gcat.api.GCatConstants;
|
||||
import org.gcube.grsf.publisher.annotation.PATCH;
|
||||
import org.gcube.grsf.publisher.annotation.PURGE;
|
||||
import org.gcube.grsf.publisher.ckan.record.StockRecord;
|
||||
|
||||
import com.webcohesion.enunciate.metadata.rs.ResponseCode;
|
||||
import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
||||
|
||||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
@Path(Stock.COLLECTION_PATH)
|
||||
public class Stock extends BaseRESTAPIs<StockRecord> {
|
||||
|
||||
public static final String COLLECTION_PATH = "stock";
|
||||
public static final String RECORD_ID_PARAMETER = "stock_record_id";
|
||||
|
||||
public Stock() {
|
||||
super(COLLECTION_PATH, RECORD_ID_PARAMETER, StockRecord.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* <p>
|
||||
* The listing API provides paginated results by using the query parameters limit and offset.<br/>
|
||||
* It returns an array list of string containing the GRSF UUIDs of the records.<br/>
|
||||
* Each name can be used as <code>{stock_record_id}</code> path parameter to manage such a record.
|
||||
* </p>
|
||||
*
|
||||
* <h3>Filtering options</h3>
|
||||
* <p>
|
||||
* The listing method offers options to filter the results, thus enacting to search for records including spatial search (see ext_bbox below).<br/>
|
||||
* </p>
|
||||
*
|
||||
* <h4>Basic Filtering options</h4>
|
||||
* <dl>
|
||||
* <dt>include_private (bool)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:false</em>.<br/>
|
||||
* If True, private records will be included in the results.<br/>
|
||||
* For the sysadmins will be returned all private datasets.<br/>
|
||||
* E.g. <code>/stock?include_private=true</code>
|
||||
* </dd>
|
||||
*
|
||||
* <dt style="margin-top: 5px;">ext_bbox</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:null</em>.<br/>
|
||||
* The coordinates of the upper-right and bottom-left angle of a rectangular to query for.
|
||||
* The form is <code>Lat,Long,Lat,Long</code><br/>
|
||||
* E.g. <code>/stock?limit=10&offset=0&q=Gadus&ext_bbox=-7.535093,49.208494,3.890688,57.372349</code>
|
||||
* returns the first 10 records with 'Gadus' having a spatial coverage in the specified bounding box.
|
||||
* </dd>
|
||||
*
|
||||
* </dl>
|
||||
*
|
||||
* <h4>Filtering options based on Solr query parameters</h4>
|
||||
* <p>
|
||||
* It accepts the following query parameters (a subset of Solr search query parameters, see {@see <a href="https://solrtutorial.com/solr-query-syntax.html">Solr Query Syntax</a>}):
|
||||
* </p>
|
||||
* <dl>
|
||||
* <dt>q (string)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:"*:*"</em><br/>
|
||||
* The solr query.<br/>
|
||||
* E.g. <code>/stock?q=title:Gadus</code> returns the stock records with word "Gadus" in the title.<br/>
|
||||
* E.g. <code>/stock?q=extras_systemtype:Marine Resource</code> returns the GRSF <em>Marine Resource</em> records.
|
||||
* </dd>
|
||||
*
|
||||
* <dt style="margin-top: 5px;">fq (string)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:null</em>.<br/>
|
||||
* Filter query. A query string that limits the query results without influencing their scores.<br/>
|
||||
* E.g. <code>/stock?q=title:Gadus&fq=annotations:test</code> returns with word "Gadus" in the 'title' and the word "test" in the 'Annotations'.
|
||||
* </dd>
|
||||
*
|
||||
* <dt style="margin-top: 5px;">fq_list (list of strings)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:null</em>.<br/>
|
||||
* Additional filter queries to apply.<br/>
|
||||
* E.g. <code>/stock?q=title:Gadus&fq_list=...</code> returns the records with word "Gadus" in the 'title'.
|
||||
* </dd>
|
||||
*
|
||||
* <dt style="margin-top: 5px;">sort (string)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:"relevance asc, metadata_modified desc"</em>.<br/>
|
||||
* Sorting of the search results.<br/>
|
||||
* As per the solr documentation, this is a comma-separated string of field names and sort-orderings.<br/>
|
||||
* E.g. <code>/stock?q=title:Gadus&sort=name+asc</code> returns the records with word "Gadus" in the 'title'
|
||||
* sorting the results by name ascending.
|
||||
* </dd>
|
||||
* <dl>
|
||||
*
|
||||
* <h3>Query results options</h3>
|
||||
* <p>
|
||||
* The result is by default an array list of string containing the GRSF UUIDs of the records.
|
||||
* Anyway, there are two options to get a different results.
|
||||
* </p>
|
||||
* <dl>
|
||||
* <dt>count (bool)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:false</em>.<br/>
|
||||
* If True, it indicates that the result must contains only the total number of records of the query.<br/>
|
||||
* E.g. <code>/stock?limit=10&offset=0&count=true</code>
|
||||
* </dd>
|
||||
*
|
||||
* <dt style="margin-top: 5px;">all_fields (bool)</dt>
|
||||
* <dd>
|
||||
* <em>Optional</em>.<em>Default:false</em>.
|
||||
* If True, the returned array list contains the whole records representation and not only the GRSF UUIDs of the records.</br/>
|
||||
* E.g. <code>/stock?limit=10&offset=0&all_fields=true</code>
|
||||
* </dd>
|
||||
* </dl>
|
||||
* <p>
|
||||
* Please note that, <code>count</code> query parameter has priority over <code>all_fields</code> query parameter.
|
||||
* In other words, <code>all_fields</code> query parameter is not considered is <code>count</code> query parameter is true.
|
||||
* </p>
|
||||
*
|
||||
*
|
||||
* @param limit (<em>Default:10</em>) To get unlimited results the limit query parameters must be set to -1.
|
||||
* If the results are too much the operation could fail.
|
||||
* It is recommended to request no more than 1000 results.
|
||||
* @param offset (<em>Default:0</em>) The offset parameter indicates the starting position of the result.
|
||||
* @return It returns an array list of string containing the GRSF UUIDs of the records.
|
||||
* E.g.<pre>["GRSF_UUID_0","GRSF_UUID_1",...,"GRSF_UUID_10"]</pre>
|
||||
*
|
||||
* In the case the query parameter <code>count=true</code> it returns the total number of records of the query.
|
||||
* E.g. <pre>{"count":148}</pre>
|
||||
*
|
||||
* In the case the query parameter <code>all_fields=true</code> each element of the resulting array contains the record representation:
|
||||
* E.g.
|
||||
* <pre>
|
||||
* [
|
||||
* {
|
||||
* "name"="GRSF_UUID_0",
|
||||
* ...,
|
||||
* "private": false,
|
||||
* "license_id": "CC-BY-SA-4.0",
|
||||
* },
|
||||
* {
|
||||
* "name"="GRSF_UUID_1",
|
||||
* ...,
|
||||
* "private": false,
|
||||
* "license_id": "CC-BY-SA-4.0",
|
||||
* },
|
||||
* ...,
|
||||
* {
|
||||
* "name"="GRSF_UUID_N",
|
||||
* ...,
|
||||
* "private": false,
|
||||
* "license_id": "CC-BY-SA-4.0",
|
||||
* }
|
||||
*
|
||||
* ]</pre>
|
||||
*
|
||||
* @pathExample /stock?limit=10&offset=0
|
||||
* @responseExample application/json;charset=UTF-8 ["GRSF_UUID_0","GRSF_UUID_1",...,"GRSF_UUID_N"]
|
||||
*/
|
||||
@GET
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The request succeeded.")
|
||||
})
|
||||
public String list(@QueryParam(GCatConstants.LIMIT_QUERY_PARAMETER) @DefaultValue("10") int limit,
|
||||
@QueryParam(GCatConstants.OFFSET_QUERY_PARAMETER) @DefaultValue("0") int offset) {
|
||||
return super.list(limit, offset);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock
|
||||
*/
|
||||
@POST
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 201, condition = "The stock record has been created successfully.")
|
||||
})
|
||||
public Response create(String json) {
|
||||
return super.create(json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@GET
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record exists.")
|
||||
})
|
||||
@Override
|
||||
public String read(@PathParam(RECORD_ID_PARAMETER) String id) {
|
||||
return super.read(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PUT
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record has been updated successfully.")
|
||||
})
|
||||
@Override
|
||||
public String update(@PathParam(RECORD_ID_PARAMETER) String id, String json) {
|
||||
return super.update(id, json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PATCH
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record has been patched successfully.")
|
||||
})
|
||||
@Override
|
||||
public String patch(@PathParam(RECORD_ID_PARAMETER) String id, String json) {
|
||||
return super.patch(id, json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@DELETE
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 204, condition = "The stock record has been deleted successfully."),
|
||||
@ResponseCode ( code = 404, condition = "The stock record was not found.")
|
||||
})
|
||||
@Override
|
||||
public Response delete(@PathParam(RECORD_ID_PARAMETER) String id,
|
||||
@QueryParam(GCatConstants.PURGE_QUERY_PARAMETER) @DefaultValue("false") Boolean purge) {
|
||||
return super.delete(id, purge);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PURGE
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 204, condition = "The stock record has been purged successfully."),
|
||||
@ResponseCode ( code = 404, condition = "The stock record was not found.")
|
||||
})
|
||||
@Override
|
||||
public Response purge(@PathParam(RECORD_ID_PARAMETER) String id) {
|
||||
return super.purge(id);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,135 +0,0 @@
|
|||
package org.gcube.grsf.publisher.rest;
|
||||
|
||||
import javax.ws.rs.Consumes;
|
||||
import javax.ws.rs.DELETE;
|
||||
import javax.ws.rs.DefaultValue;
|
||||
import javax.ws.rs.GET;
|
||||
import javax.ws.rs.POST;
|
||||
import javax.ws.rs.PUT;
|
||||
import javax.ws.rs.Path;
|
||||
import javax.ws.rs.PathParam;
|
||||
import javax.ws.rs.Produces;
|
||||
import javax.ws.rs.QueryParam;
|
||||
import javax.ws.rs.core.Response;
|
||||
|
||||
import org.gcube.gcat.api.GCatConstants;
|
||||
import org.gcube.grsf.publisher.annotation.PATCH;
|
||||
import org.gcube.grsf.publisher.annotation.PURGE;
|
||||
import org.gcube.grsf.publisher.ckan.record.Stock;
|
||||
|
||||
import com.webcohesion.enunciate.metadata.rs.ResponseCode;
|
||||
import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
||||
|
||||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
@Path(StockRESTAPIs.COLLECTION_PATH)
|
||||
public class StockRESTAPIs extends BaseRESTAPIs<Stock> {
|
||||
|
||||
public static final String COLLECTION_PATH = "stock";
|
||||
public static final String RECORD_ID_PARAMETER = "stock_record_id";
|
||||
|
||||
public StockRESTAPIs() {
|
||||
super(COLLECTION_PATH, RECORD_ID_PARAMETER, Stock.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock
|
||||
*/
|
||||
@GET
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The request succeeded.")
|
||||
})
|
||||
public String list(@QueryParam(GCatConstants.LIMIT_QUERY_PARAMETER) @DefaultValue("10") int limit,
|
||||
@QueryParam(GCatConstants.OFFSET_QUERY_PARAMETER) @DefaultValue("0") int offset) {
|
||||
return super.list(limit, offset);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock
|
||||
*/
|
||||
@POST
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 201, condition = "The stock record has been created successfully.")
|
||||
})
|
||||
public Response create(String json) {
|
||||
return super.create(json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@GET
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record exists.")
|
||||
})
|
||||
@Override
|
||||
public String read(@PathParam(RECORD_ID_PARAMETER) String id) {
|
||||
return super.read(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PUT
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record has been updated successfully.")
|
||||
})
|
||||
@Override
|
||||
public String update(@PathParam(RECORD_ID_PARAMETER) String id, String json) {
|
||||
return super.update(id, json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PATCH
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@Consumes(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@Produces(GCatConstants.APPLICATION_JSON_CHARSET_UTF_8)
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 200, condition = "The stock record has been patched successfully.")
|
||||
})
|
||||
@Override
|
||||
public String patch(@PathParam(RECORD_ID_PARAMETER) String id, String json) {
|
||||
return super.patch(id, json);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@DELETE
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 204, condition = "The stock record has been deleted successfully."),
|
||||
@ResponseCode ( code = 404, condition = "The stock record was not found.")
|
||||
})
|
||||
@Override
|
||||
public Response delete(@PathParam(RECORD_ID_PARAMETER) String id,
|
||||
@QueryParam(GCatConstants.PURGE_QUERY_PARAMETER) @DefaultValue("false") Boolean purge) {
|
||||
return super.delete(id, purge);
|
||||
}
|
||||
|
||||
/**
|
||||
* @pathExample /stock/866a479a-643a-4c21-bbcd-a3a73f28ea50
|
||||
*/
|
||||
@PURGE
|
||||
@Path("/{" + RECORD_ID_PARAMETER + "}")
|
||||
@StatusCodes ({
|
||||
@ResponseCode ( code = 204, condition = "The stock record has been purged successfully."),
|
||||
@ResponseCode ( code = 404, condition = "The stock record was not found.")
|
||||
})
|
||||
@Override
|
||||
public Response purge(@PathParam(RECORD_ID_PARAMETER) String id) {
|
||||
return super.purge(id);
|
||||
}
|
||||
|
||||
}
|
|
@ -15,7 +15,7 @@ import javax.ws.rs.core.Response;
|
|||
import org.gcube.gcat.api.GCatConstants;
|
||||
import org.gcube.grsf.publisher.annotation.PATCH;
|
||||
import org.gcube.grsf.publisher.annotation.PURGE;
|
||||
import org.gcube.grsf.publisher.ckan.record.TraceabilityUnit;
|
||||
import org.gcube.grsf.publisher.ckan.record.TraceabilityUnitRecord;
|
||||
|
||||
import com.webcohesion.enunciate.metadata.rs.ResponseCode;
|
||||
import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
||||
|
@ -23,14 +23,14 @@ import com.webcohesion.enunciate.metadata.rs.StatusCodes;
|
|||
/**
|
||||
* @author Luca Frosini (ISTI - CNR)
|
||||
*/
|
||||
@Path(TraceabilityUnitRESTAPIs.COLLECTION_PATH)
|
||||
public class TraceabilityUnitRESTAPIs extends BaseRESTAPIs<TraceabilityUnit>{
|
||||
@Path(TraceabilityUnit.COLLECTION_PATH)
|
||||
public class TraceabilityUnit extends BaseRESTAPIs<TraceabilityUnitRecord>{
|
||||
|
||||
public static final String COLLECTION_PATH = "traceability-unit";
|
||||
public static final String RECORD_ID_PARAMETER = "traceability_unit_record_id";
|
||||
|
||||
public TraceabilityUnitRESTAPIs() {
|
||||
super(COLLECTION_PATH, RECORD_ID_PARAMETER, TraceabilityUnit.class);
|
||||
public TraceabilityUnit() {
|
||||
super(COLLECTION_PATH, RECORD_ID_PARAMETER, TraceabilityUnitRecord.class);
|
||||
}
|
||||
|
||||
/**
|
Loading…
Reference in New Issue