Children
Goals
- Preservation storage
- Simplicity
- Performance
Implementation Plan
- Remove Modeshape (done)
- Create 2-3 APIs to allow plugging in new backends
- Implement OCFL
Major CRUD-Related Interfaces (Out of date)
Gliffy Diagram |
---|
name | Major interfaces and their interactions |
---|
pagePin | 14 |
---|
|
Use Case: Simple OCFL - based implementation
Gliffy Diagram |
---|
name | Simple OCFL implementation |
---|
pagePin | 6 |
---|
|
OCFL Client with persistent database as authoritative metadata source
Gliffy Diagram |
---|
name | ocfl client with database as authoritative metadata source |
---|
pagePin | 8 |
---|
|
Use Case - Horizontally-Scaled Fedora Instances Running against a single OCFL
Gliffy Diagram |
---|
name | horizontally scaled fedora |
---|
pagePin | 9 |
---|
|
WIP: Persistent vs Derived Application State
This diagram highlights the logical division of persistent content as well a derived state that persists across instance restarts.
Gliffy Diagram |
---|
name | Persistent Storage |
---|
pagePin | 6 |
---|
|
WIP: Fedora Session to OCFL Session Management - try to understand how Fedora Transactions (managed by FedoraSession) would map to a set of OCFL Sessions.
The problem: A Fedora transaction may span multiple HTTP Requests. Assuming that we do not want to commit anything to OCFL until the Fedora Transaction is committed, how do we maintain the state of open OCFL Sessions
across requests. How also do we ensure that two requests using the same transaction ID do not stomp on each other? It seems that this is only becomes a problem if we want to support autoscaling of Fedora instances.
...
- (done)
- Implement OCFL - Fedora interaction
OCFL Representation of Fedora Resources: