-
Notifications
You must be signed in to change notification settings - Fork 56
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(EDR): adds EDR state machine for handling EDR renewal
- Loading branch information
Showing
54 changed files
with
2,313 additions
and
186 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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# EDR core extension | ||
|
||
This extension provide a base implementation of `EdrManager` and `EdrService` both | ||
required for interacting with the EDR APIs and state machine | ||
|
||
The EDR state machine handle the lifecycle of a negotiated EDR. The negotiation request can be submitted | ||
via EDR APIs, and it will go through two phases: | ||
|
||
- Contract Negotiation | ||
- Transfer Request | ||
|
||
Once the latter has completed the EDR entry will be saved with the associated EDR in the primordial state `NEGOTIATED` | ||
The state machine will also manage the lifecycle and the renewal of the `EDR`. If a token is about to expire it will | ||
transition to the `REFRESHING` state and fire off another transfer process with the same parameter of the expiring | ||
one. Once completed the new `EDR` will be cached and the old ones, with same `assetId` and `agreementId` will transition | ||
into the `EXPIRED` state. Then the state machine will also monitor the `EXPIRED` ones, and will delete them according to the | ||
retention configuration. | ||
|
||
## 1. EDR state machine Configuration | ||
|
||
| Key | Description | Mandatory | Default | | ||
|:--------------------------------------------|:----------------------------------------------------------------------------------------------------|-----------|---------| | ||
| edc.edr.state-machine.iteration-wait-millis | The iteration wait time in milliseconds in the edr state machine | | 1000 | | ||
| edc.edr.state-machine.batch-size | The batch size in the edr negotiation state machine | | 20 | | ||
| edc.edr.state-machine.expiring-duration | The minimum duration on which the EDR token can be eligible for renewal (seconds) | | 60 | | ||
| edc.edr.state-machine.expired-retention | The minimum duration on with the EDR token can be eligible for deletion when it's expired (seconds) | | 60 | |
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
Oops, something went wrong.