kamiliff 0.27.0 → 0.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +6 -0
- data/app/controllers/liff_controller.rb +34 -13
- data/app/helpers/liff_helper.rb +1 -1
- data/app/views/liff/_share_target_picker.liff.erb +31 -0
- data/config/initializers/mime_types.rb +1 -1
- data/lib/kamiliff.rb +2 -1
- data/lib/kamiliff/services/base64_decode_service.rb +16 -0
- data/lib/kamiliff/services/base64_encode_service.rb +15 -0
- data/lib/kamiliff/services/liff_service.rb +12 -2
- data/lib/kamiliff/version.rb +1 -1
- metadata +5 -3
- data/lib/kamiliff/services/liff_base64_service.rb +0 -52
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 955111b68428e0cc0e93dbae9efb62e05c5fadcdff1ea4c54f18fa0cc8fd3bda
|
|
4
|
+
data.tar.gz: 72bcfbce267e8ffc9697eb4477dea346f7e3af54aaec07c83191823f37e12ae4
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 480280f31fc7637bb3a013d67c8255dc4e54b5bb6fe9fd6b92ba61cb6d6148d047e27c53ded5ab4a299cfb2cdb308196198716268fcb1809066fecd3081dfb77
|
|
7
|
+
data.tar.gz: 98e29a589edd018a0382072bd55d45e70189d6f3a7d4727828069deba66af7cd5e92329963841701feed672751c3c79144a9743cfda6bc00f2d3523785eb7e3b
|
data/README.md
CHANGED
|
@@ -1,41 +1,62 @@
|
|
|
1
1
|
|
|
2
2
|
class LiffController < ActionController::Base
|
|
3
3
|
layout false, only: :route
|
|
4
|
+
before_action :set_liff_param, only: [:entry]
|
|
4
5
|
|
|
5
6
|
def entry
|
|
7
|
+
@liff = LiffService.new(@liff_param)
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def route
|
|
11
|
+
path, query = params["path"].split("?")
|
|
12
|
+
query = Rack::Utils.parse_nested_query(query)
|
|
13
|
+
http_method = query["_method"]&.upcase || "GET"
|
|
14
|
+
@body = reserve_route(path, http_method: http_method, request_params: source_info.merge(query), format: :liff)
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
private
|
|
18
|
+
|
|
19
|
+
# {"path"=>"/orders", "liff_size"=>"TALL"}
|
|
20
|
+
def set_liff_param
|
|
6
21
|
query = Rack::Utils.parse_nested_query(request.query_string)
|
|
7
22
|
|
|
8
23
|
# fix liff 2.0 redirect issue
|
|
9
24
|
@need_reload = query["liff.state"].present?
|
|
10
25
|
|
|
26
|
+
# 需要從 session 讀取 @liff_param
|
|
27
|
+
if query["liffRedirectUri"].present?
|
|
28
|
+
@liff_param = Base64DecodeService.new(session[:liff_param]).run
|
|
29
|
+
session[:liff_param] = nil
|
|
30
|
+
return
|
|
31
|
+
end
|
|
32
|
+
|
|
11
33
|
# 第一次 redirect
|
|
12
34
|
if(@need_reload)
|
|
35
|
+
# base64 的情況
|
|
13
36
|
if(query["liff.state"][0] == '/')
|
|
14
|
-
|
|
37
|
+
base64_string = query["liff.state"][1..-1]
|
|
38
|
+
@liff_param = Base64DecodeService.new(base64_string).run
|
|
39
|
+
# query 的情況
|
|
15
40
|
else
|
|
16
41
|
querystring = query["liff.state"][(query["liff.state"].index('?')+1)..-1]
|
|
17
|
-
|
|
18
|
-
@liff = LiffService.new(query)
|
|
42
|
+
@liff_param = Rack::Utils.parse_nested_query(querystring)
|
|
19
43
|
end
|
|
20
44
|
# 第二次 redirect
|
|
21
45
|
else
|
|
46
|
+
# base64 的情況
|
|
22
47
|
if params[:base64].present?
|
|
23
|
-
|
|
48
|
+
base64_string = params[:base64]
|
|
49
|
+
@liff_param = Base64DecodeService.new(base64_string).run
|
|
50
|
+
# query 的情況
|
|
24
51
|
else
|
|
25
|
-
@
|
|
52
|
+
@liff_param = query
|
|
26
53
|
end
|
|
27
54
|
end
|
|
28
|
-
end
|
|
29
55
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
query = Rack::Utils.parse_nested_query(query)
|
|
33
|
-
http_method = query["_method"]&.upcase || "GET"
|
|
34
|
-
@body = reserve_route(path, http_method: http_method, request_params: source_info.merge(query), format: :liff)
|
|
56
|
+
# 保存最後一次 liff_param 到 session
|
|
57
|
+
session[:liff_param] = Base64EncodeService.new(@liff_param).run
|
|
35
58
|
end
|
|
36
59
|
|
|
37
|
-
private
|
|
38
|
-
|
|
39
60
|
def reserve_route(path, http_method: "GET", request_params: nil, format: nil)
|
|
40
61
|
request.request_method = http_method
|
|
41
62
|
request.path_info = path
|
data/app/helpers/liff_helper.rb
CHANGED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
<script>
|
|
2
|
+
(function(){
|
|
3
|
+
async function share_target_picker(messages){
|
|
4
|
+
/* JS 不支援的情況 */
|
|
5
|
+
if (!liff.isApiAvailable('shareTargetPicker')){
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/* 分享訊息給好友 */
|
|
10
|
+
const response = await liff.shareTargetPicker(messages);
|
|
11
|
+
|
|
12
|
+
/* 分享訊息失敗 */
|
|
13
|
+
if(!response){
|
|
14
|
+
const [majorVer, minorVer] = (liff.getLineVersion() || "").split('.');
|
|
15
|
+
if (parseInt(majorVer) == 10 && parseInt(minorVer) < 11) {
|
|
16
|
+
alert("你的 LINE 版本太舊,無法使用分享訊息功能。");
|
|
17
|
+
} else {
|
|
18
|
+
alert("你已取消分享訊息。");
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
async function send_messages(){
|
|
24
|
+
const messages = <%= raw messages %>;
|
|
25
|
+
await share_target_picker(messages);
|
|
26
|
+
liff.closeWindow();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
send_messages();
|
|
30
|
+
})();
|
|
31
|
+
</script>
|
data/lib/kamiliff.rb
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
require "kamiliff/engine"
|
|
2
|
+
require "kamiliff/services/base64_encode_service"
|
|
3
|
+
require "kamiliff/services/base64_decode_service"
|
|
2
4
|
require "kamiliff/services/liff_service"
|
|
3
|
-
require "kamiliff/services/liff_base64_service"
|
|
4
5
|
|
|
5
6
|
module Kamiliff
|
|
6
7
|
# Your code goes here...
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
require "base64"
|
|
2
|
+
|
|
3
|
+
class Base64DecodeService
|
|
4
|
+
|
|
5
|
+
def initialize(base64_string)
|
|
6
|
+
@base64_string = base64_string
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def run
|
|
10
|
+
string = @base64_string.tr('-','+').tr('_','/')
|
|
11
|
+
json = Base64.decode64(string)
|
|
12
|
+
options = JSON.parse(json)
|
|
13
|
+
options.with_indifferent_access
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
require "base64"
|
|
2
|
+
|
|
3
|
+
class Base64EncodeService
|
|
4
|
+
|
|
5
|
+
def initialize(options)
|
|
6
|
+
@options = options
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def run
|
|
10
|
+
json = @options.to_json
|
|
11
|
+
base64_string = Base64.encode64(json)
|
|
12
|
+
base64_string.tr('+','-').tr('/','_').tr("\n", '').tr('=', '')
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
end
|
|
@@ -15,12 +15,22 @@ class LiffService
|
|
|
15
15
|
attr_accessor :id
|
|
16
16
|
|
|
17
17
|
def initialize(options)
|
|
18
|
-
self.path = options[:path] ||
|
|
19
|
-
self.size = options[:liff_size] ||
|
|
18
|
+
self.path = options[:path] || "/"
|
|
19
|
+
self.size = options[:liff_size] || :compact
|
|
20
20
|
self.size = size.to_s.upcase
|
|
21
21
|
raise "liff_size should be compact, tall or full." unless size.in? %w[COMPACT TALL FULL]
|
|
22
22
|
self.url = ENV["LIFF_#{size}"]
|
|
23
23
|
raise "LIFF_#{size} should be in the env variables" if url.blank?
|
|
24
24
|
self.id = url[(url.rindex('/')+1)..-1]
|
|
25
25
|
end
|
|
26
|
+
|
|
27
|
+
def full_url
|
|
28
|
+
# liff mode is Concatenate
|
|
29
|
+
base64_string = Base64EncodeService.new({
|
|
30
|
+
path: path,
|
|
31
|
+
liff_size: size
|
|
32
|
+
}).run
|
|
33
|
+
"#{url}/#{base64_string}"
|
|
34
|
+
end
|
|
35
|
+
|
|
26
36
|
end
|
data/lib/kamiliff/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: kamiliff
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.
|
|
4
|
+
version: 0.31.0
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- etrex kuo
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2021-
|
|
11
|
+
date: 2021-08-07 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: rails
|
|
@@ -39,6 +39,7 @@ files:
|
|
|
39
39
|
- app/helpers/liff_helper.rb
|
|
40
40
|
- app/views/layouts/application.liff.erb
|
|
41
41
|
- app/views/layouts/liff.html.erb
|
|
42
|
+
- app/views/liff/_share_target_picker.liff.erb
|
|
42
43
|
- app/views/liff/entry.html.erb
|
|
43
44
|
- app/views/liff/route.html.erb
|
|
44
45
|
- config/initializers/assets.rb
|
|
@@ -46,7 +47,8 @@ files:
|
|
|
46
47
|
- config/routes.rb
|
|
47
48
|
- lib/kamiliff.rb
|
|
48
49
|
- lib/kamiliff/engine.rb
|
|
49
|
-
- lib/kamiliff/services/
|
|
50
|
+
- lib/kamiliff/services/base64_decode_service.rb
|
|
51
|
+
- lib/kamiliff/services/base64_encode_service.rb
|
|
50
52
|
- lib/kamiliff/services/liff_service.rb
|
|
51
53
|
- lib/kamiliff/version.rb
|
|
52
54
|
- lib/tasks/kamiliff_tasks.rake
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
require "base64"
|
|
2
|
-
|
|
3
|
-
class LiffBase64Service
|
|
4
|
-
|
|
5
|
-
# rails routes path
|
|
6
|
-
attr_accessor :path
|
|
7
|
-
|
|
8
|
-
# size
|
|
9
|
-
# COMPACT TALL FULL
|
|
10
|
-
attr_accessor :size
|
|
11
|
-
|
|
12
|
-
# liff app url
|
|
13
|
-
# https://liff.line.me/app/#{liff_id}
|
|
14
|
-
attr_accessor :url
|
|
15
|
-
|
|
16
|
-
# liff id
|
|
17
|
-
attr_accessor :id
|
|
18
|
-
|
|
19
|
-
def self.from_base64(base64_string)
|
|
20
|
-
base64_string = base64_string.tr('-','+').tr('_','/')
|
|
21
|
-
json = Base64.decode64(base64_string)
|
|
22
|
-
options = JSON.parse(json)
|
|
23
|
-
LiffBase64Service.new(options)
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
def to_base64
|
|
27
|
-
json = {
|
|
28
|
-
path: path,
|
|
29
|
-
liff_size: size
|
|
30
|
-
}.to_json
|
|
31
|
-
base64_string = Base64.encode64(json)
|
|
32
|
-
base64_string.tr('+','-').tr('/','_').tr("\n", '').tr('=', '')
|
|
33
|
-
end
|
|
34
|
-
|
|
35
|
-
def initialize(options)
|
|
36
|
-
options = options.with_indifferent_access
|
|
37
|
-
self.path = options[:path] || "/"
|
|
38
|
-
self.size = options[:liff_size] || :compact
|
|
39
|
-
self.size = size.to_s.upcase
|
|
40
|
-
raise "liff_size should be compact, tall or full." unless size.in? %w[COMPACT TALL FULL]
|
|
41
|
-
self.url = ENV["LIFF_#{size}"]
|
|
42
|
-
raise "LIFF_#{size} should be in the env variables" if url.blank?
|
|
43
|
-
self.id = url[(url.rindex('/')+1)..-1]
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
def full_url
|
|
47
|
-
if ENV["LIFF_MODE"]&.downcase == "replace"
|
|
48
|
-
end
|
|
49
|
-
# liff mode is Concatenate
|
|
50
|
-
"#{url}/#{to_base64}"
|
|
51
|
-
end
|
|
52
|
-
end
|