Slide 1

Slide 1 text

No content

Slide 2

Slide 2 text

   

Slide 3

Slide 3 text

  

Slide 4

Slide 4 text

No content

Slide 5

Slide 5 text

No content

Slide 6

Slide 6 text

No content

Slide 7

Slide 7 text

Effect Effect Success: Error Requirements

Slide 8

Slide 8 text

import { Cause, Effect } from 'effect'; Effect.succeed({ id: 1n, name: 'yasaichi' }) satisfies Effect.Effect; const getUserRequest = ( userId: bigint ): Effect.Effect => Effect.tryPromise(() => fetch(`${API_ORIGIN}/users/${userId}`).then((res) => res.json()) ); const parseUser = (data: unknown): Effect.Effect => Effect.try({ try: () => User.parse(data), catch: () => new Error('Failed to parse user'), });

Slide 9

Slide 9 text

No content

Slide 10

Slide 10 text

// Unlike Promises, you must explicitly run effects using these methods. await Effect.runPromise(getUserRequest(1n)); // => { id: "1", name: "yasaichi", ... } // You do not use `runSync` usually because there is no way to know in advance // if an effect will execute synchronously or asynchronously. Effect.runSync(parseUser({ id: '1', name: '' })); // throws (FiberFailure) Error: Failed to parse user

Slide 11

Slide 11 text

// Using Pipe & Functor/Monad const getUserByIdUsingPipe = ( userId: bigint ): Effect.Effect => getUserRequest(userId).pipe(Effect.andThen(parseUser)); // Using Generator & yield* const getUserByIdUsingGenerator = ( userId: bigint ): Effect.Effect => Effect.gen(function* () { const res = yield* getUserRequest(userId); return yield* parseUser(res); });

Slide 12

Slide 12 text

No content

Slide 13

Slide 13 text

No content

Slide 14

Slide 14 text

No content

Slide 15

Slide 15 text

No content

Slide 16

Slide 16 text

No content

Slide 17

Slide 17 text

No content