package org.apereo.cas.ticket.registry.support.kryo.serial;
import com.esotericsoftware.kryo.Kryo;
import com.esotericsoftware.kryo.Serializer;
import com.esotericsoftware.kryo.io.Input;
import com.esotericsoftware.kryo.io.Output;
import org.apereo.cas.util.DateTimeUtils;
import java.time.ZoneId;
import java.time.ZonedDateTime;
/**
* @author Timur Duehr timur.duehr@nccgroup.trust
* @since 5.0.0
*/
public class ZonedDateTimeTranscoder extends Serializer<ZonedDateTime> {
@Override
public void write(final Kryo kryo, final Output output, final ZonedDateTime dateTime) {
kryo.writeObject(output, dateTime.toInstant().toEpochMilli());
kryo.writeObject(output, dateTime.getZone().getId());
}
@Override
public ZonedDateTime read(final Kryo kryo, final Input input, final Class<ZonedDateTime> type) {
final long time = kryo.readObject(input, Long.class);
final ZoneId zone = ZoneId.of(input.readString());
return DateTimeUtils.zonedDateTimeOf(time, zone);
}
}