diff --git a/.circleci/config.yml b/.circleci/config.yml deleted file mode 100644 index 26fcf888..00000000 --- a/.circleci/config.yml +++ /dev/null @@ -1,272 +0,0 @@ -version: 2.1 -orbs: - android: circleci/android@2 - macos: circleci/macos@2 - flutter: circleci/flutter@2 - browser-tools: circleci/browser-tools@1 - codecov: codecov/codecov@3 - node: circleci/node@5 - local-android: - orbs: - android: circleci/android@2 - commands: - prepare-config: - description: Prepares the environment configuration files - steps: - - run: - name: Prepare Environment Configuration - command: | - cp .env.example .env - sed -i "s/YOUR_AUTH0_DOMAIN/$AUTH0_DOMAIN/" .env - sed -i "s/YOUR_AUTH0_CLIENT_ID/$AUTH0_CLIENT_ID/" .env - sed -i "s/YOUR_AUTH0_CUSTOM_SCHEME/$AUTH0_CUSTOM_SCHEME/" .env - mv android/app/src/main/res/values/strings.xml.example android/app/src/main/res/values/strings.xml - sed -i "s/YOUR_AUTH0_DOMAIN/$AUTH0_DOMAIN/" android/app/src/main/res/values/strings.xml - mv android/local.properties.ci android/local.properties - working_directory: ./auth0_flutter/example -parameters: - flutter_version: - type: string - default: 3.10.5 -jobs: - test_flutter_package: - docker: - - image: cimg/base:current - steps: - - checkout - - flutter/install_sdk_and_pub: - app-dir: ./auth0_flutter - version: << pipeline.parameters.flutter_version >> - - flutter/install_pub: - app-dir: ./auth0_flutter - - browser-tools/install-chrome - - run: - name: Analyze App Facing Package - command: | - cp example/.env.example example/.env - dart analyze - working_directory: ./auth0_flutter - - run: - name: Run package unit tests - command: | - flutter test --tags browser --platform chrome - flutter test --coverage --exclude-tags browser - working_directory: ./auth0_flutter - - flutter/install_pub: - app-dir: ./auth0_flutter_platform_interface - - run: - name: Analyze Platform Interface Package - command: dart analyze - working_directory: ./auth0_flutter_platform_interface - - run: - name: Run platform interface unit tests - command: flutter test --coverage - working_directory: ./auth0_flutter_platform_interface - - codecov/upload: - file: ./auth0_flutter/coverage/lcov.info - upload_name: Auth0 Flutter - flags: auth0_flutter - - codecov/upload: - file: ./auth0_flutter_platform_interface/coverage/lcov.info - upload_name: Auth0 Flutter Platform Interface - flags: auth0_flutter_platform_interface - test_android: - executor: - name: android/android-machine - resource-class: medium - tag: 2022.06.1 - steps: - - checkout - - flutter/install_sdk_and_pub: - app-dir: ./auth0_flutter - version: << pipeline.parameters.flutter_version >> - - flutter/install_pub: - app-dir: ./auth0_flutter - - android/restore-gradle-cache - - android/restore-build-cache - - local-android/prepare-config - - run: - name: Build Android Example App - command: flutter build apk - working_directory: ./auth0_flutter/example - - run: - name: Run Android Unit tests - command: gradle clean jacocoTestReportDebug - working_directory: ./auth0_flutter/example/android - - android/save-gradle-cache - - android/save-build-cache - - run: - name: Save test results - when: always - command: | - mkdir -p ~/test-results/junit/ - find . -type f -regex ".*/build/auth0_flutter/test-results/.*xml" -exec cp {} ~/test-results/junit/ \; - - store_test_results: - path: ~/test-results - - store_artifacts: - path: ~/test-results/junit - - codecov/upload: - file: ./auth0_flutter/example/build/auth0_flutter/reports/jacoco/debug/jacoco.xml - upload_name: Auth0 Flutter Android - flags: auth0_flutter_android - smoke_test_android: - machine: - image: android:2022.12.1 - # To optimize build times, we recommend "large" and above for Android-related jobs - resource_class: xlarge - steps: - - run: - name: Guard Smoke Tests - command: | - if ! [[ -z "$CIRCLE_PR_NUMBER" ]]; then - circleci-agent step halt - fi - - checkout - - flutter/install_sdk_and_pub: - app-dir: ./auth0_flutter - version: << pipeline.parameters.flutter_version >> - - local-android/prepare-config - - node/install: - node-version: '18.16.0' - install-yarn: true - - run: - name: Setup Appium Test - working_directory: ./appium-test - command: yarn - - run: - name: Setup Appium driver - command: APPIUM_SKIP_CHROMEDRIVER_INSTALL=1 npx --yes appium@next driver install uiautomator2 - - run: - name: Start appium - command: npx --yes appium@next #Appium recommends this until v2 is released - background: true - - run: - name: Generate cache key - command: | - find . -name 'build.gradle' | sort | xargs cat | - shasum | awk '{print $1}' > /tmp/gradle_cache_seed - - restore_cache: - key: gradle-v1-{{ arch }}-{{ checksum "/tmp/gradle_cache_seed" }} - - run: - name: Gradle Wrapper - working_directory: ./auth0_flutter/example/android - command: gradle wrapper - - run: - name: Build Android Example App - command: | - flutter clean - flutter build apk --split-per-abi - working_directory: ./auth0_flutter/example - - run: - name: Create avd - command: | - SYSTEM_IMAGES="system-images;android-29;google_apis_playstore;x86_64" - sdkmanager "$SYSTEM_IMAGES" - echo "no" | avdmanager --verbose create avd -n test -k "$SYSTEM_IMAGES" - - run: - name: Launch emulator - command: | - emulator -avd test -delay-adb -verbose -no-window -gpu swiftshader_indirect -no-snapshot -noaudio -no-boot-anim - background: true - - run: - name: Wait for emulator to start - command: | - circle-android wait-for-boot - - run: - name: Disable emulator animations and Chrome terms page - command: | - adb shell settings put global window_animation_scale 0.0 - adb shell settings put global transition_animation_scale 0.0 - adb shell settings put global animator_duration_scale 0.0 - adb shell am set-debug-app --persistent com.android.chrome - adb shell 'echo "chrome --disable-fre --no-default-browser-check --no-first-run" > /data/local/tmp/chrome-command-line' - - run: - name: Record screen - command: | - adb emu screenrecord start --time-limit 300 ./recording_video.webm - - run: - name: Run Appium Tests - command: USER_EMAIL=$USER_EMAIL USER_PASSWORD=$USER_PASSWORD node test.js - working_directory: ./appium-test - - save_cache: - key: gradle-v1-{{ arch }}-{{ checksum "/tmp/gradle_cache_seed" }} - paths: - - ~/.gradle/caches - - ~/.gradle/wrapper - - store_artifacts: - path: ./recording_video.webm - when: on_fail - test_ios: - parameters: - ios_version: - type: string - ios_simulator: - type: string - macos: - xcode: "14.2.0" - resource_class: macos.m1.large.gen1 - environment: - BUNDLE_RETRY: 3 - HOMEBREW_NO_AUTO_UPDATE: 1 - HOMEBREW_NO_INSTALL_CLEANUP: 1 - steps: - - checkout - - macos/preboot-simulator: - version: << parameters.ios_version >> - platform: iOS - device: << parameters.ios_simulator >> - - run: - name: Install Rosetta - command: /usr/sbin/softwareupdate --install-rosetta --agree-to-license - - flutter/install_sdk_and_pub: - app-dir: ./auth0_flutter - version: << pipeline.parameters.flutter_version >> - - flutter/install_pub: - app-dir: ./auth0_flutter/example - - flutter/install_ios_gem: - app-dir: ./auth0_flutter/example - - flutter/install_ios_pod: - app-dir: ./auth0_flutter/example - - run: - name: Run iOS tests - command: | - printf '%s\n%s\n%s' "AUTH0_DOMAIN=$AUTH0_DOMAIN" "AUTH0_CLIENT_ID=$AUTH0_CLIENT_ID" 'AUTH0_CUSTOM_SCHEME=demo' >> ../.env - pod install - SCHEME=Runner - WORKSPACE="$SCHEME".xcworkspace - SIMULATOR='platform=iOS Simulator,name=<< parameters.ios_simulator >>' - if [ -z "$CIRCLE_PR_NUMBER" ]; then - xcodebuild test -scheme "$SCHEME" -workspace "$WORKSPACE" -destination "$SIMULATOR" - else - xcodebuild test -scheme "$SCHEME" -workspace "$WORKSPACE" -destination "$SIMULATOR" -skip-testing:"$SCHEME"UITests - fi - working_directory: ./auth0_flutter/example/ios - - run: - name: Generate iOS test coverage report - command: | - mkdir cobertura - bundle exec slather - working_directory: ./auth0_flutter/example/ios - - run: - name: Create ~/.gnupg dir if it does not exist - command: mkdir -p ~/.gnupg - - codecov/upload: - file: ./auth0_flutter/example/ios/cobertura/cobertura.xml - upload_name: Auth0 Flutter iOS - flags: auth0_flutter_ios - xtra_args: -s ./auth0_flutter/example/ios/cobertura -workflows: - build_and_test: - jobs: - - test_flutter_package - - test_android: - requires: - - test_flutter_package - - smoke_test_android: - requires: - - test_flutter_package - - test_ios: - ios_version: "16.2" - ios_simulator: iPhone 14 - requires: - - test_flutter_package \ No newline at end of file diff --git a/README.md b/README.md index 6de9385e..06c789fa 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ ![Auth0 Flutter SDK](https://cdn.auth0.com/website/sdks/banners/flutter-banner.png) -[![CircleCI](https://img.shields.io/circleci/build/github/auth0/auth0-flutter)](https://circleci.com/gh/auth0/auth0-flutter) +![Build Status](https://img.shields.io/github/actions/workflow/status/auth0/auth0-flutter/main.yml?style=flat) [![Codecov](https://codecov.io/gh/auth0/auth0-flutter/branch/main/graph/badge.svg)](https://codecov.io/gh/auth0/auth0-flutter) Auth0 SDK for Android, iOS, and web Flutter apps. diff --git a/auth0_flutter/.shiprc b/auth0_flutter/.shiprc index 51bd573f..1652b452 100644 --- a/auth0_flutter/.shiprc +++ b/auth0_flutter/.shiprc @@ -1,4 +1,5 @@ { + "packageLabel": "af", "files": { "lib/src/version.dart": [], "pubspec.yaml": [ @@ -8,7 +9,7 @@ "= '{MAJOR}.{MINOR}.{PATCH}'" ] }, - "prebump": "flutter analyze", + "prebump": "flutter analyze && dart pub upgrade auth0_flutter_platform_interface", "prFilters": [ { "type": "title", diff --git a/auth0_flutter/CHANGELOG.md b/auth0_flutter/CHANGELOG.md index 339965b4..693c9d6c 100644 --- a/auth0_flutter/CHANGELOG.md +++ b/auth0_flutter/CHANGELOG.md @@ -1,5 +1,17 @@ # Change Log +## [af-v1.3.0](https://github.com/auth0/auth0-flutter/tree/af-v1.3.0) (2023-10-27) +[Full Changelog](https://github.com/auth0/auth0-flutter/compare/v1.2.1...af-v1.3.0) + +**Changed** +- Lock Auth0.Android version to avoid dynamic versioning [\#311](https://github.com/auth0/auth0-flutter/pull/311) ([poovamraj](https://github.com/poovamraj)) +- Add namespace to build.gradle [\#290](https://github.com/auth0/auth0-flutter/pull/290) ([poovamraj](https://github.com/poovamraj)) +- af: Pin Auth0.swift and its dependencies to last version that supports iOS 12 [\#276](https://github.com/auth0/auth0-flutter/pull/276) ([Widcket](https://github.com/Widcket)) + +**Fixed** +- Fix access token expiry android [\#315](https://github.com/auth0/auth0-flutter/pull/315) ([poovamraj](https://github.com/poovamraj)) +- af: Use Application Context for Credentials Manager [\#289](https://github.com/auth0/auth0-flutter/pull/289) ([poovamraj](https://github.com/poovamraj)) + ## [v1.2.1](https://github.com/auth0/auth0-flutter/tree/v1.2.1) (2023-06-06) [Full Changelog](https://github.com/auth0/auth0-flutter/compare/v1.2.0...v1.2.1) diff --git a/auth0_flutter/README.md b/auth0_flutter/README.md index dd135d6f..37f09d4c 100644 --- a/auth0_flutter/README.md +++ b/auth0_flutter/README.md @@ -3,7 +3,7 @@ [![Package](https://img.shields.io/pub/v/auth0_flutter.svg)](https://pub.dartlang.org/packages/auth0_flutter) [![Codecov](https://codecov.io/gh/auth0/auth0-flutter/branch/main/graph/badge.svg)](https://codecov.io/gh/auth0/auth0-flutter) [![License](https://img.shields.io/github/license/auth0/auth0-flutter)](https://www.apache.org/licenses/LICENSE-2.0) -[![CircleCI](https://img.shields.io/circleci/project/github/auth0/auth0-flutter.svg)](https://circleci.com/gh/auth0/auth0-flutter/tree/main) +![Build Status](https://img.shields.io/github/actions/workflow/status/auth0/auth0-flutter/main.yml?style=flat)
📚 Documentation • 🚀 Getting started • 💻 API reference • 💬 Feedback @@ -80,7 +80,7 @@ Head to the [Auth0 Dashboard](https://manage.auth0.com/#/applications/) and crea
Using an existing Single Page application? -Select the **Settings** tab of your [application's page](https://manage.auth0.com/#/applications/) and ensure that **Application Type** is set to `Single Page Application`. +Select the **Settings** tab of your [application's page](https://manage.auth0.com/#/applications/) and ensure that **Application Type** is set to `Single Page Application`. Then, scroll down and select the **Show Advanced Settings** link. Under **Advanced Settings**, select the **OAuth** tab and verify the following: @@ -179,6 +179,11 @@ Re-declare the activity manually using `tools:node="remove"` in the `android/src
+> 💡 `https` schemes require enabling [Android App +> Links](https://auth0.com/docs/applications/enable-android-app-links). You can +> read more about setting this value in the [Auth0.Android SDK +> README](https://github.com/auth0/Auth0.Android#a-note-about-app-deep-linking). + > 💡 If your Android app is using [product flavors](https://developer.android.com/studio/build/build-variants#product-flavors), you might need to specify different manifest placeholders for each flavor. ##### iOS: Configure custom URL scheme diff --git a/auth0_flutter/example/ios/Runner.xcodeproj/project.pbxproj b/auth0_flutter/example/ios/Runner.xcodeproj/project.pbxproj index 03ef4917..c6806c31 100644 --- a/auth0_flutter/example/ios/Runner.xcodeproj/project.pbxproj +++ b/auth0_flutter/example/ios/Runner.xcodeproj/project.pbxproj @@ -380,7 +380,7 @@ isa = PBXProject; attributes = { LastSwiftUpdateCheck = 1330; - LastUpgradeCheck = 1300; + LastUpgradeCheck = 1430; ORGANIZATIONNAME = ""; TargetAttributes = { 5C328B4427F7822600451E70 = { diff --git a/auth0_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/auth0_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme index 16bacd93..d663bf2a 100644 --- a/auth0_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +++ b/auth0_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme @@ -1,6 +1,6 @@