blob: b4b33c89cfea2b34b59cdcfe2495ed749ee3c6f6 [file] [log] [blame]
/*
* Copyright 2011 Marc Grue.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied.
*
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.qi4j.sample.dcicargo.sample_b.data.structure.handling;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.qi4j.api.association.Association;
import org.qi4j.api.common.Optional;
import org.qi4j.api.mixin.Mixins;
import org.qi4j.api.property.Immutable;
import org.qi4j.api.property.Property;
import org.qi4j.sample.dcicargo.sample_b.data.structure.location.Location;
import org.qi4j.sample.dcicargo.sample_b.data.structure.tracking.TrackingId;
import org.qi4j.sample.dcicargo.sample_b.data.structure.voyage.Voyage;
/**
* HandlingEvent
*
* A HandlingEvent is used to register the event when, for instance,
* a cargo is unloaded from a carrier at some location at a given time.
*
* The HandlingEvents are sent from different Incident Logging Applications
* some time after the event occurred and contain information about the
* {@link TrackingId}, {@link Location}, timestamp of the completion of the event,
* and possibly, if applicable a {@link Voyage}.
*
* Note that we don't save the whole cargo graph here as in the DDD sample! With
* the tracking id saved only, our HandlingEvent objects become much lighter and
* faster to save as we register incoming handling event data in high volumes from
* incident logging applications.
*
* HandlingEvents could contain information about a {@link Voyage} and if so,
* the event type must be either {@link HandlingEventType#LOAD} or
* {@link HandlingEventType#UNLOAD}.
*
* All other events must be of type {@link HandlingEventType#RECEIVE},
* {@link HandlingEventType#CLAIM} or {@link HandlingEventType#CUSTOMS}.
*/
@Immutable
@Mixins( HandlingEvent.Mixin.class )
public interface HandlingEvent
{
Property<Date> registrationTime();
Property<Date> completionTime();
Property<TrackingId> trackingId();
Property<HandlingEventType> handlingEventType();
Association<Location> location();
@Optional
Association<Voyage> voyage();
String print();
abstract class Mixin
implements HandlingEvent
{
public String print()
{
String voyage = "";
if( voyage().get() != null )
{
voyage = voyage().get().voyageNumber().get().number().get();
}
SimpleDateFormat date = new SimpleDateFormat( "yyyy-MM-dd" );
StringBuilder builder = new StringBuilder( "\nHANDLING EVENT -----------------" ).
append( "\n Cargo " ).append( trackingId().get().id().get() ).
append( "\n Type " ).append( handlingEventType().get().name() ).
append( "\n Location " ).append( location().get().getString() ).
append( "\n Completed " ).append( date.format( completionTime().get() ) ).
append( "\n Registered " ).append( date.format( registrationTime().get() ) ).
append( "\n Voyage " ).append( voyage ).
append( "\n--------------------------------\n" );
return builder.toString();
}
}
}