From f304021d16e433b261226a8293f03e7de30a08a4 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Sun, 12 Jul 2015 13:05:10 +1200 Subject: Re-factor all channel handlers --- src/org/traccar/ReverseGeocoderHandler.java | 33 ++++++----------------------- 1 file changed, 6 insertions(+), 27 deletions(-) (limited to 'src/org/traccar/ReverseGeocoderHandler.java') diff --git a/src/org/traccar/ReverseGeocoderHandler.java b/src/org/traccar/ReverseGeocoderHandler.java index aaa491ae7..bb4f5cedd 100644 --- a/src/org/traccar/ReverseGeocoderHandler.java +++ b/src/org/traccar/ReverseGeocoderHandler.java @@ -15,14 +15,11 @@ */ package org.traccar; -import java.net.SocketAddress; -import java.util.List; -import org.jboss.netty.channel.Channel; import org.traccar.geocode.AddressFormat; import org.traccar.geocode.ReverseGeocoder; import org.traccar.model.Position; -public class ReverseGeocoderHandler extends ExtendedObjectDecoder { +public class ReverseGeocoderHandler extends BaseDataHandler { private final ReverseGeocoder geocoder; private final boolean processInvalidPositions; @@ -35,30 +32,12 @@ public class ReverseGeocoderHandler extends ExtendedObjectDecoder { } @Override - protected Object decode( - Channel channel, SocketAddress remoteAddress, Object msg) - throws Exception { - - if (geocoder != null) { - if (msg instanceof Position) { - Position position = (Position) msg; - - if (processInvalidPositions || position.getValid()) { - position.setAddress(geocoder.getAddress( - addressFormat, position.getLatitude(), position.getLongitude())); - } - } else if (msg instanceof List) { - List positions = (List) msg; - for (Position position : positions) { - if (processInvalidPositions || position.getValid()) { - position.setAddress(geocoder.getAddress( - addressFormat, position.getLatitude(), position.getLongitude())); - } - } - } + protected Position handlePosition(Position position) { + if (geocoder != null && (processInvalidPositions || position.getValid())) { + position.setAddress(geocoder.getAddress( + addressFormat, position.getLatitude(), position.getLongitude())); } - - return msg; + return position; } } -- cgit v1.2.3