NatsConnection
import type { NatsConnection } from "https://raw.githubusercontent.com/nats-io/nats.deno/v1.28.2/nats-base-client/internal_mod.ts";
§Properties
ServerInfo to the currently connected server or undefined
Returns a ServicesAPI which allows you to build services using NATS.
§Methods
Close will close the connection to the server. This call will terminate all pending requests and subscriptions. The returned promise resolves when the connection closes.
Returns a promise that can be used to monitor if the client closes. The promise can resolve an Error if the reason for the close was an error. Note that the promise doesn't reject, but rather resolves to the error if there was one.
Initiates a drain on the connection and returns a promise that resolves when the drain completes and the connection closes.
Drain is an ordered shutdown of the client. Instead of abruptly closing the client, subscriptions are drained, that is messages not yet processed by a subscription are handled before the subscription is closed. After subscriptions are drained it is not possible to create a new subscription. Then all pending outbound messages are sent to the server. Finally, the connection is closed.
Returns a Promise that resolves when the client receives a reply from the server. Use of this API is not necessary by clients.
Returns a {@link JetStreamClient} which allows publishing messages to JetStream or consuming messages from streams.
Returns a Promise to a {@link JetStreamManager} which allows the client to access Streams and Consumers information.
Publishes the specified data to the specified subject.
Use of this API is experimental, and it is subject to be removed.
reconnect() enables a client to force a reconnect. A reconnect will disconnect the client, and possibly initiate a reconnect to the cluster. Note that all reconnect caveats apply:
-
If the reconnection policy given to the client doesn't allow reconnects, the connection will close.
-
Messages that are inbound or outbound could be lost.
-
All requests that are in flight will be rejected.
Note that the returned promise will reject if the client is already closed, or if it is in the process of draining. If the client is currently disconnected, this API has no effect, as the client is already attempting to reconnect.
Publishes a request with specified data in the specified subject expecting a response before {@link RequestOptions#timeout} milliseconds. The api returns a Promise that resolves when the first response to the request is received. If there are no responders (a subscription) listening on the request subject, the request will fail as soon as the server processes it.
Publishes a request expecting multiple responses back. Several strategies to determine when the request should stop gathering responses.