diff --git a/.gitignore b/.gitignore index e902ae5..7025388 100644 --- a/.gitignore +++ b/.gitignore @@ -46,3 +46,6 @@ dist # XCUserData xcuserdata/ + +# Fastlane +app_store_connect_api_key.json \ No newline at end of file diff --git a/Converter.xcodeproj/project.pbxproj b/Converter.xcodeproj/project.pbxproj index 20dcb79..64ce4b0 100644 --- a/Converter.xcodeproj/project.pbxproj +++ b/Converter.xcodeproj/project.pbxproj @@ -698,11 +698,12 @@ "@executable_path/../Frameworks", ); MACOSX_DEPLOYMENT_TARGET = 10.15; - MARKETING_VERSION = 1.1.3; + MARKETING_VERSION = 1; PRODUCT_BUNDLE_IDENTIFIER = io.airtv.Converter; PRODUCT_NAME = "Video Converter"; SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; }; name = "Development Debug"; }; @@ -787,11 +788,12 @@ "@executable_path/../Frameworks", ); MACOSX_DEPLOYMENT_TARGET = 10.15; - MARKETING_VERSION = 1.1.3; + MARKETING_VERSION = 1; PRODUCT_BUNDLE_IDENTIFIER = io.airtv.Converter; PRODUCT_NAME = "Video Converter"; SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; }; name = "Development Release"; }; @@ -935,11 +937,12 @@ "@executable_path/../Frameworks", ); MACOSX_DEPLOYMENT_TARGET = 10.15; - MARKETING_VERSION = 1.1.3; + MARKETING_VERSION = 1; PRODUCT_BUNDLE_IDENTIFIER = io.airtv.Converter; PRODUCT_NAME = "Video Converter"; SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; }; name = "Production Debug"; }; @@ -968,11 +971,12 @@ "@executable_path/../Frameworks", ); MACOSX_DEPLOYMENT_TARGET = 10.15; - MARKETING_VERSION = 1.1.3; + MARKETING_VERSION = 1; PRODUCT_BUNDLE_IDENTIFIER = io.airtv.Converter; PRODUCT_NAME = "Video Converter"; SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; }; name = "Production Release"; }; diff --git a/Converter/Info.plist b/Converter/Info.plist index 1b583fd..508d902 100644 --- a/Converter/Info.plist +++ b/Converter/Info.plist @@ -2,8 +2,10 @@ - Configuration - $(CONFIGURATION) + CFBundleShortVersionString + 1.1.4 + CFBundleVersion + 10 CFBundleDocumentTypes @@ -27,6 +29,8 @@ + Configuration + $(CONFIGURATION) ITSAppUsesNonExemptEncryption diff --git a/Gemfile b/Gemfile new file mode 100644 index 0000000..7a118b4 --- /dev/null +++ b/Gemfile @@ -0,0 +1,3 @@ +source "https://rubygems.org" + +gem "fastlane" diff --git a/Gemfile.lock b/Gemfile.lock new file mode 100644 index 0000000..a4d9b3b --- /dev/null +++ b/Gemfile.lock @@ -0,0 +1,218 @@ +GEM + remote: https://rubygems.org/ + specs: + CFPropertyList (3.0.5) + rexml + addressable (2.8.1) + public_suffix (>= 2.0.2, < 6.0) + artifactory (3.0.15) + atomos (0.1.3) + aws-eventstream (1.2.0) + aws-partitions (1.697.0) + aws-sdk-core (3.169.0) + aws-eventstream (~> 1, >= 1.0.2) + aws-partitions (~> 1, >= 1.651.0) + aws-sigv4 (~> 1.5) + jmespath (~> 1, >= 1.6.1) + aws-sdk-kms (1.62.0) + aws-sdk-core (~> 3, >= 3.165.0) + aws-sigv4 (~> 1.1) + aws-sdk-s3 (1.118.0) + aws-sdk-core (~> 3, >= 3.165.0) + aws-sdk-kms (~> 1) + aws-sigv4 (~> 1.4) + aws-sigv4 (1.5.2) + aws-eventstream (~> 1, >= 1.0.2) + babosa (1.0.4) + claide (1.1.0) + colored (1.2) + colored2 (3.1.2) + commander (4.6.0) + highline (~> 2.0.0) + declarative (0.0.20) + digest-crc (0.6.4) + rake (>= 12.0.0, < 14.0.0) + domain_name (0.5.20190701) + unf (>= 0.0.5, < 1.0.0) + dotenv (2.8.1) + emoji_regex (3.2.3) + excon (0.97.2) + faraday (1.10.3) + faraday-em_http (~> 1.0) + faraday-em_synchrony (~> 1.0) + faraday-excon (~> 1.1) + faraday-httpclient (~> 1.0) + faraday-multipart (~> 1.0) + faraday-net_http (~> 1.0) + faraday-net_http_persistent (~> 1.0) + faraday-patron (~> 1.0) + faraday-rack (~> 1.0) + faraday-retry (~> 1.0) + ruby2_keywords (>= 0.0.4) + faraday-cookie_jar (0.0.7) + faraday (>= 0.8.0) + http-cookie (~> 1.0.0) + faraday-em_http (1.0.0) + faraday-em_synchrony (1.0.0) + faraday-excon (1.1.0) + faraday-httpclient (1.0.1) + faraday-multipart (1.0.4) + multipart-post (~> 2) + faraday-net_http (1.0.1) + faraday-net_http_persistent (1.2.0) + faraday-patron (1.0.0) + faraday-rack (1.0.0) + faraday-retry (1.0.3) + faraday_middleware (1.2.0) + faraday (~> 1.0) + fastimage (2.2.6) + fastlane (2.211.0) + CFPropertyList (>= 2.3, < 4.0.0) + addressable (>= 2.8, < 3.0.0) + artifactory (~> 3.0) + aws-sdk-s3 (~> 1.0) + babosa (>= 1.0.3, < 2.0.0) + bundler (>= 1.12.0, < 3.0.0) + colored + commander (~> 4.6) + dotenv (>= 2.1.1, < 3.0.0) + emoji_regex (>= 0.1, < 4.0) + excon (>= 0.71.0, < 1.0.0) + faraday (~> 1.0) + faraday-cookie_jar (~> 0.0.6) + faraday_middleware (~> 1.0) + fastimage (>= 2.1.0, < 3.0.0) + gh_inspector (>= 1.1.2, < 2.0.0) + google-apis-androidpublisher_v3 (~> 0.3) + google-apis-playcustomapp_v1 (~> 0.1) + google-cloud-storage (~> 1.31) + highline (~> 2.0) + json (< 3.0.0) + jwt (>= 2.1.0, < 3) + mini_magick (>= 4.9.4, < 5.0.0) + multipart-post (~> 2.0.0) + naturally (~> 2.2) + optparse (~> 0.1.1) + plist (>= 3.1.0, < 4.0.0) + rubyzip (>= 2.0.0, < 3.0.0) + security (= 0.1.3) + simctl (~> 1.6.3) + terminal-notifier (>= 2.0.0, < 3.0.0) + terminal-table (>= 1.4.5, < 2.0.0) + tty-screen (>= 0.6.3, < 1.0.0) + tty-spinner (>= 0.8.0, < 1.0.0) + word_wrap (~> 1.0.0) + xcodeproj (>= 1.13.0, < 2.0.0) + xcpretty (~> 0.3.0) + xcpretty-travis-formatter (>= 0.0.3) + gh_inspector (1.1.3) + google-apis-androidpublisher_v3 (0.32.0) + google-apis-core (>= 0.9.1, < 2.a) + google-apis-core (0.9.5) + addressable (~> 2.5, >= 2.5.1) + googleauth (>= 0.16.2, < 2.a) + httpclient (>= 2.8.1, < 3.a) + mini_mime (~> 1.0) + representable (~> 3.0) + retriable (>= 2.0, < 4.a) + rexml + webrick + google-apis-iamcredentials_v1 (0.16.0) + google-apis-core (>= 0.9.1, < 2.a) + google-apis-playcustomapp_v1 (0.12.0) + google-apis-core (>= 0.9.1, < 2.a) + google-apis-storage_v1 (0.19.0) + google-apis-core (>= 0.9.0, < 2.a) + google-cloud-core (1.6.0) + google-cloud-env (~> 1.0) + google-cloud-errors (~> 1.0) + google-cloud-env (1.6.0) + faraday (>= 0.17.3, < 3.0) + google-cloud-errors (1.3.0) + google-cloud-storage (1.44.0) + addressable (~> 2.8) + digest-crc (~> 0.4) + google-apis-iamcredentials_v1 (~> 0.1) + google-apis-storage_v1 (~> 0.19.0) + google-cloud-core (~> 1.6) + googleauth (>= 0.16.2, < 2.a) + mini_mime (~> 1.0) + googleauth (1.3.0) + faraday (>= 0.17.3, < 3.a) + jwt (>= 1.4, < 3.0) + memoist (~> 0.16) + multi_json (~> 1.11) + os (>= 0.9, < 2.0) + signet (>= 0.16, < 2.a) + highline (2.0.3) + http-cookie (1.0.5) + domain_name (~> 0.5) + httpclient (2.8.3) + jmespath (1.6.2) + json (2.6.3) + jwt (2.6.0) + memoist (0.16.2) + mini_magick (4.12.0) + mini_mime (1.1.2) + multi_json (1.15.0) + multipart-post (2.0.0) + nanaimo (0.3.0) + naturally (2.2.1) + optparse (0.1.1) + os (1.1.4) + plist (3.6.0) + public_suffix (5.0.1) + rake (13.0.6) + representable (3.2.0) + declarative (< 0.1.0) + trailblazer-option (>= 0.1.1, < 0.2.0) + uber (< 0.2.0) + retriable (3.1.2) + rexml (3.2.5) + rouge (2.0.7) + ruby2_keywords (0.0.5) + rubyzip (2.3.2) + security (0.1.3) + signet (0.17.0) + addressable (~> 2.8) + faraday (>= 0.17.5, < 3.a) + jwt (>= 1.5, < 3.0) + multi_json (~> 1.10) + simctl (1.6.8) + CFPropertyList + naturally + terminal-notifier (2.0.0) + terminal-table (1.8.0) + unicode-display_width (~> 1.1, >= 1.1.1) + trailblazer-option (0.1.2) + tty-cursor (0.7.1) + tty-screen (0.8.1) + tty-spinner (0.9.3) + tty-cursor (~> 0.7) + uber (0.1.0) + unf (0.1.4) + unf_ext + unf_ext (0.0.8.2) + unicode-display_width (1.8.0) + webrick (1.7.0) + word_wrap (1.0.0) + xcodeproj (1.22.0) + CFPropertyList (>= 2.3.3, < 4.0) + atomos (~> 0.1.3) + claide (>= 1.0.2, < 2.0) + colored2 (~> 3.1) + nanaimo (~> 0.3.0) + rexml (~> 3.2.4) + xcpretty (0.3.0) + rouge (~> 2.0.7) + xcpretty-travis-formatter (1.0.1) + xcpretty (~> 0.2, >= 0.0.7) + +PLATFORMS + x86_64-darwin-22 + +DEPENDENCIES + fastlane + +BUNDLED WITH + 2.4.2 diff --git a/fastlane/Appfile b/fastlane/Appfile new file mode 100644 index 0000000..f29b1eb --- /dev/null +++ b/fastlane/Appfile @@ -0,0 +1,8 @@ +app_identifier("io.airtv.Converter") # The bundle identifier of your app +apple_id("justin@devsec.ca") # Your Apple email address + +itc_team_id("872163") # App Store Connect Team ID TODO verify this +team_id("85N3S3DG8M") # Developer Portal Team ID + +# For more information about the Appfile, see: +# https://docs.fastlane.tools/advanced/#appfile diff --git a/fastlane/Fastfile b/fastlane/Fastfile new file mode 100644 index 0000000..2060d4b --- /dev/null +++ b/fastlane/Fastfile @@ -0,0 +1,90 @@ +# TODOS REMAINING FOR SETUP +# - Download screenshots from App store (need to wait till app is not in a pending state): fastlane deliver download_screenshots +# - Download any other metadata we want to track in git +# - Setup match for code signing https://codesigning.guide/ https://docs.fastlane.tools/actions/match/ + +# This file contains the fastlane.tools configuration +# You can find the documentation at https://docs.fastlane.tools +# +# For a list of all available actions, check out +# +# https://docs.fastlane.tools/actions +# +# For a list of all available plugins, check out +# +# https://docs.fastlane.tools/plugins/available-plugins +# + +# Uncomment the line if you want fastlane to automatically update itself +# update_fastlane + +default_platform(:ios) + +# uncomment for a specific xcode version +# xcode_select "/Applications/Xcode_13.2.1.app" + +platform :ios do + + desc "Push a new release build to the App Store" + lane :release do + match(type: "appstore", readonly: true) + + increment_build_number(xcodeproj: "Converter.xcodeproj") + + # https://docs.fastlane.tools/actions/build_app/#parameters + build_app( + project: "Converter.xcodeproj", + scheme: "Converter (Production)", + # silent: true, + # suppress_xcode_output: true, + ) + + upload_to_app_store( + skip_metadata: false, + skip_screenshots: true, # Can change this if we want to change screenshots locally, or capture with fastlane + force: true, # Skip HTML report verification + automatic_release: false, + submit_for_review: false, + submission_information: { + add_id_info_uses_idfa: false + }, + precheck_include_in_app_purchases: false, + api_key_path: "app_store_connect_api_key.json" + ) + + increment_version_number(xcodeproj: "Converter.xcodeproj") + + # TODO: rm -rf video covnerter app bundle + + # commit_version_bump(xcodeproj: "Converter.xcodeproj", force: true, message: "build: version bump") + + # TODO: Push + end + + desc "Push a new beta build to TestFlight" + lane :beta do + match(type: "appstore", readonly: true) + + increment_build_number(xcodeproj: "Converter.xcodeproj") + + # https://docs.fastlane.tools/actions/build_app/#parameters + build_app( + project: "Converter.xcodeproj", + scheme: "Converter (Development)", + # silent: true, + # suppress_xcode_output: true, + ) + + upload_to_testflight( + skip_waiting_for_build_processing: true, + api_key_path: "app_store_connect_api_key.json" + ) + + # TODO: rm -rf video covnerter app bundle + + # commit_version_bump(xcodeproj: "Converter.xcodeproj", force: true, message: "build: version bump") + + # TODO: Push + end + +end diff --git a/fastlane/Matchfile b/fastlane/Matchfile new file mode 100644 index 0000000..0facd23 --- /dev/null +++ b/fastlane/Matchfile @@ -0,0 +1,13 @@ +git_url("https://github.com/inter-ops/converter-code-signing") + +storage_mode("git") + +type("development") # The default type, can be: appstore, adhoc, enterprise or development + +app_identifier("io.airtv.Converter") +# username("user@fastlane.tools") # Your Apple Developer Portal username + +# For all available options run `fastlane match --help` +# Remove the # in the beginning of the line to enable the other options + +# The docs are available on https://docs.fastlane.tools/actions/match diff --git a/fastlane/README.md b/fastlane/README.md new file mode 100644 index 0000000..054434a --- /dev/null +++ b/fastlane/README.md @@ -0,0 +1,40 @@ +fastlane documentation +---- + +# Installation + +Make sure you have the latest version of the Xcode command line tools installed: + +```sh +xcode-select --install +``` + +For _fastlane_ installation instructions, see [Installing _fastlane_](https://docs.fastlane.tools/#installing-fastlane) + +# Available Actions + +## iOS + +### ios release + +```sh +[bundle exec] fastlane ios release +``` + +Push a new release build to the App Store + +### ios beta + +```sh +[bundle exec] fastlane ios beta +``` + +Push a new beta build to TestFlight + +---- + +This README.md is auto-generated and will be re-generated every time [_fastlane_](https://fastlane.tools) is run. + +More information about _fastlane_ can be found on [fastlane.tools](https://fastlane.tools). + +The documentation of _fastlane_ can be found on [docs.fastlane.tools](https://docs.fastlane.tools). diff --git a/fastlane/metadata/en-CA/apple_tv_privacy_policy.txt b/fastlane/metadata/en-CA/apple_tv_privacy_policy.txt new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/fastlane/metadata/en-CA/apple_tv_privacy_policy.txt @@ -0,0 +1 @@ + diff --git a/fastlane/metadata/en-CA/name.txt b/fastlane/metadata/en-CA/name.txt new file mode 100644 index 0000000..2cd1f4d --- /dev/null +++ b/fastlane/metadata/en-CA/name.txt @@ -0,0 +1 @@ +Video Converter diff --git a/fastlane/metadata/en-CA/privacy_url.txt b/fastlane/metadata/en-CA/privacy_url.txt new file mode 100644 index 0000000..8aff45b --- /dev/null +++ b/fastlane/metadata/en-CA/privacy_url.txt @@ -0,0 +1 @@ +https://converter.airtv.io/privacy.html diff --git a/fastlane/metadata/en-CA/subtitle.txt b/fastlane/metadata/en-CA/subtitle.txt new file mode 100644 index 0000000..eaf915e --- /dev/null +++ b/fastlane/metadata/en-CA/subtitle.txt @@ -0,0 +1 @@ +All-in-One Video Conversion diff --git a/fastlane/report.xml b/fastlane/report.xml new file mode 100644 index 0000000..12e2886 --- /dev/null +++ b/fastlane/report.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +