-
Notifications
You must be signed in to change notification settings - Fork 83
/
grpc-web-transport.ts
135 lines (123 loc) · 4.1 KB
/
grpc-web-transport.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
// Copyright 2021-2023 Buf Technologies, Inc.
//
// Licensed 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.
import type { Interceptor, Transport } from "@bufbuild/connect";
import type { Compression } from "@bufbuild/connect/protocol";
import { createTransport } from "@bufbuild/connect/protocol-grpc-web";
import type {
BinaryReadOptions,
BinaryWriteOptions,
JsonReadOptions,
JsonWriteOptions,
} from "@bufbuild/protobuf";
import type {
NodeHttp1TransportOptions,
NodeHttp2TransportOptions,
} from "./validate-node-transport-options.js";
import { validateNodeTransportOptions } from "./validate-node-transport-options.js";
/**
* Options used to configure the gRPC-web transport.
*
* See createGrpcWebTransport().
*/
type GrpcWebTransportOptions = (
| NodeHttp1TransportOptions
| NodeHttp2TransportOptions
) & {
/**
* Base URI for all HTTP requests.
*
* Requests will be made to <baseUrl>/<package>.<service>/method
*
* Example: `baseUrl: "https://example.com/my-api"`
*
* This will make a `POST /my-api/my_package.MyService/Foo` to
* `example.com` via HTTPS.
*/
baseUrl: string;
/**
* By default, clients use the binary format for gRPC-web, because
* not all gRPC-web implementations support JSON.
*/
useBinaryFormat?: boolean;
/**
* Interceptors that should be applied to all calls running through
* this transport. See the Interceptor type for details.
*/
interceptors?: Interceptor[];
/**
* Options for the JSON format.
*/
jsonOptions?: Partial<JsonReadOptions & JsonWriteOptions>;
/**
* Options for the binary wire format.
*/
binaryOptions?: Partial<BinaryReadOptions & BinaryWriteOptions>;
/**
* Compression algorithms available to a client. Clients ask servers to
* compress responses using any of the registered algorithms. The first
* registered algorithm is the most preferred.
*
* It is safe to use this option liberally: servers will ignore any
* compression algorithms they don't support. To compress requests, pair this
* option with `sendCompression`.
*
* If this option is not provided, the compression algorithms "gzip" and "br"
* (Brotli) are accepted. To opt out of response compression, pass an
* empty array.
*/
acceptCompression?: Compression[];
/**
* Configures the client to use the specified algorithm to compress request
* messages.
*
* Because some servers don't support compression, clients default to sending
* uncompressed requests.
*/
sendCompression?: Compression;
/**
* Sets a minimum size threshold for compression: Messages that are smaller
* than the configured minimum are sent uncompressed.
*
* The default value is 1 kibibyte, because the CPU cost of compressing very
* small messages usually isn't worth the small reduction in network I/O.
*/
compressMinBytes?: number;
/**
* Limits the performance impact of pathologically large messages sent by the
* server. Limits apply to each individual message, not to the stream as a
* whole.
*
* The default limit is the maximum supported value of ~4GiB.
*/
readMaxBytes?: number;
/**
* Prevents sending messages too large for the server to handle.
*
* The default limit is the maximum supported value of ~4GiB.
*/
writeMaxBytes?: number;
};
/**
* Create a Transport for the gRPC-web protocol using the Node.js `http`,
* `http2`, or `http2` module.
*/
export function createGrpcWebTransport(
options: GrpcWebTransportOptions
): Transport {
const { client, ...opt } = validateNodeTransportOptions(options);
return createTransport({
...opt,
httpClient: client,
});
}