@jonaskello-forks/amqp-client
Version:
AMQP 0-9-1 client, both for browsers (WebSocket) and node (TCP Socket)
302 lines • 13.3 kB
TypeScript
/// <reference types="node" />
import { AMQPQueue } from './amqp-queue.js';
import { AMQPConsumer } from './amqp-consumer.js';
import { AMQPMessage } from './amqp-message.js';
import { AMQPBaseClient } from './amqp-base-client.js';
import { AMQPProperties } from './amqp-properties.js';
/**
* Represents an AMQP Channel. Almost all actions in AMQP are performed on a Channel.
*/
export declare class AMQPChannel {
readonly connection: AMQPBaseClient;
readonly id: number;
readonly consumers: Map<string, AMQPConsumer>;
readonly promises: [(arg0: any) => void, (err?: Error) => void][];
private readonly unconfirmedPublishes;
private closed;
/** Used for string -> arraybuffer when publishing */
private static textEncoder;
/** Frame buffer, reuse when publishes to avoid repated allocations */
private readonly buffer;
confirmId: number;
delivery?: AMQPMessage;
getMessage?: AMQPMessage;
returned?: AMQPMessage;
/**
* @param connection - The connection this channel belongs to
* @param id - ID of the channel
*/
constructor(connection: AMQPBaseClient, id: number);
/**
* Declare a queue and return an AMQPQueue instance.
*/
queue(name?: string, { passive, durable, autoDelete, exclusive }?: {
passive?: boolean | undefined;
durable?: boolean | undefined;
autoDelete?: boolean | undefined;
exclusive?: boolean | undefined;
}, args?: {}): Promise<AMQPQueue>;
/**
* Alias for basicQos
* @param prefetchCount - max inflight messages
*/
prefetch(prefetchCount: number): Promise<any>;
/**
* Default handler for Returned messages
* @param message returned from server
*/
onReturn(message: AMQPMessage): void;
/**
* Close the channel gracefully
* @param [reason] might be logged by the server
*/
close(reason?: string, code?: number): Promise<any>;
/**
* Synchronously receive a message from a queue
* @param queue - name of the queue to poll
* @param param
* @param [param.noAck=true] - if message is removed from the server upon delivery, or have to be acknowledged
* @return - returns null if the queue is empty otherwise a single message
*/
basicGet(queue: string, { noAck }?: {
noAck?: boolean | undefined;
}): Promise<AMQPMessage | null>;
/**
* Consume from a queue. Messages will be delivered asynchronously.
* @param queue - name of the queue to poll
* @param param
* @param [param.tag=""] - tag of the consumer, will be server generated if left empty
* @param [param.noAck=true] - if messages are removed from the server upon delivery, or have to be acknowledged
* @param [param.exclusive=false] - if this can be the only consumer of the queue, will return an Error if there are other consumers to the queue already
* @param [param.args={}] - custom arguments
* @param {function(AMQPMessage) : void} callback - will be called for each message delivered to this consumer
*/
basicConsume(queue: string, { tag, noAck, exclusive, args }: {
tag?: string | undefined;
noAck?: boolean | undefined;
exclusive?: boolean | undefined;
args?: {} | undefined;
} | undefined, callback: (msg: AMQPMessage) => void): Promise<AMQPConsumer>;
/**
* Cancel/stop a consumer
* @param tag - consumer tag
*/
basicCancel(tag: string): Promise<AMQPChannel>;
/**
* Acknowledge a delivered message
* @param deliveryTag - tag of the message
* @param [multiple=false] - batch confirm all messages up to this delivery tag
*/
basicAck(deliveryTag: number, multiple?: boolean): Promise<void>;
/**
* Acknowledge a delivered message
* @param deliveryTag - tag of the message
* @param [requeue=false] - if the message should be requeued or removed
* @param [multiple=false] - batch confirm all messages up to this delivery tag
*/
basicNack(deliveryTag: number, requeue?: boolean, multiple?: boolean): Promise<void>;
/**
* Acknowledge a delivered message
* @param deliveryTag - tag of the message
* @param [requeue=false] - if the message should be requeued or removed
*/
basicReject(deliveryTag: number, requeue?: boolean): Promise<void>;
/**
* Tell the server to redeliver all unacknowledged messages again, or reject and requeue them.
* @param [requeue=false] - if the message should be requeued or redeliviered to this channel
*/
basicRecover(requeue?: boolean): Promise<any>;
/**
* Publish a message
* @param exchange - the exchange to publish to, the exchange must exists
* @param routingKey - routing key
* @param data - the data to be published, can be a string or an uint8array
* @param [mandatory] - if the message should be returned if there's no queue to be delivered to
* @param [immediate] - if the message should be returned if it can't be delivered to a consumer immediately (not supported in RabbitMQ)
* @return - fulfilled when the message is enqueue on the socket, or if publish confirm is enabled when the message is confirmed by the server
*/
basicPublish(exchange: string, routingKey: string, data: string | Uint8Array | ArrayBuffer | Buffer | null, properties?: AMQPProperties, mandatory?: boolean, immediate?: boolean): Promise<number>;
/**
* Set prefetch limit.
* Recommended to set as each unacknowledge message will be store in memory of the client.
* The server won't deliver more messages than the limit until messages are acknowledged.
* @param prefetchCount - number of messages to limit to
* @param prefetchSize - number of bytes to limit to (not supported by RabbitMQ)
* @param global - if the prefetch is limited to the channel, or if false to each consumer
*/
basicQos(prefetchCount: number, prefetchSize?: number, global?: boolean): Promise<any>;
/**
* Enable or disable flow. Disabling flow will stop the server from delivering messages to consumers.
* Not supported in RabbitMQ
* @param active - false to stop the flow, true to accept messages
*/
basicFlow(active?: boolean): Promise<any>;
/**
* Enable publish confirm. The server will then confirm each publish with an Ack or Nack when the message is enqueued.
*/
confirmSelect(): Promise<any>;
/**
* Declare a queue
* @param name - name of the queue, if empty the server will generate a name
* @param params
* @param [params.passive=false] - if the queue name doesn't exists the channel will be closed with an error, fulfilled if the queue name does exists
* @param [params.durable=true] - if the queue should survive server restarts
* @param [params.autoDelete=false] - if the queue should be deleted when the last consumer of the queue disconnects
* @param [params.exclusive=false] - if the queue should be deleted when the channel is closed
* @param args - optional custom queue arguments
* @return fulfilled when confirmed by the server
*/
queueDeclare(name?: string, { passive, durable, autoDelete, exclusive }?: {
passive?: boolean | undefined;
durable?: boolean | undefined;
autoDelete?: boolean | undefined;
exclusive?: boolean | undefined;
}, args?: {}): Promise<any>;
/**
* Delete a queue
* @param name - name of the queue, if empty it will delete the last declared queue
* @param params
* @param [params.ifUnused=false] - only delete if the queue doesn't have any consumers
* @param [params.ifEmpty=false] - only delete if the queue is empty
*/
queueDelete(name?: string, { ifUnused, ifEmpty }?: {
ifUnused?: boolean | undefined;
ifEmpty?: boolean | undefined;
}): Promise<any>;
/**
* Bind a queue to an exchange
* @param queue - name of the queue
* @param exchange - name of the exchange
* @param routingKey - key to bind with
* @param args - optional arguments, e.g. for header exchanges
* @return fulfilled when confirmed by the server
*/
queueBind(queue: string, exchange: string, routingKey: string, args?: {}): Promise<any>;
/**
* Unbind a queue from an exchange
* @param queue - name of the queue
* @param exchange - name of the exchange
* @param routingKey - key that was bound
* @param args - arguments, e.g. for header exchanges
* @return fulfilled when confirmed by the server
*/
queueUnbind(queue: string, exchange: string, routingKey: string, args?: {}): Promise<any>;
/**
* Purge a queue
* @param queue - name of the queue
* @return fulfilled when confirmed by the server
*/
queuePurge(queue: string): Promise<{
messageCount: number;
}>;
/**
* Declare an exchange
* @param name - name of the exchange
* @param type - type of exchange (direct, fanout, topic, header, or a custom type)
* @param param
* @param [param.passive=false] - if the exchange name doesn't exists the channel will be closed with an error, fulfilled if the exchange name does exists
* @param [param.durable=true] - if the exchange should survive server restarts
* @param [param.autoDelete=false] - if the exchange should be deleted when the last binding from it is deleted
* @param [param.internal=false] - if exchange is internal to the server. Client's can't publish to internal exchanges.
* @param args - optional arguments
* @return Fulfilled when the exchange is created or if it already exists
*/
exchangeDeclare(name: string, type: string, { passive, durable, autoDelete, internal }?: {
passive?: boolean | undefined;
durable?: boolean | undefined;
autoDelete?: boolean | undefined;
internal?: boolean | undefined;
}, args?: {}): Promise<any>;
/**
* Delete an exchange
* @param name - name of the exchange
* @param param
* @param [param.ifUnused=false] - only delete if the exchange doesn't have any bindings
* @return Fulfilled when the exchange is deleted or if it's already deleted
*/
exchangeDelete(name: string, { ifUnused }?: {
ifUnused?: boolean | undefined;
}): Promise<any>;
/**
* Exchange to exchange binding.
* @param destination - name of the destination exchange
* @param source - name of the source exchange
* @param routingKey - key to bind with
* @param args - optional arguments, e.g. for header exchanges
* @return fulfilled when confirmed by the server
*/
exchangeBind(destination: string, source: string, routingKey?: string, args?: {}): Promise<any>;
/**
* Delete an exchange-to-exchange binding
* @param destination - name of destination exchange
* @param source - name of the source exchange
* @param routingKey - key that was bound
* @param args - arguments, e.g. for header exchanges
* @return fulfilled when confirmed by the server
*/
exchangeUnbind(destination: string, source: string, routingKey?: string, args?: {}): Promise<any>;
/**
* Set this channel in Transaction mode.
* Rember to commit the transaction, overwise the server will eventually run out of memory.
*/
txSelect(): Promise<any>;
/**
* Commit a transaction
*/
txCommit(): Promise<any>;
/**
* Rollback a transaction
*/
txRollback(): Promise<any>;
private txMethod;
/**
* Resolves the next RPC promise
* @ignore
*/
resolvePromise(value?: any): boolean;
/**
* Rejects the next RPC promise
* @return true if a promise was rejected, otherwise false
*/
private rejectPromise;
/**
* Send a RPC request, will resolve a RPC promise when RPC response arrives
* @param frame with data
* @param frameSize - bytes the frame actually is
*/
private sendRpc;
/**
* Marks the channel as closed
* All outstanding RPC requests will be rejected
* All outstanding publish confirms will be rejected
* All consumers will be marked as closed
* @ignore
* @param [err] - why the channel was closed
*/
setClosed(err?: Error): void;
/**
* @return Rejected promise with an error
*/
private rejectClosed;
/**
* Called from AMQPBaseClient when a publish is confirmed by the server.
* Will fulfill one or more (if multiple) Unconfirmed Publishes.
* @ignore
* @param deliveryTag
* @param multiple - true if all unconfirmed publishes up to this deliveryTag should be resolved or just this one
* @param nack - true if negative confirm, hence reject the unconfirmed publish(es)
*/
publishConfirmed(deliveryTag: number, multiple: boolean, nack: boolean): void;
/**
* Called from AMQPBaseClient when a message is ready
* @ignore
* @param message
*/
onMessageReady(message: AMQPMessage): void;
/**
* Deliver a message to a consumer
* @ignore
*/
deliver(message: AMQPMessage): void;
}
//# sourceMappingURL=amqp-channel.d.ts.map