Config loading and Schema validation/transform. Use when defining configuration or validating inputs.
import { Config } from "effect"
const Server = Config.nested("SERVER")(Config.all({
host: Config.string("HOST"),
port: Config.number("PORT")
}))
import { Schema as S } from "effect"
const User = S.Struct({ id: S.Number, name: S.String })
const decodeUser = (u: unknown) => S.decodeUnknown(User)(u)
const IsoDate = S.String // then transform to Date in pipeline where needed
class AwsCredentials extends Effect.Service<AwsCredentials>()("AwsCredentials", {
effect: Effect.gen(function* () {
const accessKeys = yield* Config.option(
Config.all([Config.string("CAP_AWS_ACCESS_KEY"), Config.string("CAP_AWS_SECRET_KEY")])
)
const vercelAwsRole = yield* Config.option(Config.string("VERCEL_AWS_ROLE_ARN"))
const credentials = yield* Effect.gen(function* () {
if (Option.isSome(vercelAwsRole)) return awsCredentialsProvider({ roleArn: vercelAwsRole.value })
if (Option.isSome(accessKeys)) {
const [accessKeyId, secretAccessKey] = accessKeys.value
return { accessKeyId, secretAccessKey }
}
return fromContainerMetadata()
})
return { credentials }
})
})
unknown into core → always decode firstCRITICAL: Search local Effect source before implementing
The full Effect source code is available at docs/effect-source/. Always search the actual implementation before writing Effect code.
docs/effect-source/effect/src/Config.tsdocs/effect-source/schema/src/Schema.ts# Find Config patterns and options
grep -F "Config.string" docs/effect-source/effect/src/Config.ts
grep -F "Config.number" docs/effect-source/effect/src/Config.ts
grep -F "Config.option" docs/effect-source/effect/src/Config.ts
# Study Schema validation
grep -F "Struct" docs/effect-source/schema/src/Schema.ts
grep -F "decodeUnknown" docs/effect-source/schema/src/Schema.ts
# Find Schema transforms
grep -rF "transform" docs/effect-source/schema/src/
grep -rF "brand" docs/effect-source/schema/src/
# Look at Config test examples
grep -F "Config." docs/effect-source/effect/test/Config.test.ts
docs/effect-source/effect/src/Config.ts or docs/effect-source/schema/src/Schema.tsReal source code > documentation > assumptions