-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathSplitModule.java
More file actions
57 lines (48 loc) · 1.56 KB
/
SplitModule.java
File metadata and controls
57 lines (48 loc) · 1.56 KB
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
package io.split.openfeature;
import dev.openfeature.sdk.exceptions.GeneralError;
import io.split.client.SplitClient;
import io.split.client.SplitClientConfig;
import io.split.client.SplitFactory;
import io.split.client.SplitFactoryBuilder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.net.URISyntaxException;
import java.util.concurrent.TimeoutException;
public class SplitModule {
private static final Logger _log = LoggerFactory.getLogger(SplitModule.class);
private static SplitModule instance = null;
private SplitClient client;
private SplitModule() {
}
public void init(String apiKey) {
SplitClientConfig config = SplitClientConfig.builder()
.setBlockUntilReadyTimeout(10000)
.build();
SplitFactory splitFactory;
try {
splitFactory = SplitFactoryBuilder.build(apiKey, config);
} catch (IOException | URISyntaxException e) {
// exception occurred
throw new GeneralError("Error occurred creating split factory", e);
}
this.client = splitFactory.client();
try {
this.client.blockUntilReady();
} catch (InterruptedException e) {
_log.error("Interrupted Exception: ", e);
Thread.currentThread().interrupt();
} catch (TimeoutException e) {
throw new GeneralError("Error occurred initializing the client.", e);
}
}
public static SplitModule getInstance() {
if (instance == null) {
instance = new SplitModule();
}
return instance;
}
public io.split.client.SplitClient getClient() {
return client;
}
}