diff options
author | Abyss777 <abyss@fox5.ru> | 2016-08-03 17:53:54 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2016-08-04 16:33:34 +0500 |
commit | 504a555b40ee0c2c14e8679ed320b8c2578f8610 (patch) | |
tree | d6b0fb2fb95253afcbe7dd7fcb1cbf367b45acc6 /src/org/traccar/reports/Events.java | |
parent | a5c431069ca0dfe8240f0c8b43f0508189f8fc86 (diff) | |
download | trackermap-server-504a555b40ee0c2c14e8679ed320b8c2578f8610.tar.gz trackermap-server-504a555b40ee0c2c14e8679ed320b8c2578f8610.tar.bz2 trackermap-server-504a555b40ee0c2c14e8679ed320b8c2578f8610.zip |
- Moved retrieving Accept to BaseResource
- Added Events report
- Removed deviceIds from csv
Diffstat (limited to 'src/org/traccar/reports/Events.java')
-rw-r--r-- | src/org/traccar/reports/Events.java | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/org/traccar/reports/Events.java b/src/org/traccar/reports/Events.java index 1edeb0773..d3457e5a5 100644 --- a/src/org/traccar/reports/Events.java +++ b/src/org/traccar/reports/Events.java @@ -1,5 +1,45 @@ package org.traccar.reports; +import java.sql.SQLException; +import java.util.Collection; +import java.util.Date; + +import javax.json.Json; +import javax.json.JsonObjectBuilder; + +import org.traccar.Context; +import org.traccar.model.Event; +import org.traccar.web.CsvBuilder; +import org.traccar.web.JsonConverter; + public final class Events { + private Events() { + } + + public static String getJson(long userId, Collection<Long> deviceIds, Collection<Long> groupIds, + Collection<String> types, Date from, Date to) throws SQLException { + JsonObjectBuilder json = Json.createObjectBuilder(); + for (long deviceId: ReportUtils.getReportedDevices(deviceIds, groupIds)) { + Context.getPermissionsManager().checkDevice(userId, deviceId); + for (String type : types) { + json.add(String.valueOf(deviceId), JsonConverter.arrayToJson(Context.getDataManager() + .getEvents(deviceId, type, from, to))); + } + } + return json.build().toString(); + } + + public static byte[] getCsv(long userId, Collection<Long> deviceIds, Collection<Long> groupIds, + Collection<String> types, Date from, Date to) throws SQLException { + CsvBuilder csv = new CsvBuilder(); + csv.addHeaderLine(new Event()); + for (long deviceId: ReportUtils.getReportedDevices(deviceIds, groupIds)) { + Context.getPermissionsManager().checkDevice(userId, deviceId); + for (String type : types) { + csv.addArray(Context.getDataManager().getEvents(deviceId, type, from, to)); + } + } + return csv.get(); + } } |