fastlane-plugin-update_android_strings 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: 9561fd6b69ba743b1e374d32cd0192ac68abd17a
4
+ data.tar.gz: 65bc7b7413d4f6526cbaea05f33c251aed3ee018
5
+ SHA512:
6
+ metadata.gz: 59e5fcce959dbd18eb18f7dfd4f0cacebff91d53c5a73fc092209c93c897cf97d89149db6de4acb04f86a71d23dc560681971ef361dfa1039545b332c5b2ff5c
7
+ data.tar.gz: 7aa38a86822ed85dc0f6205cdeece101b2ee6c7a67b09d8d8c950d7946863481e712163a9218f3376b9a4f31fc2ba613efe2ab59510c504c9d1542a55868d75a
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2017 bang <sqibang@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.
@@ -0,0 +1,52 @@
1
+ # update_android_strings plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-update_android_strings)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [_fastlane_](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-update_android_strings`, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin update_android_strings
11
+ ```
12
+
13
+ ## About update_android_strings
14
+
15
+ Update Android res strings.xml
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/update_android_strings/version'
2
+
3
+ module Fastlane
4
+ module UpdateAndroidStrings
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::UpdateAndroidStrings.all_classes.each do |current|
15
+ require current
16
+ end
@@ -0,0 +1,94 @@
1
+ module Fastlane
2
+ module Actions
3
+ class UpdateAndroidStringsAction < Action
4
+ def self.run(params)
5
+ require 'ox'
6
+
7
+ if params[:block]
8
+ if params[:xml_path]
9
+ xmlPath = params[:xml_path]
10
+ else
11
+ xmlPath = "android/app/src/main/res/values/strings.xml"
12
+ end
13
+ unless File.exist?(xmlPath)
14
+ UI.user_error!("The xml file at path `#{xmlPath}` doesn't exist.")
15
+ end
16
+ f = File.open(xmlPath, "r")
17
+ xml = f.read
18
+ f.close
19
+
20
+ strings = Ox.parse(xml)
21
+
22
+ unless strings
23
+ UI.error("xml is Empty!")
24
+ return
25
+ end
26
+ # find key and update text with new value
27
+ strings.nodes.each do |element|
28
+ if element.respond_to? :name and element["name"] == "reactNativeCodePush_androidDeploymentKey"
29
+ element.replace_text("hello")
30
+ end
31
+ end
32
+ if params[:block]
33
+ hashes = {}
34
+ params[:block].call(hashes)
35
+
36
+ Helper::UpdateAndroidStringsHelper.updateXml(strings.nodes, hashes)
37
+
38
+ # dump new xml file
39
+ newXml = Ox.dump(strings)
40
+ if xml != newXml
41
+ File.write(xmlPath, newXml)
42
+ UI.success("Update xml file success.")
43
+ else
44
+ UI.message("Nothing has changed.")
45
+ end
46
+ end
47
+
48
+ else
49
+ UI.important("You haven't specified block parameter to update your xml file")
50
+ false
51
+ end
52
+ end
53
+
54
+ def self.description
55
+ "Update Android res strings.xml"
56
+ end
57
+
58
+ def self.authors
59
+ ["bang"]
60
+ end
61
+
62
+ def self.return_value
63
+ # If your method provides a return value, you can describe here what it does
64
+ end
65
+
66
+ def self.details
67
+ # Optional:
68
+ "This plugin help you update strings.xml"
69
+ end
70
+
71
+ def self.available_options
72
+ [
73
+ FastlaneCore::ConfigItem.new(key: :xml_path,
74
+ env_name: "UPDATE_ANDROID_STRINGS_XML_PATH",
75
+ description: "Path to strings.xml",
76
+ optional: true),
77
+ FastlaneCore::ConfigItem.new(key: :block,
78
+ description: "A block to process strings.xml with custom logic",
79
+ optional: false,
80
+ is_string: false)
81
+ ]
82
+ end
83
+
84
+ def self.is_supported?(platform)
85
+ # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example)
86
+ # See: https://github.com/fastlane/fastlane/blob/master/fastlane/docs/Platforms.md
87
+ #
88
+ # [:ios, :mac, :android].include?(platform)
89
+ [:android].include?(platform)
90
+ true
91
+ end
92
+ end
93
+ end
94
+ end
@@ -0,0 +1,21 @@
1
+
2
+ module Fastlane
3
+ module Helper
4
+ class UpdateAndroidStringsHelper
5
+ # class methods that you define here become available in your action
6
+ # as `Helper::UpdateAndroidStringsHelper.your_method`
7
+ #
8
+ def self.updateXml(nodes, hashes = {})
9
+ if hashes and nodes
10
+ # find key and update text with new value
11
+ nodes.each do |element|
12
+ if element.respond_to? :name and hashes.has_key?(element["name"])
13
+ element.replace_text(hashes.fetch(element["name"]))
14
+ end
15
+ end
16
+ end
17
+
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module UpdateAndroidStrings
3
+ VERSION = "0.1.0"
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,161 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-update_android_strings
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - bang
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-08-15 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: ox
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: simplecov
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - '>='
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - '>='
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: fastlane
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - '>='
116
+ - !ruby/object:Gem::Version
117
+ version: 2.53.1
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - '>='
123
+ - !ruby/object:Gem::Version
124
+ version: 2.53.1
125
+ description:
126
+ email: sqibang@gmail.com
127
+ executables: []
128
+ extensions: []
129
+ extra_rdoc_files: []
130
+ files:
131
+ - lib/fastlane/plugin/update_android_strings/actions/update_android_strings_action.rb
132
+ - lib/fastlane/plugin/update_android_strings/helper/update_android_strings_helper.rb
133
+ - lib/fastlane/plugin/update_android_strings/version.rb
134
+ - lib/fastlane/plugin/update_android_strings.rb
135
+ - README.md
136
+ - LICENSE
137
+ homepage:
138
+ licenses:
139
+ - MIT
140
+ metadata: {}
141
+ post_install_message:
142
+ rdoc_options: []
143
+ require_paths:
144
+ - lib
145
+ required_ruby_version: !ruby/object:Gem::Requirement
146
+ requirements:
147
+ - - '>='
148
+ - !ruby/object:Gem::Version
149
+ version: '0'
150
+ required_rubygems_version: !ruby/object:Gem::Requirement
151
+ requirements:
152
+ - - '>='
153
+ - !ruby/object:Gem::Version
154
+ version: '0'
155
+ requirements: []
156
+ rubyforge_project:
157
+ rubygems_version: 2.0.14.1
158
+ signing_key:
159
+ specification_version: 4
160
+ summary: Update Android res strings.xml
161
+ test_files: []