All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.eightkdata.mongowp.server.api.CommandReply Maven / Gradle / Ivy

There is a newer version: 0.50.0
Show newest version
/*
 *     This file is part of mongowp.
 *
 *     mongowp is free software: you can redistribute it and/or modify
 *     it under the terms of the GNU Affero General Public License as published by
 *     the Free Software Foundation, either version 3 of the License, or
 *     (at your option) any later version.
 *
 *     mongowp is distributed in the hope that it will be useful,
 *     but WITHOUT ANY WARRANTY; without even the implied warranty of
 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *     GNU Affero General Public License for more details.
 *
 *     You should have received a copy of the GNU Affero General Public License
 *     along with mongowp. If not, see .
 *
 *     Copyright (c) 2014, 8Kdata Technology
 *     
 */
package com.eightkdata.mongowp.server.api;

import com.eightkdata.mongowp.ErrorCode;
import com.eightkdata.mongowp.bson.BsonDocument;
import com.eightkdata.mongowp.exceptions.CommandFailed;
import com.eightkdata.mongowp.exceptions.MongoException;
import com.eightkdata.mongowp.fields.DoubleField;
import com.eightkdata.mongowp.fields.StringField;
import com.eightkdata.mongowp.server.callback.WriteOpResult;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;

/**
 *
 * @param  the type of the result of the command this reply represents
 */
@Immutable
public interface CommandReply {
    public static final StringField ERR_MSG_FIELD = new StringField("errmsg");
    public static final DoubleField OK_FIELD = new DoubleField("ok");

    public boolean isOk();

    @Nonnull
    public ErrorCode getErrorCode();

    /**
     *
     * @return
     * @throws IllegalStateException if {@linkplain #isOk() } returns {@linkplain ErrorCode#OK}
     */
    @Nullable
    public String getErrorMessage() throws IllegalStateException;

    /**
     *
     * @return
     * @throws IllegalStateException if {@linkplain #isOk() } returns {@linkplain ErrorCode#OK}
     */
    @Nonnull
    public MongoException getErrorAsException() throws IllegalStateException;

    /**
     * @return null if the command is not a write command
     */
    public @Nullable WriteOpResult getWriteOpResult();

    /**
     *
     * @return
     * @throws IllegalStateException if {@linkplain #isOk() } returns something
     *         different than {@linkplain ErrorCode#OK}
     */
    /**
     *
     * @return the result of the command execution
     * @throws CommandFailed if the command execution failed because its own
     *         semantic
     * @throws MongoException if something else went wrong during the execution
     */
    @Nonnull
    public Result getResult() throws IllegalStateException;

    @Nonnull
    public BsonDocument marshall() throws MongoException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy