forked from grpc/grpc-java
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCompressorRegistry.java
77 lines (67 loc) · 2.37 KB
/
CompressorRegistry.java
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
/*
* Copyright 2015 The gRPC Authors
*
* 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.
*/
package io.grpc;
import static com.google.common.base.Preconditions.checkArgument;
import com.google.common.annotations.VisibleForTesting;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import javax.annotation.Nullable;
import javax.annotation.concurrent.ThreadSafe;
/**
* Encloses classes related to the compression and decompression of messages.
*/
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/1704")
@ThreadSafe
public final class CompressorRegistry {
private static final CompressorRegistry DEFAULT_INSTANCE = new CompressorRegistry(
new Codec.Gzip(),
Codec.Identity.NONE);
/**
* Returns the default instance used by gRPC when the registry is not specified.
* Currently the registry just contains support for gzip.
*/
public static CompressorRegistry getDefaultInstance() {
return DEFAULT_INSTANCE;
}
/**
* Returns a new instance with no registered compressors.
*/
public static CompressorRegistry newEmptyInstance() {
return new CompressorRegistry();
}
private final ConcurrentMap<String, Compressor> compressors;
@VisibleForTesting
CompressorRegistry(Compressor ...cs) {
compressors = new ConcurrentHashMap<>();
for (Compressor c : cs) {
compressors.put(c.getMessageEncoding(), c);
}
}
@Nullable
public Compressor lookupCompressor(String compressorName) {
return compressors.get(compressorName);
}
/**
* Registers a compressor for both decompression and message encoding negotiation.
*
* @param c The compressor to register
*/
public void register(Compressor c) {
String encoding = c.getMessageEncoding();
checkArgument(!encoding.contains(","), "Comma is currently not allowed in message encoding");
compressors.put(encoding, c);
}
}