jets 3.0.4 → 3.0.9
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +20 -0
- data/lib/jets/aws_info.rb +1 -1
- data/lib/jets/builders/tidy.rb +1 -0
- data/lib/jets/cfn/upload.rb +12 -10
- data/lib/jets/commands/templates/skeleton/Gemfile.tt +2 -2
- data/lib/jets/controller/callbacks.rb +6 -18
- data/lib/jets/controller/rack/adapter.rb +14 -8
- data/lib/jets/resource/lambda/function.rb +8 -1
- data/lib/jets/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bccb565973aab7e6793924820d026a97e056a75fc5827f0e227d11d17f2c76d8
|
4
|
+
data.tar.gz: c0935a069903b2406e4c06948d35e679d4a2837dc002bc56168f94a4c441774f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a0368aad05b5cd49fb3e5f175e672306c62906b9f3909fc8e9df29ca722cff15695a8c9de2a9d5f34bfe404828fc06401f04bc1b63ed6486c57f963191d3de43
|
7
|
+
data.tar.gz: 90eab98e9f5664bb27b67a14f5d3b2cba53f4cdfabd8828629d467cd0c00351746c6425ef5a38080cdec814ebd2d69aa480d132415bf6531bf1775f37bf944d1
|
data/CHANGELOG.md
CHANGED
@@ -3,6 +3,26 @@
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
4
4
|
This project *loosely tries* to adhere to [Semantic Versioning](http://semver.org/).
|
5
5
|
|
6
|
+
## [3.0.9] - 2021-06-14
|
7
|
+
- fix content type s3 metadata (#564)
|
8
|
+
|
9
|
+
## [3.0.8] - 2021-06-03
|
10
|
+
- Update cli.md (#560)
|
11
|
+
- respect .jetsignore also (#562)
|
12
|
+
|
13
|
+
## [3.0.7] - 2021-05-27
|
14
|
+
- Dont bypass class_attribute setters (#559)
|
15
|
+
- update pg version in jets new Gemfile to latest (#558)
|
16
|
+
|
17
|
+
## [3.0.6] - 2021-05-27
|
18
|
+
- Handle Errors::InvalidClientTokenId when `get_caller_identity` fails (#543)
|
19
|
+
- Use description specifed in function properties (#545)
|
20
|
+
- allow multi value response headers (#556)
|
21
|
+
- rails support update
|
22
|
+
|
23
|
+
## [3.0.5] - 2021-04-23
|
24
|
+
- [#542](https://github.com/boltops-tools/jets/pull/542) fix custom layers
|
25
|
+
|
6
26
|
## [3.0.4] - 2021-04-13
|
7
27
|
- [#537](https://github.com/boltops-tools/jets/pull/537) Docs Add instructions for aws-cli prerequisite
|
8
28
|
- [#528](https://github.com/boltops-tools/jets/pull/528) Adjust permissions to fix custom layer
|
data/lib/jets/aws_info.rb
CHANGED
@@ -55,7 +55,7 @@ module Jets
|
|
55
55
|
ENV['AWS_REGION'] ||= region
|
56
56
|
begin
|
57
57
|
sts.get_caller_identity.account
|
58
|
-
rescue Aws::Errors::MissingCredentialsError, Aws::Errors::NoSuchEndpointError
|
58
|
+
rescue Aws::Errors::MissingCredentialsError, Aws::Errors::NoSuchEndpointError, Aws::STS::Errors::InvalidClientTokenId
|
59
59
|
puts "INFO: You're missing AWS credentials. Only local services are currently available"
|
60
60
|
rescue Seahorse::Client::NetworkingError
|
61
61
|
puts "INFO: No internet connection available. Only local services are currently available"
|
data/lib/jets/builders/tidy.rb
CHANGED
@@ -35,6 +35,7 @@ module Jets::Builders
|
|
35
35
|
removals = always_removals
|
36
36
|
removals += get_removals("#{@project_root}/.gitignore")
|
37
37
|
removals += get_removals("#{@project_root}/.dockerignore")
|
38
|
+
removals += get_removals("#{@project_root}/.jetsignore")
|
38
39
|
removals = removals.reject do |p|
|
39
40
|
jetskeep.find do |keep|
|
40
41
|
p.include?(keep)
|
data/lib/jets/cfn/upload.rb
CHANGED
@@ -1,5 +1,6 @@
|
|
1
1
|
require 'action_view'
|
2
2
|
require 'digest'
|
3
|
+
require 'rack/mime'
|
3
4
|
|
4
5
|
module Jets::Cfn
|
5
6
|
class Upload
|
@@ -8,12 +9,6 @@ module Jets::Cfn
|
|
8
9
|
|
9
10
|
attr_reader :bucket_name
|
10
11
|
|
11
|
-
CONTENT_TYPES_BY_EXTENSION = {
|
12
|
-
'.css' => 'text/css',
|
13
|
-
'.js' => 'application/javascript',
|
14
|
-
'.html' => 'text/html'
|
15
|
-
}
|
16
|
-
|
17
12
|
def initialize(bucket_name)
|
18
13
|
@bucket_name = bucket_name
|
19
14
|
end
|
@@ -93,16 +88,23 @@ module Jets::Cfn
|
|
93
88
|
end
|
94
89
|
|
95
90
|
def upload_to_s3(full_path)
|
96
|
-
return if identical_on_s3?(full_path)
|
91
|
+
return if identical_on_s3?(full_path) && !ENV['JETS_ASSET_UPLOAD_FORCE']
|
97
92
|
|
98
93
|
key = s3_key(full_path)
|
99
94
|
obj = s3_resource.bucket(bucket_name).object(key)
|
100
|
-
|
101
|
-
|
95
|
+
content_type = content_type_headers(full_path)
|
96
|
+
puts "Uploading and setting content type for s3://#{bucket_name}/#{key} content_type #{content_type[:content_type].inspect}"
|
97
|
+
obj.upload_file(full_path, { acl: "public-read", cache_control: cache_control }.merge(content_type))
|
102
98
|
end
|
103
99
|
|
100
|
+
CONTENT_TYPES_BY_EXTENSION = {
|
101
|
+
'.css' => 'text/css',
|
102
|
+
'.html' => 'text/html',
|
103
|
+
'.js' => 'application/javascript',
|
104
|
+
}
|
104
105
|
def content_type_headers(full_path)
|
105
|
-
|
106
|
+
ext = File.extname(full_path)
|
107
|
+
content_type = CONTENT_TYPES_BY_EXTENSION[ext] || Rack::Mime.mime_type(ext)
|
106
108
|
if content_type
|
107
109
|
{ content_type: content_type }
|
108
110
|
else
|
@@ -9,11 +9,11 @@ gem "jetpacker"
|
|
9
9
|
<% if @database == 'postgresql' %>
|
10
10
|
# Include pg gem if you are using ActiveRecord, remove next line
|
11
11
|
# and config/database.yml file if you are not
|
12
|
-
gem "pg", "~> 1.
|
12
|
+
gem "pg", "~> 1.2.3"
|
13
13
|
<% elsif @database == 'mysql' %>
|
14
14
|
# Include mysql2 gem if you are using ActiveRecord, remove next line
|
15
15
|
# and config/database.yml file if you are not
|
16
|
-
gem "mysql2", "~> 0.5.
|
16
|
+
gem "mysql2", "~> 0.5.3"
|
17
17
|
<% end %>
|
18
18
|
<% unless options[:mode] == 'job' -%>
|
19
19
|
gem "dynomite"
|
@@ -17,10 +17,12 @@ class Jets::Controller
|
|
17
17
|
end
|
18
18
|
|
19
19
|
def skip_before_action(meth, options = {})
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
20
|
+
self.before_actions = before_actions
|
21
|
+
.reject { |act| act.first.to_s == meth.to_s }
|
22
|
+
|
23
|
+
# If options include the `only` option,
|
24
|
+
# re-add the action using the setter with the `except` option
|
25
|
+
before_action(meth, { except: options[:only] }) if options[:only].present?
|
24
26
|
end
|
25
27
|
|
26
28
|
alias_method :append_before_action, :before_action
|
@@ -38,20 +40,6 @@ class Jets::Controller
|
|
38
40
|
end
|
39
41
|
|
40
42
|
alias_method :append_after_action, :after_action
|
41
|
-
|
42
|
-
private
|
43
|
-
|
44
|
-
def append_except_to_callbacks(callback_methods, meth, excepted_methods)
|
45
|
-
callback_methods.map! do |callback_method|
|
46
|
-
if callback_method.first.to_s == meth.to_s
|
47
|
-
exceptions = callback_method.second[:except] || []
|
48
|
-
exceptions.concat(Array.wrap(excepted_methods))
|
49
|
-
callback_method.second[:except] = exceptions
|
50
|
-
end
|
51
|
-
|
52
|
-
callback_method
|
53
|
-
end
|
54
|
-
end
|
55
43
|
end
|
56
44
|
end # included
|
57
45
|
|
@@ -34,14 +34,20 @@ module Jets::Controller::Rack
|
|
34
34
|
body = body.respond_to?(:read) ? body.read : body
|
35
35
|
body = Base64.encode64(body) if base64
|
36
36
|
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
37
|
+
{}.tap do |resp|
|
38
|
+
resp['statusCode'] = status
|
39
|
+
resp['body'] = body
|
40
|
+
resp['isBase64Encoded'] = base64
|
41
|
+
add_response_headers(resp, headers)
|
42
|
+
adjust_for_elb(resp)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def add_response_headers(resp, headers)
|
47
|
+
resp['headers'] = headers.reject { |_, val| val.is_a?(Array) }
|
48
|
+
multi_value_headers = headers.select { |_, val| val.is_a?(Array) }
|
49
|
+
|
50
|
+
resp['multiValueHeaders'] = multi_value_headers unless multi_value_headers.blank?
|
45
51
|
end
|
46
52
|
|
47
53
|
# Note: ELB is not officially support. This is just in case users wish to manually
|
@@ -123,6 +123,7 @@ module Jets::Resource::Lambda
|
|
123
123
|
def finalize_properties!(props)
|
124
124
|
handler = full_handler(props)
|
125
125
|
runtime = get_runtime(props)
|
126
|
+
description = get_descripton(props)
|
126
127
|
managed = {
|
127
128
|
handler: handler,
|
128
129
|
runtime: runtime,
|
@@ -136,6 +137,8 @@ module Jets::Resource::Lambda
|
|
136
137
|
|
137
138
|
def get_layers(runtime)
|
138
139
|
return nil unless runtime =~ /^ruby/
|
140
|
+
return Jets.config.lambda.layers if Jets.config.gems.disable
|
141
|
+
|
139
142
|
["!Ref GemLayer"] + Jets.config.lambda.layers
|
140
143
|
end
|
141
144
|
|
@@ -202,7 +205,11 @@ module Jets::Resource::Lambda
|
|
202
205
|
function_name.size > Jets::MAX_FUNCTION_NAME_SIZE ? nil : function_name
|
203
206
|
end
|
204
207
|
|
205
|
-
def
|
208
|
+
def get_descripton(props)
|
209
|
+
props[:description] || default_description
|
210
|
+
end
|
211
|
+
|
212
|
+
def default_description
|
206
213
|
# Example values:
|
207
214
|
# @app_class: Admin/PagesController
|
208
215
|
# @task.meth: index
|
data/lib/jets/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: jets
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.0.
|
4
|
+
version: 3.0.9
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Tung Nguyen
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-06-14 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: actionmailer
|