A maintained swift client for interacting with a nats server based on NIO2.
Tested with Swift 5.4 on and
Swift Version Compatibility:
Platform Compatibility:
Support
Join the #swift channel on nats.io Slack.
We’ll do our best to help quickly. You can also just drop by and say hello. We’re looking forward to developing the community.
Installation via Swift Package Manager
In Package.swift
Add this packages as a dependency in your projects Package.swift file and add the Name to your target like shown in this example:
Open the project inspector in XCode and select your project. It is importent to select the project and not a target!
Klick on the third tab Package Dependencies and add the git url https://github.com/aus-der-technik/SwiftyNats.git by selecting the litte +-sign at the end of the package list.
Basic Usage
import SwiftyNats
// register a new client
let client = NatsClient("http://nats.server:4222")
// listen to an event
client.on(.connect) { _ in
print("Client connected")
}
// try to connect to the server
try? client.connect()
// subscribe to a channel with a inline message handler.
client.subscribe("foo.bar") { message in
print("payload: \(message.payload)")
print("size: \(message.byteCount)")
print("reply subject: \(message.replySubject.subject)")
}
// publish an event onto the message strem into a subject
client.publish("this event happened", to: "foo.bar")
Setting the loglevel
The default loglevel is .error. You can reset it to see more verbose messages. Possible
Values are .debug, .info, .error or .critical
let client = NatsClient("http://nats.server:4222")
client.config.loglevel = .info
Reconnection is up to you
Reconnection is not part of this package, because if a server diconnects your application have to be sure that
subscribtions are made up again correctly.
With SwiftyNats this is a very easy step:
// register a new client
let client = NatsClient(url)
// listen to the .disconnected event to try a reconnect
client.on(.disconnected) { [self] _ in
sleep(5);
try? client.reconnect()
doSubscribe()
}
// subscribe to the channels
doSubscribe()
// private function to subscribe to channels
private func doSubscribe(){
client.subscribe("foo.bar") { message in
print("payload: \(message.payload)")
}
}
List of events
The public class NatsEvent contains all events you can subscribt to.
event
description
connected
The client is conected to the server.
disconnected
The client disconnects and was connectd before.
response
The client gets an response from the server (internal).
error
The server sends an error that can’t be handled.
dropped
The clients droped a message. Mostly because of queue length to short.
reconnecting
The client reconencts to the server, (Because of a called reconnect()).
informed
The server sends his information data successfully to the client.
Information about the connected server
Since 2.0.2 it is possible to get the informations from the conencted server
let client = NatsClient("http://nats.server:4222")
print("\(client.serverInformation.serverName) has Version: \(client.serverInformation.version))");
Contribution
Contribution is always welcome. Just send me a pull request.
Changelog
2.2.0
The client configuration is now publicly available
The handling of the connection status has been rewritten
Rewrite of the connection setup
The connection termination was rewritten
All classes have been cleaned up (refactoring)
A new license was added (BSD-0)
The reconnection code was removed
Subscription queue is an optional property of NatsSubject
2.1.1
rewrite the ChannelHandler: remove a bug that could lead into dropped messages.
2.1.0
uses NIO2
works with Vapor, now!
2.0.3
supports iOS anf tvOS
2.0.2
Get information from the connected Server (Version, name, id, …)
2.0.1
Test with GitHub Actions
Update Dockerfile to build and test on Swift 5.4 (Linux)
SwiftyNats
A maintained swift client for interacting with a nats server based on NIO2.
Tested with Swift 5.4 on
and data:image/s3,"s3://crabby-images/15b6e/15b6ed9a92727d235ef5099ff52aff91efec8ea9" alt="Linux"
Swift Version Compatibility:data:image/s3,"s3://crabby-images/64f5e/64f5e50897399ba345f2ed85e5bc20c59e79b6f8" alt=""
Platform Compatibility:data:image/s3,"s3://crabby-images/ddab7/ddab793795d204ffdc58bea839200341b4616b3d" alt=""
Support
Join the #swift channel on nats.io Slack. We’ll do our best to help quickly. You can also just drop by and say hello. We’re looking forward to developing the community.
Installation via Swift Package Manager
In Package.swift
Add this packages as a dependency in your projects
Package.swift
file and add the Name to your target like shown in this example:In an .xcodeproj
Open the project inspector in XCode and select your project. It is importent to select the project and not a target! Klick on the third tab
Package Dependencies
and add the git urlhttps://github.com/aus-der-technik/SwiftyNats.git
by selecting the litte+
-sign at the end of the package list.Basic Usage
Setting the loglevel
The default loglevel is
.error
. You can reset it to see more verbose messages. Possible Values are.debug
,.info
,.error
or.critical
Reconnection is up to you
Reconnection is not part of this package, because if a server diconnects your application have to be sure that subscribtions are made up again correctly.
With SwiftyNats this is a very easy step:
List of events
The public class
NatsEvent
contains all events you can subscribt to.Information about the connected server
Since 2.0.2 it is possible to get the informations from the conencted server
Contribution
Contribution is always welcome. Just send me a pull request.
Changelog
2.2.0
2.1.1
2.1.0
2.0.3
2.0.2
2.0.1
2.0.0
Roadmap
See: Contribution ;)