domata-core_sjs1_3.0.12.5.source-code.CQRSDomainDSL.scala Maven / Gradle / Ivy
/*
* Copyright 2021 Hossein Naderi
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package edomata.core
import cats.*
import cats.data.*
import cats.implicits.*
final class CQRSDomainDSL[C, S, R, N](
private val dummy: Boolean = true
) extends AnyVal {
type App[F[_], T] = Stomaton[F, CommandMessage[C], S, R, N, T]
inline def pure[F[_]: Monad, T](
t: T
): App[F, T] =
Stomaton.pure(t)
inline def unit[F[_]: Monad]: App[F, Unit] =
Stomaton.unit
inline def eval[F[_]: Applicative, T](
f: F[T]
): App[F, T] = Stomaton.eval(f)
inline def set[F[_]: Applicative](
s: S
): App[F, Unit] =
Stomaton.set(s)
/** constructs an stomaton that outputs what's read */
inline def modify[F[_]: Applicative](
f: S => S
): App[F, S] =
Stomaton.modify(f)
inline def decideS[F[_]: Applicative](
f: S => EitherNec[R, S]
): App[F, S] =
Stomaton.decideS(f)
inline def decide[F[_]: Applicative, T](
f: => EitherNec[R, T]
): App[F, T] = Stomaton.decide(f)
/** constructs an stomaton that decides to modify state based on current state
*/
inline def modifyS[F[_]: Applicative](
f: S => EitherNec[R, S]
): App[F, S] = Stomaton.modifyS(f)
inline def reject[F[_]: Applicative, T](
r: R,
rs: R*
): App[F, T] =
Stomaton.reject(r, rs: _*)
inline def validate[F[_]: Applicative, T](
v: ValidatedNec[R, T]
): App[F, T] =
Stomaton.validate(v)
inline def fromOption[F[_]: Applicative, T](
opt: Option[T],
orElse: R,
other: R*
): App[F, T] = Stomaton.fromOption(opt, orElse, other: _*)
inline def fromEither[F[_]: Applicative, T](
eit: Either[R, T]
): App[F, T] = Stomaton.fromEither(eit)
inline def fromEitherNec[F[_]: Applicative, T](
eit: EitherNec[R, T]
): App[F, T] = Stomaton.fromEitherNec(eit)
inline def publish[F[_]: Applicative](
ns: N*
): App[F, Unit] =
Stomaton.publish(ns: _*)
inline def state[F[_]: Monad]: App[F, S] =
Stomaton.state
inline def context[F[_]: Monad]: App[F, CommandMessage[C]] =
Stomaton.context
inline def aggregateId[F[_]: Monad]: App[F, String] =
Stomaton.context.map(_.address)
inline def metadata[F[_]: Monad]: App[F, MessageMetadata] =
Stomaton.context.map(_.metadata)
inline def messageId[F[_]: Monad]: App[F, String] =
Stomaton.context.map(_.id)
inline def command[F[_]: Monad]: App[F, C] =
Stomaton.context.map(_.payload)
inline def router[F[_]: Monad, T](
f: C => App[F, T]
): App[F, T] =
command.flatMap(f)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy