-
Notifications
You must be signed in to change notification settings - Fork 40
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #141 from ahjohannessen/wip-change-aliases
client: clean up eventstore package object
- Loading branch information
Showing
4 changed files
with
269 additions
and
252 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,190 @@ | ||
package eventstore | ||
|
||
import eventstore.core.{settings ⇒ cs} | ||
import eventstore.{core ⇒ c} | ||
|
||
trait CoreCompat { | ||
|
||
private lazy val RequireMaster: Boolean = Settings.Default.requireMaster | ||
private lazy val ResolveLinkTos: Boolean = Settings.Default.resolveLinkTos | ||
private lazy val ReadBatchSize: Int = Settings.Default.readBatchSize | ||
|
||
object WriteEvents { | ||
|
||
def unapply(arg: c.WriteEvents): Option[(c.EventStream.Id, List[c.EventData], c.ExpectedVersion, Boolean)] = | ||
c.WriteEvents.unapply(arg) | ||
|
||
def apply( | ||
streamId: c.EventStream.Id, | ||
events: List[c.EventData], | ||
expectedVersion: c.ExpectedVersion = c.ExpectedVersion.Any, | ||
requireMaster: Boolean = RequireMaster | ||
): c.WriteEvents = c.WriteEvents(streamId, events, expectedVersion, requireMaster) | ||
|
||
object StreamMetadata { | ||
|
||
def apply( | ||
streamId: c.EventStream.Metadata, | ||
data: c.Content, | ||
expectedVersion: c.ExpectedVersion = c.ExpectedVersion.Any, | ||
requireMaster: Boolean = RequireMaster | ||
): c.WriteEvents = c.WriteEvents.StreamMetadata(streamId, data, randomUuid, expectedVersion, requireMaster) | ||
|
||
} | ||
} | ||
|
||
object DeleteStream { | ||
|
||
def unapply(arg: c.DeleteStream): Option[(c.EventStream.Id, c.ExpectedVersion.Existing, Boolean, Boolean)] = | ||
c.DeleteStream.unapply(arg) | ||
|
||
def apply( | ||
streamId: c.EventStream.Id, | ||
expectedVersion: c.ExpectedVersion.Existing = c.ExpectedVersion.Any, | ||
hard: Boolean = false, | ||
requireMaster: Boolean = RequireMaster | ||
): c.DeleteStream = c.DeleteStream(streamId, expectedVersion, hard, requireMaster) | ||
} | ||
|
||
object TransactionStart { | ||
|
||
def unapply(arg: c.TransactionStart): Option[(c.EventStream.Id, c.ExpectedVersion, Boolean)] = | ||
c.TransactionStart.unapply(arg) | ||
|
||
def apply( | ||
streamId: c.EventStream.Id, | ||
expectedVersion: c.ExpectedVersion = c.ExpectedVersion.Any, | ||
requireMaster: Boolean = RequireMaster | ||
): c.TransactionStart = c.TransactionStart(streamId, expectedVersion, requireMaster) | ||
} | ||
|
||
object TransactionWrite { | ||
|
||
def unapply(arg: c.TransactionWrite): Option[(Long, List[c.EventData], Boolean)] = | ||
c.TransactionWrite.unapply(arg) | ||
|
||
def apply( | ||
transactionId: Long, | ||
events: List[c.EventData], | ||
requireMaster: Boolean = RequireMaster | ||
): c.TransactionWrite = c.TransactionWrite(transactionId, events, requireMaster) | ||
} | ||
|
||
object TransactionCommit { | ||
|
||
def unapply(arg: c.TransactionCommit): Option[(Long, Boolean)] = | ||
c.TransactionCommit.unapply(arg) | ||
|
||
def apply( | ||
transactionId: Long, | ||
requireMaster: Boolean = RequireMaster | ||
): c.TransactionCommit = c.TransactionCommit(transactionId, requireMaster) | ||
} | ||
|
||
|
||
object ReadEvent { | ||
|
||
def unapply(arg: c.ReadEvent): Option[(c.EventStream.Id, c.EventNumber, Boolean, Boolean)] = | ||
c.ReadEvent.unapply(arg) | ||
|
||
def apply( | ||
streamId: c.EventStream.Id, | ||
eventNumber: c.EventNumber = c.EventNumber.First, | ||
resolveLinkTos: Boolean = ResolveLinkTos, | ||
requireMaster: Boolean = RequireMaster | ||
): c.ReadEvent = c.ReadEvent(streamId, eventNumber, resolveLinkTos, requireMaster) | ||
|
||
object StreamMetadata { | ||
def apply( | ||
streamId: c.EventStream.Metadata, | ||
eventNumber: c.EventNumber = c.EventNumber.Last, | ||
resolveLinkTos: Boolean = ResolveLinkTos, | ||
requireMaster: Boolean = RequireMaster | ||
): c.ReadEvent = c.ReadEvent.StreamMetadata(streamId, eventNumber, resolveLinkTos, requireMaster) | ||
} | ||
} | ||
|
||
object ReadStreamEvents { | ||
|
||
def unapply(arg: c.ReadStreamEvents): Option[(c.EventStream.Id, c.EventNumber, Int, c.ReadDirection, Boolean, Boolean)] = | ||
c.ReadStreamEvents.unapply(arg) | ||
|
||
def apply( | ||
streamId: c.EventStream.Id, | ||
fromNumber: c.EventNumber = c.EventNumber.First, | ||
maxCount: Int = ReadBatchSize, | ||
direction: c.ReadDirection = c.ReadDirection.Forward, | ||
resolveLinkTos: Boolean = ResolveLinkTos, | ||
requireMaster: Boolean = RequireMaster | ||
): c.ReadStreamEvents = c.ReadStreamEvents(streamId, fromNumber, maxCount, direction, resolveLinkTos, requireMaster) | ||
} | ||
|
||
object ReadAllEvents { | ||
|
||
def unapply(arg: c.ReadAllEvents): Option[(c.Position, Int, c.ReadDirection, Boolean, Boolean)] = | ||
c.ReadAllEvents.unapply(arg) | ||
|
||
def apply( | ||
fromPosition: c.Position = c.Position.First, | ||
maxCount: Int = ReadBatchSize, | ||
direction: c.ReadDirection = c.ReadDirection.Forward, | ||
resolveLinkTos: Boolean = ResolveLinkTos, | ||
requireMaster: Boolean = RequireMaster | ||
): c.ReadAllEvents = c.ReadAllEvents(fromPosition, maxCount, direction, resolveLinkTos, requireMaster) | ||
} | ||
|
||
object PersistentSubscriptionSettings { | ||
import com.typesafe.config.{Config, ConfigFactory} | ||
|
||
lazy val Default: cs.PersistentSubscriptionSettings = apply(ConfigFactory.load()) | ||
def apply(conf: Config): cs.PersistentSubscriptionSettings = cs.PersistentSubscriptionSettings(conf) | ||
} | ||
|
||
object PersistentSubscription { | ||
|
||
import PersistentSubscriptionSettings.{Default ⇒ D} | ||
import c.EventStream.Id | ||
import c.{PersistentSubscription ⇒ PS} | ||
import cs.{PersistentSubscriptionSettings ⇒ PSS} | ||
|
||
def create(streamId: Id, groupName: String, settings: PSS): Create = Create(streamId, groupName, settings) | ||
def update(streamId: Id, groupName: String, settings: PSS): Update = Update(streamId, groupName, settings) | ||
def delete(streamId: Id, groupName: String): Delete = Delete(streamId, groupName) | ||
|
||
object Create { | ||
def unapply(arg: Create): Option[(Id, String, PSS)] = PS.Create.unapply(arg) | ||
def apply(streamId: Id, groupName: String, settings: PSS = D): Create = PS.Create(streamId, groupName, settings) | ||
} | ||
|
||
object Update { | ||
def unapply(arg: Update): Option[(Id, String, PSS)] = PS.Update.unapply(arg) | ||
def apply(streamId: Id, groupName: String, settings: PSS = D): Update = PS.Update(streamId, groupName, settings) | ||
} | ||
|
||
type Create = PS.Create | ||
val CreateCompleted = PS.CreateCompleted | ||
type Update = PS.Update | ||
val UpdateCompleted = PS.UpdateCompleted | ||
type Delete = PS.Delete | ||
val Delete = PS.Delete | ||
val DeleteCompleted = PS.DeleteCompleted | ||
type Ack = PS.Ack | ||
val Ack = PS.Ack | ||
type Nak = PS.Nak | ||
val Nak = PS.Nak | ||
type Connect = PS.Connect | ||
val Connect = PS.Connect | ||
type Connected = PS.Connected | ||
val Connected = PS.Connected | ||
type EventAppeared = PS.EventAppeared | ||
val EventAppeared = PS.EventAppeared | ||
|
||
} | ||
|
||
object SubscribeTo { | ||
def unapply(arg: c.SubscribeTo): Option[(c.EventStream, Boolean)] = c.SubscribeTo.unapply(arg) | ||
def apply(stream: c.EventStream, resolveLinkTos: Boolean = ResolveLinkTos): c.SubscribeTo = c.SubscribeTo(stream, resolveLinkTos) | ||
} | ||
} | ||
|
||
object compat extends CoreCompat |
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.