/*
 * Copyright 2008-present MongoDB, Inc.
 *
 * 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 com.mongodb.session;

import org.bson.BsonDocument;

A MongoDB server session.
@mongodb.server.release3.6
Since:3.6
/** * A MongoDB server session. * * @mongodb.server.release 3.6 * @since 3.6 */
public interface ServerSession {
Returns:the server session identifier
/** * @return the server session identifier */
BsonDocument getIdentifier();
Gets the current transaction number.
Returns:the current transaction number
Since:3.8
/** * Gets the current transaction number. * * @return the current transaction number * @since 3.8 */
long getTransactionNumber();
Return the next available transaction number.
Returns:the next transaction number
/** * Return the next available transaction number. * * @return the next transaction number */
long advanceTransactionNumber();
Whether the server session is closed.
Returns:true if the session has been closed
/** * Whether the server session is closed. * * @return true if the session has been closed */
boolean isClosed();
Mark the server session as dirty. A server session is marked dirty when a command fails with a network error. Dirty sessions are later discarded from the server session pool.
Since:3.12
/** * Mark the server session as dirty. * * A server session is marked dirty when a command fails with a network * error. Dirty sessions are later discarded from the server session pool. * @since 3.12 */
void markDirty();
Whether the server session is marked dirty.
Returns:true if the session has been marked dirty
Since:3.12
/** * Whether the server session is marked dirty. * * @return true if the session has been marked dirty * @since 3.12 */
boolean isMarkedDirty(); }