rocketmq-client-nodejs-beta
Version:
RocketMQ Node.js Client
208 lines • 17.6 kB
JavaScript
;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.RpcClient = void 0;
const grpc_js_1 = require("@grpc/grpc-js");
const service_grpc_pb_1 = require("../../proto/apache/rocketmq/v2/service_grpc_pb");
class RpcClient {
#client;
#activityTime = Date.now();
constructor(endpoints, sslEnabled) {
const address = endpoints.getGrpcTarget();
const grpcCredentials = sslEnabled ? grpc_js_1.ChannelCredentials.createSsl() : grpc_js_1.ChannelCredentials.createInsecure();
this.#client = new service_grpc_pb_1.MessagingServiceClient(address, grpcCredentials);
}
#getAndActivityRpcClient() {
this.#activityTime = Date.now();
return this.#client;
}
#getDeadline(duration) {
return Date.now() + duration;
}
idleDuration() {
return Date.now() - this.#activityTime;
}
close() {
this.#client.close();
}
/**
* Query topic route
*
* @param request query route request.
* @param metadata gRPC request header metadata.
* @param duration request max duration in milliseconds.
*/
async queryRoute(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.queryRoute(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async heartbeat(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.heartbeat(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async sendMessage(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.sendMessage(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async queryAssignment(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.queryAssignment(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async receiveMessage(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
const readable = client.receiveMessage(request, metadata, { deadline });
const responses = [];
for await (const res of readable) {
responses.push(res);
}
return responses;
}
async ackMessage(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.ackMessage(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async forwardMessageToDeadLetterQueue(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.forwardMessageToDeadLetterQueue(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async pullMessage(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
const readable = client.pullMessage(request, metadata, { deadline });
const responses = [];
for await (const res of readable) {
responses.push(res);
}
return responses;
}
async updateOffset(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.updateOffset(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async getOffset(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.getOffset(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async queryOffset(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.queryOffset(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async endTransaction(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.endTransaction(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
telemetry(metadata) {
const client = this.#getAndActivityRpcClient();
return client.telemetry(metadata);
}
async notifyClientTermination(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.notifyClientTermination(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
async changeInvisibleDuration(request, metadata, duration) {
const client = this.#getAndActivityRpcClient();
const deadline = this.#getDeadline(duration);
return new Promise((resolve, reject) => {
client.changeInvisibleDuration(request, metadata, { deadline }, (e, res) => {
if (e)
return reject(e);
resolve(res);
});
});
}
}
exports.RpcClient = RpcClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RpcClient.js","sourceRoot":"","sources":["../../src/client/RpcClient.ts"],"names":[],"mappings":"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"}