Class: Toys::Middleware::Stack

Inherits:
Object
  • Object
show all
Defined in:
lib/toys/middleware.rb

Overview

A stack of middleware specs, which can be applied in order to a tool.

A middleware stack is separated into three groups:

  • #pre_specs, which are applied first.
  • #default_specs, which are applied next. The default specs are set when the stack is created and are generally not modified.
  • #post_specs, which are applied third.

When adding middleware to a stack, you should normally add them to the pre or post specs. By default, #add appends to the pre specs, inserting new middleware just before the defaults.

Use stack to create a middleware stack.

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#default_specsArray<Toys::Middleware:Spec> (readonly)

The default set of middleware specs.

Returns:

  • (Array<Toys::Middleware:Spec>)


311
312
313
# File 'lib/toys/middleware.rb', line 311

def default_specs
  @default_specs
end

#post_specsArray<Toys::Middleware:Spec> (readonly)

The middleware specs that follow the default set.

Returns:

  • (Array<Toys::Middleware:Spec>)


317
318
319
# File 'lib/toys/middleware.rb', line 317

def post_specs
  @post_specs
end

#pre_specsArray<Toys::Middleware:Spec> (readonly)

The middleware specs that precede the default set.

Returns:

  • (Array<Toys::Middleware:Spec>)


305
306
307
# File 'lib/toys/middleware.rb', line 305

def pre_specs
  @pre_specs
end

Instance Method Details

#==(other) ⇒ Boolean Also known as: eql?

Equality check

Parameters:

  • other (Object)

Returns:

  • (Boolean)


358
359
360
361
362
363
# File 'lib/toys/middleware.rb', line 358

def ==(other)
  other.is_a?(Stack) &&
    pre_specs.eql?(other.pre_specs) &&
    default_specs.eql?(other.default_specs) &&
    post_specs.eql?(other.post_specs)
end

#add(name, *args, **kwargs, &block) ⇒ Object #add(array) ⇒ Object #add(middleware_object) ⇒ Object

Add a middleware spec to the stack, in the default location, which is at the end of pre_specs). See Toys::Middleware.spec for a description of the arguments you can pass.



328
329
330
# File 'lib/toys/middleware.rb', line 328

def add(middleware, *args, **kwargs, &block)
  pre_specs.push(Middleware.spec(middleware, *args, **kwargs, &block))
end

#build(middleware_lookup) ⇒ Array<Toys::Middleware>

Build the middleware in this stack.

Returns:



348
349
350
# File 'lib/toys/middleware.rb', line 348

def build(middleware_lookup)
  (@pre_specs + @default_specs + @post_specs).map { |spec| spec.build(middleware_lookup) }
end

#dupToys::Middleware::Stack

Duplicate this stack.



337
338
339
340
341
# File 'lib/toys/middleware.rb', line 337

def dup
  Stack.new(pre_specs: pre_specs.dup,
            post_specs: post_specs.dup,
            default_specs: default_specs.dup)
end

#hashInteger

Return the hash code

Returns:

  • (Integer)


371
372
373
# File 'lib/toys/middleware.rb', line 371

def hash
  [@pre_specs, @default_specs, @post_specs].hash
end