nice-grpc
Version:
A Node.js gRPC library that is nice to you
85 lines • 3.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.createServerStreamingMethod = createServerStreamingMethod;
const abort_controller_x_1 = require("abort-controller-x");
const nice_grpc_common_1 = require("nice-grpc-common");
const service_definitions_1 = require("../service-definitions");
const convertMetadata_1 = require("../utils/convertMetadata");
const isAsyncIterable_1 = require("../utils/isAsyncIterable");
const readableToAsyncIterable_1 = require("../utils/readableToAsyncIterable");
const wrapClientError_1 = require("./wrapClientError");
/** @internal */
function createServerStreamingMethod(definition, client, middleware, defaultOptions) {
const grpcMethodDefinition = (0, service_definitions_1.toGrpcJsMethodDefinition)(definition);
const methodDescriptor = {
path: definition.path,
requestStream: definition.requestStream,
responseStream: definition.responseStream,
options: definition.options,
};
async function* serverStreamingMethod(request, options) {
if ((0, isAsyncIterable_1.isAsyncIterable)(request)) {
throw new Error('A middleware passed invalid request to next(): expected a single message for server streaming method');
}
const { metadata = (0, nice_grpc_common_1.Metadata)(), onHeader, onTrailer } = options;
const signal = options.signal ?? new AbortController().signal;
const call = client.makeServerStreamRequest(grpcMethodDefinition.path, grpcMethodDefinition.requestSerialize, grpcMethodDefinition.responseDeserialize, request, (0, convertMetadata_1.convertMetadataToGrpcJs)(metadata));
call.on('metadata', metadata => {
onHeader?.((0, convertMetadata_1.convertMetadataFromGrpcJs)(metadata));
});
call.on('status', status => {
onTrailer?.((0, convertMetadata_1.convertMetadataFromGrpcJs)(status.metadata));
});
const abortListener = () => {
call.cancel();
};
signal.addEventListener('abort', abortListener);
try {
yield* (0, readableToAsyncIterable_1.readableToAsyncIterable)(call);
}
catch (err) {
throw (0, wrapClientError_1.wrapClientError)(err, definition.path);
}
finally {
signal.removeEventListener('abort', abortListener);
(0, abort_controller_x_1.throwIfAborted)(signal);
call.cancel();
}
}
const method = middleware == null
? serverStreamingMethod
: (request, options) => middleware({
method: methodDescriptor,
requestStream: false,
request,
responseStream: true,
next: serverStreamingMethod,
}, options);
return (request, options) => {
const iterable = method(request, {
...defaultOptions,
...options,
});
const iterator = iterable[Symbol.asyncIterator]();
return {
[Symbol.asyncIterator]() {
return {
async next() {
const result = await iterator.next();
if (result.done && result.value != null) {
return await iterator.throw(new Error('A middleware returned a message, but expected to return void for server streaming method'));
}
return result;
},
return() {
return iterator.return();
},
throw(err) {
return iterator.throw(err);
},
};
},
};
};
}
//# sourceMappingURL=createServerStreamingMethod.js.map