-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: refactor GrpcConnector to use grpc builtin reconnection
Signed-off-by: Bernd Warmuth <[email protected]>
- Loading branch information
Bernd Warmuth
committed
Dec 18, 2024
1 parent
d8daa07
commit f11e0d5
Showing
15 changed files
with
974 additions
and
1,226 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
110 changes: 80 additions & 30 deletions
110
...rc/main/java/dev/openfeature/contrib/providers/flagd/resolver/common/ConnectionEvent.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,69 +1,119 @@ | ||
package dev.openfeature.contrib.providers.flagd.resolver.common; | ||
|
||
import java.util.Collections; | ||
import java.util.List; | ||
|
||
import dev.openfeature.sdk.ImmutableStructure; | ||
import dev.openfeature.sdk.Structure; | ||
import lombok.AllArgsConstructor; | ||
import lombok.Getter; | ||
|
||
import java.util.Collections; | ||
import java.util.List; | ||
|
||
/** | ||
* Event payload for a | ||
* {@link dev.openfeature.contrib.providers.flagd.resolver.Resolver} connection | ||
* state change event. | ||
* Represents an event payload for a connection state change in a | ||
* {@link dev.openfeature.contrib.providers.flagd.resolver.Resolver}. | ||
* The event includes information about the connection status, any flags that have changed, | ||
* and metadata associated with the synchronization process. | ||
*/ | ||
@AllArgsConstructor | ||
public class ConnectionEvent { | ||
@Getter | ||
private final boolean connected; | ||
|
||
/** | ||
* The current state of the connection. | ||
*/ | ||
private final ConnectionState connected; | ||
|
||
/** | ||
* A list of flags that have changed due to this connection event. | ||
*/ | ||
private final List<String> flagsChanged; | ||
|
||
/** | ||
* Metadata associated with synchronization in this connection event. | ||
*/ | ||
private final Structure syncMetadata; | ||
|
||
/** | ||
* Construct a new ConnectionEvent. | ||
* | ||
* @param connected status of the connection | ||
* Constructs a new {@code ConnectionEvent} with the connection status only. | ||
* | ||
* @param connected {@code true} if the connection is established, otherwise {@code false}. | ||
*/ | ||
public ConnectionEvent(boolean connected) { | ||
this(connected ? ConnectionState.Connected() : ConnectionState.Disconnected(), | ||
Collections.emptyList(), new ImmutableStructure()); | ||
} | ||
|
||
/** | ||
* Constructs a new {@code ConnectionEvent} with the specified connection state. | ||
* | ||
* @param connected the connection state indicating if the connection is established or not. | ||
*/ | ||
public ConnectionEvent(ConnectionState connected) { | ||
this(connected, Collections.emptyList(), new ImmutableStructure()); | ||
} | ||
|
||
/** | ||
* Construct a new ConnectionEvent. | ||
* | ||
* @param connected status of the connection | ||
* @param flagsChanged list of flags changed | ||
* Constructs a new {@code ConnectionEvent} with the specified connection state and changed flags. | ||
* | ||
* @param connected the connection state indicating if the connection is established or not. | ||
* @param flagsChanged a list of flags that have changed due to this connection event. | ||
*/ | ||
public ConnectionEvent(boolean connected, List<String> flagsChanged) { | ||
public ConnectionEvent(ConnectionState connected, List<String> flagsChanged) { | ||
this(connected, flagsChanged, new ImmutableStructure()); | ||
} | ||
|
||
/** | ||
* Construct a new ConnectionEvent. | ||
* | ||
* @param connected status of the connection | ||
* @param syncMetadata sync.getMetadata | ||
* Constructs a new {@code ConnectionEvent} with the specified connection state and synchronization metadata. | ||
* | ||
* @param connected the connection state indicating if the connection is established or not. | ||
* @param syncMetadata metadata related to the synchronization process of this event. | ||
*/ | ||
public ConnectionEvent(boolean connected, Structure syncMetadata) { | ||
public ConnectionEvent(ConnectionState connected, Structure syncMetadata) { | ||
this(connected, Collections.emptyList(), new ImmutableStructure(syncMetadata.asMap())); | ||
} | ||
|
||
/** | ||
* Get changed flags. | ||
* | ||
* @return an unmodifiable view of the changed flags | ||
* Constructs a new {@code ConnectionEvent} with the specified connection state, changed flags, and synchronization metadata. | ||
* | ||
* @param connectionState the state of the connection. | ||
* @param flagsChanged a list of flags that have changed due to this connection event. | ||
* @param syncMetadata metadata related to the synchronization process of this event. | ||
*/ | ||
public ConnectionEvent(ConnectionState connectionState, List<String> flagsChanged, Structure syncMetadata) { | ||
this.connected = connectionState; | ||
this.flagsChanged = flagsChanged != null ? flagsChanged : Collections.emptyList(); // Ensure non-null list | ||
this.syncMetadata = syncMetadata != null ? new ImmutableStructure(syncMetadata.asMap()) : new ImmutableStructure(); // Ensure valid syncMetadata | ||
} | ||
|
||
/** | ||
* Retrieves an unmodifiable view of the list of changed flags. | ||
* | ||
* @return an unmodifiable list of changed flags. | ||
*/ | ||
public List<String> getFlagsChanged() { | ||
return Collections.unmodifiableList(flagsChanged); | ||
} | ||
|
||
/** | ||
* Get changed sync metadata represented as SDK structure type. | ||
* | ||
* @return an unmodifiable view of the sync metadata | ||
* Retrieves the synchronization metadata represented as an immutable SDK structure type. | ||
* | ||
* @return an immutable structure containing the synchronization metadata. | ||
*/ | ||
public Structure getSyncMetadata() { | ||
return new ImmutableStructure(syncMetadata.asMap()); | ||
} | ||
|
||
/** | ||
* Indicates whether the current connection state is connected. | ||
* | ||
* @return {@code true} if connected, otherwise {@code false}. | ||
*/ | ||
public boolean isConnected() { | ||
return this.connected.isConnected(); | ||
} | ||
|
||
/** | ||
* Indicates whether the current connection state is stale. | ||
* | ||
* @return {@code true} if stale, otherwise {@code false}. | ||
*/ | ||
public boolean isStale() { | ||
return this.connected.isStale(); | ||
} | ||
} |
58 changes: 58 additions & 0 deletions
58
...rc/main/java/dev/openfeature/contrib/providers/flagd/resolver/common/ConnectionState.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package dev.openfeature.contrib.providers.flagd.resolver.common; | ||
|
||
import lombok.AllArgsConstructor; | ||
import lombok.Getter; | ||
|
||
/** | ||
* Represents the state of a connection, indicating whether it is connected, | ||
* disconnected, or stale. | ||
* | ||
* This class is immutable and uses the {@link lombok.AllArgsConstructor} annotation | ||
* to generate a constructor with parameters for all fields. | ||
* It also uses {@link lombok.Getter} to provide getter methods for the fields. | ||
*/ | ||
@AllArgsConstructor | ||
public class ConnectionState { | ||
|
||
/** | ||
* Indicates whether the connection is currently active. | ||
*/ | ||
@Getter | ||
private final boolean connected; | ||
|
||
/** | ||
* Indicates whether the connection is stale (e.g., no longer valid or in a degraded state). | ||
*/ | ||
@Getter | ||
private final boolean stale; | ||
|
||
/** | ||
* Returns a {@code ConnectionState} representing a connected state. | ||
* | ||
* @return a new {@code ConnectionState} instance where {@code connected} is {@code true} | ||
* and {@code stale} is {@code false}. | ||
*/ | ||
public static ConnectionState Connected() { | ||
return new ConnectionState(true, false); | ||
} | ||
|
||
/** | ||
* Returns a {@code ConnectionState} representing a disconnected state. | ||
* | ||
* @return a new {@code ConnectionState} instance where {@code connected} is {@code false} | ||
* and {@code stale} is {@code false}. | ||
*/ | ||
public static ConnectionState Disconnected() { | ||
return new ConnectionState(false, false); | ||
} | ||
|
||
/** | ||
* Returns a {@code ConnectionState} representing a stale state. | ||
* | ||
* @return a new {@code ConnectionState} instance where {@code connected} is {@code false} | ||
* and {@code stale} is {@code true}. | ||
*/ | ||
public static ConnectionState Stale() { | ||
return new ConnectionState(false, true); | ||
} | ||
} |
Oops, something went wrong.