MessageCommand.java

/*
 * Copyright 2005-2025 the original author or authors.
 *
 * 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.openwms.common.transport.api.commands;

import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull;

import java.beans.ConstructorProperties;
import java.io.Serializable;
import java.time.LocalDateTime;

/**
 * A MessageCommand is used to attach Messages.
 *
 * @author Heiko Scherrer
 */
public class MessageCommand implements Command<MessageCommand.Type>, Serializable {

    public enum Type {
        /** Add a message to a TransportUnit. */
        ADD_TO_TU
    }

    @NotNull
    private Type type;
    private String transportUnitId;

    @NotEmpty
    private String messageText;
    private String messageNumber;
    private LocalDateTime messageOccurred;

    /*~-------------------- constructors --------------------*/
    @ConstructorProperties({"type", "messageText"})
    protected MessageCommand(Type type, String messageText) {
        this.type = type;
        this.messageText = messageText;
    }

    private MessageCommand(Builder builder) {
        type = builder.type;
        transportUnitId = builder.transportUnitId;
        messageText = builder.messageText;
        messageNumber = builder.messageNumber;
        messageOccurred = builder.messageOccurred;
    }

    /*~-------------------- methods --------------------*/
    public static Builder newBuilder(Type type) {
        return new Builder(type);
    }

    /*~-------------------- accessors --------------------*/
    public Type getType() {
        return type;
    }

    public void setType(Type type) {
        this.type = type;
    }

    public String getTransportUnitId() {
        return transportUnitId;
    }

    public void setTransportUnitId(String transportUnitId) {
        this.transportUnitId = transportUnitId;
    }

    public String getMessageText() {
        return messageText;
    }

    public void setMessageText(String messageText) {
        this.messageText = messageText;
    }

    public String getMessageNumber() {
        return messageNumber;
    }

    public void setMessageNumber(String messageNumber) {
        this.messageNumber = messageNumber;
    }

    public LocalDateTime getMessageOccurred() {
        return messageOccurred;
    }

    public void setMessageOccurred(LocalDateTime messageOccurred) {
        this.messageOccurred = messageOccurred;
    }

    public static final class Builder {
        private Type type;
        private String transportUnitId;
        private String messageText;
        private String messageNumber;
        private LocalDateTime messageOccurred;

        private Builder(Type type) {
            this.type = type;
        }

        public Builder withTransportUnitId(String val) {
            transportUnitId = val;
            return this;
        }

        public Builder withMessageText(@NotEmpty String val) {
            messageText = val;
            return this;
        }

        public Builder withMessageNumber(String val) {
            messageNumber = val;
            return this;
        }

        public Builder withMessageOccurred(LocalDateTime val) {
            messageOccurred = val;
            return this;
        }

        public MessageCommand build() {
            return new MessageCommand(this);
        }
    }
}