yake 0.1.4 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 47b755f324408681d9e9d4e46fb13dda73624e023467f5477b568535b0ceecd9
4
- data.tar.gz: 2870d5e7a9d3ed5ba7b179f032c656cac5fb0e61f94eb65ba648d0ba303e819d
3
+ metadata.gz: 498a95a56043103e5ab1315fefef95a6f55a27136fe5013df544e3fe83ed77dc
4
+ data.tar.gz: 92dfac92a9036c96ea622228795e268b906f156b526b1a1cb46313fa2f4af0c8
5
5
  SHA512:
6
- metadata.gz: 8fcf70ec87e8c199218e84e789a7b4231fc6186158131256a66bd590f2843a1bac16b90900e7d68fde2325ce75b8125af9113710a748dc13f70fa3cec9053507
7
- data.tar.gz: a0b103f2416df14640927006993e2ad991444329060f541f337c7c59385d4fb8c6a063a7184d065b24f7f34dba2501cd1a5b492fe8e3a3cfd73ba57e5ed5d5a6
6
+ metadata.gz: b26c78cfe69bb588cf37bafeeacc53314e40106eb38416d6b52dd652e2a954c3767fb5c4f5852ea3d132558f69a6d512cfbc48f6c11f766e3a099a5bb7c95697
7
+ data.tar.gz: c063851aac6c3554dd36a05db53e846d835019bf973c0b060b6cf673697350eeeba6d3ddb0585eaeed92fd165bf1767cf0f9fb0e514ef49c16de604f04783f03
data/README.md CHANGED
@@ -88,6 +88,17 @@ This feature can be disabled by adding a declaration in your handler file:
88
88
  logging :off
89
89
  ```
90
90
 
91
+ Include `Yake::Logger` on a class to access this logger:
92
+
93
+ ```ruby
94
+ class Fizz
95
+ include Yake::Logger
96
+ end
97
+
98
+ Fizz.new.logger == Yake.logger
99
+ # => true
100
+ ```
101
+
91
102
  #### API Routes
92
103
 
93
104
  A common use of Lambda functions is as a proxy for API Gateway. Oftentimes users will deploy a single Lambda function to handle all requests coming from API Gateway.
@@ -97,6 +108,10 @@ Requiring the `yake/api` module will add the API-specific DSL into your handler.
97
108
  Define API routes using Sinatra-like syntax
98
109
 
99
110
  ```ruby
111
+ any "/…" do |event|
112
+ # Handle 'ANY /…' route key events
113
+ end
114
+
100
115
  delete "/…" do |event|
101
116
  # Handle 'DELETE /…' route key events
102
117
  end
data/lib/yake/api.rb CHANGED
@@ -11,7 +11,7 @@ module Yake
11
11
  module DSL
12
12
  ##
13
13
  # Proxy handler for HTTP requests from Slack
14
- def route(event, context = nil)
14
+ def route(event, context = nil, &block)
15
15
  # Extract route method
16
16
  method = event["routeKey"]
17
17
  raise Yake::Errors::UndeclaredRoute, method unless respond_to?(method)
@@ -26,7 +26,7 @@ module Yake
26
26
  end
27
27
 
28
28
  # Execute request
29
- send(method, event, context)
29
+ send(method, event, context).then { |res| block_given? ? yield(res) : res }
30
30
  end
31
31
 
32
32
  ##
@@ -55,6 +55,12 @@ module Yake
55
55
  (@headers ||= {}).update(headers)
56
56
  end
57
57
 
58
+ ##
59
+ # Define ANY route
60
+ def any(path, &block)
61
+ define_singleton_method("ANY #{ path }") { |*args| instance_exec(*args, &block) }
62
+ end
63
+
58
64
  ##
59
65
  # Define DELETE route
60
66
  def delete(path, &block)
data/lib/yake/dsl.rb CHANGED
@@ -10,17 +10,23 @@ module Yake
10
10
  # Lambda handler task wrapper
11
11
  def handler(name, &block)
12
12
  define_method(name) do |event:nil, context:nil|
13
- Yake.logger.nil? ? yield(event, context) : Yake.logger.wrap(event, context, &block)
13
+ Yake.wrap(event, context, &block)
14
14
  end
15
15
  end
16
16
 
17
+ ##
18
+ # Helper to get logger
19
+ def logger
20
+ Yake.logger
21
+ end
22
+
17
23
  ##
18
24
  # Turn logging on/off
19
- def logging(switch, logdev = $stdout, **options)
25
+ def logging(switch, logger = nil)
20
26
  if switch == :on
21
- Yake.logger = Yake::Logger.new(logdev)
27
+ Yake.logger = logger
22
28
  elsif switch == :off
23
- Yake.logger = Yake::Logger.new(nil)
29
+ Yake.logger = ::Logger.new(nil)
24
30
  else
25
31
  raise Errors::UnknownLoggingSetting, switch
26
32
  end
data/lib/yake/logger.rb CHANGED
@@ -4,37 +4,42 @@ require "json"
4
4
  require "logger"
5
5
 
6
6
  module Yake
7
- class Logger < ::Logger
8
- def initialize(logdev = $stdout, *)
9
- super
10
- @progname = "-"
11
- @formatter = LambdaFormatter.new
7
+ module Logger
8
+ attr_accessor :logger
9
+
10
+ def logger
11
+ @logger ||= Yake.logger
12
12
  end
13
13
 
14
- def wrap(event = nil, context = nil, &block)
15
- @progname = "RequestId: #{ context.aws_request_id }" if context.respond_to?(:aws_request_id)
16
- info("EVENT #{ event.to_json }")
17
- yield(event, context).tap { |res| info("RETURN #{ res.to_json }") }
18
- ensure
19
- @progname = "-"
14
+ class << self
15
+ def new(logdev = $stdout, **params)
16
+ ::Logger.new(logdev, formatter: Formatter.new, **params)
17
+ end
20
18
  end
21
- end
22
19
 
23
- class LambdaFormatter < ::Logger::Formatter
24
- Format = "%s %s %s\n"
20
+ class Formatter < ::Logger::Formatter
21
+ Format = "%s %s %s\n"
25
22
 
26
- def call(severity, time, progname, msg)
27
- Format % [ severity, progname, msg2str(msg).strip ]
23
+ def call(severity, time, progname, msg)
24
+ Format % [ severity, progname.nil? ? "-" : "RequestId: #{ progname }", msg2str(msg).strip ]
25
+ end
28
26
  end
29
27
  end
30
28
 
31
- module Loggable
29
+ class << self
32
30
  attr_accessor :logger
33
31
 
34
32
  def logger
35
33
  @logger ||= Logger.new
36
34
  end
37
- end
38
35
 
39
- extend Loggable
36
+ def wrap(event = nil, context = nil, &block)
37
+ original_progname = logger.progname
38
+ logger.progname = context&.aws_request_id
39
+ logger.info("EVENT #{ event.to_json }")
40
+ yield(event, context).tap { |res| logger.info("RETURN #{ res.to_json }") }
41
+ ensure
42
+ logger.progname = original_progname
43
+ end
44
+ end
40
45
  end
data/lib/yake/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Yake
4
- VERSION = "0.1.4"
4
+ VERSION = "0.3.0"
5
5
  end
metadata CHANGED
@@ -1,16 +1,16 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: yake
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.4
4
+ version: 0.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Alexander Mancevice
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-04-30 00:00:00.000000000 Z
11
+ date: 2021-06-28 00:00:00.000000000 Z
12
12
  dependencies: []
13
- description:
13
+ description:
14
14
  email:
15
15
  - alexander.mancevice@hey.com
16
16
  executables: []
@@ -30,7 +30,7 @@ homepage: https://github.com/amancevice/yake
30
30
  licenses:
31
31
  - MIT
32
32
  metadata: {}
33
- post_install_message:
33
+ post_install_message:
34
34
  rdoc_options: []
35
35
  require_paths:
36
36
  - lib
@@ -46,7 +46,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
46
46
  version: '0'
47
47
  requirements: []
48
48
  rubygems_version: 3.1.6
49
- signing_key:
49
+ signing_key:
50
50
  specification_version: 4
51
51
  summary: Rake-like DSL for declaring AWS Lambda function handlers
52
52
  test_files: []