Mordil/RediStack

View on GitHub
Sources/RediStack/Commands/ServerCommands.swift

Summary

Maintainability
A
1 hr
Test Coverage
//===----------------------------------------------------------------------===//
//
// This source file is part of the RediStack open source project
//
// Copyright (c) 2020-2022 RediStack project authors
// Licensed under Apache License v2.0
//
// See LICENSE.txt for license information
// See CONTRIBUTORS.txt for the list of RediStack project authors
//
// SPDX-License-Identifier: Apache-2.0
//
//===----------------------------------------------------------------------===//

import struct Logging.Logger
import NIOCore

// MARK: Server

extension RedisCommand {
    /// [SWAPDB](https://redis.io/commands/swapdb)
    /// - Parameters:
    ///     - first: The index of the first database.
    ///     - second: The index of the second database.
    public static func swapdb(_ first: Int, with second: Int) -> RedisCommand<Bool> {
        let args: [RESPValue] = [
            .init(bulk: first),
            .init(bulk: second)
        ]
        return .init(keyword: "SWAPDB", arguments: args) {
            return (try $0.map()) == "OK"
        }
    }
}

// MARK: -

extension RedisClient {
    /// Swaps the data of two Redis databases by their index IDs.
    ///
    /// See ``RedisCommand/swapdb(_:with:)``
    /// - Parameters:
    ///     - first: The index of the first database.
    ///     - second: The index of the second database.
    ///     - eventLoop: An optional event loop to hop to for any further chaining on the returned event loop future.
    ///     - logger: An optional logger instance to use for logs generated from this command.
    /// - Returns: A `NIO.EventLoopFuture` that resolves `true` if the command succeed or `false` if it didn't.
    public func swapDatabase(
        _ first: Int,
        with second: Int,
        eventLoop: EventLoop? = nil,
        logger: Logger? = nil
    ) -> EventLoopFuture<Bool> {
        return self.send(.swapdb(first, with: second), eventLoop: eventLoop, logger: logger)
    }
}