fastlane-plugin-github_status 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 4c63210bd71ce1329379c0a2c407cb7eedd50b5a
4
+ data.tar.gz: 43b0022b168f882f9e3215f39df7f0f58200aa5c
5
+ SHA512:
6
+ metadata.gz: 10537b24a43898835f9f4e5efaab406a33429be0a9fcd8b1838322573b4f15d58022277714e42da3a1e38a4e385ee550ed50876ab9366297a376b190a808b6a4
7
+ data.tar.gz: 5649d201f794cd449c6c1288f18ef8b1752f7aef241790785d0f9c99a95d030a26cef510ee2db749c69b23e5b075a4766c36ff838eeff2c6db5aa663e56c8395
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 Michael Furtak <michael.furtak@gmail.com>
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 all
13
+ 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 THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,52 @@
1
+ # github_status plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-github_status)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [fastlane](https://github.com/fastlane/fastlane) plugin. To get started with fastlane-plugin-github_status, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin github_status
11
+ ```
12
+
13
+ ## About github_status
14
+
15
+ Provides the ability to check on GitHub server status as part of your build
16
+
17
+ **Note to author:** Add a more detailed description about this plugin here. If your plugin contains multiple actions, make sure to mention them here.
18
+
19
+ ## Example
20
+
21
+ Check out the [example `Fastfile`](fastlane/Fastfile) to see how to use this plugin. Try it by cloning the repo, running `fastlane install_plugins` and `bundle exec fastlane test`.
22
+
23
+ **Note to author:** Please set up a sample project to make it easy for users to explore what your plugin does. Provide everything that is necessary to try out the plugin in this project (including a sample Xcode/Android project if necessary)
24
+
25
+ ## Run tests for this plugin
26
+
27
+ To run both the tests, and code style validation, run
28
+
29
+ ````
30
+ rake
31
+ ```
32
+
33
+ To automatically fix many of the styling issues, use
34
+ ```
35
+ rubocop -a
36
+ ```
37
+
38
+ ## Issues and Feedback
39
+
40
+ For any other issues and feedback about this plugin, please submit it to this repository.
41
+
42
+ ## Troubleshooting
43
+
44
+ If you have trouble using plugins, check out the [Plugins Troubleshooting](https://github.com/fastlane/fastlane/blob/master/fastlane/docs/PluginsTroubleshooting.md) doc in the main `fastlane` repo.
45
+
46
+ ## Using `fastlane` Plugins
47
+
48
+ For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://github.com/fastlane/fastlane/blob/master/fastlane/docs/Plugins.md).
49
+
50
+ ## About `fastlane`
51
+
52
+ `fastlane` is the easiest way to automate building and releasing your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
@@ -0,0 +1,24 @@
1
+ require 'open-uri'
2
+ require 'time'
3
+ require 'colored'
4
+ require 'json'
5
+
6
+ require 'fastlane/plugin/github_status/version'
7
+ require 'fastlane/plugin/github_status/ui'
8
+ require 'fastlane/plugin/github_status/message'
9
+ require 'fastlane/plugin/github_status/client'
10
+
11
+ module Fastlane
12
+ module GithubStatus
13
+ # Return all .rb files inside the "actions" and "helper" directory
14
+ def self.all_classes
15
+ Dir[File.expand_path('**/{actions,helper}/*.rb', File.dirname(__FILE__))]
16
+ end
17
+ end
18
+ end
19
+
20
+ # By default we want to import all available actions and helpers
21
+ # A plugin can contain any number of actions and plugins
22
+ Fastlane::GithubStatus.all_classes.each do |current|
23
+ require current
24
+ end
@@ -0,0 +1,53 @@
1
+ module Fastlane
2
+ module Actions
3
+ class GithubStatusAction < Action
4
+ def self.run(params)
5
+ ui.print_message(client.last_message)
6
+ end
7
+
8
+ def self.description
9
+ 'Provides the ability to check on GitHub server status as part of your build'
10
+ end
11
+
12
+ def self.authors
13
+ ['Michael Furtak']
14
+ end
15
+
16
+ def self.available_options
17
+ [
18
+ # FastlaneCore::ConfigItem.new(key: :your_option,
19
+ # env_name: "GITHUB_STATUS_YOUR_OPTION",
20
+ # description: "A description of your option",
21
+ # optional: false,
22
+ # type: String)
23
+ ]
24
+ end
25
+
26
+ def self.is_supported?(platform)
27
+ true
28
+ end
29
+
30
+ #
31
+ # collaborators
32
+ #
33
+
34
+ # Used to override the UI for testing
35
+ def self.ui=(ui)
36
+ @ui = ui
37
+ end
38
+
39
+ def self.ui
40
+ @ui ||= Plugin::GitHubStatus::UI.new
41
+ end
42
+
43
+ # Used to override the Client for testing
44
+ def self.client=(client)
45
+ @client = client
46
+ end
47
+
48
+ def self.client
49
+ @client ||= Plugin::GitHubStatus::Client.new
50
+ end
51
+ end
52
+ end
53
+ end
@@ -0,0 +1,16 @@
1
+ module Fastlane
2
+ module Plugin
3
+ module GitHubStatus
4
+ # Calls GitHub's status API and returns model objects to represent the data
5
+ class Client
6
+ API_ENDPOINT = 'https://status.github.com/api'.freeze
7
+
8
+ # @return Message representing the last status update from GitHub
9
+ def last_message
10
+ message_json = JSON.parse(open("#{API_ENDPOINT}/last-message.json").read)
11
+ Plugin::GitHubStatus::Message.new(message_json)
12
+ end
13
+ end
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,38 @@
1
+ module Fastlane
2
+ module Plugin
3
+ module GitHubStatus
4
+ # Immutable module object representing the last status message
5
+ # provided by GitHub
6
+ class Message
7
+ # String representing one of three possible statuses:
8
+ # * 'good' - Everything is OK
9
+ # * 'minor' - GitHub is experiencing minor problems
10
+ # * 'major' - GitHub is experiencing major problems
11
+ attr_reader :status
12
+
13
+ # A more descriptive message describing the current situation
14
+ attr_reader :body
15
+
16
+ # Time object representing when this status message was
17
+ # created by GitHub
18
+ attr_reader :created_on
19
+
20
+ # Expects to be called with a hash of the JSON data
21
+ # returned from the GitHub status API endpoint
22
+ #
23
+ # https://status.github.com/api
24
+ #
25
+ # {
26
+ # 'status' => 'good',
27
+ # 'body' => 'Everything operating normally.',
28
+ # 'created_on' => '2016-06-01T16:40:35Z'
29
+ # }
30
+ def initialize(data_hash)
31
+ @status = data_hash['status']
32
+ @body = data_hash['body']
33
+ @created_on = Time.parse(data_hash['created_on'])
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
@@ -0,0 +1,32 @@
1
+ module Fastlane
2
+ module Plugin
3
+ module GitHubStatus
4
+ class UI
5
+ FastlaneUI = FastlaneCore::UI
6
+
7
+ STATUS_TO_COLOR = {
8
+ 'good' => :green,
9
+ 'minor' => :yellow,
10
+ 'major' => :red
11
+ }.freeze
12
+
13
+ def print_message(message)
14
+ FastlaneUI.message '🐙 🐱'
15
+ FastlaneUI.message "GitHub status is: #{status_statement(message)}"
16
+ FastlaneUI.message "Last updated: #{message.created_on}"
17
+ FastlaneUI.message '🐙 🐱'
18
+ end
19
+
20
+ def status_statement(message)
21
+ status = message.status
22
+ colorize_for_status(status, "#{status.upcase} - #{message.body}")
23
+ end
24
+
25
+ def colorize_for_status(status, message)
26
+ color = STATUS_TO_COLOR[status]
27
+ message.send(color) if color
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module GithubStatus
3
+ VERSION = "0.1.0"
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,136 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-github_status
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Michael Furtak
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-06-05 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: colored
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: pry
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
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: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
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: rspec
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: rubocop
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: fastlane
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: 1.93.1
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: 1.93.1
97
+ description:
98
+ email: michael.furtak@gmail.com
99
+ executables: []
100
+ extensions: []
101
+ extra_rdoc_files: []
102
+ files:
103
+ - LICENSE
104
+ - README.md
105
+ - lib/fastlane/plugin/github_status.rb
106
+ - lib/fastlane/plugin/github_status/actions/github_status_action.rb
107
+ - lib/fastlane/plugin/github_status/client.rb
108
+ - lib/fastlane/plugin/github_status/message.rb
109
+ - lib/fastlane/plugin/github_status/ui.rb
110
+ - lib/fastlane/plugin/github_status/version.rb
111
+ homepage: https://github.com/mfurtak/fastlane-plugin-github_status
112
+ licenses:
113
+ - MIT
114
+ metadata: {}
115
+ post_install_message:
116
+ rdoc_options: []
117
+ require_paths:
118
+ - lib
119
+ required_ruby_version: !ruby/object:Gem::Requirement
120
+ requirements:
121
+ - - ">="
122
+ - !ruby/object:Gem::Version
123
+ version: '0'
124
+ required_rubygems_version: !ruby/object:Gem::Requirement
125
+ requirements:
126
+ - - ">="
127
+ - !ruby/object:Gem::Version
128
+ version: '0'
129
+ requirements: []
130
+ rubyforge_project:
131
+ rubygems_version: 2.4.5.1
132
+ signing_key:
133
+ specification_version: 4
134
+ summary: Provides the ability to check on GitHub server status as part of your build
135
+ test_files: []
136
+ has_rdoc: