fastlane 1.111.0 → 2.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +76 -111
- data/bin/bin-proxy +19 -0
- data/cert/README.md +163 -0
- data/cert/lib/cert.rb +18 -0
- data/cert/lib/cert/commands_generator.rb +51 -0
- data/cert/lib/cert/options.rb +67 -0
- data/cert/lib/cert/runner.rb +181 -0
- data/credentials_manager/README.md +62 -0
- data/credentials_manager/lib/credentials_manager.rb +12 -0
- data/credentials_manager/lib/credentials_manager/account_manager.rb +104 -0
- data/credentials_manager/lib/credentials_manager/appfile_config.rb +186 -0
- data/credentials_manager/lib/credentials_manager/cli.rb +65 -0
- data/deliver/README.md +271 -0
- data/deliver/lib/assets/DeliverfileDefault +10 -0
- data/deliver/lib/assets/ScreenshotsHelp +7 -0
- data/deliver/lib/assets/summary.html.erb +210 -0
- data/deliver/lib/deliver.rb +31 -0
- data/deliver/lib/deliver/app_screenshot.rb +226 -0
- data/deliver/lib/deliver/commands_generator.rb +150 -0
- data/deliver/lib/deliver/detect_values.rb +69 -0
- data/deliver/lib/deliver/download_screenshots.rb +46 -0
- data/deliver/lib/deliver/generate_summary.rb +9 -0
- data/deliver/lib/deliver/html_generator.rb +58 -0
- data/deliver/lib/deliver/loader.rb +18 -0
- data/deliver/lib/deliver/options.rb +269 -0
- data/deliver/lib/deliver/runner.rb +99 -0
- data/deliver/lib/deliver/setup.rb +78 -0
- data/deliver/lib/deliver/submit_for_review.rb +87 -0
- data/deliver/lib/deliver/upload_assets.rb +22 -0
- data/deliver/lib/deliver/upload_metadata.rb +191 -0
- data/deliver/lib/deliver/upload_price_tier.rb +21 -0
- data/deliver/lib/deliver/upload_screenshots.rb +110 -0
- data/fastlane/README.md +193 -0
- data/{lib → fastlane/lib}/assets/Actions.md.erb +0 -0
- data/{lib → fastlane/lib}/assets/AppfileTemplate +0 -0
- data/{lib → fastlane/lib}/assets/AppfileTemplateAndroid +0 -0
- data/{lib → fastlane/lib}/assets/AvailablePlugins.md.erb +0 -0
- data/{lib → fastlane/lib}/assets/DefaultFastfileTemplate +2 -2
- data/{lib → fastlane/lib}/assets/FastfileTemplateAndroid +2 -2
- data/{lib → fastlane/lib}/assets/completions/completion.bash +0 -0
- data/{lib → fastlane/lib}/assets/completions/completion.sh +0 -0
- data/{lib → fastlane/lib}/assets/completions/completion.zsh +0 -0
- data/{lib → fastlane/lib}/assets/custom_action_template.rb +0 -0
- data/{lib → fastlane/lib}/assets/mailgun_html_template.erb +0 -0
- data/{lib → fastlane/lib}/assets/report_template.xml.erb +0 -0
- data/{lib → fastlane/lib}/assets/s3_html_template.erb +0 -0
- data/{lib → fastlane/lib}/assets/s3_plist_template.erb +0 -0
- data/{lib → fastlane/lib}/assets/s3_version_template.erb +0 -0
- data/{lib → fastlane/lib}/fastlane.rb +3 -3
- data/{lib → fastlane/lib}/fastlane/action.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/action_collector.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/README.md +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/actions_helper.rb +16 -0
- data/{lib → fastlane/lib}/fastlane/actions/adb.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/adb_devices.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/add_git_tag.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/app_store_build_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/appaloosa.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/appetize.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/appetize_viewing_url_generator.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/appium.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/appledoc.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/appstore.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/apteligent.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/artifactory.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/backup_file.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/backup_xcarchive.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/badge.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/build_and_upload_to_appetize.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/bundle_install.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/carthage.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/actions/cert.rb +0 -4
- data/{lib → fastlane/lib}/fastlane/actions/changelog_from_git_commits.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/chatwork.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/clean_build_artifacts.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/clean_cocoapods_cache.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/clear_derived_data.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/clipboard.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/cloc.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/cocoapods.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/commit_version_bump.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/copy_artifacts.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/crashlytics.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/create_keychain.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/create_pull_request.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/danger.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/debug.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/default_platform.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/delete_keychain.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/deliver.rb +0 -4
- data/{lib → fastlane/lib}/fastlane/actions/deploygate.rb +34 -19
- data/{lib → fastlane/lib}/fastlane/actions/device_grid/README.md +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/dotgpg_environment.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/download.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/download_dsyms.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/dsym_zip.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/ensure_git_branch.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/ensure_git_status_clean.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/ensure_no_debug_code.rb +10 -2
- data/{lib → fastlane/lib}/fastlane/actions/ensure_xcode_version.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/erb.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/fastlane_version.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/flock.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/frameit.rb +6 -10
- data/{lib → fastlane/lib}/fastlane/actions/gcovr.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_build_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_build_number_repository.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_github_release.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_info_plist_value.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_ipa_info_plist_value.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/get_version_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/git_add.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/git_branch.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/git_commit.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/git_pull.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/git_tag_exists.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/gradle.rb +0 -0
- data/fastlane/lib/fastlane/actions/gym.rb +84 -0
- data/{lib → fastlane/lib}/fastlane/actions/hg_add_tag.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/hg_commit_version_bump.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/hg_ensure_clean_status.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/hg_push.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/hipchat.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/hockey.rb +37 -11
- data/{lib → fastlane/lib}/fastlane/actions/ifttt.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/import.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/import_certificate.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/import_from_git.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/increment_build_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/increment_version_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/install_on_device.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/install_xcode_plugin.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/installr.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/ipa.rb +12 -4
- data/{lib → fastlane/lib}/fastlane/actions/is_ci.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/jazzy.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/jira.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/lane_context.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/last_git_commit.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/last_git_tag.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/latest_testflight_build_number.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/lcov.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/mailgun.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/make_changelog_from_jenkins.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/match.rb +3 -9
- data/{lib → fastlane/lib}/fastlane/actions/nexus_upload.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/notification.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/notify.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/number_of_commits.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/oclint.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/onesignal.rb +3 -0
- data/{lib → fastlane/lib}/fastlane/actions/opt_out_usage.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/pem.rb +9 -15
- data/{lib → fastlane/lib}/fastlane/actions/pilot.rb +6 -12
- data/{lib → fastlane/lib}/fastlane/actions/pod_lib_lint.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/pod_push.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/podio_item.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/produce.rb +7 -11
- data/{lib → fastlane/lib}/fastlane/actions/prompt.rb +5 -2
- data/{lib → fastlane/lib}/fastlane/actions/push_git_tags.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/push_to_git_remote.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/puts.rb +8 -0
- data/{lib → fastlane/lib}/fastlane/actions/read_podspec.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/recreate_schemes.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/register_devices.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/reset_git_repo.rb +0 -0
- data/fastlane/lib/fastlane/actions/reset_simulator_contents.rb +62 -0
- data/{lib → fastlane/lib}/fastlane/actions/resign.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/restore_file.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/rocket.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/rsync.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/s3.rb +2 -1
- data/{lib → fastlane/lib}/fastlane/actions/say.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/scan.rb +0 -4
- data/{lib → fastlane/lib}/fastlane/actions/scp.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/screengrab.rb +7 -13
- data/{lib → fastlane/lib}/fastlane/actions/set_build_number_repository.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/set_changelog.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/set_github_release.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/set_info_plist_value.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/set_pod_key.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/setup_jenkins.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/sigh.rb +9 -15
- data/{lib → fastlane/lib}/fastlane/actions/skip_docs.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/slack.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/slather.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/snapshot.rb +5 -11
- data/{lib → fastlane/lib}/fastlane/actions/sonar.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/splunkmint.rb +3 -0
- data/{lib → fastlane/lib}/fastlane/actions/ssh.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/supply.rb +9 -13
- data/{lib → fastlane/lib}/fastlane/actions/swiftlint.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/team_id.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/team_name.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/testfairy.rb +28 -9
- data/{lib → fastlane/lib}/fastlane/actions/testflight.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/tryouts.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/twitter.rb +4 -0
- data/{lib → fastlane/lib}/fastlane/actions/typetalk.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/unlock_keychain.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_app_group_identifiers.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_app_identifier.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_fastlane.rb +1 -20
- data/{lib → fastlane/lib}/fastlane/actions/update_icloud_container_identifiers.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_info_plist.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_project_code_signing.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_project_provisioning.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_project_team.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_urban_airship_configuration.rb +4 -0
- data/{lib → fastlane/lib}/fastlane/actions/update_url_schemes.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/upload_symbols_to_crashlytics.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/upload_symbols_to_sentry.rb +2 -0
- data/{lib → fastlane/lib}/fastlane/actions/verify_build.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/verify_pod_keys.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/verify_xcode.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/version_bump_podspec.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/version_get_podspec.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/xcode_install.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/xcode_select.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/xcode_server_get_assets.rb +1 -0
- data/{lib → fastlane/lib}/fastlane/actions/xcodebuild.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/xcov.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/xctool.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/actions/xcversion.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/actions/zip.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/auto_complete.rb +0 -0
- data/fastlane/lib/fastlane/cli_tools_distributor.rb +125 -0
- data/{lib → fastlane/lib}/fastlane/command_line_handler.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/commands_generator.rb +5 -4
- data/{lib → fastlane/lib}/fastlane/configuration_helper.rb +0 -1
- data/{lib → fastlane/lib}/fastlane/core_ext/bundler_monkey_patch.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/documentation/actions_list.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/documentation/docs_generator.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/documentation/markdown_docs_generator.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/environment_printer.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/erb_template_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/fast_file.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/fastlane_require.rb +27 -3
- data/{lib → fastlane/lib}/fastlane/features.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/README.md +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/adb_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/cocoapod_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/crashlytics_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/gem_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/git_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/gradle_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/podspec_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/sh_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/helper/xcversion_helper.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/junit_generator.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/lane.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/lane_list.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/lane_manager.rb +25 -6
- data/{lib → fastlane/lib}/fastlane/markdown_table_formatter.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/new_action.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/one_off.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/other_action.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_fetcher.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_generator.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_generator_ui.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_info.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_info_collector.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_manager.rb +4 -4
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_search.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugin_update_manager.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/plugins.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/%gem_name%.gemspec.erb +3 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/.gitignore +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/.rspec +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/.rubocop.yml +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/.travis.yml +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/Gemfile +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/LICENSE.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/README.md.erb +2 -2
- data/{lib → fastlane/lib}/fastlane/plugins/template/Rakefile +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/circle.yml +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/fastlane/Fastfile.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/fastlane/Pluginfile.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/lib/fastlane/plugin/%plugin_name%.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/lib/fastlane/plugin/%plugin_name%/actions/%plugin_name%_action.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/lib/fastlane/plugin/%plugin_name%/helper/%plugin_name%_helper.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/lib/fastlane/plugin/%plugin_name%/version.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/spec/%plugin_name%_action_spec.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/plugins/template/spec/spec_helper.rb.erb +0 -0
- data/{lib → fastlane/lib}/fastlane/runner.rb +25 -2
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta.rb +1 -1
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta_command_line_handler.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta_info.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta_info_collector.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta_ui.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_beta_user_email_fetcher.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/crashlytics_project_parser.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/setup/setup.rb +2 -2
- data/{lib → fastlane/lib}/fastlane/setup/setup_android.rb +2 -2
- data/{lib → fastlane/lib}/fastlane/setup/setup_ios.rb +3 -3
- data/{lib → fastlane/lib}/fastlane/supported_platforms.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/tools.rb +0 -0
- data/{lib → fastlane/lib}/fastlane/version.rb +2 -2
- data/fastlane_core/README.md +54 -0
- data/fastlane_core/lib/assets/XMLTemplate.xml.erb +12 -0
- data/fastlane_core/lib/fastlane_core.rb +48 -0
- data/fastlane_core/lib/fastlane_core/cert_checker.rb +94 -0
- data/fastlane_core/lib/fastlane_core/command_executor.rb +98 -0
- data/fastlane_core/lib/fastlane_core/configuration/commander_generator.rb +82 -0
- data/fastlane_core/lib/fastlane_core/configuration/config_item.rb +133 -0
- data/fastlane_core/lib/fastlane_core/configuration/configuration.rb +266 -0
- data/fastlane_core/lib/fastlane_core/configuration/configuration_file.rb +82 -0
- data/fastlane_core/lib/fastlane_core/core_ext/string.rb +17 -0
- data/fastlane_core/lib/fastlane_core/device_manager.rb +231 -0
- data/fastlane_core/lib/fastlane_core/env.rb +9 -0
- data/{lib/fastlane → fastlane_core/lib/fastlane_core}/fastlane_folder.rb +1 -11
- data/fastlane_core/lib/fastlane_core/feature/feature.rb +49 -0
- data/fastlane_core/lib/fastlane_core/features.rb +2 -0
- data/fastlane_core/lib/fastlane_core/helper.rb +240 -0
- data/fastlane_core/lib/fastlane_core/ipa_file_analyser.rb +55 -0
- data/fastlane_core/lib/fastlane_core/ipa_upload_package_builder.rb +44 -0
- data/fastlane_core/lib/fastlane_core/itunes_search_api.rb +48 -0
- data/fastlane_core/lib/fastlane_core/itunes_transporter.rb +409 -0
- data/fastlane_core/lib/fastlane_core/keychain_importer.rb +27 -0
- data/fastlane_core/lib/fastlane_core/languages.rb +11 -0
- data/fastlane_core/lib/fastlane_core/pkg_file_analyser.rb +42 -0
- data/fastlane_core/lib/fastlane_core/pkg_upload_package_builder.rb +44 -0
- data/fastlane_core/lib/fastlane_core/print_table.rb +63 -0
- data/fastlane_core/lib/fastlane_core/project.rb +450 -0
- data/fastlane_core/lib/fastlane_core/provisioning_profile.rb +69 -0
- data/fastlane_core/lib/fastlane_core/string_filters.rb +34 -0
- data/fastlane_core/lib/fastlane_core/tool_collector.rb +179 -0
- data/fastlane_core/lib/fastlane_core/ui/disable_colors.rb +17 -0
- data/fastlane_core/lib/fastlane_core/ui/fastlane_runner.rb +190 -0
- data/fastlane_core/lib/fastlane_core/ui/github_issue_inspector_reporter.rb +50 -0
- data/fastlane_core/lib/fastlane_core/ui/implementations/shell.rb +122 -0
- data/fastlane_core/lib/fastlane_core/ui/interface.rb +159 -0
- data/fastlane_core/lib/fastlane_core/ui/ui.rb +26 -0
- data/fastlane_core/lib/fastlane_core/update_checker/changelog.rb +37 -0
- data/fastlane_core/lib/fastlane_core/update_checker/update_checker.rb +198 -0
- data/fastlane_core/lib/fastlane_core/xcodebuild_list_output_parser.rb +28 -0
- data/frameit/README.md +284 -0
- data/frameit/lib/assets/empty.png +0 -0
- data/frameit/lib/frameit.rb +52 -0
- data/frameit/lib/frameit/commands_generator.rb +99 -0
- data/frameit/lib/frameit/config_parser.rb +98 -0
- data/frameit/lib/frameit/dependency_checker.rb +20 -0
- data/frameit/lib/frameit/device_types.rb +13 -0
- data/frameit/lib/frameit/editor.rb +351 -0
- data/frameit/lib/frameit/frame_downloader.rb +71 -0
- data/frameit/lib/frameit/mac_editor.rb +32 -0
- data/frameit/lib/frameit/offsets.rb +19 -0
- data/frameit/lib/frameit/options.rb +46 -0
- data/frameit/lib/frameit/runner.rb +45 -0
- data/frameit/lib/frameit/screenshot.rb +89 -0
- data/frameit/lib/frameit/strings_parser.rb +35 -0
- data/frameit/lib/frameit/template_finder.rb +36 -0
- data/gym/README.md +288 -0
- data/gym/lib/assets/GymfileTemplate +13 -0
- data/gym/lib/assets/package_application_patches/0001_codesign_args_patch.diff +38 -0
- data/gym/lib/assets/package_application_patches/0002_no_strict_parameter_patch.diff +42 -0
- data/gym/lib/assets/package_application_patches/PackageApplication_MD5 +2 -0
- data/gym/lib/assets/wrap_xcodebuild/xcbuild-safe.sh +58 -0
- data/gym/lib/gym.rb +49 -0
- data/gym/lib/gym/commands_generator.rb +62 -0
- data/gym/lib/gym/detect_values.rb +105 -0
- data/gym/lib/gym/error_handler.rb +186 -0
- data/gym/lib/gym/generators/README.md +1 -0
- data/gym/lib/gym/generators/build_command_generator.rb +136 -0
- data/gym/lib/gym/generators/package_command_generator.rb +58 -0
- data/gym/lib/gym/generators/package_command_generator_legacy.rb +102 -0
- data/gym/lib/gym/generators/package_command_generator_xcode7.rb +191 -0
- data/gym/lib/gym/manager.rb +17 -0
- data/gym/lib/gym/options.rb +254 -0
- data/gym/lib/gym/runner.rb +256 -0
- data/gym/lib/gym/xcode.rb +21 -0
- data/gym/lib/gym/xcodebuild_fixes/README.md +9 -0
- data/gym/lib/gym/xcodebuild_fixes/generic_archive_fix.rb +32 -0
- data/gym/lib/gym/xcodebuild_fixes/package_application_fix.rb +53 -0
- data/gym/lib/gym/xcodebuild_fixes/swift_fix.rb +99 -0
- data/gym/lib/gym/xcodebuild_fixes/watchkit2_fix.rb +35 -0
- data/gym/lib/gym/xcodebuild_fixes/watchkit_fix.rb +40 -0
- data/match/README.md +414 -0
- data/match/lib/assets/MatchfileTemplate +9 -0
- data/match/lib/assets/READMETemplate.md +49 -0
- data/match/lib/match.rb +57 -0
- data/match/lib/match/change_password.rb +30 -0
- data/match/lib/match/commands_generator.rb +120 -0
- data/match/lib/match/encrypt.rb +93 -0
- data/match/lib/match/generator.rb +74 -0
- data/match/lib/match/git_helper.rb +139 -0
- data/match/lib/match/nuke.rb +190 -0
- data/match/lib/match/options.rb +124 -0
- data/match/lib/match/runner.rb +172 -0
- data/match/lib/match/setup.rb +20 -0
- data/match/lib/match/spaceship_ensure.rb +78 -0
- data/match/lib/match/table_printer.rb +43 -0
- data/match/lib/match/utils.rb +59 -0
- data/pem/README.md +175 -0
- data/pem/lib/pem.rb +21 -0
- data/pem/lib/pem/commands_generator.rb +41 -0
- data/pem/lib/pem/manager.rb +93 -0
- data/pem/lib/pem/options.rb +79 -0
- data/pilot/README.md +285 -0
- data/pilot/lib/pilot.rb +22 -0
- data/pilot/lib/pilot/build_manager.rb +209 -0
- data/pilot/lib/pilot/commands_generator.rb +136 -0
- data/pilot/lib/pilot/features.rb +0 -0
- data/pilot/lib/pilot/manager.rb +71 -0
- data/pilot/lib/pilot/options.rb +161 -0
- data/pilot/lib/pilot/tester_exporter.rb +37 -0
- data/pilot/lib/pilot/tester_importer.rb +51 -0
- data/pilot/lib/pilot/tester_manager.rb +212 -0
- data/pilot/lib/pilot/tester_util.rb +23 -0
- data/produce/README.md +232 -0
- data/produce/lib/produce.rb +21 -0
- data/produce/lib/produce/available_default_languages.rb +36 -0
- data/produce/lib/produce/commands_generator.rb +134 -0
- data/produce/lib/produce/developer_center.rb +58 -0
- data/produce/lib/produce/group.rb +89 -0
- data/produce/lib/produce/itunes_connect.rb +87 -0
- data/produce/lib/produce/manager.rb +11 -0
- data/produce/lib/produce/options.rb +114 -0
- data/produce/lib/produce/service.rb +227 -0
- data/scan/README.md +219 -0
- data/scan/lib/assets/ScanfileTemplate +13 -0
- data/scan/lib/scan.rb +40 -0
- data/scan/lib/scan/commands_generator.rb +61 -0
- data/scan/lib/scan/detect_values.rb +184 -0
- data/scan/lib/scan/error_handler.rb +43 -0
- data/scan/lib/scan/manager.rb +17 -0
- data/scan/lib/scan/options.rb +189 -0
- data/scan/lib/scan/report_collector.rb +70 -0
- data/scan/lib/scan/runner.rb +103 -0
- data/scan/lib/scan/slack_poster.rb +59 -0
- data/scan/lib/scan/test_command_generator.rb +130 -0
- data/scan/lib/scan/test_result_parser.rb +21 -0
- data/screengrab/README.md +190 -0
- data/screengrab/lib/assets/ScreengrabfileTemplate +15 -0
- data/screengrab/lib/screengrab.rb +32 -0
- data/screengrab/lib/screengrab/android_environment.rb +88 -0
- data/screengrab/lib/screengrab/commands_generator.rb +60 -0
- data/screengrab/lib/screengrab/dependency_checker.rb +56 -0
- data/screengrab/lib/screengrab/detect_values.rb +16 -0
- data/screengrab/lib/screengrab/options.rb +109 -0
- data/screengrab/lib/screengrab/page.html.erb +206 -0
- data/screengrab/lib/screengrab/runner.rb +336 -0
- data/screengrab/lib/screengrab/setup.rb +16 -0
- data/sigh/README.md +256 -0
- data/sigh/lib/assets/resign.sh +774 -0
- data/sigh/lib/sigh.rb +19 -0
- data/sigh/lib/sigh/commands_generator.rb +133 -0
- data/sigh/lib/sigh/download_all.rb +36 -0
- data/sigh/lib/sigh/local_manage.rb +140 -0
- data/sigh/lib/sigh/manager.rb +44 -0
- data/sigh/lib/sigh/options.rb +117 -0
- data/sigh/lib/sigh/repair.rb +30 -0
- data/sigh/lib/sigh/resign.rb +201 -0
- data/sigh/lib/sigh/runner.rb +235 -0
- data/snapshot/README.md +400 -0
- data/snapshot/lib/assets/SnapfileTemplate +36 -0
- data/snapshot/lib/assets/SnapshotHelper.swift +138 -0
- data/snapshot/lib/assets/SnapshotHelper2-3.swift +140 -0
- data/snapshot/lib/snapshot.rb +59 -0
- data/snapshot/lib/snapshot/collector.rb +92 -0
- data/snapshot/lib/snapshot/commands_generator.rb +108 -0
- data/snapshot/lib/snapshot/dependency_checker.rb +50 -0
- data/snapshot/lib/snapshot/detect_values.rb +53 -0
- data/snapshot/lib/snapshot/error_handler.rb +22 -0
- data/snapshot/lib/snapshot/fixes/README.md +5 -0
- data/snapshot/lib/snapshot/fixes/hardware_keyboard_fix.rb +14 -0
- data/snapshot/lib/snapshot/fixes/simulator_zoom_fix.rb +25 -0
- data/snapshot/lib/snapshot/latest_os_version.rb +31 -0
- data/snapshot/lib/snapshot/options.rb +161 -0
- data/snapshot/lib/snapshot/page.html.erb +206 -0
- data/snapshot/lib/snapshot/reports_generator.rb +64 -0
- data/snapshot/lib/snapshot/reset_simulators.rb +88 -0
- data/snapshot/lib/snapshot/runner.rb +294 -0
- data/snapshot/lib/snapshot/screenshot_flatten.rb +18 -0
- data/snapshot/lib/snapshot/screenshot_rotate.rb +38 -0
- data/snapshot/lib/snapshot/setup.rb +35 -0
- data/snapshot/lib/snapshot/test_command_generator.rb +118 -0
- data/snapshot/lib/snapshot/update.rb +29 -0
- data/spaceship/README.md +191 -0
- data/spaceship/lib/assets/languageMapping.json +240 -0
- data/spaceship/lib/assets/languageMappingReadable.json +30 -0
- data/spaceship/lib/spaceship.rb +31 -0
- data/spaceship/lib/spaceship/babosa_fix.rb +30 -0
- data/spaceship/lib/spaceship/base.rb +236 -0
- data/spaceship/lib/spaceship/client.rb +487 -0
- data/spaceship/lib/spaceship/commands_generator.rb +48 -0
- data/spaceship/lib/spaceship/du/du_client.rb +122 -0
- data/spaceship/lib/spaceship/du/upload_file.rb +56 -0
- data/spaceship/lib/spaceship/du/utilities.rb +81 -0
- data/spaceship/lib/spaceship/helper/net_http_generic_request.rb +14 -0
- data/spaceship/lib/spaceship/helper/plist_middleware.rb +15 -0
- data/spaceship/lib/spaceship/launcher.rb +94 -0
- data/spaceship/lib/spaceship/playground.rb +72 -0
- data/spaceship/lib/spaceship/portal/app.rb +148 -0
- data/spaceship/lib/spaceship/portal/app_group.rb +77 -0
- data/spaceship/lib/spaceship/portal/app_service.rb +278 -0
- data/spaceship/lib/spaceship/portal/certificate.rb +333 -0
- data/spaceship/lib/spaceship/portal/device.rb +192 -0
- data/spaceship/lib/spaceship/portal/portal.rb +8 -0
- data/spaceship/lib/spaceship/portal/portal_base.rb +13 -0
- data/spaceship/lib/spaceship/portal/portal_client.rb +491 -0
- data/spaceship/lib/spaceship/portal/provisioning_profile.rb +467 -0
- data/spaceship/lib/spaceship/portal/spaceship.rb +112 -0
- data/spaceship/lib/spaceship/portal/ui/select_team.rb +83 -0
- data/spaceship/lib/spaceship/spaceauth_runner.rb +50 -0
- data/spaceship/lib/spaceship/tunes/app_details.rb +139 -0
- data/spaceship/lib/spaceship/tunes/app_image.rb +55 -0
- data/spaceship/lib/spaceship/tunes/app_ratings.rb +107 -0
- data/spaceship/lib/spaceship/tunes/app_screenshot.rb +17 -0
- data/spaceship/lib/spaceship/tunes/app_status.rb +60 -0
- data/spaceship/lib/spaceship/tunes/app_submission.rb +136 -0
- data/spaceship/lib/spaceship/tunes/app_trailer.rb +68 -0
- data/spaceship/lib/spaceship/tunes/app_version.rb +766 -0
- data/spaceship/lib/spaceship/tunes/app_version_common.rb +33 -0
- data/spaceship/lib/spaceship/tunes/app_version_generated_promocodes.rb +35 -0
- data/spaceship/lib/spaceship/tunes/app_version_history.rb +59 -0
- data/spaceship/lib/spaceship/tunes/app_version_promocodes.rb +34 -0
- data/spaceship/lib/spaceship/tunes/app_version_ref.rb +19 -0
- data/spaceship/lib/spaceship/tunes/app_version_states_history.rb +34 -0
- data/spaceship/lib/spaceship/tunes/application.rb +437 -0
- data/spaceship/lib/spaceship/tunes/build.rb +269 -0
- data/spaceship/lib/spaceship/tunes/build_details.rb +48 -0
- data/spaceship/lib/spaceship/tunes/build_train.rb +182 -0
- data/spaceship/lib/spaceship/tunes/device_type.rb +14 -0
- data/spaceship/lib/spaceship/tunes/language_converter.rb +63 -0
- data/spaceship/lib/spaceship/tunes/language_item.rb +56 -0
- data/spaceship/lib/spaceship/tunes/pricing_tier.rb +81 -0
- data/spaceship/lib/spaceship/tunes/recovery_device.rb +69 -0
- data/spaceship/lib/spaceship/tunes/spaceship.rb +34 -0
- data/spaceship/lib/spaceship/tunes/tester.rb +283 -0
- data/spaceship/lib/spaceship/tunes/transit_app_file.rb +27 -0
- data/spaceship/lib/spaceship/tunes/tunes.rb +35 -0
- data/spaceship/lib/spaceship/tunes/tunes_base.rb +15 -0
- data/spaceship/lib/spaceship/tunes/tunes_client.rb +1068 -0
- data/spaceship/lib/spaceship/tunes/user_detail.rb +19 -0
- data/spaceship/lib/spaceship/tunes/version_set.rb +35 -0
- data/spaceship/lib/spaceship/two_step_client.rb +195 -0
- data/spaceship/lib/spaceship/ui.rb +27 -0
- data/supply/README.md +214 -0
- data/supply/lib/supply.rb +29 -0
- data/supply/lib/supply/apk_listing.rb +14 -0
- data/supply/lib/supply/client.rb +345 -0
- data/supply/lib/supply/commands_generator.rb +62 -0
- data/supply/lib/supply/listing.rb +32 -0
- data/supply/lib/supply/options.rb +135 -0
- data/supply/lib/supply/setup.rb +102 -0
- data/supply/lib/supply/uploader.rb +221 -0
- metadata +699 -428
- data/bin//360/237/232/200 +0 -5
- data/lib/.DS_Store +0 -0
- data/lib/assets/.DS_Store +0 -0
- data/lib/assets/completions/.DS_Store +0 -0
- data/lib/fastlane/.DS_Store +0 -0
- data/lib/fastlane/actions/gym.rb +0 -90
- data/lib/fastlane/actions/reset_simulators.rb +0 -44
- data/lib/fastlane/cli_tools_distributor.rb +0 -100
- data/lib/fastlane/setup/.DS_Store +0 -0
@@ -0,0 +1,30 @@
|
|
1
|
+
{
|
2
|
+
"Brazilian Portuguese": "Brazilian Portuguese",
|
3
|
+
"Danish": "Danish",
|
4
|
+
"Dutch": "Dutch",
|
5
|
+
"English": "English",
|
6
|
+
"English_Australian": "Australian English",
|
7
|
+
"English_CA": "Canadian English",
|
8
|
+
"English_UK": "UK English",
|
9
|
+
"Finnish": "Finnish",
|
10
|
+
"French": "French",
|
11
|
+
"French_CA": "Canadian French",
|
12
|
+
"German": "German",
|
13
|
+
"Greek": "Greek",
|
14
|
+
"Indonesian": "Indonesian",
|
15
|
+
"Italian": "Italian",
|
16
|
+
"Japanese": "Japanese",
|
17
|
+
"Korean": "Korean",
|
18
|
+
"Malay": "Malay",
|
19
|
+
"Norwegian": "Norwegian",
|
20
|
+
"Portuguese": "Portuguese",
|
21
|
+
"Russian": "Russian",
|
22
|
+
"Simplified Chinese": "Simplified Chinese",
|
23
|
+
"Spanish": "Spanish",
|
24
|
+
"Spanish_MX": "Mexican Spanish",
|
25
|
+
"Swedish": "Swedish",
|
26
|
+
"Thai": "Thai",
|
27
|
+
"Traditional Chinese": "Traditional Chinese",
|
28
|
+
"Turkish": "Turkish",
|
29
|
+
"Vietnamese": "Vietnamese"
|
30
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
require 'spaceship/base'
|
2
|
+
require 'spaceship/client'
|
3
|
+
require 'spaceship/launcher'
|
4
|
+
|
5
|
+
# Dev Portal
|
6
|
+
require 'spaceship/portal/portal'
|
7
|
+
require 'spaceship/portal/spaceship'
|
8
|
+
|
9
|
+
# iTunes Connect
|
10
|
+
require 'spaceship/tunes/tunes'
|
11
|
+
require 'spaceship/tunes/spaceship'
|
12
|
+
|
13
|
+
# To support legacy code
|
14
|
+
module Spaceship
|
15
|
+
ROOT = Pathname.new(File.expand_path('../..', __FILE__))
|
16
|
+
|
17
|
+
# Dev Portal
|
18
|
+
Certificate = Spaceship::Portal::Certificate
|
19
|
+
ProvisioningProfile = Spaceship::Portal::ProvisioningProfile
|
20
|
+
Device = Spaceship::Portal::Device
|
21
|
+
App = Spaceship::Portal::App
|
22
|
+
AppGroup = Spaceship::Portal::AppGroup
|
23
|
+
AppService = Spaceship::Portal::AppService
|
24
|
+
|
25
|
+
# iTunes Connect
|
26
|
+
AppVersion = Spaceship::Tunes::AppVersion
|
27
|
+
AppSubmission = Spaceship::Tunes::AppSubmission
|
28
|
+
Application = Spaceship::Tunes::Application
|
29
|
+
|
30
|
+
DESCRIPTION = "Ruby library to access the Apple Dev Center and iTunes Connect".freeze
|
31
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# Babosa has a conflict with the unicode-string_width gem. unicode-string_width defines
|
2
|
+
# a module called `Unicode`, but Babosa uses the presence of this constant as
|
3
|
+
# the sign that it should try to require the `unicode` gem, which will not be present.
|
4
|
+
#
|
5
|
+
# We don't want to introduce the `unicode` gem because it depends on native extensions.
|
6
|
+
#
|
7
|
+
# This works around the possibility that the unicode-string_width gem may already be
|
8
|
+
# loaded by temporarily undefining the `Unicode` constant while we load Babosa,
|
9
|
+
# then restoring it to its previous state if necessary.
|
10
|
+
#
|
11
|
+
# Can be removed once https://github.com/norman/babosa/pull/42 is merged and released
|
12
|
+
class BabosaFix
|
13
|
+
def apply
|
14
|
+
unicode_removed = false
|
15
|
+
|
16
|
+
if defined? Unicode
|
17
|
+
orig_unicode = Unicode
|
18
|
+
Object.send(:remove_const, :Unicode)
|
19
|
+
unicode_removed = true
|
20
|
+
end
|
21
|
+
|
22
|
+
require 'babosa'
|
23
|
+
|
24
|
+
if unicode_removed
|
25
|
+
Object.send(:const_set, :Unicode, orig_unicode)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
BabosaFix.new.apply
|
@@ -0,0 +1,236 @@
|
|
1
|
+
module Spaceship
|
2
|
+
##
|
3
|
+
# Spaceship::Base is the superclass for models in Apple Developer Portal.
|
4
|
+
# It's mainly responsible for mapping responses to objects.
|
5
|
+
#
|
6
|
+
# A class-level attribute `client` is used to maintain the spaceship which we
|
7
|
+
# are using to talk to ADP.
|
8
|
+
#
|
9
|
+
# Example of creating a new ADP model:
|
10
|
+
#
|
11
|
+
# class Widget < Spaceship::Base
|
12
|
+
# attr_accessor :id, :name, :foo_bar, :wiz_baz
|
13
|
+
# attr_mapping({
|
14
|
+
# 'name' => :name,
|
15
|
+
# 'fooBar' => :foo_bar,
|
16
|
+
# 'wizBaz' => :wiz_baz
|
17
|
+
# })
|
18
|
+
# end
|
19
|
+
#
|
20
|
+
# When you want to instantiate a model pass in the parsed response: `Widget.new(widget_json)`
|
21
|
+
class Base
|
22
|
+
class DataHash
|
23
|
+
def initialize(hash)
|
24
|
+
@hash = hash || {}
|
25
|
+
end
|
26
|
+
|
27
|
+
def get(*keys)
|
28
|
+
lookup(keys)
|
29
|
+
end
|
30
|
+
|
31
|
+
alias [] get
|
32
|
+
|
33
|
+
def set(keys, value)
|
34
|
+
raise "'keys' must be an array, got #{keys.class} instead" unless keys.kind_of?(Array)
|
35
|
+
last = keys.pop
|
36
|
+
ref = lookup(keys) || @hash
|
37
|
+
ref[last] = value
|
38
|
+
end
|
39
|
+
|
40
|
+
def lookup(keys)
|
41
|
+
head, *tail = *keys
|
42
|
+
if tail.empty?
|
43
|
+
@hash[head]
|
44
|
+
else
|
45
|
+
DataHash.new(@hash[head]).lookup(tail)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
def to_json(*a)
|
50
|
+
h = @hash.dup
|
51
|
+
h.delete(:application)
|
52
|
+
h.to_json(*a)
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
class << self
|
57
|
+
attr_accessor :client
|
58
|
+
|
59
|
+
##
|
60
|
+
# The client used to make requests.
|
61
|
+
# @return (Spaceship::Client) Defaults to the singleton
|
62
|
+
def client
|
63
|
+
raise "`client` must be implemented in subclasses"
|
64
|
+
end
|
65
|
+
|
66
|
+
##
|
67
|
+
# Sets client and returns self for chaining.
|
68
|
+
# @return (Spaceship::Base)
|
69
|
+
# rubocop:disable Style/AccessorMethodName
|
70
|
+
def set_client(client)
|
71
|
+
self.client = client
|
72
|
+
self
|
73
|
+
end
|
74
|
+
# rubocop:enable Style/AccessorMethodName
|
75
|
+
|
76
|
+
##
|
77
|
+
# Binds attributes getters and setters to underlying data returned from the API.
|
78
|
+
# Setting any properties will alter the `raw_data` hash.
|
79
|
+
#
|
80
|
+
# @return (Module) with the mapped getters and setters defined. Can be `include`, `extend`, or `prepend` into a class or object
|
81
|
+
def mapping_module(attr_mapping)
|
82
|
+
Module.new do
|
83
|
+
attr_mapping.each do |source, dest|
|
84
|
+
getter = dest.to_sym
|
85
|
+
setter = "#{dest}=".to_sym
|
86
|
+
|
87
|
+
define_method(getter) do
|
88
|
+
raw_data.get(*source.split('.'))
|
89
|
+
end
|
90
|
+
|
91
|
+
define_method(setter) do |value|
|
92
|
+
self.raw_data ||= DataHash.new({})
|
93
|
+
raw_data.set(source.split('.'), value)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
98
|
+
|
99
|
+
##
|
100
|
+
# Defines the attribute mapping between the response from Apple and our model objects.
|
101
|
+
# Keys are to match keys in the response and the values are to match attributes on the model.
|
102
|
+
#
|
103
|
+
# Example of using `attr_mapping`
|
104
|
+
#
|
105
|
+
# class Widget < Spaceship::Base
|
106
|
+
# attr_accessor :id, :name, :foo_bar, :wiz_baz
|
107
|
+
# attr_mapping({
|
108
|
+
# 'name' => :name,
|
109
|
+
# 'fooBar' => :foo_bar,
|
110
|
+
# 'wizBaz' => :wiz_baz
|
111
|
+
# })
|
112
|
+
# end
|
113
|
+
def attr_mapping(attr_map = nil)
|
114
|
+
if attr_map
|
115
|
+
@attr_mapping = attr_map
|
116
|
+
@attr_mapping.values.each do |method_name|
|
117
|
+
getter = method_name.to_sym
|
118
|
+
setter = "#{method_name}=".to_sym
|
119
|
+
remove_method(getter) if public_instance_methods.include?(getter)
|
120
|
+
remove_method(setter) if public_instance_methods.include?(setter)
|
121
|
+
end
|
122
|
+
include(mapping_module(@attr_mapping))
|
123
|
+
else
|
124
|
+
begin
|
125
|
+
@attr_mapping ||= ancestors[1].attr_mapping
|
126
|
+
rescue NoMethodError
|
127
|
+
rescue NameError
|
128
|
+
end
|
129
|
+
end
|
130
|
+
return @attr_mapping
|
131
|
+
end
|
132
|
+
|
133
|
+
##
|
134
|
+
# Call a method to return a subclass constant.
|
135
|
+
#
|
136
|
+
# If `method_sym` is an underscored name of a class,
|
137
|
+
# return the class with the current client passed into it.
|
138
|
+
# If the method does not match, NoMethodError is raised.
|
139
|
+
#
|
140
|
+
# Example:
|
141
|
+
#
|
142
|
+
# Certificate.production_push
|
143
|
+
# #=> Certificate::ProductionPush
|
144
|
+
#
|
145
|
+
# ProvisioningProfile.ad_hoc
|
146
|
+
# #=> ProvisioningProfile::AdHoc
|
147
|
+
#
|
148
|
+
# ProvisioningProfile.some_other_method
|
149
|
+
# #=> NoMethodError: undefined method `some_other_method' for ProvisioningProfile
|
150
|
+
def method_missing(method_sym, *args, &block)
|
151
|
+
module_name = method_sym.to_s
|
152
|
+
module_name.sub!(/^[a-z\d]/) { $&.upcase }
|
153
|
+
module_name.gsub!(%r{(?:_|(/))([a-z\d])}) { $2.upcase }
|
154
|
+
if const_defined?(module_name)
|
155
|
+
klass = const_get(module_name)
|
156
|
+
klass.set_client(@client)
|
157
|
+
else
|
158
|
+
super
|
159
|
+
end
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
163
|
+
##
|
164
|
+
# @return (Spaceship::Client) The current spaceship client used by the model to make requests.
|
165
|
+
attr_reader :client
|
166
|
+
|
167
|
+
##
|
168
|
+
# @return (Hash/Array) Holds the raw data we got from Apple's
|
169
|
+
# server to use it later
|
170
|
+
attr_accessor :raw_data
|
171
|
+
|
172
|
+
##
|
173
|
+
# The initialize method accepts a parsed response from Apple and sets all
|
174
|
+
# attributes that are defined by `attr_mapping`
|
175
|
+
#
|
176
|
+
# Do not override `initialize` in your own models.
|
177
|
+
def initialize(attrs = {})
|
178
|
+
attrs.each do |key, val|
|
179
|
+
self.send("#{key}=", val) if respond_to?("#{key}=")
|
180
|
+
end
|
181
|
+
self.raw_data = DataHash.new(attrs)
|
182
|
+
@client = self.class.client
|
183
|
+
self.setup
|
184
|
+
end
|
185
|
+
|
186
|
+
# This method can be used by subclasses to do additional initialisation
|
187
|
+
# using the `raw_data`
|
188
|
+
def setup; end
|
189
|
+
|
190
|
+
#####################################################
|
191
|
+
# @!group Storing the `attr_accessor`
|
192
|
+
#####################################################
|
193
|
+
|
194
|
+
# From https://stackoverflow.com/questions/2487333/fastest-one-liner-way-to-list-attr-accessors-in-ruby
|
195
|
+
# This will store a list of defined attr_accessors to easily access them when inspecting the values
|
196
|
+
def self.attr_accessor(*vars)
|
197
|
+
@attributes ||= []
|
198
|
+
@attributes.concat vars
|
199
|
+
super(*vars)
|
200
|
+
end
|
201
|
+
|
202
|
+
def self.attributes
|
203
|
+
@attributes ||= []
|
204
|
+
par = []
|
205
|
+
|
206
|
+
par = (self.superclass.attributes || []) unless self == Base
|
207
|
+
|
208
|
+
@attributes + par
|
209
|
+
end
|
210
|
+
|
211
|
+
def attributes
|
212
|
+
self.class.attributes
|
213
|
+
end
|
214
|
+
|
215
|
+
#####################################################
|
216
|
+
# @!group Inspect related code
|
217
|
+
#####################################################
|
218
|
+
|
219
|
+
def inspect
|
220
|
+
inspectables = self.attributes
|
221
|
+
|
222
|
+
value = inspectables.map do |k|
|
223
|
+
v = self.send(k).inspect
|
224
|
+
v.gsub!("\n", "\n\t") # to align nested elements
|
225
|
+
|
226
|
+
"\t#{k}=#{v}"
|
227
|
+
end.join(", \n")
|
228
|
+
|
229
|
+
"<#{self.class.name} \n#{value}>"
|
230
|
+
end
|
231
|
+
|
232
|
+
def to_s
|
233
|
+
self.inspect
|
234
|
+
end
|
235
|
+
end
|
236
|
+
end
|
@@ -0,0 +1,487 @@
|
|
1
|
+
require 'faraday' # HTTP Client
|
2
|
+
require 'logger'
|
3
|
+
require 'faraday_middleware'
|
4
|
+
require 'faraday-cookie_jar'
|
5
|
+
require 'spaceship/ui'
|
6
|
+
require 'spaceship/helper/plist_middleware'
|
7
|
+
require 'spaceship/helper/net_http_generic_request'
|
8
|
+
require 'tmpdir'
|
9
|
+
require 'spaceship/babosa_fix'
|
10
|
+
|
11
|
+
Faraday::Utils.default_params_encoder = Faraday::FlatParamsEncoder
|
12
|
+
|
13
|
+
if ENV["SPACESHIP_DEBUG"]
|
14
|
+
require 'openssl'
|
15
|
+
# this has to be on top of this file, since the value can't be changed later
|
16
|
+
OpenSSL::SSL::VERIFY_PEER = OpenSSL::SSL::VERIFY_NONE
|
17
|
+
end
|
18
|
+
|
19
|
+
module Spaceship
|
20
|
+
class Client
|
21
|
+
PROTOCOL_VERSION = "QH65B2"
|
22
|
+
USER_AGENT = "Spaceship #{Fastlane::VERSION}"
|
23
|
+
|
24
|
+
attr_reader :client
|
25
|
+
|
26
|
+
# The user that is currently logged in
|
27
|
+
attr_accessor :user
|
28
|
+
|
29
|
+
# The logger in which all requests are logged
|
30
|
+
# /tmp/spaceship[time]_[pid].log by default
|
31
|
+
attr_accessor :logger
|
32
|
+
|
33
|
+
attr_accessor :csrf_tokens
|
34
|
+
|
35
|
+
# Base class for errors that want to present their message as
|
36
|
+
# preferred error info for fastlane error handling. See:
|
37
|
+
# fastlane_core/lib/fastlane_core/ui/fastlane_runner.rb
|
38
|
+
class BasicPreferredInfoError < StandardError
|
39
|
+
TITLE = 'The request could not be completed because:'.freeze
|
40
|
+
|
41
|
+
def preferred_error_info
|
42
|
+
message ? [TITLE, message] : nil
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
# Invalid user credentials were provided
|
47
|
+
class InvalidUserCredentialsError < BasicPreferredInfoError; end
|
48
|
+
|
49
|
+
# Raised when no user credentials were passed at all
|
50
|
+
class NoUserCredentialsError < BasicPreferredInfoError; end
|
51
|
+
|
52
|
+
class UnexpectedResponse < StandardError
|
53
|
+
attr_reader :error_info
|
54
|
+
|
55
|
+
def initialize(error_info = nil)
|
56
|
+
super(error_info)
|
57
|
+
@error_info = error_info
|
58
|
+
end
|
59
|
+
|
60
|
+
def preferred_error_info
|
61
|
+
return nil unless @error_info.kind_of?(Hash) && @error_info['resultString']
|
62
|
+
|
63
|
+
[
|
64
|
+
"Apple provided the following error info:",
|
65
|
+
@error_info['resultString'],
|
66
|
+
@error_info['userString']
|
67
|
+
].compact.uniq # sometimes 'resultString' and 'userString' are the same value
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
# Raised when 302 is received from portal request
|
72
|
+
class AppleTimeoutError < BasicPreferredInfoError; end
|
73
|
+
|
74
|
+
# Raised when 401 is received from portal request
|
75
|
+
class UnauthorizedAccessError < BasicPreferredInfoError; end
|
76
|
+
|
77
|
+
# Authenticates with Apple's web services. This method has to be called once
|
78
|
+
# to generate a valid session. The session will automatically be used from then
|
79
|
+
# on.
|
80
|
+
#
|
81
|
+
# This method will automatically use the username from the Appfile (if available)
|
82
|
+
# and fetch the password from the Keychain (if available)
|
83
|
+
#
|
84
|
+
# @param user (String) (optional): The username (usually the email address)
|
85
|
+
# @param password (String) (optional): The password
|
86
|
+
#
|
87
|
+
# @raise InvalidUserCredentialsError: raised if authentication failed
|
88
|
+
#
|
89
|
+
# @return (Spaceship::Client) The client the login method was called for
|
90
|
+
def self.login(user = nil, password = nil)
|
91
|
+
instance = self.new
|
92
|
+
if instance.login(user, password)
|
93
|
+
instance
|
94
|
+
else
|
95
|
+
raise InvalidUserCredentialsError.new, "Invalid User Credentials"
|
96
|
+
end
|
97
|
+
end
|
98
|
+
|
99
|
+
def self.hostname
|
100
|
+
raise "You must implemented self.hostname"
|
101
|
+
end
|
102
|
+
|
103
|
+
def initialize
|
104
|
+
options = {
|
105
|
+
request: {
|
106
|
+
timeout: (ENV["SPACESHIP_TIMEOUT"] || 300).to_i,
|
107
|
+
open_timeout: (ENV["SPACESHIP_TIMEOUT"] || 300).to_i
|
108
|
+
}
|
109
|
+
}
|
110
|
+
@cookie = HTTP::CookieJar.new
|
111
|
+
@client = Faraday.new(self.class.hostname, options) do |c|
|
112
|
+
c.response :json, content_type: /\bjson$/
|
113
|
+
c.response :xml, content_type: /\bxml$/
|
114
|
+
c.response :plist, content_type: /\bplist$/
|
115
|
+
c.use :cookie_jar, jar: @cookie
|
116
|
+
c.adapter Faraday.default_adapter
|
117
|
+
|
118
|
+
if ENV['SPACESHIP_DEBUG']
|
119
|
+
# for debugging only
|
120
|
+
# This enables tracking of networking requests using Charles Web Proxy
|
121
|
+
c.proxy "https://127.0.0.1:8888"
|
122
|
+
end
|
123
|
+
|
124
|
+
if ENV["DEBUG"]
|
125
|
+
puts "To run _spaceship_ through a local proxy, use SPACESHIP_DEBUG"
|
126
|
+
end
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
# The logger in which all requests are logged
|
131
|
+
# /tmp/spaceship[time]_[pid].log by default
|
132
|
+
def logger
|
133
|
+
unless @logger
|
134
|
+
if ENV["VERBOSE"]
|
135
|
+
@logger = Logger.new(STDOUT)
|
136
|
+
else
|
137
|
+
# Log to file by default
|
138
|
+
path = "/tmp/spaceship#{Time.now.to_i}_#{Process.pid}.log"
|
139
|
+
@logger = Logger.new(path)
|
140
|
+
end
|
141
|
+
|
142
|
+
@logger.formatter = proc do |severity, datetime, progname, msg|
|
143
|
+
"[#{datetime.strftime('%H:%M:%S')}]: #{msg}\n"
|
144
|
+
end
|
145
|
+
end
|
146
|
+
|
147
|
+
@logger
|
148
|
+
end
|
149
|
+
|
150
|
+
##
|
151
|
+
# Return the session cookie.
|
152
|
+
#
|
153
|
+
# @return (String) the cookie-string in the RFC6265 format: https://tools.ietf.org/html/rfc6265#section-4.2.1
|
154
|
+
def cookie
|
155
|
+
@cookie.map(&:to_s).join(';')
|
156
|
+
end
|
157
|
+
|
158
|
+
def store_cookie(path: nil)
|
159
|
+
path ||= persistent_cookie_path
|
160
|
+
FileUtils.mkdir_p(File.expand_path("..", path))
|
161
|
+
|
162
|
+
# really important to specify the session to true
|
163
|
+
# otherwise myacinfo and more won't be stored
|
164
|
+
@cookie.save(path, :yaml, session: true)
|
165
|
+
return File.read(path)
|
166
|
+
end
|
167
|
+
|
168
|
+
# Returns preferred path for storing cookie
|
169
|
+
# for two step verification.
|
170
|
+
def persistent_cookie_path
|
171
|
+
if ENV["SPACESHIP_COOKIE_PATH"]
|
172
|
+
path = File.expand_path(File.join(ENV["SPACESHIP_COOKIE_PATH"], "spaceship", self.user, "cookie"))
|
173
|
+
else
|
174
|
+
["~/.spaceship", "/var/tmp/spaceship", "#{Dir.tmpdir}/spaceship"].each do |dir|
|
175
|
+
dir_parts = File.split(dir)
|
176
|
+
if directory_accessible?(dir_parts.first)
|
177
|
+
path = File.expand_path(File.join(dir, self.user, "cookie"))
|
178
|
+
break
|
179
|
+
end
|
180
|
+
end
|
181
|
+
end
|
182
|
+
|
183
|
+
return path
|
184
|
+
end
|
185
|
+
|
186
|
+
#####################################################
|
187
|
+
# @!group Automatic Paging
|
188
|
+
#####################################################
|
189
|
+
|
190
|
+
# The page size we want to request, defaults to 500
|
191
|
+
def page_size
|
192
|
+
@page_size ||= 500
|
193
|
+
end
|
194
|
+
|
195
|
+
# Handles the paging for you... for free
|
196
|
+
# Just pass a block and use the parameter as page number
|
197
|
+
def paging
|
198
|
+
page = 0
|
199
|
+
results = []
|
200
|
+
loop do
|
201
|
+
page += 1
|
202
|
+
current = yield(page)
|
203
|
+
|
204
|
+
results += current
|
205
|
+
|
206
|
+
break if (current || []).count < page_size # no more results
|
207
|
+
end
|
208
|
+
|
209
|
+
return results
|
210
|
+
end
|
211
|
+
|
212
|
+
#####################################################
|
213
|
+
# @!group Login and Team Selection
|
214
|
+
#####################################################
|
215
|
+
|
216
|
+
# Authenticates with Apple's web services. This method has to be called once
|
217
|
+
# to generate a valid session. The session will automatically be used from then
|
218
|
+
# on.
|
219
|
+
#
|
220
|
+
# This method will automatically use the username from the Appfile (if available)
|
221
|
+
# and fetch the password from the Keychain (if available)
|
222
|
+
#
|
223
|
+
# @param user (String) (optional): The username (usually the email address)
|
224
|
+
# @param password (String) (optional): The password
|
225
|
+
#
|
226
|
+
# @raise InvalidUserCredentialsError: raised if authentication failed
|
227
|
+
#
|
228
|
+
# @return (Spaceship::Client) The client the login method was called for
|
229
|
+
def login(user = nil, password = nil)
|
230
|
+
if user.to_s.empty? or password.to_s.empty?
|
231
|
+
require 'credentials_manager'
|
232
|
+
|
233
|
+
keychain_entry = CredentialsManager::AccountManager.new(user: user, password: password)
|
234
|
+
user ||= keychain_entry.user
|
235
|
+
password = keychain_entry.password
|
236
|
+
end
|
237
|
+
|
238
|
+
if user.to_s.strip.empty? or password.to_s.strip.empty?
|
239
|
+
raise NoUserCredentialsError.new, "No login data provided"
|
240
|
+
end
|
241
|
+
|
242
|
+
self.user = user
|
243
|
+
@password = password
|
244
|
+
begin
|
245
|
+
do_login(user, password)
|
246
|
+
rescue InvalidUserCredentialsError => ex
|
247
|
+
raise ex unless keychain_entry
|
248
|
+
|
249
|
+
if keychain_entry.invalid_credentials
|
250
|
+
login(user)
|
251
|
+
else
|
252
|
+
puts "Please run this tool again to apply the new password"
|
253
|
+
end
|
254
|
+
end
|
255
|
+
end
|
256
|
+
|
257
|
+
# This method is used for both the Apple Dev Portal and iTunes Connect
|
258
|
+
# This will also handle 2 step verification
|
259
|
+
def send_shared_login_request(user, password)
|
260
|
+
# First we see if we have a stored cookie for 2 step enabled accounts
|
261
|
+
# this is needed as it stores the information on if this computer is a
|
262
|
+
# trusted one. In general I think spaceship clients should be trusted
|
263
|
+
load_session_from_file
|
264
|
+
# If this is a CI, the user can pass the session via environment variable
|
265
|
+
load_session_from_env
|
266
|
+
|
267
|
+
data = {
|
268
|
+
accountName: user,
|
269
|
+
password: password,
|
270
|
+
rememberMe: true
|
271
|
+
}
|
272
|
+
|
273
|
+
begin
|
274
|
+
# The below workaround is only needed for 2 step verified machines
|
275
|
+
# Due to escaping of cookie values we have a little workaround here
|
276
|
+
# By default the cookie jar would generate the following header
|
277
|
+
# DES5c148...=HSARM.......xaA/O69Ws/CHfQ==SRVT
|
278
|
+
# However we need the following
|
279
|
+
# DES5c148...="HSARM.......xaA/O69Ws/CHfQ==SRVT"
|
280
|
+
# There is no way to get the cookie jar value with " around the value
|
281
|
+
# so we manually modify the cookie (only this one) to be properly escaped
|
282
|
+
# Afterwards we pass this value manually as a header
|
283
|
+
# It's not enough to just modify @cookie, it needs to be done after self.cookie
|
284
|
+
# as a string operation
|
285
|
+
important_cookie = @cookie.store.entries.find { |a| a.name.include?("DES") }
|
286
|
+
if important_cookie
|
287
|
+
modified_cookie = self.cookie # returns a string of all cookies
|
288
|
+
unescaped_important_cookie = "#{important_cookie.name}=#{important_cookie.value}"
|
289
|
+
escaped_important_cookie = "#{important_cookie.name}=\"#{important_cookie.value}\""
|
290
|
+
modified_cookie.gsub!(unescaped_important_cookie, escaped_important_cookie)
|
291
|
+
end
|
292
|
+
|
293
|
+
response = request(:post) do |req|
|
294
|
+
req.url "https://idmsa.apple.com/appleauth/auth/signin?widgetKey=#{itc_service_key}"
|
295
|
+
req.body = data.to_json
|
296
|
+
req.headers['Content-Type'] = 'application/json'
|
297
|
+
req.headers['X-Requested-With'] = 'XMLHttpRequest'
|
298
|
+
req.headers['Accept'] = 'application/json, text/javascript'
|
299
|
+
req.headers["Cookie"] = modified_cookie if modified_cookie
|
300
|
+
end
|
301
|
+
rescue UnauthorizedAccessError
|
302
|
+
raise InvalidUserCredentialsError.new, "Invalid username and password combination. Used '#{user}' as the username."
|
303
|
+
end
|
304
|
+
|
305
|
+
# get woinst, wois, and itctx cookie values
|
306
|
+
request(:get, "https://itunesconnect.apple.com/WebObjects/iTunesConnect.woa/wa")
|
307
|
+
|
308
|
+
case response.status
|
309
|
+
when 403
|
310
|
+
raise InvalidUserCredentialsError.new, "Invalid username and password combination. Used '#{user}' as the username."
|
311
|
+
when 200
|
312
|
+
return response
|
313
|
+
else
|
314
|
+
location = response["Location"]
|
315
|
+
if location && URI.parse(location).path == "/auth" # redirect to 2 step auth page
|
316
|
+
handle_two_step(response)
|
317
|
+
return true
|
318
|
+
elsif (response.body || "").include?('invalid="true"')
|
319
|
+
# User Credentials are wrong
|
320
|
+
raise InvalidUserCredentialsError.new, "Invalid username and password combination. Used '#{user}' as the username."
|
321
|
+
elsif (response['Set-Cookie'] || "").include?("itctx")
|
322
|
+
raise "Looks like your Apple ID is not enabled for iTunes Connect, make sure to be able to login online"
|
323
|
+
else
|
324
|
+
info = [response.body, response['Set-Cookie']]
|
325
|
+
raise TunesClient::ITunesConnectError.new, info.join("\n")
|
326
|
+
end
|
327
|
+
end
|
328
|
+
end
|
329
|
+
|
330
|
+
def itc_service_key
|
331
|
+
return @service_key if @service_key
|
332
|
+
|
333
|
+
# Check if we have a local cache of the key
|
334
|
+
itc_service_key_path = "/tmp/spaceship_itc_service_key.txt"
|
335
|
+
return File.read(itc_service_key_path) if File.exist?(itc_service_key_path)
|
336
|
+
|
337
|
+
# Some customers in Asia have had trouble with the CDNs there that cache and serve this content, leading
|
338
|
+
# to "buffer error (Zlib::BufError)" from deep in the Ruby HTTP stack. Setting this header requests that
|
339
|
+
# the content be served only as plain-text, which seems to work around their problem, while not affecting
|
340
|
+
# other clients.
|
341
|
+
#
|
342
|
+
# https://github.com/fastlane/fastlane/issues/4610
|
343
|
+
headers = { 'Accept-Encoding' => 'identity' }
|
344
|
+
# We need a service key from a JS file to properly auth
|
345
|
+
js = request(:get, "https://itunesconnect.apple.com/itc/static-resources/controllers/login_cntrl.js", nil, headers)
|
346
|
+
@service_key = js.body.match(/itcServiceKey = '(.*)'/)[1]
|
347
|
+
|
348
|
+
# Cache the key locally
|
349
|
+
File.write(itc_service_key_path, @service_key)
|
350
|
+
|
351
|
+
return @service_key
|
352
|
+
rescue => ex
|
353
|
+
puts ex.to_s
|
354
|
+
raise AppleTimeoutError.new, "Could not receive latest API key from iTunes Connect, this might be a server issue."
|
355
|
+
end
|
356
|
+
|
357
|
+
#####################################################
|
358
|
+
# @!group Helpers
|
359
|
+
#####################################################
|
360
|
+
|
361
|
+
def with_retry(tries = 5, &_block)
|
362
|
+
return yield
|
363
|
+
rescue Faraday::Error::ConnectionFailed, Faraday::Error::TimeoutError, AppleTimeoutError, Errno::EPIPE => ex # New Faraday version: Faraday::TimeoutError => ex
|
364
|
+
unless (tries -= 1).zero?
|
365
|
+
logger.warn("Timeout received: '#{ex.message}'. Retrying after 3 seconds (remaining: #{tries})...")
|
366
|
+
sleep 3 unless defined? SpecHelper
|
367
|
+
retry
|
368
|
+
end
|
369
|
+
raise ex # re-raise the exception
|
370
|
+
rescue UnauthorizedAccessError => ex
|
371
|
+
if @loggedin && !(tries -= 1).zero?
|
372
|
+
msg = "Auth error received: '#{ex.message}'. Login in again then retrying after 3 seconds (remaining: #{tries})..."
|
373
|
+
puts msg if $verbose
|
374
|
+
logger.warn msg
|
375
|
+
do_login(self.user, @password)
|
376
|
+
sleep 3 unless defined? SpecHelper
|
377
|
+
retry
|
378
|
+
end
|
379
|
+
raise ex # re-raise the exception
|
380
|
+
end
|
381
|
+
|
382
|
+
# memorize the last csrf tokens from responses
|
383
|
+
def csrf_tokens
|
384
|
+
@csrf_tokens || {}
|
385
|
+
end
|
386
|
+
|
387
|
+
def request(method, url_or_path = nil, params = nil, headers = {}, &block)
|
388
|
+
headers.merge!(csrf_tokens)
|
389
|
+
headers['User-Agent'] = USER_AGENT
|
390
|
+
|
391
|
+
# Before encoding the parameters, log them
|
392
|
+
log_request(method, url_or_path, params)
|
393
|
+
|
394
|
+
# form-encode the params only if there are params, and the block is not supplied.
|
395
|
+
# this is so that certain requests can be made using the block for more control
|
396
|
+
if method == :post && params && !block_given?
|
397
|
+
params, headers = encode_params(params, headers)
|
398
|
+
end
|
399
|
+
|
400
|
+
response = send_request(method, url_or_path, params, headers, &block)
|
401
|
+
|
402
|
+
log_response(method, url_or_path, response)
|
403
|
+
|
404
|
+
return response
|
405
|
+
end
|
406
|
+
|
407
|
+
def parse_response(response, expected_key = nil)
|
408
|
+
if response.body
|
409
|
+
# If we have an `expected_key`, select that from response.body Hash
|
410
|
+
# Else, don't.
|
411
|
+
content = expected_key ? response.body[expected_key] : response.body
|
412
|
+
end
|
413
|
+
|
414
|
+
if content.nil?
|
415
|
+
raise UnexpectedResponse, response.body
|
416
|
+
else
|
417
|
+
store_csrf_tokens(response)
|
418
|
+
content
|
419
|
+
end
|
420
|
+
end
|
421
|
+
|
422
|
+
private
|
423
|
+
|
424
|
+
def directory_accessible?(path)
|
425
|
+
Dir.exist?(File.expand_path(path))
|
426
|
+
end
|
427
|
+
|
428
|
+
def do_login(user, password)
|
429
|
+
@loggedin = false
|
430
|
+
ret = send_login_request(user, password) # different in subclasses
|
431
|
+
@loggedin = true
|
432
|
+
ret
|
433
|
+
end
|
434
|
+
|
435
|
+
# Is called from `parse_response` to store the latest csrf_token (if available)
|
436
|
+
def store_csrf_tokens(response)
|
437
|
+
if response and response.headers
|
438
|
+
tokens = response.headers.select { |k, v| %w(csrf csrf_ts).include?(k) }
|
439
|
+
if tokens and !tokens.empty?
|
440
|
+
@csrf_tokens = tokens
|
441
|
+
end
|
442
|
+
end
|
443
|
+
end
|
444
|
+
|
445
|
+
def log_request(method, url, params)
|
446
|
+
params_to_log = Hash(params).dup # to also work with nil
|
447
|
+
params_to_log.delete(:accountPassword) # Dev Portal
|
448
|
+
params_to_log.delete(:theAccountPW) # iTC
|
449
|
+
params_to_log = params_to_log.collect do |key, value|
|
450
|
+
"{#{key}: #{value}}"
|
451
|
+
end
|
452
|
+
logger.info(">> #{method.upcase}: #{url} #{params_to_log.join(', ')}")
|
453
|
+
end
|
454
|
+
|
455
|
+
def log_response(method, url, response)
|
456
|
+
body = response.body.kind_of?(String) ? response.body.force_encoding(Encoding::UTF_8) : response.body
|
457
|
+
logger.debug("<< #{method.upcase}: #{url}: #{body}")
|
458
|
+
end
|
459
|
+
|
460
|
+
# Actually sends the request to the remote server
|
461
|
+
# Automatically retries the request up to 3 times if something goes wrong
|
462
|
+
def send_request(method, url_or_path, params, headers, &block)
|
463
|
+
with_retry do
|
464
|
+
response = @client.send(method, url_or_path, params, headers, &block)
|
465
|
+
resp_hash = response.to_hash
|
466
|
+
if resp_hash[:status] == 401
|
467
|
+
msg = "Auth lost"
|
468
|
+
logger.warn msg
|
469
|
+
raise UnauthorizedAccessError.new, "Unauthorized Access"
|
470
|
+
end
|
471
|
+
|
472
|
+
if response.body.to_s.include?("<title>302 Found</title>")
|
473
|
+
raise AppleTimeoutError.new, "Apple 302 detected"
|
474
|
+
end
|
475
|
+
return response
|
476
|
+
end
|
477
|
+
end
|
478
|
+
|
479
|
+
def encode_params(params, headers)
|
480
|
+
params = Faraday::Utils::ParamsHash[params].to_query
|
481
|
+
headers = { 'Content-Type' => 'application/x-www-form-urlencoded' }.merge(headers)
|
482
|
+
return params, headers
|
483
|
+
end
|
484
|
+
end
|
485
|
+
end
|
486
|
+
|
487
|
+
require 'spaceship/two_step_client'
|