UNPKG

rocketmq-client-nodejs-beta

Version:
208 lines 17.6 kB
"use strict"; /** * 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":";AAAA;;;;;;;;;;;;;;;GAeG;;;AAEH,2CAA6D;AAC7D,oFAAwF;AAiCxF,MAAa,SAAS;IACpB,OAAO,CAAyB;IAChC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAE3B,YAAY,SAAoB,EAAE,UAAmB;QACnD,MAAM,OAAO,GAAG,SAAS,CAAC,aAAa,EAAE,CAAC;QAC1C,MAAM,eAAe,GAAG,UAAU,CAAC,CAAC,CAAC,4BAAkB,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,4BAAkB,CAAC,cAAc,EAAE,CAAC;QAC1G,IAAI,CAAC,OAAO,GAAG,IAAI,wCAAsB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IACtE,CAAC;IAED,wBAAwB;QACtB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,YAAY,CAAC,QAAgB;QAC3B,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC;IAC/B,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC;IACzC,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,UAAU,CAAC,OAA0B,EAAE,QAAkB,EAAE,QAAgB;QAC/E,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAqB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACzD,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC5D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,OAAyB,EAAE,QAAkB,EAAE,QAAgB;QAC7E,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxD,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC3D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAA2B,EAAE,QAAkB,EAAE,QAAgB;QACjF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC1D,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC7D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,OAA+B,EAAE,QAAkB,EAAE,QAAgB;QACzF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAA0B,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC9D,MAAM,CAAC,eAAe,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBACjE,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,OAA8B,EAAE,QAAkB,EAAE,QAAgB;QACvF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,QAAQ,GAAG,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;QACxE,MAAM,SAAS,GAA6B,EAAE,CAAC;QAC/C,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;YACjC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,OAA0B,EAAE,QAAkB,EAAE,QAAgB;QAC/E,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAqB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACzD,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC5D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,+BAA+B,CAAC,OAA+C,EACnF,QAAkB,EAAE,QAAgB;QACpC,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAA0C,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC9E,MAAM,CAAC,+BAA+B,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBACjF,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAA2B,EAAE,QAAkB,EAAE,QAAgB;QACjF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;QACrE,MAAM,SAAS,GAA0B,EAAE,CAAC;QAC5C,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;YACjC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,OAA4B,EAAE,QAAkB,EAAE,QAAgB;QACnF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3D,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC9D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,OAAyB,EAAE,QAAkB,EAAE,QAAgB;QAC7E,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxD,MAAM,CAAC,SAAS,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC3D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAA2B,EAAE,QAAkB,EAAE,QAAgB;QACjF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC1D,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAC7D,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,OAA8B,EAAE,QAAkB,EAAE,QAAgB;QACvF,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC7D,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBAChE,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,SAAS,CAAC,QAAkB;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,OAAO,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,OAAuC,EAAE,QAAkB,EAAE,QAAgB;QACzG,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAkC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtE,MAAM,CAAC,uBAAuB,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBACzE,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,OAAuC,EAAE,QAAkB,EAAE,QAAgB;QACzG,MAAM,MAAM,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAO,IAAI,OAAO,CAAkC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtE,MAAM,CAAC,uBAAuB,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBACzE,IAAI,CAAC;oBAAE,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAjMD,8BAiMC"}