A Swift client library for Valkey.
The valkey-swift project uses a connection pool, which requires a background process to manage it. You can either run it using a TaskGroup or async let. Below we are using async let to run the connection pool background process.
let valkeyClient = ValkeyClient(.hostname("localhost", port: 6379), logger: logger)
async let _ = valkeyClient.run()
// use valkey clientOr you can use ValkeyClient with swift-service-lifecycle.
Once you have a valkey client setup and running you can call valkey commands directly from the ValkeyClient.
try await valkeyClient.set(key: "foo", value: "bar")Or you can create a connection and run multiple commands from that connection using ValkeyClient.withConnection().
try await valkeyClient.withConnection { connection in
    try await connection.set(key: "foo1", value: "bar")
    try await connection.set(key: "foo2", value: "baz")
}All the Valkey commands are in the Commands folder of the Valkey target. These are generated from the model files Valkey supplies in the valkey repository. In many cases where it was possible to ascertain the return type of a command these functions will return that expected type. In situations where this is not possible we have either added a custom return type or a RESPToken is returned and you'll need to convert it manually.
In some cases it is desirable to send multiple commands at one time, without waiting for the response after each command. This is called pipelining. You can do this using the function execute(_:). This function takes multiple commands in the form of a parameter pack. It sends all the commands off at the same time and once it has received all the responses, returns a parameter pack containing the responses.
let (setResponse, getResponse) = await connection.execute(
    SET(key: "MyKey", value: "TestString"),
    GET(key: "MyKey")
)
let value = try getResponse.get()As Valkey is a fork of Redis v7.2.4, valkey-swift is compatible with Redis databases up to v7.2.4. There is a chance that v7.2.4 features will still be compatible in later versions of Redis, but these are now considered two different projects and they will diverge. valkey-swift uses the RESP3 protocol.
User guides and reference documentation for valkey-swift can be found on the Swift Package Index.