errand-boy 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: 963677910772bb3be583fdc5d8658faba15e58e7
4
+ data.tar.gz: a93a425772796f890058c7c5c57ff21f07827d59
5
+ SHA512:
6
+ metadata.gz: 27723cc2ea5280885ba9085e03f562319cf6bef96aa1c4a46bc0ef630b275608d0db543d19fa879290e8697a317079e54cecd33be99e6abfda2b052a4d5510b5
7
+ data.tar.gz: f20debb75df3cf447300bb7aa92e19a8bb40a2ed98b92afa3894a65c1996e42676b4e7330b98c506ee01a7ff129e25300aaf47a73e34c942115657679efc4582
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
@@ -0,0 +1 @@
1
+ 2.3.1
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in errand_boy.gemspec
4
+ gemspec
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 yuta-muramoto
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,170 @@
1
+ # ErrandBoy [![CircleCI](https://circleci.com/gh/bm-sms/errand_boy.svg?style=shield&circle-token=79a65d3d5cdad3c9536ae7d25ddd462093267b9d)](https://circleci.com/gh/bm-sms/errand_boy)
2
+
3
+ ErrandBoy is the admin support tool.
4
+
5
+
6
+ ## Description
7
+
8
+ ErrandBoy helps a administrator job. It executes the action when administrator merged pull request.
9
+ If you want to request for slack invitation to administrator, all it takes is to write a request file and create pull request to the ErrandBoy repository.
10
+ When the administrator merge pull request that allowed by him, ErrandBoy sends slack invitation mail instead of the administrator.
11
+
12
+
13
+ ## Installation
14
+
15
+ ### \* See [errandboy_example](https://github.com/bm-sms/errand_boy/tree/master/example)
16
+
17
+ #### Add this line to your application's Gemfile:
18
+
19
+ ```ruby
20
+ gem 'errand-boy'
21
+ ```
22
+
23
+ #### Add `index/` and `requests/`:
24
+
25
+ ```shell
26
+ $ mkdir ./index
27
+ $ mkdir ./requests
28
+ $ touch ./requests/.keep
29
+ ```
30
+
31
+ #### Add `bin/exe`:
32
+
33
+ ```ruby
34
+ #!/usr/bin/env ruby
35
+
36
+ require 'bundler/setup'
37
+ require 'errand_boy'
38
+
39
+ ErrandBoy::Brain.new.command
40
+ ```
41
+
42
+ #### Add circle.yml:
43
+
44
+ ```yml
45
+ machine:
46
+ timezone:
47
+ Asia/Tokyo
48
+
49
+ ruby:
50
+ version:
51
+ 2.3.1
52
+
53
+ post:
54
+ - sudo service mysql stop
55
+ - sudo service postgresql stop
56
+
57
+ dependencies:
58
+ pre:
59
+ - gem install bundler -v 1.11
60
+
61
+ override:
62
+ - bundle install
63
+
64
+ test:
65
+ override:
66
+ - echo "-----no test-----"
67
+
68
+ deployment:
69
+ run:
70
+ branch: /master|.*request.*/
71
+ commands:
72
+ - git config --global user.name errand-boy
73
+ - git config --global user.email errandboy0.1.0@gmail.com
74
+ - bin/exe
75
+ ```
76
+
77
+ ## Setting
78
+
79
+ ### Slack
80
+
81
+ #### Get a slack access token from https://api.slack.com/web:
82
+
83
+ [![generate_test_tokens](https://github.com/bm-sms/errand_boy/wiki/images/generate_test_tokens.png)](https://api.slack.com/web)
84
+
85
+ #### Create access token:
86
+
87
+ [![create_token](https://github.com/bm-sms/errand_boy/wiki/images/create_token.png)](#)
88
+
89
+ ### CircleCI
90
+
91
+ #### Build CircleCI project from https://circleci.com/add-projects:
92
+
93
+ [![build_project](https://github.com/bm-sms/errand_boy/wiki/images/build_project.png)](https://circleci.com/add-projects)
94
+
95
+ #### Registered a deploy key:
96
+
97
+ place: Project Settings >> Permissions >> Checkout SSH keys
98
+
99
+ [![authorize_w](https://github.com/bm-sms/errand_boy/wiki/images/authorize_w.png)](#)
100
+
101
+ #### Add slack access token to environment variable:
102
+
103
+ place: Project Setting >> Build Settings >> Environment Variables
104
+
105
+ [![environment_variable](https://github.com/bm-sms/errand_boy/wiki/images/environment_variable.png)](#)
106
+
107
+
108
+ ## Usage
109
+
110
+ Make and checkout a new branch that named including `request` (prefix):
111
+
112
+ ```shell
113
+ $ git checkout -b new_request
114
+ ```
115
+
116
+ Make a new request file in `requests/` folder:
117
+
118
+ - The file should be formatted by [TOML](https://github.com/toml-lang/toml).
119
+
120
+ ```shell
121
+ $ vim requests/example.toml
122
+ ```
123
+
124
+ ```toml
125
+ # requests/example.toml
126
+
127
+ provider = 'slack' # Now slack only.
128
+ action = 'invite' # Now invite only.
129
+ sender = { name = 'tanaka taro', email = 'taro@example.com' } # Sender information.
130
+ # Register information. It is required information.
131
+ register = { name = 'yamada hanako', email = 'hanako@example.com' }
132
+ destination = { team = 'example' } # It is team that the register will be invited.
133
+ ```
134
+
135
+ Push a new request file and create a pull request:
136
+
137
+ - Push a new request file
138
+
139
+ ```
140
+ $ git add .
141
+ $ git commit -m 'request slack invite example'
142
+ $ git push -u origin new_request
143
+ ```
144
+
145
+ - Create a new pull request on your `errand_boy` repository.
146
+
147
+ Merge pull request by administrator:
148
+
149
+ ErrandBoy executes the action when the administrator merge pull request.
150
+
151
+
152
+ ### Confirm action histories
153
+
154
+ If you want to see invite histories, you can see `index/***.csv` on your `errand_boy` repository.
155
+
156
+
157
+ ## ENV
158
+
159
+ ```
160
+ SLACK_ACCESS_TOKEN - You should set slack access token on CircleCI.
161
+ ```
162
+
163
+ ## Contributing
164
+
165
+ Bug reports and pull requests are welcome on GitHub at https://github.com/bm-sms/errand_boy.
166
+
167
+
168
+ ## License
169
+
170
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
@@ -0,0 +1,11 @@
1
+ require 'bundler/gem_tasks'
2
+ require 'rake/testtask'
3
+
4
+ Rake::TestTask.new(:test) do |t|
5
+ t.libs << 'test'
6
+ t.libs << 'lib'
7
+ t.warning = false
8
+ t.test_files = FileList['test/**/*_test.rb']
9
+ end
10
+
11
+ task default: :test
@@ -0,0 +1,10 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'bundler/setup'
4
+ require 'errand_boy'
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ require 'pry'
10
+ Pry.start
data/bin/exe ADDED
@@ -0,0 +1,6 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'bundler/setup'
4
+ require 'errand_boy'
5
+
6
+ ErrandBoy::Brain.new.command
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,23 @@
1
+ machine:
2
+ timezone:
3
+ Asia/Tokyo
4
+
5
+ ruby:
6
+ version:
7
+ 2.3.1
8
+
9
+ post:
10
+ - sudo service mysql stop
11
+ - sudo service postgresql stop
12
+
13
+ dependencies:
14
+ pre:
15
+ - gem install bundler -v 1.11
16
+
17
+ override:
18
+ - bundle install:
19
+ timeout: 180
20
+
21
+ test:
22
+ override:
23
+ - bundle exec rake test
@@ -0,0 +1,32 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'errand_boy/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = 'errand-boy'
8
+ spec.version = ErrandBoy::VERSION
9
+ spec.authors = ['yuta-muramoto']
10
+ spec.email = ['s1513114@u.tsukuba.ac.jp']
11
+
12
+ spec.summary = 'ErrandBoy is admin support tool.'
13
+ spec.description = 'ErrandBoy is admin support tool. He will send slack invitation instead of you.'
14
+ spec.homepage = 'https://github.com/bm-sms/errand_boy.git'
15
+ spec.license = 'MIT'
16
+
17
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
18
+ spec.bindir = 'exe'
19
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
20
+ spec.require_paths = ['lib']
21
+
22
+ spec.add_dependency 'toml-rb'
23
+ spec.add_dependency 'faraday'
24
+ spec.add_dependency 'git'
25
+
26
+ spec.add_development_dependency 'pry'
27
+ spec.add_development_dependency 'bundler', '~> 1.11'
28
+ spec.add_development_dependency 'rake', '~> 10.0'
29
+ spec.add_development_dependency 'minitest', '~> 5.0'
30
+ spec.add_development_dependency 'minitest-reporters'
31
+ spec.add_development_dependency 'minitest-stub_any_instance'
32
+ end
@@ -0,0 +1,3 @@
1
+ source 'http://rubygems.org'
2
+
3
+ gem 'errand-boy'
@@ -0,0 +1,6 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'bundler/setup'
4
+ require 'errand_boy'
5
+
6
+ ErrandBoy::Brain.new.command
@@ -0,0 +1,30 @@
1
+ machine:
2
+ timezone:
3
+ Asia/Tokyo
4
+
5
+ ruby:
6
+ version:
7
+ 2.3.1
8
+
9
+ post:
10
+ - sudo service mysql stop
11
+ - sudo service postgresql stop
12
+
13
+ dependencies:
14
+ pre:
15
+ - gem install bundler -v 1.11
16
+
17
+ override:
18
+ - bundle install
19
+
20
+ test:
21
+ override:
22
+ - echo "-----no test-----"
23
+
24
+ deployment:
25
+ run:
26
+ branch: /master|.*request.*/
27
+ commands:
28
+ - git config --global user.name errand-boy
29
+ - git config --global user.email errandboy0.1.0@gmail.com
30
+ - bin/exe
File without changes
File without changes
@@ -0,0 +1,21 @@
1
+ require 'errand_boy/version'
2
+ require 'errand_boy/brain'
3
+ require 'errand_boy/request'
4
+ require 'errand_boy/csv'
5
+ require 'errand_boy/git'
6
+ require 'errand_boy/error'
7
+ require 'errand_boy/validator'
8
+ require 'errand_boy/validator/base'
9
+ require 'errand_boy/validator/slack_invite'
10
+ require 'errand_boy/gateway'
11
+ require 'errand_boy/gateway/slack'
12
+ require 'errand_boy/csv/base'
13
+ require 'errand_boy/csv/slack_invite'
14
+
15
+ module ErrandBoy
16
+ class << self
17
+ def slack_access_token
18
+ ENV['SLACK_ACCESS_TOKEN']
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,54 @@
1
+ module ErrandBoy
2
+ class Brain
3
+ def initialize
4
+ @git = Git.new(Dir.pwd)
5
+ @requests = requests
6
+ end
7
+
8
+ def command
9
+ case @git.branch
10
+ when /master/ then run
11
+ when /.*request.*/ then validate
12
+ end
13
+ end
14
+
15
+ def run
16
+ @requests.each do |request|
17
+ gateway = Gateway.build(request)
18
+ csv = CSV.build(request)
19
+
20
+ gateway.call
21
+ next if processed?(gateway, csv)
22
+
23
+ csv.push
24
+ request.delete
25
+ @git.commit "[auto][ci skip] add request to index"
26
+ @git.push
27
+ end
28
+ end
29
+
30
+ def validate
31
+ @requests.each do |request|
32
+ Validator.build(request).run
33
+ request.rename
34
+
35
+ @git.commit '[auto][ci skip] rename request file'
36
+ @git.push
37
+ end
38
+ end
39
+
40
+ private
41
+
42
+ def requests
43
+ entries.map {|path| Request.new(path) }
44
+ end
45
+
46
+ def entries
47
+ Dir.glob("#{Request.dir}/*.toml").sort
48
+ end
49
+
50
+ def processed?(gateway, csv)
51
+ gateway.processed? && csv.duplicated?
52
+ end
53
+ end
54
+ end
@@ -0,0 +1,19 @@
1
+ require 'csv'
2
+
3
+ module ErrandBoy
4
+ class CSV
5
+ class << self
6
+ def build(request)
7
+ provider = request.provider.capitalize
8
+ action = request.action.capitalize
9
+ const_get("#{provider}#{action}").new(request)
10
+ rescue
11
+ raise NoActionError, "No such provider or action `#{provider}`, `#{action}`."
12
+ end
13
+
14
+ def dir
15
+ File.expand_path 'index'
16
+ end
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,47 @@
1
+ require 'csv'
2
+
3
+ module ErrandBoy
4
+ class CSV
5
+ class Base
6
+ def initialize(request)
7
+ @request = request
8
+ end
9
+
10
+ def push
11
+ write_header unless File.exist?(path)
12
+ File.open path, 'a' do |f|
13
+ f.puts values
14
+ end
15
+ end
16
+
17
+ def include?(key, value)
18
+ ::CSV.table(path).by_col[key].include?(value)
19
+ end
20
+
21
+ def path
22
+ File.join CSV.dir, filename
23
+ end
24
+
25
+ def filename
26
+ "#{@request.provider}_#{@request.action}.csv"
27
+ end
28
+
29
+ def headers
30
+ raise NotImplementedError, 'Subclass must implement this method!'
31
+ end
32
+
33
+ def values
34
+ raise NotImplementedError, 'Subclass must implement this method!'
35
+ end
36
+
37
+ private
38
+
39
+ def write_header
40
+ File.write path, headers
41
+ rescue Errno::ENOENT
42
+ Dir.mkdir CSV.dir
43
+ retry
44
+ end
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,23 @@
1
+ require 'csv'
2
+
3
+ module ErrandBoy
4
+ class CSV
5
+ class SlackInvite < Base
6
+ def headers
7
+ result = %w(sender_name sender_email register_name register_email team)
8
+ result.to_csv
9
+ end
10
+
11
+ def values
12
+ result = [@request.sender['name'].to_s, @request.sender['email'].to_s,
13
+ @request.register['name'].to_s, @request.register['email'].to_s,
14
+ @request.destination['team'].to_s]
15
+ result.to_csv
16
+ end
17
+
18
+ def duplicated?
19
+ include?(:register_email, @request.register['email'].to_s)
20
+ end
21
+ end
22
+ end
23
+ end
@@ -0,0 +1,8 @@
1
+ module ErrandBoy
2
+ class InvalidError < StandardError; end
3
+ class NoActionError < StandardError; end
4
+ class NoRequestError < StandardError; end
5
+ class NoProviderError < StandardError; end
6
+ class GitExecuteError < StandardError; end
7
+ class SlackInviteMissingError < StandardError; end
8
+ end
@@ -0,0 +1,10 @@
1
+ module ErrandBoy
2
+ module Gateway
3
+ def self.build(request)
4
+ provider = request.provider.capitalize
5
+ const_get(provider).new(request)
6
+ rescue
7
+ raise NoProviderError, "No such provider `#{provider}`."
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,57 @@
1
+ require 'json'
2
+ require 'faraday'
3
+
4
+ module ErrandBoy
5
+ module Gateway
6
+ class Slack
7
+ def initialize(request)
8
+ @request = request
9
+ end
10
+
11
+ def call
12
+ send(@request.action)
13
+ rescue NoMethodError
14
+ raise NoActionError, "#{@request.action}: action not found."
15
+ end
16
+
17
+ def invite
18
+ response = connect.post 'api/users.admin.invite', params
19
+ result = JSON.parse response.body
20
+ unless result['ok']
21
+ @processed = true if result['error'] == 'already_invited'
22
+ raise SlackInviteMissingError, result['error'] unless processed?
23
+ end
24
+ end
25
+
26
+ def team
27
+ @request.destination['team']
28
+ end
29
+
30
+ def url
31
+ "https://#{team}.slack.com/"
32
+ end
33
+
34
+ def processed?
35
+ @processed
36
+ end
37
+
38
+ private
39
+
40
+ def connect
41
+ Faraday.new(url: url) do |faraday|
42
+ faraday.request :url_encoded
43
+ # faraday.response :logger
44
+ faraday.adapter Faraday.default_adapter
45
+ end
46
+ end
47
+
48
+ def params
49
+ {
50
+ email: @request.register['email'],
51
+ token: ErrandBoy.slack_access_token,
52
+ set_active: true
53
+ }
54
+ end
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,22 @@
1
+ require 'git'
2
+
3
+ module ErrandBoy
4
+ class Git
5
+ def initialize(working_dir)
6
+ @git = ::Git.open(working_dir)
7
+ end
8
+
9
+ def push
10
+ @git.push 'origin', branch
11
+ end
12
+
13
+ def commit(message)
14
+ @git.add
15
+ @git.commit message
16
+ end
17
+
18
+ def branch
19
+ @git.lib.branch_current
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,38 @@
1
+ require 'toml'
2
+
3
+ module ErrandBoy
4
+ class Request
5
+ attr_reader :sender, :provider, :action, :register, :destination, :path
6
+
7
+ def self.dir
8
+ File.expand_path 'requests'
9
+ end
10
+
11
+ def initialize(path)
12
+ @path = path.to_s
13
+ request.each do |key, value|
14
+ instance_variable_set("@#{key}", value)
15
+ end
16
+ @sender = '' unless instance_variable_defined? :@sender
17
+ end
18
+
19
+ def rename
20
+ timestamp = Time.now.strftime '%y%m%d%H%M%S'
21
+ index = path.index('.toml')
22
+ File.rename path, path.dup.insert(index, "_#{timestamp}")
23
+ end
24
+
25
+ def delete
26
+ File.delete path
27
+ end
28
+
29
+ private
30
+
31
+ def request
32
+ TOML.load_file(path)
33
+ rescue Errno::ENOENT
34
+ raise NoRequestError, 'No such request file in this commit. ' \
35
+ 'You should add a request file to `requests/` folder.'
36
+ end
37
+ end
38
+ end
@@ -0,0 +1,11 @@
1
+ module ErrandBoy
2
+ module Validator
3
+ def self.build(request)
4
+ class_name = request.provider.capitalize
5
+ class_name += request.action.capitalize
6
+ const_get(class_name).new(request)
7
+ rescue NameError
8
+ raise InvalidError, "#{request.provider} #{request.action} does not defined."
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,36 @@
1
+ module ErrandBoy
2
+ module Validator
3
+ class Base
4
+ def initialize(request)
5
+ @request = request
6
+ end
7
+
8
+ def run
9
+ methods.each do |method|
10
+ send(method) if /check_\w+/ === method
11
+ end
12
+ end
13
+
14
+ def check_sender_name
15
+ warn 'sender_name is empty.' if @request.sender['name'].empty?
16
+ rescue NoMethodError
17
+ warn 'sender does not set.'
18
+ end
19
+
20
+ def check_sender_email
21
+ email = @request.sender['email']
22
+ if email.empty?
23
+ warn 'sender_email is empty.'
24
+ elsif email !~ valid_address
25
+ warn 'sender_email is invalid address.'
26
+ end
27
+ rescue NoMethodError
28
+ warn 'sender does not set.'
29
+ end
30
+
31
+ def valid_address
32
+ %r(\A[a-zA-Z0-9_\#!$%&`'*+\-{|}~^\/=?\.]+@[a-zA-Z0-9][a-zA-Z0-9\.-]+\z)
33
+ end
34
+ end
35
+ end
36
+ end
@@ -0,0 +1,30 @@
1
+ module ErrandBoy
2
+ module Validator
3
+ class SlackInvite < Base
4
+ def check_register_name
5
+ warn 'register_name is empty.' if @request.register['name'].empty?
6
+ rescue NoMethodError
7
+ raise InvalidError, 'register does not set.'
8
+ end
9
+
10
+ def check_register_email
11
+ email = @request.register['email']
12
+ if email.empty?
13
+ raise InvalidError, 'register_email is empty.'
14
+ elsif email !~ valid_address
15
+ raise InvalidError, 'register_email is invalid address.'
16
+ end
17
+ rescue NoMethodError
18
+ raise InvalidError, 'register does not set.'
19
+ end
20
+
21
+ def check_team
22
+ if @request.destination['team'].empty?
23
+ raise InvalidError, 'team is empty.'
24
+ end
25
+ rescue NoMethodError
26
+ raise InvalidError, 'destination does not set.'
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,3 @@
1
+ module ErrandBoy
2
+ VERSION = "0.1.0"
3
+ end
File without changes
metadata ADDED
@@ -0,0 +1,202 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: errand-boy
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - yuta-muramoto
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2016-10-21 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: toml-rb
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: faraday
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: git
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: pry
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: bundler
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '1.11'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '1.11'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rake
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '10.0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: '10.0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: minitest
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: '5.0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: '5.0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: minitest-reporters
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: minitest-stub_any_instance
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ description: ErrandBoy is admin support tool. He will send slack invitation instead
140
+ of you.
141
+ email:
142
+ - s1513114@u.tsukuba.ac.jp
143
+ executables: []
144
+ extensions: []
145
+ extra_rdoc_files: []
146
+ files:
147
+ - ".gitignore"
148
+ - ".ruby-version"
149
+ - Gemfile
150
+ - LICENSE.txt
151
+ - README.md
152
+ - Rakefile
153
+ - bin/console
154
+ - bin/exe
155
+ - bin/setup
156
+ - circle.yml
157
+ - errand_boy.gemspec
158
+ - example/Gemfile
159
+ - example/bin/exe
160
+ - example/circle.yml
161
+ - example/index/.keep
162
+ - example/requests/.keep
163
+ - lib/errand_boy.rb
164
+ - lib/errand_boy/brain.rb
165
+ - lib/errand_boy/csv.rb
166
+ - lib/errand_boy/csv/base.rb
167
+ - lib/errand_boy/csv/slack_invite.rb
168
+ - lib/errand_boy/error.rb
169
+ - lib/errand_boy/gateway.rb
170
+ - lib/errand_boy/gateway/slack.rb
171
+ - lib/errand_boy/git.rb
172
+ - lib/errand_boy/request.rb
173
+ - lib/errand_boy/validator.rb
174
+ - lib/errand_boy/validator/base.rb
175
+ - lib/errand_boy/validator/slack_invite.rb
176
+ - lib/errand_boy/version.rb
177
+ - requests/.keep
178
+ homepage: https://github.com/bm-sms/errand_boy.git
179
+ licenses:
180
+ - MIT
181
+ metadata: {}
182
+ post_install_message:
183
+ rdoc_options: []
184
+ require_paths:
185
+ - lib
186
+ required_ruby_version: !ruby/object:Gem::Requirement
187
+ requirements:
188
+ - - ">="
189
+ - !ruby/object:Gem::Version
190
+ version: '0'
191
+ required_rubygems_version: !ruby/object:Gem::Requirement
192
+ requirements:
193
+ - - ">="
194
+ - !ruby/object:Gem::Version
195
+ version: '0'
196
+ requirements: []
197
+ rubyforge_project:
198
+ rubygems_version: 2.5.1
199
+ signing_key:
200
+ specification_version: 4
201
+ summary: ErrandBoy is admin support tool.
202
+ test_files: []