diff --git a/.circleci/config.yml b/.circleci/config.yml index 6978303b8a2..280e8ae043d 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -1592,15 +1592,25 @@ jobs: - amplify-ssh-deps-{{ .Branch }} - amplify-ssh-deps - run: - name: 'Post-release steps' + name: 'Update roll-back infrastructure' command: | git config --global user.email $GITHUB_EMAIL git config --global user.name $GITHUB_USER git pull origin release - yarn workspace @aws-amplify/core build - git add ./packages/core/src/Platform/version.ts - git commit -m "chore(release): update version.ts [ci skip]" + PUBLISH_COMMIT_HASH=$(git log -n 1 --pretty=format:"%H") + RELEASE_COMMIT_MESSAGE=$(git log -n 1 --skip 1 --pretty=oneline) + if [[ $RELEASE_COMMIT_MESSAGE = *release\(required\)* ]]; then git tag -f required-release $PUBLISH_COMMIT_HASH; fi + - run: + name: 'Update API documentation' + command: | + yarn run docs + git add ./docs/api/ + git commit -m "chore(release): update API docs [ci skip]" + - run: + name: 'Push post release changes' + command: | git push origin release + git push -f origin required-release git push --force-with-lease origin release:main # Specifies the branches that can be considered releasable. @@ -2325,16 +2335,18 @@ workflows: - getting-started-smoke-test/web: name: Next.js - latest npx-command: create-next-app + npx-post: --use-npm --ts --tailwind --no-eslint --no-src-dir --no-app --import-alias "@/*"` framework: nextjs - main-file-path: pages/_app.js + main-file-path: pages/_app.tsx dev-start: dev build-dir: build ssr: true - getting-started-smoke-test/web: name: Next.js - next npx-command: create-next-app@canary + npx-post: --use-npm --ts --tailwind --no-eslint --no-src-dir --no-app --import-alias "@/*"` framework: nextjs - main-file-path: pages/_app.js + main-file-path: pages/_app.tsx dev-start: dev build-dir: build ssr: true @@ -2510,7 +2522,10 @@ orbs: no_output_timeout: 2m - run-with-retry: label: Install AmplifyJS - command: npm i -S aws-amplify && npm i -g wait-on serve + command: | + npm i -S aws-amplify + npm i -g wait-on serve + ~/amplify-js/.circleci/duplicates-npm.sh - run: name: Call Amplify library in code command: | diff --git a/.circleci/duplicates-npm.sh b/.circleci/duplicates-npm.sh new file mode 100644 index 00000000000..fb54ab6f690 --- /dev/null +++ b/.circleci/duplicates-npm.sh @@ -0,0 +1,17 @@ +#!/usr/bin/env bash + +# This script detects duplicated Amplify dependencies in the dependency graph (with NPM) +duplicatedDependencies=$( + npm ls -all 2>/dev/null | \ + grep -o -e '@\?aws-amplify[^ ]*' | \ + sort | uniq | \ + sed -E 's/^(@?[^@]+).*$/\1/g' | \ + uniq -d | sort +) + +if [ ! "$duplicatedDependencies" ]; then + echo "No duplicated Amplify dependencies detected." +else + echo "Duplicated Amplify dependencies detected: $duplicatedDependencies" + false +fi diff --git a/.github/ISSUE_TEMPLATE/1.bug_report.yaml b/.github/ISSUE_TEMPLATE/1.bug_report.yaml index 3e890e53ee9..ec21d2b2b40 100644 --- a/.github/ISSUE_TEMPLATE/1.bug_report.yaml +++ b/.github/ISSUE_TEMPLATE/1.bug_report.yaml @@ -21,10 +21,7 @@ body: | ------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------ | | `amazon-cognito-identity-js` | [data:image/s3,"s3://crabby-images/f5e87/f5e870a610dc69b6a98af39d616b4e73f2691969" alt="version"](https://www.npmjs.com/package/amazon-cognito-identity-js) | | `aws-amplify` | [data:image/s3,"s3://crabby-images/b25ea/b25eaba9cd3004b64a2d9e516a067bb2162835b9" alt="version"](https://www.npmjs.com/package/aws-amplify) | - | `aws-amplify-angular` | [data:image/s3,"s3://crabby-images/64421/644210b826abb69366420484197b5d800c8b0e13" alt="version"](https://www.npmjs.com/package/aws-amplify-angular) | - | `aws-amplify-react` | [data:image/s3,"s3://crabby-images/bf292/bf29231e8c390c9a9ccefcc71d5a725f2cb02a64" alt="version"](https://www.npmjs.com/package/aws-amplify-react) | | `aws-amplify-react-native` | [data:image/s3,"s3://crabby-images/2bbe4/2bbe47442880f95a6e71ba9d4b6d86a37ff84a20" alt="version"](https://www.npmjs.com/package/aws-amplify-react-native) | - | `aws-amplify-vue` | [data:image/s3,"s3://crabby-images/0e66a/0e66ae8289b8e626f1cac987e36991be0591ada2" alt="version"](https://www.npmjs.com/package/aws-amplify-vue) | | `@aws-amplify/analytics` | [data:image/s3,"s3://crabby-images/ef32b/ef32b726d61109a8ea82009d76196c320f4c859d" alt="version"](https://www.npmjs.com/package/@aws-amplify/analytics) | | `@aws-amplify/api` | [data:image/s3,"s3://crabby-images/a1d41/a1d4134dba1b5eaaef8d872b32a41d0b3506cbe6" alt="version"](https://www.npmjs.com/package/@aws-amplify/api) | | `@aws-amplify/api-graphql` | [data:image/s3,"s3://crabby-images/293e6/293e6dbb03aeb9db1a0626b4ff98ebd53d8410b4" alt="version"](https://www.npmjs.com/package/@aws-amplify/api-graphql) | @@ -38,12 +35,6 @@ body: | `@aws-amplify/pubsub` | [data:image/s3,"s3://crabby-images/93e9e/93e9eca3f2e01eabc9d1c864280b8dee316abc92" alt="version"](https://www.npmjs.com/package/@aws-amplify/pubsub) | | `@aws-amplify/pushnotification` | [data:image/s3,"s3://crabby-images/523e6/523e661627e8dc93527c9bbe19e690dcba3e60fe" alt="version"](https://www.npmjs.com/package/@aws-amplify/pushnotification) | | `@aws-amplify/storage` | [data:image/s3,"s3://crabby-images/1004f/1004f8de2112b90d3f37c567feec455bc7332cb3" alt="version"](https://www.npmjs.com/package/@aws-amplify/storage) | - | `@aws-amplify/ui` | [data:image/s3,"s3://crabby-images/ad0d0/ad0d0d6c5c4ba46a2d472d155bc799fceb33801c" alt="version"](https://www.npmjs.com/package/@aws-amplify/ui) | - | `@aws-amplify/ui-angular` | [data:image/s3,"s3://crabby-images/54a7b/54a7b801700ff5ec9e6e983a7ac25480359c86b6" alt="version"](https://www.npmjs.com/package/@aws-amplify/ui-angular) | - | `@aws-amplify/ui-components` | [data:image/s3,"s3://crabby-images/98b0c/98b0c0bcaaa3725d5035c19afb16116b123e59a9" alt="version"](https://www.npmjs.com/package/@aws-amplify/ui-components) | - | `@aws-amplify/ui-react` | [data:image/s3,"s3://crabby-images/982a3/982a37e0aac067ee60749504c9b8dcb1cc36099e" alt="version"](https://www.npmjs.com/package/@aws-amplify/ui-react) | - | `@aws-amplify/ui-vue` | [data:image/s3,"s3://crabby-images/2e268/2e268a1c366432bf4c824b564e886c9ca588b1fd" alt="version"](https://www.npmjs.com/package/@aws-amplify/ui-vue) | - | `@aws-amplify/xr` | [data:image/s3,"s3://crabby-images/f235e/f235e98c4809a78b1629961c6ed847075ab72bd8" alt="version"](https://www.npmjs.com/package/@aws-amplify/xr) | @@ -118,7 +109,6 @@ body: - notifications - interactions - predictions - - xr - Not applicable - type: textarea attributes: diff --git a/.github/workflows/issue-pending-response.yml b/.github/workflows/issue-pending-response.yml new file mode 100644 index 00000000000..d69cd643bcd --- /dev/null +++ b/.github/workflows/issue-pending-response.yml @@ -0,0 +1,15 @@ +name: issue-pending-response +on: + issue_comment: + types: [created] +permissions: + issues: write +jobs: + issue_commented: + if: ${{ !github.event.issue.pull_request && contains(github.event.issue.labels.*.name, 'pending-response') }} + runs-on: ubuntu-latest + steps: + - uses: siegerts/pending-author-response@v1 + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + pending-response-label: pending-response diff --git a/.github/workflows/snyk-security.yml b/.github/workflows/snyk-security.yml new file mode 100644 index 00000000000..c1000a48191 --- /dev/null +++ b/.github/workflows/snyk-security.yml @@ -0,0 +1,36 @@ +name: 'Snyk Security' + +on: + push: + branches: ['release'] + schedule: + - cron: '0 0 * * *' # run daily at midnight GMT + +permissions: + contents: read + +jobs: + snyk: + if: github.repository == 'aws-amplify/amplify-js' + permissions: + contents: read # for actions/checkout to fetch code + security-events: write # for github/codeql-action/upload-sarif to upload SARIF results + actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Set up Snyk CLI to check for security issues + uses: snyk/actions/setup@806182742461562b67788a64410098c9d9b96adb + - name: Build + run: yarn install || true + # Using `|| true` to not fail the pipeline + - name: Snyk test + env: + SNYK_TOKEN: ${{secrets.SNYK_TOKEN}} + run: snyk test --sarif | tee snyk-code.sarif # || true + + # Push the Snyk Code results into GitHub Code Scanning tab + - name: Upload result to GitHub Code Scanning + uses: github/codeql-action/upload-sarif@v2 + with: + sarif_file: snyk-code.sarif diff --git a/.gitignore b/.gitignore index ebf4d950ae4..ea82d0b8e71 100644 --- a/.gitignore +++ b/.gitignore @@ -20,6 +20,9 @@ package-lock.json packages/*/.watchmanconfig dual-publish-tmp +### Version file - core build artifact +packages/core/src/Platform/version.ts + ### Gradle ### .gradle/ local.properties diff --git a/docs/Gemfile.lock b/docs/Gemfile.lock index 1417008e883..bceea9f2f0c 100644 --- a/docs/Gemfile.lock +++ b/docs/Gemfile.lock @@ -13,7 +13,7 @@ GEM execjs coffee-script-source (1.11.1) colorator (1.1.0) - commonmarker (0.23.8) + commonmarker (0.23.9) concurrent-ruby (1.2.2) dnsruby (1.61.9) simpleidn (~> 0.1) @@ -211,7 +211,7 @@ GEM jekyll-feed (~> 0.9) jekyll-seo-tag (~> 2.1) minitest (5.18.0) - nokogiri (1.13.10) + nokogiri (1.14.3) mini_portile2 (~> 2.8.0) racc (~> 1.4) octokit (4.25.1) diff --git a/docs/_config.yml b/docs/_config.yml index 55771997bd8..b848fe11fce 100644 --- a/docs/_config.yml +++ b/docs/_config.yml @@ -9,6 +9,7 @@ # 'bundle exec jekyll serve'. If you change this file, please restart the server process. # Site settings +# # These are used to personalize your new site. If you look in the HTML files, # you will see them accessed via {{ site.title }}, {{ site.email }}, and so on. # You can create any custom variable you would like, and they will be accessible @@ -341,4 +342,4 @@ js_libraries: - title: Ionic url: '?platform=ionic' - title: JavaScript - url: '?platform=purejs' \ No newline at end of file + url: '?platform=purejs' diff --git a/docs/amplify-theme/_includes/site-head.html b/docs/amplify-theme/_includes/site-head.html index f146b3b33ad..243481d5ea3 100755 --- a/docs/amplify-theme/_includes/site-head.html +++ b/docs/amplify-theme/_includes/site-head.html @@ -9,8 +9,8 @@ {% if page.keywords %} {% endif %} - - + + - \ No newline at end of file + diff --git a/docs/amplify-theme/_includes/site-header.html b/docs/amplify-theme/_includes/site-header.html index d3aaffcef26..a2e8b3cfda2 100755 --- a/docs/amplify-theme/_includes/site-header.html +++ b/docs/amplify-theme/_includes/site-header.html @@ -54,13 +54,13 @@ {% if site.amplify.header.logo.text %}
{% elsif site.amplify.header.logo.image %} -