Sha256: a2f2f50b3599ab203ff95dcbbfbc5a0c3efd568e2c4889c38e462a5ce1405f2f
Contents?: true
Size: 1.91 KB
Versions: 1
Compression:
Stored size: 1.91 KB
Contents
# frozen_string_literal: true require "dry/core" require "dry/configurable" require "dry/logic" require "dry/types" require "dry/schema/config" require "dry/schema/constants" require "dry/schema/dsl" require "dry/schema/params" require "dry/schema/json" module Dry # Main interface # # @api public module Schema extend Dry::Core::Extensions # Configuration # # @example # Dry::Schema.config.messages.backend = :i18n # # @return [Config] # # @api public def self.config @config ||= Config.new end # Define a schema # # @example # Dry::Schema.define do # required(:name).filled(:string) # required(:age).value(:integer, gt?: 0) # end # # @param [Hash] options # # @return [Processor] # # @see DSL.new # # @api public def self.define(**options, &block) DSL.new(**options, &block).call end # Define a schema suitable for HTTP params # # This schema type uses `Types::Params` for coercion by default # # @example # Dry::Schema.Params do # required(:name).filled(:string) # required(:age).value(:integer, gt?: 0) # end # # @return [Params] # # @see Schema#define # # @api public def self.Params(**options, &block) define(**options, processor_type: Params, &block) end singleton_class.send(:alias_method, :Form, :Params) # Define a schema suitable for JSON data # # This schema type uses `Types::JSON` for coercion by default # # @example # Dry::Schema.JSON do # required(:name).filled(:string) # required(:age).value(:integer, gt?: 0) # end # # @return [Params] # # @see Schema#define # # @api public def self.JSON(**options, &block) define(**options, processor_type: JSON, &block) end end end require "dry/schema/extensions"
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
dry-schema-1.10.3 | lib/dry/schema.rb |