fastlane-plugin-verify_ipa 0.2.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: 42b7db74543c5f6bc6a5ed8c8cd8ba34bfabde66
4
+ data.tar.gz: 338343d1b42adffb30af58d44f70028db4f2e7a1
5
+ SHA512:
6
+ metadata.gz: c3659616ced5fa968695cf27e7ae13dbc642a24450092c75c01c7a02f03153a36c3b802d164eb968583d4a619d88d91cea2f85e88f5930f8f923a027835623a5
7
+ data.tar.gz: 3d4c4de32c3266934c9777fdf4a82f538ed5bf2fa742c601d20b4fe427d9e27bd6a17527db73328867bd38c16728f67d762eeb4646d1e0272c5c293a0d67d6c6
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2017 Derek Yang <yanghada@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
+ # verify_ipa plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-verify_ipa)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [fastlane](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-verify_ipa`, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin verify_ipa
11
+ ```
12
+
13
+ ## About verify_ipa
14
+
15
+ verify_ipa
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://docs.fastlane.tools/plugins/plugins-troubleshooting/) guide.
45
+
46
+ ## Using `fastlane` Plugins
47
+
48
+ For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://docs.fastlane.tools/plugins/create-plugin/).
49
+
50
+ ## About `fastlane`
51
+
52
+ `fastlane` is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
@@ -0,0 +1,16 @@
1
+ require 'fastlane/plugin/verify_ipa/version'
2
+
3
+ module Fastlane
4
+ module VerifyIpa
5
+ # Return all .rb files inside the "actions" and "helper" directory
6
+ def self.all_classes
7
+ Dir[File.expand_path('**/{actions,helper}/*.rb', File.dirname(__FILE__))]
8
+ end
9
+ end
10
+ end
11
+
12
+ # By default we want to import all available actions and helpers
13
+ # A plugin can contain any number of actions and plugins
14
+ Fastlane::VerifyIpa.all_classes.each do |current|
15
+ require current
16
+ end
@@ -0,0 +1,85 @@
1
+ require 'plist'
2
+
3
+ module Fastlane
4
+ module Actions
5
+ class VerifyIpaEntitlementsAction < Action
6
+ def self.run(params)
7
+ Dir.mktmpdir do |dir|
8
+ app_path = Helper::VerifyIpaHelper.app_path(params, dir)
9
+ entitlements = self.read_entitlements(params, app_path)
10
+ self.verify_entitlements(params, entitlements)
11
+ end
12
+ end
13
+
14
+ def self.read_entitlements(params, app_path)
15
+ profile_path = "#{app_path}/embedded.mobileprovision"
16
+ profile_plist = sh("security cms -D -i #{profile_path}")
17
+ UI.user_error!("Unable to extract profile") unless $? == 0
18
+
19
+ profile = Plist.parse_xml(profile_plist)
20
+ profile['Entitlements']
21
+ end
22
+
23
+ def self.verify_entitlements(params, entitlements)
24
+ if params[:application_identifier]
25
+ self.verify_param(:application_identifier, params[:application_identifier], entitlements['application-identifier'])
26
+ end
27
+ if params[:team_identifier]
28
+ self.verify_param(:team_identifier, params[:team_identifier], entitlements['com.apple.developer.team-identifier'])
29
+ end
30
+ if params[:aps_environment]
31
+ self.verify_param(:aps_environment, params[:aps_environment], entitlements['aps-environment'])
32
+ end
33
+ if params[:other_params]
34
+ params[:other_params].keys.each do |key|
35
+ self.verify_param(key, params[:other_params][key], entitlements[key.to_s.tr('_', '-')])
36
+ end
37
+ end
38
+
39
+ UI.success("Entitlements are verified.")
40
+ end
41
+
42
+ def self.verify_param(param, expected, actual)
43
+ UI.user_error!("Mismatched #{param}. Expected: '#{expected}'; Found: '#{actual}'") unless expected == actual
44
+ end
45
+
46
+ def self.description
47
+ 'Verify ipa entitlements'
48
+ end
49
+
50
+ def self.authors
51
+ ['Derek Yang']
52
+ end
53
+
54
+ def self.available_options
55
+ [
56
+ FastlaneCore::ConfigItem.new(key: :ipa_path,
57
+ env_name: 'VERIFY_IPA_IPA_PATH',
58
+ description: 'Explicitly set the ipa path',
59
+ optional: true),
60
+ FastlaneCore::ConfigItem.new(key: :application_identifier,
61
+ env_name: 'VERIFY_IPA_APPLICATION_IDENTIFIER',
62
+ description: 'Key application-identifier in Entitlements',
63
+ optional: true),
64
+ FastlaneCore::ConfigItem.new(key: :team_identifier,
65
+ env_name: 'VERIFY_IPA_TEAM_IDENTIFIER',
66
+ description: 'Key com.apple.developer.team-identifier in Entitlements',
67
+ optional: true),
68
+ FastlaneCore::ConfigItem.new(key: :aps_environment,
69
+ env_name: 'VERIFY_IPA_APS_ENVIRONMENT',
70
+ description: 'Key aps-environment in Entitlements',
71
+ optional: true),
72
+ FastlaneCore::ConfigItem.new(key: :other_params,
73
+ env_name: 'VERIFY_IPA_OTHER_PARAMS',
74
+ description: 'A hash of entitlement key and expected values',
75
+ optional: true,
76
+ type: Hash)
77
+ ]
78
+ end
79
+
80
+ def self.is_supported?(platform)
81
+ [:ios].include?(platform)
82
+ end
83
+ end
84
+ end
85
+ end
@@ -0,0 +1,60 @@
1
+ module Fastlane
2
+ module Actions
3
+ class VerifyIpaFilesAction < Action
4
+ def self.run(params)
5
+ Dir.mktmpdir do |dir|
6
+ app_path = Helper::VerifyIpaHelper.app_path(params, dir)
7
+ self.verify_files(params, app_path)
8
+ end
9
+ end
10
+
11
+ def self.verify_files(params, app_path)
12
+ files_on_blacklist = []
13
+ files_on_whitelist = []
14
+
15
+ Dir.chdir(app_path) do
16
+ params[:blacklist].each { |pattern| files_on_blacklist << Dir.glob(pattern) }
17
+ params[:whitelist].each { |pattern| files_on_whitelist << Dir.glob(pattern) } if params[:whitelist]
18
+
19
+ invalid_files = files_on_blacklist.flatten - files_on_whitelist.flatten
20
+ UI.user_error!("Found files on the blacklist: #{invalid_files}") unless invalid_files.empty?
21
+ end
22
+ end
23
+
24
+ def self.description
25
+ 'Verify files in ipa file'
26
+ end
27
+
28
+ def self.details
29
+ 'Make sure no sensible files (e.g. build script or mock data with sensible info) are accidentally included in ipa file'
30
+ end
31
+
32
+ def self.authors
33
+ ['Derek Yang']
34
+ end
35
+
36
+ def self.available_options
37
+ [
38
+ FastlaneCore::ConfigItem.new(key: :ipa_path,
39
+ env_name: 'VERIFY_IPA_IPA_PATH',
40
+ description: 'Explicitly set the ipa path',
41
+ optional: true),
42
+ FastlaneCore::ConfigItem.new(key: :blacklist,
43
+ env_name: 'VERIFY_IPA_BLACKLIST',
44
+ description: 'A list of glob patterns that define what files should NOT make their way into the ipa',
45
+ optional: false,
46
+ type: Array),
47
+ FastlaneCore::ConfigItem.new(key: :whitelist,
48
+ env_name: 'VERIFY_IPA_WHITELIST',
49
+ description: 'A list of glob patterns that are allowed to be included in the ipa',
50
+ optional: true,
51
+ type: Array)
52
+ ]
53
+ end
54
+
55
+ def self.is_supported?(platform)
56
+ [:ios].include?(platform)
57
+ end
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,15 @@
1
+ module Fastlane
2
+ module Helper
3
+ class VerifyIpaHelper
4
+ def self.app_path(params, dir)
5
+ ipa_path = params[:ipa_path] || Actions.lane_context[SharedValues::IPA_OUTPUT_PATH] || ''
6
+ UI.user_error!("Unable to find ipa file '#{ipa_path}'.") unless File.exist?(ipa_path)
7
+
8
+ ipa_path = File.expand_path(ipa_path)
9
+ `unzip '#{ipa_path}' -d #{dir}`
10
+ UI.user_error!("Unable to unzip ipa '#{ipa_path}'") unless $? == 0
11
+ File.expand_path("#{dir}/Payload/*.app")
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module VerifyIpa
3
+ VERSION = "0.2.0"
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,148 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-verify_ipa
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.2.0
5
+ platform: ruby
6
+ authors:
7
+ - Derek Yang
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-03-04 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: plist
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: rake
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: rubocop
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: fastlane
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: 2.18.2
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: 2.18.2
111
+ description:
112
+ email: yanghada@gmail.com
113
+ executables: []
114
+ extensions: []
115
+ extra_rdoc_files: []
116
+ files:
117
+ - LICENSE
118
+ - README.md
119
+ - lib/fastlane/plugin/verify_ipa.rb
120
+ - lib/fastlane/plugin/verify_ipa/actions/verify_ipa_entitlements_action.rb
121
+ - lib/fastlane/plugin/verify_ipa/actions/verify_ipa_files_action.rb
122
+ - lib/fastlane/plugin/verify_ipa/helper/verify_ipa_helper.rb
123
+ - lib/fastlane/plugin/verify_ipa/version.rb
124
+ homepage: https://github.com/dyang/verify_ipa
125
+ licenses:
126
+ - MIT
127
+ metadata: {}
128
+ post_install_message:
129
+ rdoc_options: []
130
+ require_paths:
131
+ - lib
132
+ required_ruby_version: !ruby/object:Gem::Requirement
133
+ requirements:
134
+ - - ">="
135
+ - !ruby/object:Gem::Version
136
+ version: '0'
137
+ required_rubygems_version: !ruby/object:Gem::Requirement
138
+ requirements:
139
+ - - ">="
140
+ - !ruby/object:Gem::Version
141
+ version: '0'
142
+ requirements: []
143
+ rubyforge_project:
144
+ rubygems_version: 2.6.10
145
+ signing_key:
146
+ specification_version: 4
147
+ summary: verify_ipa
148
+ test_files: []