line-bot-api 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 0cd22ba8ed93ba3f1577f70a5095439755dda529
4
+ data.tar.gz: 75eae8e81a15b2e6d950487dd18516aea4fd95f9
5
+ SHA512:
6
+ metadata.gz: dce0e680763a9d4929580cdb9e0fb75ee7591071d95d2687496e696dbc5ffe666e51644e615c94a31934ffe53e7c66e1e73739fe826dae62471678e114163842
7
+ data.tar.gz: 7a9538fb64eed37b366366658af3707dce8664e3b26967db41809c2bd0379ec476a60f2359e97f8eb029f6c0c963cd802621492b38e67fd0be6086b59912168b
@@ -0,0 +1,49 @@
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, and in the interest of
4
+ fostering an open and welcoming community, we pledge to respect all people who
5
+ contribute through reporting issues, posting feature requests, updating
6
+ documentation, submitting pull requests or patches, and other activities.
7
+
8
+ We are committed to making participation in this project a harassment-free
9
+ experience for everyone, regardless of level of experience, gender, gender
10
+ identity and expression, sexual orientation, disability, personal appearance,
11
+ body size, race, ethnicity, age, religion, or nationality.
12
+
13
+ Examples of unacceptable behavior by participants include:
14
+
15
+ * The use of sexualized language or imagery
16
+ * Personal attacks
17
+ * Trolling or insulting/derogatory comments
18
+ * Public or private harassment
19
+ * Publishing other's private information, such as physical or electronic
20
+ addresses, without explicit permission
21
+ * Other unethical or unprofessional conduct
22
+
23
+ Project maintainers have the right and responsibility to remove, edit, or
24
+ reject comments, commits, code, wiki edits, issues, and other contributions
25
+ that are not aligned to this Code of Conduct, or to ban temporarily or
26
+ permanently any contributor for other behaviors that they deem inappropriate,
27
+ threatening, offensive, or harmful.
28
+
29
+ By adopting this Code of Conduct, project maintainers commit themselves to
30
+ fairly and consistently applying these principles to every aspect of managing
31
+ this project. Project maintainers who do not follow or enforce the Code of
32
+ Conduct may be permanently removed from the project team.
33
+
34
+ This code of conduct applies both within project spaces and in public spaces
35
+ when an individual is representing the project or its community.
36
+
37
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
38
+ reported by contacting a project maintainer at hirohisa.kawasaki@gmail.com. All
39
+ complaints will be reviewed and investigated and will result in a response that
40
+ is deemed necessary and appropriate to the circumstances. Maintainers are
41
+ obligated to maintain confidentiality with regard to the reporter of an
42
+ incident.
43
+
44
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage],
45
+ version 1.3.0, available at
46
+ [http://contributor-covenant.org/version/1/3/0/][version]
47
+
48
+ [homepage]: http://contributor-covenant.org
49
+ [version]: http://contributor-covenant.org/version/1/3/0/
data/LICENSE ADDED
@@ -0,0 +1,202 @@
1
+
2
+ Apache License
3
+ Version 2.0, January 2004
4
+ http://www.apache.org/licenses/
5
+
6
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7
+
8
+ 1. Definitions.
9
+
10
+ "License" shall mean the terms and conditions for use, reproduction,
11
+ and distribution as defined by Sections 1 through 9 of this document.
12
+
13
+ "Licensor" shall mean the copyright owner or entity authorized by
14
+ the copyright owner that is granting the License.
15
+
16
+ "Legal Entity" shall mean the union of the acting entity and all
17
+ other entities that control, are controlled by, or are under common
18
+ control with that entity. For the purposes of this definition,
19
+ "control" means (i) the power, direct or indirect, to cause the
20
+ direction or management of such entity, whether by contract or
21
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
22
+ outstanding shares, or (iii) beneficial ownership of such entity.
23
+
24
+ "You" (or "Your") shall mean an individual or Legal Entity
25
+ exercising permissions granted by this License.
26
+
27
+ "Source" form shall mean the preferred form for making modifications,
28
+ including but not limited to software source code, documentation
29
+ source, and configuration files.
30
+
31
+ "Object" form shall mean any form resulting from mechanical
32
+ transformation or translation of a Source form, including but
33
+ not limited to compiled object code, generated documentation,
34
+ and conversions to other media types.
35
+
36
+ "Work" shall mean the work of authorship, whether in Source or
37
+ Object form, made available under the License, as indicated by a
38
+ copyright notice that is included in or attached to the work
39
+ (an example is provided in the Appendix below).
40
+
41
+ "Derivative Works" shall mean any work, whether in Source or Object
42
+ form, that is based on (or derived from) the Work and for which the
43
+ editorial revisions, annotations, elaborations, or other modifications
44
+ represent, as a whole, an original work of authorship. For the purposes
45
+ of this License, Derivative Works shall not include works that remain
46
+ separable from, or merely link (or bind by name) to the interfaces of,
47
+ the Work and Derivative Works thereof.
48
+
49
+ "Contribution" shall mean any work of authorship, including
50
+ the original version of the Work and any modifications or additions
51
+ to that Work or Derivative Works thereof, that is intentionally
52
+ submitted to Licensor for inclusion in the Work by the copyright owner
53
+ or by an individual or Legal Entity authorized to submit on behalf of
54
+ the copyright owner. For the purposes of this definition, "submitted"
55
+ means any form of electronic, verbal, or written communication sent
56
+ to the Licensor or its representatives, including but not limited to
57
+ communication on electronic mailing lists, source code control systems,
58
+ and issue tracking systems that are managed by, or on behalf of, the
59
+ Licensor for the purpose of discussing and improving the Work, but
60
+ excluding communication that is conspicuously marked or otherwise
61
+ designated in writing by the copyright owner as "Not a Contribution."
62
+
63
+ "Contributor" shall mean Licensor and any individual or Legal Entity
64
+ on behalf of whom a Contribution has been received by Licensor and
65
+ subsequently incorporated within the Work.
66
+
67
+ 2. Grant of Copyright License. Subject to the terms and conditions of
68
+ this License, each Contributor hereby grants to You a perpetual,
69
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70
+ copyright license to reproduce, prepare Derivative Works of,
71
+ publicly display, publicly perform, sublicense, and distribute the
72
+ Work and such Derivative Works in Source or Object form.
73
+
74
+ 3. Grant of Patent License. Subject to the terms and conditions of
75
+ this License, each Contributor hereby grants to You a perpetual,
76
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77
+ (except as stated in this section) patent license to make, have made,
78
+ use, offer to sell, sell, import, and otherwise transfer the Work,
79
+ where such license applies only to those patent claims licensable
80
+ by such Contributor that are necessarily infringed by their
81
+ Contribution(s) alone or by combination of their Contribution(s)
82
+ with the Work to which such Contribution(s) was submitted. If You
83
+ institute patent litigation against any entity (including a
84
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
85
+ or a Contribution incorporated within the Work constitutes direct
86
+ or contributory patent infringement, then any patent licenses
87
+ granted to You under this License for that Work shall terminate
88
+ as of the date such litigation is filed.
89
+
90
+ 4. Redistribution. You may reproduce and distribute copies of the
91
+ Work or Derivative Works thereof in any medium, with or without
92
+ modifications, and in Source or Object form, provided that You
93
+ meet the following conditions:
94
+
95
+ (a) You must give any other recipients of the Work or
96
+ Derivative Works a copy of this License; and
97
+
98
+ (b) You must cause any modified files to carry prominent notices
99
+ stating that You changed the files; and
100
+
101
+ (c) You must retain, in the Source form of any Derivative Works
102
+ that You distribute, all copyright, patent, trademark, and
103
+ attribution notices from the Source form of the Work,
104
+ excluding those notices that do not pertain to any part of
105
+ the Derivative Works; and
106
+
107
+ (d) If the Work includes a "NOTICE" text file as part of its
108
+ distribution, then any Derivative Works that You distribute must
109
+ include a readable copy of the attribution notices contained
110
+ within such NOTICE file, excluding those notices that do not
111
+ pertain to any part of the Derivative Works, in at least one
112
+ of the following places: within a NOTICE text file distributed
113
+ as part of the Derivative Works; within the Source form or
114
+ documentation, if provided along with the Derivative Works; or,
115
+ within a display generated by the Derivative Works, if and
116
+ wherever such third-party notices normally appear. The contents
117
+ of the NOTICE file are for informational purposes only and
118
+ do not modify the License. You may add Your own attribution
119
+ notices within Derivative Works that You distribute, alongside
120
+ or as an addendum to the NOTICE text from the Work, provided
121
+ that such additional attribution notices cannot be construed
122
+ as modifying the License.
123
+
124
+ You may add Your own copyright statement to Your modifications and
125
+ may provide additional or different license terms and conditions
126
+ for use, reproduction, or distribution of Your modifications, or
127
+ for any such Derivative Works as a whole, provided Your use,
128
+ reproduction, and distribution of the Work otherwise complies with
129
+ the conditions stated in this License.
130
+
131
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
132
+ any Contribution intentionally submitted for inclusion in the Work
133
+ by You to the Licensor shall be under the terms and conditions of
134
+ this License, without any additional terms or conditions.
135
+ Notwithstanding the above, nothing herein shall supersede or modify
136
+ the terms of any separate license agreement you may have executed
137
+ with Licensor regarding such Contributions.
138
+
139
+ 6. Trademarks. This License does not grant permission to use the trade
140
+ names, trademarks, service marks, or product names of the Licensor,
141
+ except as required for reasonable and customary use in describing the
142
+ origin of the Work and reproducing the content of the NOTICE file.
143
+
144
+ 7. Disclaimer of Warranty. Unless required by applicable law or
145
+ agreed to in writing, Licensor provides the Work (and each
146
+ Contributor provides its Contributions) on an "AS IS" BASIS,
147
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148
+ implied, including, without limitation, any warranties or conditions
149
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150
+ PARTICULAR PURPOSE. You are solely responsible for determining the
151
+ appropriateness of using or redistributing the Work and assume any
152
+ risks associated with Your exercise of permissions under this License.
153
+
154
+ 8. Limitation of Liability. In no event and under no legal theory,
155
+ whether in tort (including negligence), contract, or otherwise,
156
+ unless required by applicable law (such as deliberate and grossly
157
+ negligent acts) or agreed to in writing, shall any Contributor be
158
+ liable to You for damages, including any direct, indirect, special,
159
+ incidental, or consequential damages of any character arising as a
160
+ result of this License or out of the use or inability to use the
161
+ Work (including but not limited to damages for loss of goodwill,
162
+ work stoppage, computer failure or malfunction, or any and all
163
+ other commercial damages or losses), even if such Contributor
164
+ has been advised of the possibility of such damages.
165
+
166
+ 9. Accepting Warranty or Additional Liability. While redistributing
167
+ the Work or Derivative Works thereof, You may choose to offer,
168
+ and charge a fee for, acceptance of support, warranty, indemnity,
169
+ or other liability obligations and/or rights consistent with this
170
+ License. However, in accepting such obligations, You may act only
171
+ on Your own behalf and on Your sole responsibility, not on behalf
172
+ of any other Contributor, and only if You agree to indemnify,
173
+ defend, and hold each Contributor harmless for any liability
174
+ incurred by, or claims asserted against, such Contributor by reason
175
+ of your accepting any such warranty or additional liability.
176
+
177
+ END OF TERMS AND CONDITIONS
178
+
179
+ APPENDIX: How to apply the Apache License to your work.
180
+
181
+ To apply the Apache License to your work, attach the following
182
+ boilerplate notice, with the fields enclosed by brackets "[]"
183
+ replaced with your own identifying information. (Don't include
184
+ the brackets!) The text should be enclosed in the appropriate
185
+ comment syntax for the file format. We also recommend that a
186
+ file or class name and description of purpose be included on the
187
+ same "printed page" as the copyright notice for easier
188
+ identification within third-party archives.
189
+
190
+ Copyright [yyyy] [name of copyright owner]
191
+
192
+ Licensed under the Apache License, Version 2.0 (the "License");
193
+ you may not use this file except in compliance with the License.
194
+ You may obtain a copy of the License at
195
+
196
+ http://www.apache.org/licenses/LICENSE-2.0
197
+
198
+ Unless required by applicable law or agreed to in writing, software
199
+ distributed under the License is distributed on an "AS IS" BASIS,
200
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201
+ See the License for the specific language governing permissions and
202
+ limitations under the License.
@@ -0,0 +1,216 @@
1
+ # LINE::Bot::API
2
+
3
+ LINE::Bot::API - SDK of the LINE BOT API Trial for Ruby
4
+
5
+ ## Configuration
6
+
7
+ ```
8
+ client = Line::Bot::Client.new do |config|
9
+ config.channel_id = 'YOUR LINE BOT Channel ID'
10
+ config.channel_secret = 'YOUR LINE BOT Channel Secret'
11
+ config.channel_mid = 'YOUR LINE BOT MID'
12
+ end
13
+ ```
14
+
15
+ ## Usage
16
+
17
+ ### Sending messages
18
+
19
+ After configuring a client, you can start sending messages as the following reference.
20
+
21
+ - [https://developers.line.me/bot-api/api-reference#sending_message](https://developers.line.me/bot-api/api-reference#sending_message)
22
+
23
+ Sending message APIs requires the following parameter.
24
+ - `:to_mid` String or Array
25
+
26
+ ```
27
+ client.send_text(
28
+ to_mid: '12345678',
29
+ )
30
+ client.send_text(
31
+ to_mid: ['12345678', '23456789'],
32
+ )
33
+ ```
34
+
35
+ #### send_text
36
+
37
+ ```
38
+ client.send_text(
39
+ to_mid: to_mid,
40
+ text: 'Hello',
41
+ )
42
+ ```
43
+
44
+ #### send_image
45
+
46
+ ```
47
+ client.send_image(
48
+ to_mid: to_mid,
49
+ image_url: 'http://example.com/image.jpg', # originalContentUrl
50
+ preview_url: 'http://example.com/image_preview.jpg', # previewImageUrl
51
+ )
52
+ ```
53
+
54
+ #### send_video
55
+
56
+ ```
57
+ client.send_video(
58
+ to_mid: to_mid,
59
+ video_url: 'http://example.com/video.mp4', # originalContentUrl
60
+ preview_url: 'http://example.com/video_preview.jpg' # previewImageUrl
61
+ )
62
+ ```
63
+
64
+ #### send_audio
65
+
66
+ ```
67
+ client.send_audio(
68
+ to_mid: to_mid,
69
+ audio_url: 'http://example.com/audio.mp3', # originalContentUrl
70
+ duration: 120000
71
+ )
72
+ ```
73
+
74
+ #### send_location
75
+
76
+ ```
77
+ client.send_location(
78
+ to_mid: to_mid,
79
+ title: 'LINE Corporation.',
80
+ address: 'Hikarie Shibuya-ku Tokyo 151-0002', # location.address
81
+ latitude: 35.61823286112982, # location.latitude
82
+ longitude: 139.72824096679688, # location.longitude
83
+ )
84
+ ```
85
+
86
+ #### send_sticker
87
+
88
+ See online documentation to find which sticker's you can send.
89
+
90
+ - [https://developers.line.me/bot-api/api-reference#sending_message_sticker](https://developers.line.me/bot-api/api-reference#sending_message_sticker)
91
+
92
+ ```
93
+ client.send_sticker(
94
+ to_mid: to_mid,
95
+ stkpkgid: 2, # contentMetadata.STKPKGID
96
+ stkid: 144, # contentMetadata.STKID
97
+ stkver: 100 # contentMetadata.STKVER
98
+ )
99
+ ```
100
+
101
+ ### Sending multiple message
102
+
103
+ Support on sending multiple message.
104
+ - [https://developers.line.me/bot-api/api-reference#sending_multiple_messages](https://developers.line.me/bot-api/api-reference#sending_multiple_messages)
105
+
106
+ ```
107
+ client.multiple_message.add_text(
108
+ text: text,
109
+ ).add_image(
110
+ image_url: image_url,
111
+ preview_url: preview_url,
112
+ ).add_video(
113
+ video_url: video_url,
114
+ preview_url: preview_url,
115
+ ).add_audio(
116
+ audio_url: audio_url,
117
+ duration: duration,
118
+ ).add_location(
119
+ title: 'title',
120
+ latitude: latitude,
121
+ longitude: longitude,
122
+ ).add_sticker(
123
+ stkpkgid: stkpkgid,
124
+ stkid: stkid,
125
+ stkver: stkver,
126
+ ).send(
127
+ to_mid: to_mid,
128
+ )
129
+ ```
130
+
131
+ ### Sending rich message
132
+
133
+ Support on sending rich message.
134
+
135
+ See also a online document.
136
+ - [https://developers.line.me/bot-api/api-reference#sending_rich_content_message](https://developers.line.me/bot-api/api-reference#sending_rich_content_message)
137
+
138
+ ```
139
+ client.rich_message.set_action(
140
+ MANGA: {
141
+ text: 'manga',
142
+ link_url: link_url,
143
+ }
144
+ ).add_listener(
145
+ action: 'MANGA',
146
+ x: 0,
147
+ y: 0,
148
+ width: 520,
149
+ height: 520,
150
+ ).send(
151
+ to_mid: to_mid,
152
+ image_url: image_url,
153
+ alt_text: alt_text,
154
+ )
155
+ ```
156
+
157
+ ### Signature validation
158
+
159
+ ```
160
+ request = Rack::Request.new( .. )
161
+ signature = request.env['HTTP_X_LINE_CHANNELSIGNATURE']
162
+ unless client.validate_signature(request.body.read, signature)
163
+ return 'invalidation of signature'
164
+ end
165
+ ```
166
+
167
+ ### Receiving request
168
+
169
+ ```
170
+ request_from_rack = Rack::Request.new( .. )
171
+
172
+ request = Line::Bot::Receive::Request.new(request_from_rack.env)
173
+ request.data #=> [Array] Line::Bot::Receive::Message || Line::Bot::Receive::Operation
174
+
175
+ request.data.each { |message|
176
+ case message.content
177
+ when Line::Bot::Message::Image, Line::Bot::Message::Video
178
+ # get message content
179
+ response = client.get_message_content(message.id)
180
+ tf = Tempfile.open("content")
181
+ tf.write(response.body)
182
+
183
+ # get preview of message content
184
+ preview_response = client.get_message_content_preview(message.id)
185
+ ptf = Tempfile.open("content_preview")
186
+ ptf.write(preview_response.body)
187
+ end
188
+ }
189
+ ```
190
+
191
+ ### Getting message content
192
+
193
+ Get the original file which was sent by user.
194
+
195
+ ### Getting preview of message content
196
+
197
+ Get the preview image file which was sent by user.
198
+
199
+ ### Getting user profile information
200
+
201
+ ```
202
+ user_profile = client.get_user_profile("1234567")
203
+ user_profile #=> [Line::Bot::Response::User::Profile]
204
+ contacts = user_profile.contacts
205
+ contacts #=> [Array] Line::Bot::Response::User::Contacts
206
+ ```
207
+
208
+ ## License
209
+
210
+ The gem is available as open source under the terms of the [Apache License, Version 2.0](https://opensource.org/licenses/Apache-2.0).
211
+
212
+ ## Links
213
+
214
+ - [https://business.line.me/](https://business.line.me/)
215
+ - [https://developers.line.me/bot-api/overview](https://developers.line.me/bot-api/overview)
216
+ - [https://developers.line.me/bot-api/getting-started-with-bot-api-trial](https://developers.line.me/bot-api/getting-started-with-bot-api-trial)