# frozen_string_literal: true module ConvenientService module Core module Entities class Config module Entities class MethodMiddlewares module Entities ## # @internal # TODO: Better error explanations. # class Stack ## # @overload initialize(name:) # @param name [String] # @return [void] # # @overload initialize(plain_stack:) # @param name [ConvenientService::Support::Middleware::StackBuilder] # @return [void] # def initialize(name: nil, plain_stack: nil) @plain_stack = plain_stack || Support::Middleware::StackBuilder.new(name: name) end ## # @return [String] # def name plain_stack.name end ## # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # def dup self.class.new(plain_stack: plain_stack.dup) end ## # @param env [Hash] # @return [Object] Can be any type. # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L132 # def call(env) plain_stack.call(env) end ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # def unshift(middleware, *args, &block) plain_stack.unshift(middleware, *args, &block) self end ## # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # alias_method :prepend, :unshift ## # @param index_or_middleware [Integer, ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L88 # def insert(index_or_middleware, middleware, *args, &block) plain_stack.insert(index_or_middleware, middleware, *args, &block) self end ## # @see insert # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L94 # alias_method :insert_before, :insert ## # @param index_or_middleware [Integer, ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L97 # def insert_after(index_or_middleware, middleware, *args, &block) plain_stack.insert_after(index_or_middleware, middleware, *args, &block) self end ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L104 # def insert_before_each(middleware, *args, &block) plain_stack.insert_before_each(middleware, *args, &block) self end ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L111 # def insert_after_each(middleware, *args, &block) plain_stack.insert_after_each(middleware, *args, &block) self end ## # @param index_or_middleware [Integer, ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L118 # def replace(index_or_middleware, middleware, *args, &block) plain_stack.replace(index_or_middleware, middleware, *args, &block) self end ## # @param index_or_middleware [Integer, ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L126 # def delete(index_or_middleware) plain_stack.delete(index_or_middleware) self end ## # @return [ConvenientService::Core::Entities::Config::Entities::Concerns::Entities::Stack] # alias_method :remove, :delete ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @see https://github.com/marian13/ruby-middleware/blob/v0.4.2/lib/middleware/builder.rb#L76 # def use(middleware, *args, &block) plain_stack.use(middleware, *args, &block) self end ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @note `observe` exists only for testing purposes. Do NOT use it in production code. # # @internal # TODO: Raise if middleware is NOT used yet. # def observe(middleware, *args, &block) plain_stack.replace(middleware, middleware.observable, *args, &block) self end ## # @param middleware [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Middlewares::Base] # @param args [Array] # @param block [Proc, nil] # @return [ConvenientService::Core::Entities::Config::Entities::MethodMiddlewares::Entities::Stack] # # @note `use_and_observe` exists only for testing purposes. Do NOT use it in production code. # def use_and_observe(middleware, *args, &block) plain_stack.use(middleware.observable, *args, &block) self end ## # @return [Boolean] # def empty? to_a.empty? end ## # @param other [ConvenientService::Core::Entities::Config::Entities::Concerns::Entities::Stack, Object] # @return [Boolean, nil] # def ==(other) return unless other.instance_of?(self.class) return false if plain_stack != other.plain_stack true end ## # @return [Array] # def to_a plain_stack.to_a end protected ## # @!attribute [r] plain_stack # @return [ConvenientService::Support::Middleware::StackBuilder] # attr_reader :plain_stack end end end end end end end end