Compare commits
	
		
			134 Commits
		
	
	
		
			releases/v
			...
			reintroduc
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 5970a9ee86 | ||
|  | 4d12fe762c | ||
|  | f20f71e9fd | ||
|  | 040bca2f2d | ||
|  | 44946dc88f | ||
|  | 58fa4b7a88 | ||
|  | b260a9f8a6 | ||
|  | 17cd0d34de | ||
|  | 15d2aaca23 | ||
|  | 0465cdad11 | ||
|  | 69a9b03fd9 | ||
|  | a80139913a | ||
|  | 6034af24fb | ||
|  | 0b1e2e4582 | ||
|  | a3f0173fb3 | ||
|  | 2d72d869af | ||
|  | 730b76a669 | ||
|  | 815e458579 | ||
|  | 6ecde844e8 | ||
|  | 487fcd9442 | ||
|  | 8b7a7c0162 | ||
|  | 6c87482fb9 | ||
|  | 2956b0de81 | ||
|  | 0aec73c6d6 | ||
|  | ce95482067 | ||
|  | 2861dc8673 | ||
|  | dd98a235fd | ||
|  | 4de103f838 | ||
|  | 003621c2ca | ||
|  | 59c3b48916 | ||
|  | 8779b820d9 | ||
|  | d2a05f5e5a | ||
|  | fb0163a75b | ||
|  | 07c2133a09 | ||
|  | f5d13571ca | ||
|  | 5e6fc64554 | ||
|  | fdb5f68261 | ||
|  | 2b68b29aae | ||
|  | 6aeb2b7009 | ||
|  | b323b1872a | ||
|  | 7fd0762403 | ||
|  | f6cd293a1e | ||
|  | 350afcd40d | ||
|  | 7cf90a9adf | ||
|  | 51ef4d3b15 | ||
|  | 2e6aa9a7f0 | ||
|  | 12960c68c9 | ||
|  | e314c6fe22 | ||
|  | 3973e5f15a | ||
|  | cb6e676133 | ||
|  | defeeb7d92 | ||
|  | 9f3b580ccc | ||
|  | 59b9126341 | ||
|  | 04c14f526b | ||
|  | 2934fce629 | ||
|  | 674bcd2d67 | ||
|  | 6f63b4506e | ||
|  | 36fae76a5c | ||
|  | 5eea929306 | ||
|  | 12d1ded340 | ||
|  | 766a84c1cf | ||
|  | 3c49988886 | ||
|  | 4204c40f52 | ||
|  | f1168d714c | ||
|  | ccb8d16f08 | ||
|  | 75dbd0cd0e | ||
|  | ec9df7c385 | ||
|  | 03c4bc34bd | ||
|  | 0a4afc0be2 | ||
|  | 0a19cfc696 | ||
|  | b1829982df | ||
|  | 688f58f697 | ||
|  | 08e53e60c8 | ||
|  | bb2c91bef9 | ||
|  | e020468dd2 | ||
|  | 5e3f23f92c | ||
|  | 104b6490a7 | ||
|  | a544ba8d92 | ||
|  | 9729932bfb | ||
|  | cebd052c1e | ||
|  | 3b4957b6fd | ||
|  | 35d938cf01 | ||
|  | e99df7cd80 | ||
|  | 05d11c9fe8 | ||
|  | 1f8f474abe | ||
|  | 94651eb27f | ||
|  | dac15d39e4 | ||
|  | 7e3b173db6 | ||
|  | d5e4f508ae | ||
|  | affa18ef97 | ||
|  | 2cf5c66450 | ||
|  | aabd85678e | ||
|  | 4fb86a77e0 | ||
|  | 9439581056 | ||
|  | 9a89d1e63f | ||
|  | 91409e712c | ||
|  | b238fd05b1 | ||
|  | a0dc82a74f | ||
|  | 924757492e | ||
|  | 9993ae8534 | ||
|  | 9f4852ebe6 | ||
|  | b7e450da2a | ||
|  | 6195d81339 | ||
|  | 2803ccaf23 | ||
|  | c66575c5e3 | ||
|  | 62eba970e0 | ||
|  | 7a7960d4c7 | ||
|  | d651ef48cb | ||
|  | 37ae175992 | ||
|  | d31b44251d | ||
|  | 0e414c630a | ||
|  | 9a2319ecaf | ||
|  | 7363c39621 | ||
|  | 742de9953a | ||
|  | e234343e3e | ||
|  | c99850e5d1 | ||
|  | 845942e04a | ||
|  | 1a522d88d8 | ||
|  | 56b4c8a8ef | ||
|  | 723bed634e | ||
|  | 2e7c800734 | ||
|  | 6247f9299a | ||
|  | 5d578441a6 | ||
|  | 42a316b84f | ||
|  | 6ecc92f5ad | ||
|  | e7b71cc1a7 | ||
|  | f26a08096a | ||
|  | ba42ad9139 | ||
|  | 07c8c20669 | ||
|  | 00c56dd770 | ||
|  | 50c843ac1c | ||
|  | ef036888ec | ||
|  | 2758344bdf | ||
|  | 18d8be76a0 | 
							
								
								
									
										1
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ko_fi: softprops | ||||||
							
								
								
									
										20
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,19 +8,19 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       # https://github.com/actions/checkout |       # https://github.com/actions/checkout | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|         with: |  | ||||||
|           fetch-depth: 1 |  | ||||||
|       - name: Install |       - name: Install | ||||||
|         run: npm ci |         run: npm ci | ||||||
|       - name: Build |       - name: Build | ||||||
|         run: npm run build |         run: npm run build | ||||||
|       - name: Test |       - name: Test | ||||||
|         run: npm run test |         run: npm run test | ||||||
|       - name: "check for uncommitted changes" |       - name: Format | ||||||
|         # Ensure no changes, but ignore node_modules dir since dev/fresh ci deps installed. |         run: npm run fmtcheck | ||||||
|         run: | |       # - name: "check for uncommitted changes" | ||||||
|           git diff --exit-code --stat -- . ':!node_modules' \ |       #   # Ensure no changes, but ignore node_modules dir since dev/fresh ci deps installed. | ||||||
|           || (echo "##[error] found changed files after build. please 'npm run build && npm run format'" \ |       #   run: | | ||||||
|                   "and check in all changes" \ |       #     git diff --exit-code --stat -- . ':!node_modules' \ | ||||||
|               && exit 1) |       #     || (echo "##[error] found changed files after build. please 'npm run build && npm run fmt'" \ | ||||||
|  |       #             "and check in all changes" \ | ||||||
|  |       #         && exit 1) | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,4 @@ | |||||||
| __tests__/runner/* | __tests__/runner/* | ||||||
| # actions requires a node_modules dir https://github.com/actions/toolkit/blob/master/docs/javascript-action.md#publish-a-releasesv1-action | # actions requires a node_modules dir https://github.com/actions/toolkit/blob/master/docs/javascript-action.md#publish-a-releasesv1-action | ||||||
| # but its recommended not to check these in https://github.com/actions/toolkit/blob/master/docs/action-versioning.md#recommendations | # but its recommended not to check these in https://github.com/actions/toolkit/blob/master/docs/action-versioning.md#recommendations | ||||||
|  | node_modules | ||||||
|   | |||||||
							
								
								
									
										95
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,34 +1,99 @@ | |||||||
|  | - Add `asset` output as a JSON array containing information about the uploaded assets | ||||||
|  |  | ||||||
|  | ## 0.1.14 | ||||||
|  |  | ||||||
|  | - provides an new workflow input option `generate_release_notes` which when set to true will automatically generate release notes for you based on GitHub activity [#179](https://github.com/softprops/action-gh-release/pull/179). Please see the [GitHub docs for this feature](https://docs.github.com/en/repositories/releasing-projects-on-github/automatically-generated-release-notes) for more information | ||||||
|  |  | ||||||
|  | ## 0.1.13 | ||||||
|  |  | ||||||
|  | - fix issue with multiple runs concatenating release bodies [#145](https://github.com/softprops/action-gh-release/pull/145) | ||||||
|  |  | ||||||
|  | ## 0.1.12 | ||||||
|  |  | ||||||
|  | - fix bug leading to empty strings subsituted for inputs users don't provide breaking api calls [#144](https://github.com/softprops/action-gh-release/pull/144) | ||||||
|  |  | ||||||
|  | ## 0.1.11 | ||||||
|  |  | ||||||
|  | - better error message on release create failed [#143](https://github.com/softprops/action-gh-release/pull/143) | ||||||
|  |  | ||||||
|  | ## 0.1.10 | ||||||
|  |  | ||||||
|  | - fixed error message formatting for file uploads | ||||||
|  |  | ||||||
|  | ## 0.1.9 | ||||||
|  |  | ||||||
|  | - add support for linking release to GitHub discussion [#136](https://github.com/softprops/action-gh-release/pull/136) | ||||||
|  |  | ||||||
|  | ## 0.1.8 | ||||||
|  |  | ||||||
|  | - address recent warnings in assert upload api as well as introduce asset upload overrides, allowing for multiple runs for the same release with the same named asserts [#134](https://github.com/softprops/action-gh-release/pull/134) | ||||||
|  | - fix backwards compatibility with `GITHUB_TOKEN` resolution. `GITHUB_TOKEN` is no resolved first from an env varibale and then from and input [#133](https://github.com/softprops/action-gh-release/pull/133) | ||||||
|  | - trim white space in provided `tag_name` [#130](https://github.com/softprops/action-gh-release/pull/130) | ||||||
|  |  | ||||||
|  | ## 0.1.7 | ||||||
|  |  | ||||||
|  | - allow creating draft releases without a tag [#95](https://github.com/softprops/action-gh-release/pull/95) | ||||||
|  | - Set default token for simpler setup [#83](https://github.com/softprops/action-gh-release/pull/83) | ||||||
|  | - fix regression with action yml [#126](https://github.com/softprops/action-gh-release/pull/126) | ||||||
|  |  | ||||||
|  | ## 0.1.6 | ||||||
|  |  | ||||||
|  | This is a release catch up have a hiatus. Future releases will happen more frequently | ||||||
|  |  | ||||||
|  | - Add 'fail_on_unmatched_files' input, useful for catching cases were your `files` input does not actually match what you expect [#55](https://github.com/softprops/action-gh-release/pull/55) | ||||||
|  | - Add `repository` input, useful for creating a release in an external repository [#61](https://github.com/softprops/action-gh-release/pull/61) | ||||||
|  | - Add release `id` to outputs, useful for refering to release in workflow steps following the step that uses this action [#60](https://github.com/softprops/action-gh-release/pull/60) | ||||||
|  | - Add `upload_url` as action output, useful for managing uploads separately [#75](https://github.com/softprops/action-gh-release/pull/75) | ||||||
|  | - Support custom `target_commitish` value, useful to customize the default [#76](https://github.com/softprops/action-gh-release/pull/76) | ||||||
|  | - fix `body_path` input first then fall back on `body` input. this was the originally documented precedence but was implemened the the opposite order! [#85](https://github.com/softprops/action-gh-release/pull/85) | ||||||
|  | - Retain original release info if the keys are not set, useful for filling in blanks for a release you've already started separately [#109](https://github.com/softprops/action-gh-release/pull/109) | ||||||
|  | - Limit number of times github api request to create a release is retried, useful for avoiding eating up your rate limit and action minutes do to either an invalid token or other circumstance causing the api call to fail [#111](https://github.com/softprops/action-gh-release/pull/111) | ||||||
|  |  | ||||||
|  | ## 0.1.5 | ||||||
|  |  | ||||||
|  | - Added support for specifying tag name [#39](https://github.com/softprops/action-gh-release/pull/39) | ||||||
|  |  | ||||||
|  | ## 0.1.4 | ||||||
|  |  | ||||||
|  | - Added support for updating releases body [#36](https://github.com/softprops/action-gh-release/pull/36) | ||||||
|  | - Steps can now access the url of releases with the `url` output of this Action [#28](https://github.com/softprops/action-gh-release/pull/28) | ||||||
|  | - Added basic GitHub API retry support to manage API turbulance [#26](https://github.com/softprops/action-gh-release/pull/26) | ||||||
|  |  | ||||||
|  | ## 0.1.3 | ||||||
|  |  | ||||||
|  | - Fixed where `with: body_path` was not being used in generated GitHub releases | ||||||
|  |  | ||||||
| ## 0.1.2 | ## 0.1.2 | ||||||
|  |  | ||||||
| * Add support for merging draft releases [#16](https://github.com/softprops/action-gh-release/pull/16) | - Add support for merging draft releases [#16](https://github.com/softprops/action-gh-release/pull/16) | ||||||
|  |  | ||||||
| GitHub's api doesn't explicitly have a way of fetching a draft release by tag name which caused draft releases to appear as separate releases when used in a build matrix. | GitHub's api doesn't explicitly have a way of fetching a draft release by tag name which caused draft releases to appear as separate releases when used in a build matrix. | ||||||
| This is now fixed. | This is now fixed. | ||||||
|  |  | ||||||
| * Add support for newline-delimited asset list [#18](https://github.com/softprops/action-gh-release/pull/18) | - Add support for newline-delimited asset list [#18](https://github.com/softprops/action-gh-release/pull/18) | ||||||
|  |  | ||||||
| GitHub actions inputs don't inherently support lists of things and one might like to append a list of files to include in a release. Previously this was possible using a comma-delimited list of asset path patterns to upload. You can now provide these as a newline delimieted list for better readability | GitHub actions inputs don't inherently support lists of things and one might like to append a list of files to include in a release. Previously this was possible using a comma-delimited list of asset path patterns to upload. You can now provide these as a newline delimieted list for better readability | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
|   - name: Release | - name: Release | ||||||
|     uses: softprops/action-gh-release@v1 |   uses: softprops/action-gh-release@v1 | ||||||
|     if: startsWith(github.ref, 'refs/tags/') |   if: startsWith(github.ref, 'refs/tags/') | ||||||
|     with: |   with: | ||||||
|       files: | |     files: | | ||||||
|         filea.txt |       filea.txt | ||||||
|         fileb.txt |       fileb.txt | ||||||
|         filec.txt |       filec.txt | ||||||
|     env: |   env: | ||||||
|       GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |     GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| * Add support for prerelease annotated GitHub releases with the new input field `with.prerelease: true` | - Add support for prerelease annotated GitHub releases with the new input field `with.prerelease: true` [#19](https://github.com/softprops/action-gh-release/pull/19) | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
| ## 0.1.1 | ## 0.1.1 | ||||||
|  |  | ||||||
| * Add support for publishing releases on all supported virtual hosts | - Add support for publishing releases on all supported virtual hosts | ||||||
|  |  | ||||||
| You'll need to remove `docker://` prefix and use the `@v1` action tag | You'll need to remove `docker://` prefix and use the `@v1` action tag | ||||||
|  |  | ||||||
| @@ -36,4 +101,4 @@ You'll need to remove `docker://` prefix and use the `@v1` action tag | |||||||
|  |  | ||||||
| ## 0.1.0 | ## 0.1.0 | ||||||
|  |  | ||||||
| * Initial release | - Initial release | ||||||
|   | |||||||
| @@ -1,12 +1,12 @@ | |||||||
| ## bootstrapping | ## bootstrapping | ||||||
|  |  | ||||||
| This a [JavaScript](https://help.github.com/en/articles/about-actions#types-of-actions)  action but uses [TypeScript](https://www.typescriptlang.org/docs/home.html) to generate that JavaScript. | This a [JavaScript](https://help.github.com/en/articles/about-actions#types-of-actions) action but uses [TypeScript](https://www.typescriptlang.org/docs/home.html) to generate that JavaScript. | ||||||
|  |  | ||||||
| You can bootstrap your envrinment with a modern version of npm and by running `npm i` at the root of this repo. | You can bootstrap your environment with a modern version of npm and by running `npm i` at the root of this repo. | ||||||
|  |  | ||||||
| ## testing | ## testing | ||||||
|  |  | ||||||
| Tests can be found under under `__tests__` directory and are runnable with the `npm t` command | Tests can be found under under `__tests__` directory and are runnable with the `npm t` command. | ||||||
|  |  | ||||||
| ## source code | ## source code | ||||||
|  |  | ||||||
| @@ -14,5 +14,4 @@ Source code can be found under the `src` directory. Running `npm run build` will | |||||||
|  |  | ||||||
| ## formatting | ## formatting | ||||||
|  |  | ||||||
| A minimal attempt at keeping a consistent code style is can be applied by running `npm run fmt` | A minimal attempt at keeping a consistent code style is can be applied by running `npm run fmt`. | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										121
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,12 +1,25 @@ | |||||||
|  | <div align="center"> | ||||||
|  |   📦 :octocat: | ||||||
|  | </div> | ||||||
|  | <h1 align="center"> | ||||||
|  |   action gh-release | ||||||
|  | </h1> | ||||||
|  |  | ||||||
| # action gh-release [](https://github.com/softprops/action-gh-release/actions) | <p align="center"> | ||||||
|  |    A GitHub Action for creating GitHub Releases on Linux, Windows, and macOS virtual environments | ||||||
|  | </p> | ||||||
|  |  | ||||||
| > A GitHub Action for creating GitHub Releases on Linux, Windows, and OSX virtual environments | <div align="center"> | ||||||
|  |   <img src="demo.png"/> | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  | <div align="center"> | ||||||
|  |   <a href="https://github.com/softprops/action-gh-release/actions"> | ||||||
|  | 		<img src="https://github.com/softprops/action-gh-release/workflows/Main/badge.svg"/> | ||||||
|  | 	</a> | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  | <br /> | ||||||
| > **⚠️ Note:** To use this action, you must have access to the [GitHub Actions](https://github.com/features/actions) feature. GitHub Actions are currently only available in public beta. You can [apply for the GitHub Actions beta here](https://github.com/features/actions/signup/). |  | ||||||
|  |  | ||||||
| ## 🤸 Usage | ## 🤸 Usage | ||||||
|  |  | ||||||
| @@ -14,7 +27,7 @@ | |||||||
|  |  | ||||||
| Typically usage of this action involves adding a step to a build that | Typically usage of this action involves adding a step to a build that | ||||||
| is gated pushes to git tags. You may find `step.if` field helpful in accomplishing this | is gated pushes to git tags. You may find `step.if` field helpful in accomplishing this | ||||||
| as it maximizes the resuse value of your workflow for non-tag pushes. | as it maximizes the reuse value of your workflow for non-tag pushes. | ||||||
|  |  | ||||||
| Below is a simple example of `step.if` tag gating | Below is a simple example of `step.if` tag gating | ||||||
|  |  | ||||||
| @@ -28,12 +41,10 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|       - name: Release |       - name: Release | ||||||
|         uses: softprops/action-gh-release@v1 |         uses: softprops/action-gh-release@v1 | ||||||
|         if: startsWith(github.ref, 'refs/tags/') |         if: startsWith(github.ref, 'refs/tags/') | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| You can also use push config tag filter | You can also use push config tag filter | ||||||
| @@ -44,24 +55,21 @@ name: Main | |||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     tags: |     tags: | ||||||
|       - 'v*.*.*' |       - "v*.*.*" | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|       - name: Release |       - name: Release | ||||||
|         uses: softprops/action-gh-release@v1 |         uses: softprops/action-gh-release@v1 | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
| ### ⬆️ Uploading release assets | ### ⬆️ Uploading release assets | ||||||
|  |  | ||||||
| You can can configure a number of options for your | You can configure a number of options for your | ||||||
| GitHub release and all are optional. | GitHub release and all are optional. | ||||||
|  |  | ||||||
| A common case for GitHub releases is to upload your binary after its been validated and packaged. | A common case for GitHub releases is to upload your binary after its been validated and packaged. | ||||||
| @@ -80,7 +88,7 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|       - name: Build |       - name: Build | ||||||
|         run: echo ${{ github.sha }} > Release.txt |         run: echo ${{ github.sha }} > Release.txt | ||||||
|       - name: Test |       - name: Test | ||||||
| @@ -90,8 +98,6 @@ jobs: | |||||||
|         if: startsWith(github.ref, 'refs/tags/') |         if: startsWith(github.ref, 'refs/tags/') | ||||||
|         with: |         with: | ||||||
|           files: Release.txt |           files: Release.txt | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Below is an example of uploading more than one asset with a GitHub release | Below is an example of uploading more than one asset with a GitHub release | ||||||
| @@ -106,7 +112,7 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|       - name: Build |       - name: Build | ||||||
|         run: echo ${{ github.sha }} > Release.txt |         run: echo ${{ github.sha }} > Release.txt | ||||||
|       - name: Test |       - name: Test | ||||||
| @@ -118,8 +124,6 @@ jobs: | |||||||
|           files: | |           files: | | ||||||
|             Release.txt |             Release.txt | ||||||
|             LICENSE |             LICENSE | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| > **⚠️ Note:** Notice the `|` in the yaml syntax above ☝️. That let's you effectively declare a multi-line yaml string. You can learn more about multi-line yaml syntax [here](https://yaml-multiline.info) | > **⚠️ Note:** Notice the `|` in the yaml syntax above ☝️. That let's you effectively declare a multi-line yaml string. You can learn more about multi-line yaml syntax [here](https://yaml-multiline.info) | ||||||
| @@ -140,16 +144,19 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
|         uses: actions/checkout@master |         uses: actions/checkout@v2 | ||||||
|       - name: Generate Changelog |       - name: Generate Changelog | ||||||
|         run: echo "# Good things have arrived" > ${{ github.workflow }}-CHANGELOG.txt |         run: echo "# Good things have arrived" > ${{ github.workspace }}-CHANGELOG.txt | ||||||
|       - name: Release |       - name: Release | ||||||
|         uses: softprops/action-gh-release@v1 |         uses: softprops/action-gh-release@v1 | ||||||
|         if: startsWith(github.ref, 'refs/tags/') |         if: startsWith(github.ref, 'refs/tags/') | ||||||
|         with: |         with: | ||||||
|           body_path: ${{ github.workflow }}-CHANGELOG.txt |           body_path: ${{ github.workspace }}-CHANGELOG.txt | ||||||
|  |           # note you'll typically need to create a personal access token | ||||||
|  |           # with permissions to create releases in the other repo | ||||||
|  |           token: ${{ secrets.CUSTOM_GITHUB_TOKEN }} | ||||||
|         env: |         env: | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GITHUB_REPOSITORY: my_gh_org/my_gh_repo | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### 💅 Customizing | ### 💅 Customizing | ||||||
| @@ -158,26 +165,62 @@ jobs: | |||||||
|  |  | ||||||
| The following are optional as `step.with` keys | The following are optional as `step.with` keys | ||||||
|  |  | ||||||
| | Name        | Type    | Description                                                     | | | Name                       | Type    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     | | ||||||
| |-------------|---------|-----------------------------------------------------------------| | | -------------------------- | ------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | ||||||
| | `body`      | String  | Text communicating notable changes in this release              | | | `body`                     | String  | Text communicating notable changes in this release                                                                                                                                                                                                                                                                                                                                                                                              | | ||||||
| | `body_path` | String  | Path to load text communicating notable changes in this release | | | `body_path`                | String  | Path to load text communicating notable changes in this release                                                                                                                                                                                                                                                                                                                                                                                 | | ||||||
| | `draft`     | Boolean | Indicator of whether or not this release is a draft             | | | `draft`                    | Boolean | Indicator of whether or not this release is a draft                                                                                                                                                                                                                                                                                                                                                                                             | | ||||||
| | `prerelease`| Boolean | Indicator of whether or not is a prerelease                     | | | `prerelease`               | Boolean | Indicator of whether or not is a prerelease                                                                                                                                                                                                                                                                                                                                                                                                     | | ||||||
| | `files`     | String  | Newline-delimited globs of paths to assets to upload for release| | | `files`                    | String  | Newline-delimited globs of paths to assets to upload for release                                                                                                                                                                                                                                                                                                                                                                                | | ||||||
| | `name`      | String  | Name of the release. defaults to tag name                       | | | `name`                     | String  | Name of the release. defaults to tag name                                                                                                                                                                                                                                                                                                                                                                                                       | | ||||||
|  | | `tag_name`                 | String  | Name of a tag. defaults to `github.ref`                                                                                                                                                                                                                                                                                                                                                                                                         | | ||||||
|  | | `fail_on_unmatched_files`  | Boolean | Indicator of whether to fail if any of the `files` globs match nothing                                                                                                                                                                                                                                                                                                                                                                          | | ||||||
|  | | `repository`               | String  | Name of a target repository in `<owner>/<repo>` format. Defaults to GITHUB_REPOSITORY env variable                                                                                                                                                                                                                                                                                                                                              | | ||||||
|  | | `target_commitish`         | String  | Commitish value that determines where the Git tag is created from. Can be any branch or commit SHA.                                                                                                                                                                                                                                                                                                                                             | | ||||||
|  | | `token`                    | String  | Secret GitHub Personal Access Token. Defaults to `${{ github.token }}`                                                                                                                                                                                                                                                                                                                                                                          | | ||||||
|  | | `discussion_category_name` | String  | If specified, a discussion of the specified category is created and linked to the release. The value must be a category that already exists in the repository. For more information, see ["Managing categories for discussions in your repository."](https://docs.github.com/en/discussions/managing-discussions-for-your-community/managing-categories-for-discussions-in-your-repository)                                                     | | ||||||
|  | | `generate_release_notes`   | Boolean | Whether to automatically generate the name and body for this release. If name is specified, the specified name will be used; otherwise, a name will be automatically generated. If body is specified, the body will be pre-pended to the automatically generated notes. See the [GitHub docs for this feature](https://docs.github.com/en/repositories/releasing-projects-on-github/automatically-generated-release-notes) for more information | | ||||||
|  |  | ||||||
| 💡When providing a `body` and `body_path` at the same time, `body_path` will be attempted first, then falling back on `body` if the path can not be read from. | 💡 When providing a `body` and `body_path` at the same time, `body_path` will be | ||||||
|  | attempted first, then falling back on `body` if the path can not be read from. | ||||||
|  |  | ||||||
|  | 💡 When the release info keys (such as `name`, `body`, `draft`, `prerelease`, etc.) | ||||||
|  | are not explicitly set and there is already an existing release for the tag, the | ||||||
|  | release will retain its original info. | ||||||
|  |  | ||||||
|  | #### outputs | ||||||
|  |  | ||||||
|  | The following outputs can be accessed via `${{ steps.<step-id>.outputs }}` from this action | ||||||
|  |  | ||||||
|  | | Name         | Type   | Description                             | | ||||||
|  | | ------------ | ------ | --------------------------------------- | | ||||||
|  | | `url`        | String | Github.com URL for the release          | | ||||||
|  | | `id`         | String | Release ID                              | | ||||||
|  | | `upload_url` | String | URL for uploading assets to the release | | ||||||
|  | | `assets`     | String | JSON array containing information about each uploaded asset, in the format given [here](https://docs.github.com/en/rest/reference/repos#upload-a-release-asset--code-samples) (minus the `uploader` field) | | ||||||
|  |  | ||||||
|  | As an example, you can use `${{ fromJSON(steps.<step-id>.outputs.assets)[0].browser_download_url }}` to get the download URL of the first asset. | ||||||
|  |  | ||||||
| #### environment variables | #### environment variables | ||||||
|  |  | ||||||
| The following are *required* as `step.env` keys | The following `step.env` keys are allowed as a fallback but deprecated in favor of using inputs. | ||||||
|  |  | ||||||
| | Name           | Description                          | | | Name                | Description                                                                                | | ||||||
| |----------------|--------------------------------------| | | ------------------- | ------------------------------------------------------------------------------------------ | | ||||||
| | `GITHUB_TOKEN` | GITHUB_TOKEN as provided by `secrets`| | | `GITHUB_TOKEN`      | GITHUB_TOKEN as provided by `secrets`                                                      | | ||||||
|  | | `GITHUB_REPOSITORY` | Name of a target repository in `<owner>/<repo>` format. defaults to the current repository | | ||||||
|  |  | ||||||
|  | > **⚠️ Note:** This action was previously implemented as a Docker container, limiting its use to GitHub Actions Linux virtual environments only. With recent releases, we now support cross platform usage. You'll need to remove the `docker://` prefix in these versions | ||||||
|  |  | ||||||
| > **⚠️ Note:** This action was previously implemented as a docker container, limiting its use to GitHub Actions Linux virtual environments only. With recent releases, we now support cross platform usage. You'll need to remove the `docker://` prefix in these versions | ### Permissions | ||||||
|  |  | ||||||
|  | This Action requires the following permissions on the GitHub integration token: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | [GitHub token permissions](https://docs.github.com/en/actions/security-guides/automatic-token-authentication#permissions-for-the-github_token) can be set for an individual job, workflow, or for Actions as a whole. | ||||||
|  |  | ||||||
| Doug Tangren (softprops) 2019 | Doug Tangren (softprops) 2019 | ||||||
|   | |||||||
| @@ -15,11 +15,11 @@ describe("github", () => { | |||||||
|  |  | ||||||
|   describe("asset", () => { |   describe("asset", () => { | ||||||
|     it("derives asset info from a path", async () => { |     it("derives asset info from a path", async () => { | ||||||
|       const { name, mime, size, file } = asset("tests/data/foo/bar.txt"); |       const { name, mime, size, data } = asset("tests/data/foo/bar.txt"); | ||||||
|       assert.equal(name, "bar.txt"); |       assert.equal(name, "bar.txt"); | ||||||
|       assert.equal(mime, "text/plain"); |       assert.equal(mime, "text/plain"); | ||||||
|       assert.equal(size, 10); |       assert.equal(size, 10); | ||||||
|       assert.equal(file.toString(), "release me"); |       assert.equal(data.toString(), "release me"); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								__tests__/release.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								__tests__/release.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | bar | ||||||
| @@ -1,7 +1,25 @@ | |||||||
| import { isTag, paths, parseConfig, parseInputFiles } from "../src/util"; | import { | ||||||
|  |   releaseBody, | ||||||
|  |   isTag, | ||||||
|  |   paths, | ||||||
|  |   parseConfig, | ||||||
|  |   parseInputFiles, | ||||||
|  |   unmatchedPatterns, | ||||||
|  |   uploadUrl | ||||||
|  | } from "../src/util"; | ||||||
| import * as assert from "assert"; | import * as assert from "assert"; | ||||||
|  |  | ||||||
| describe("util", () => { | describe("util", () => { | ||||||
|  |   describe("uploadUrl", () => { | ||||||
|  |     it("strips template", () => { | ||||||
|  |       assert.equal( | ||||||
|  |         uploadUrl( | ||||||
|  |           "https://uploads.github.com/repos/octocat/Hello-World/releases/1/assets{?name,label}" | ||||||
|  |         ), | ||||||
|  |         "https://uploads.github.com/repos/octocat/Hello-World/releases/1/assets" | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|   describe("parseInputFiles", () => { |   describe("parseInputFiles", () => { | ||||||
|     it("parses empty strings", () => { |     it("parses empty strings", () => { | ||||||
|       assert.deepStrictEqual(parseInputFiles(""), []); |       assert.deepStrictEqual(parseInputFiles(""), []); | ||||||
| @@ -16,19 +34,245 @@ describe("util", () => { | |||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|  |   describe("releaseBody", () => { | ||||||
|  |     it("uses input body", () => { | ||||||
|  |       assert.equal( | ||||||
|  |         "foo", | ||||||
|  |         releaseBody({ | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: "foo", | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: false, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         }) | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it("uses input body path", () => { | ||||||
|  |       assert.equal( | ||||||
|  |         "bar", | ||||||
|  |         releaseBody({ | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: "__tests__/release.txt", | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: false, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         }) | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it("defaults to body path when both body and body path are provided", () => { | ||||||
|  |       assert.equal( | ||||||
|  |         "bar", | ||||||
|  |         releaseBody({ | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: "foo", | ||||||
|  |           input_body_path: "__tests__/release.txt", | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: false, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         }) | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|   describe("parseConfig", () => { |   describe("parseConfig", () => { | ||||||
|     it("parses basic config", () => { |     it("parses basic config", () => { | ||||||
|       assert.deepStrictEqual(parseConfig({}), { |       assert.deepStrictEqual( | ||||||
|         github_ref: "", |         parseConfig({ | ||||||
|         github_repository: "", |           // note: inputs declared in actions.yml, even when declared not required, | ||||||
|         github_token: "", |           // are still provided by the actions runtime env as empty strings instead of | ||||||
|         input_body: undefined, |           // the normal absent env value one would expect. this breaks things | ||||||
|         input_body_path: undefined, |           // as an empty string !== undefined in terms of what we pass to the api | ||||||
|         input_draft: false, |           // so we cover that in a test case here to ensure undefined values are actually | ||||||
|         input_prerelease: false, |           // resolved as undefined and not empty strings | ||||||
|         input_files: [], |           INPUT_TARGET_COMMITISH: "", | ||||||
|         input_name: undefined |           INPUT_DISCUSSION_CATEGORY_NAME: "" | ||||||
|       }); |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: undefined, | ||||||
|  |           input_prerelease: undefined, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it("parses basic config with commitish", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_TARGET_COMMITISH: "affa18ef97bc9db20076945705aba8c516139abd" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: undefined, | ||||||
|  |           input_prerelease: undefined, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: "affa18ef97bc9db20076945705aba8c516139abd", | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it("supports discussion category names", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_DISCUSSION_CATEGORY_NAME: "releases" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: undefined, | ||||||
|  |           input_prerelease: undefined, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: "releases", | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it("supports generating release notes", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_GENERATE_RELEASE_NOTES: "true" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: undefined, | ||||||
|  |           input_prerelease: undefined, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: true | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it("prefers GITHUB_TOKEN over token input for backwards compatibility", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_DRAFT: "false", | ||||||
|  |           INPUT_PRERELEASE: "true", | ||||||
|  |           GITHUB_TOKEN: "env-token", | ||||||
|  |           INPUT_TOKEN: "input-token" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "env-token", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: true, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it("uses input token as the source of GITHUB_TOKEN by default", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_DRAFT: "false", | ||||||
|  |           INPUT_PRERELEASE: "true", | ||||||
|  |           INPUT_TOKEN: "input-token" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "input-token", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: true, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |     it("parses basic config with draft and prerelease", () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         parseConfig({ | ||||||
|  |           INPUT_DRAFT: "false", | ||||||
|  |           INPUT_PRERELEASE: "true" | ||||||
|  |         }), | ||||||
|  |         { | ||||||
|  |           github_ref: "", | ||||||
|  |           github_repository: "", | ||||||
|  |           github_token: "", | ||||||
|  |           input_body: undefined, | ||||||
|  |           input_body_path: undefined, | ||||||
|  |           input_draft: false, | ||||||
|  |           input_prerelease: true, | ||||||
|  |           input_files: [], | ||||||
|  |           input_name: undefined, | ||||||
|  |           input_tag_name: undefined, | ||||||
|  |           input_fail_on_unmatched_files: false, | ||||||
|  |           input_target_commitish: undefined, | ||||||
|  |           input_discussion_category_name: undefined, | ||||||
|  |           input_generate_release_notes: false | ||||||
|  |         } | ||||||
|  |       ); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|   describe("isTag", () => { |   describe("isTag", () => { | ||||||
| @@ -42,9 +286,19 @@ describe("util", () => { | |||||||
|  |  | ||||||
|   describe("paths", () => { |   describe("paths", () => { | ||||||
|     it("resolves files given a set of paths", async () => { |     it("resolves files given a set of paths", async () => { | ||||||
|       assert.deepStrictEqual(paths(["tests/data/**/*"]), [ |       assert.deepStrictEqual( | ||||||
|         "tests/data/foo/bar.txt" |         paths(["tests/data/**/*", "tests/data/does/not/exist/*"]), | ||||||
|       ]); |         ["tests/data/foo/bar.txt"] | ||||||
|  |       ); | ||||||
|  |     }); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   describe("unmatchedPatterns", () => { | ||||||
|  |     it("returns the patterns that don't match any files", async () => { | ||||||
|  |       assert.deepStrictEqual( | ||||||
|  |         unmatchedPatterns(["tests/data/**/*", "tests/data/does/not/exist/*"]), | ||||||
|  |         ["tests/data/does/not/exist/*"] | ||||||
|  |       ); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								action.yml
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								action.yml
									
									
									
									
									
								
							| @@ -1,31 +1,62 @@ | |||||||
| # https://help.github.com/en/articles/metadata-syntax-for-github-actions | # https://help.github.com/en/articles/metadata-syntax-for-github-actions | ||||||
| name: 'GH Release' | name: "GH Release" | ||||||
| description: 'Github Action for creating Github Releases' | description: "Github Action for creating Github Releases" | ||||||
| author: 'softprops' | author: "softprops" | ||||||
| inputs: | inputs: | ||||||
|   body: |   body: | ||||||
|     description: 'Note-worthy description of changes in release' |     description: "Note-worthy description of changes in release" | ||||||
|     required: false |     required: false | ||||||
|   body-path: |   body_path: | ||||||
|     description: 'Path to load note-worthy description of changes in release from' |     description: "Path to load note-worthy description of changes in release from" | ||||||
|     required: false |     required: false | ||||||
|   name: |   name: | ||||||
|     description: 'Gives the release a custom name. Defaults to tag name' |     description: "Gives the release a custom name. Defaults to tag name" | ||||||
|  |     required: false | ||||||
|  |   tag_name: | ||||||
|  |     description: "Gives a tag name. Defaults to github.GITHUB_REF" | ||||||
|     required: false |     required: false | ||||||
|   draft: |   draft: | ||||||
|     description: 'Creates a draft release. Defaults to false' |     description: "Creates a draft release. Defaults to false" | ||||||
|     required: false |     required: false | ||||||
|   prerelease: |   prerelease: | ||||||
|     description: 'Identify the release as a prerelease. Defaults to false' |     description: "Identify the release as a prerelease. Defaults to false" | ||||||
|     required: false |     required: false | ||||||
|   files: |   files: | ||||||
|     description: 'Newline-delimited list of path globs for asset files to upload' |     description: "Newline-delimited list of path globs for asset files to upload" | ||||||
|  |     required: false | ||||||
|  |   fail_on_unmatched_files: | ||||||
|  |     description: "Fails if any of the `files` globs match nothing. Defaults to false" | ||||||
|  |     required: false | ||||||
|  |   repository: | ||||||
|  |     description: "Repository to make releases against, in <owner>/<repo> format" | ||||||
|  |     required: false | ||||||
|  |   token: | ||||||
|  |     description: "Authorized secret GitHub Personal Access Token. Defaults to github.token" | ||||||
|  |     required: false | ||||||
|  |     default: ${{ github.token }} | ||||||
|  |   target_commitish: | ||||||
|  |     description: "Commitish value that determines where the Git tag is created from. Can be any branch or commit SHA." | ||||||
|  |     required: false | ||||||
|  |   discussion_category_name: | ||||||
|  |     description: "If specified, a discussion of the specified category is created and linked to the release. The value must be a category that already exists in the repository. If there is already a discussion linked to the release, this parameter is ignored." | ||||||
|  |     required: false | ||||||
|  |   generate_release_notes: | ||||||
|  |     description: "Whether to automatically generate the name and body for this release. If name is specified, the specified name will be used; otherwise, a name will be automatically generated. If body is specified, the body will be pre-pended to the automatically generated notes." | ||||||
|     required: false |     required: false | ||||||
| env: | env: | ||||||
|   'GITHUB_TOKEN': 'As provided by Github Actions' |   "GITHUB_TOKEN": "As provided by Github Actions" | ||||||
|  | outputs: | ||||||
|  |   url: | ||||||
|  |     description: "URL to the Release HTML Page" | ||||||
|  |   id: | ||||||
|  |     description: "Release ID" | ||||||
|  |   upload_url: | ||||||
|  |     description: "URL for uploading assets to the release" | ||||||
|  |   assets: | ||||||
|  |     description: "JSON array containing information about each uploaded asset, in the format given [here](https://docs.github.com/en/rest/reference/repos#upload-a-release-asset--code-samples) (minus the `uploader` field)" | ||||||
| runs: | runs: | ||||||
|   using: 'node12' |   using: "node12" | ||||||
|   main: 'lib/main.js' |   main: "dist/index.js" | ||||||
| branding: | branding: | ||||||
|   color: 'green' |   color: "green" | ||||||
|   icon: 'package' |   icon: "package" | ||||||
|   | |||||||
							
								
								
									
										1139
									
								
								dist/contextify.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1139
									
								
								dist/contextify.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										83
									
								
								dist/fixasync.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								dist/fixasync.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | |||||||
|  | 'use strict'; | ||||||
|  |  | ||||||
|  | // eslint-disable-next-line no-invalid-this, no-shadow | ||||||
|  | const {GeneratorFunction, AsyncFunction, AsyncGeneratorFunction, global, internal, host, hook} = this; | ||||||
|  | const {Contextify, Decontextify} = internal; | ||||||
|  | // eslint-disable-next-line no-shadow | ||||||
|  | const {Function, eval: eval_, Promise, Object, Reflect} = global; | ||||||
|  | const {getOwnPropertyDescriptor, defineProperty, assign} = Object; | ||||||
|  | const {apply: rApply, construct: rConstruct} = Reflect; | ||||||
|  |  | ||||||
|  | const FunctionHandler = { | ||||||
|  | 	__proto__: null, | ||||||
|  | 	apply(target, thiz, args) { | ||||||
|  | 		const type = this.type; | ||||||
|  | 		args = Decontextify.arguments(args); | ||||||
|  | 		try { | ||||||
|  | 			args = Contextify.value(hook(type, args)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 		return rApply(target, thiz, args); | ||||||
|  | 	}, | ||||||
|  | 	construct(target, args, newTarget) { | ||||||
|  | 		const type = this.type; | ||||||
|  | 		args = Decontextify.arguments(args); | ||||||
|  | 		try { | ||||||
|  | 			args = Contextify.value(hook(type, args)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 		return rConstruct(target, args, newTarget); | ||||||
|  | 	} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | function makeCheckFunction(type) { | ||||||
|  | 	return assign({ | ||||||
|  | 		__proto__: null, | ||||||
|  | 		type | ||||||
|  | 	}, FunctionHandler); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function override(obj, prop, value) { | ||||||
|  | 	const desc = getOwnPropertyDescriptor(obj, prop); | ||||||
|  | 	desc.value = value; | ||||||
|  | 	defineProperty(obj, prop, desc); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const proxiedFunction = new host.Proxy(Function, makeCheckFunction('function')); | ||||||
|  | override(Function.prototype, 'constructor', proxiedFunction); | ||||||
|  | if (GeneratorFunction) { | ||||||
|  | 	Object.setPrototypeOf(GeneratorFunction, proxiedFunction); | ||||||
|  | 	override(GeneratorFunction.prototype, 'constructor', new host.Proxy(GeneratorFunction, makeCheckFunction('generator_function'))); | ||||||
|  | } | ||||||
|  | if (AsyncFunction) { | ||||||
|  | 	Object.setPrototypeOf(AsyncFunction, proxiedFunction); | ||||||
|  | 	override(AsyncFunction.prototype, 'constructor', new host.Proxy(AsyncFunction, makeCheckFunction('async_function'))); | ||||||
|  | } | ||||||
|  | if (AsyncGeneratorFunction) { | ||||||
|  | 	Object.setPrototypeOf(AsyncGeneratorFunction, proxiedFunction); | ||||||
|  | 	override(AsyncGeneratorFunction.prototype, 'constructor', new host.Proxy(AsyncGeneratorFunction, makeCheckFunction('async_generator_function'))); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | global.Function = proxiedFunction; | ||||||
|  | global.eval = new host.Proxy(eval_, makeCheckFunction('eval')); | ||||||
|  |  | ||||||
|  | if (Promise) { | ||||||
|  |  | ||||||
|  | 	Promise.prototype.then = new host.Proxy(Promise.prototype.then, makeCheckFunction('promise_then')); | ||||||
|  | 	// This seems not to work, and will produce | ||||||
|  | 	// UnhandledPromiseRejectionWarning: TypeError: Method Promise.prototype.then called on incompatible receiver [object Object]. | ||||||
|  | 	// This is likely caused since the host.Promise.prototype.then cannot use the VM Proxy object. | ||||||
|  | 	// Contextify.connect(host.Promise.prototype.then, Promise.prototype.then); | ||||||
|  |  | ||||||
|  | 	if (Promise.prototype.finally) { | ||||||
|  | 		Promise.prototype.finally = new host.Proxy(Promise.prototype.finally, makeCheckFunction('promise_finally')); | ||||||
|  | 		// Contextify.connect(host.Promise.prototype.finally, Promise.prototype.finally); | ||||||
|  | 	} | ||||||
|  | 	if (Promise.prototype.catch) { | ||||||
|  | 		Promise.prototype.catch = new host.Proxy(Promise.prototype.catch, makeCheckFunction('promise_catch')); | ||||||
|  | 		// Contextify.connect(host.Promise.prototype.catch, Promise.prototype.catch); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										135
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										682
									
								
								dist/sandbox.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										682
									
								
								dist/sandbox.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,682 @@ | |||||||
|  | /* eslint-disable no-shadow, no-invalid-this */ | ||||||
|  | /* global vm, host, Contextify, Decontextify, VMError, options */ | ||||||
|  |  | ||||||
|  | 'use strict'; | ||||||
|  |  | ||||||
|  | const {Script} = host.require('vm'); | ||||||
|  | const fs = host.require('fs'); | ||||||
|  | const pa = host.require('path'); | ||||||
|  |  | ||||||
|  | const BUILTIN_MODULES = host.process.binding('natives'); | ||||||
|  | const parseJSON = JSON.parse; | ||||||
|  | const importModuleDynamically = () => { | ||||||
|  | 	// We can't throw an error object here because since vm.Script doesn't store a context, we can't properly contextify that error object. | ||||||
|  | 	// eslint-disable-next-line no-throw-literal | ||||||
|  | 	throw 'Dynamic imports are not allowed.'; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param {Object} host Hosts's internal objects. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | return ((vm, host) => { | ||||||
|  | 	'use strict'; | ||||||
|  |  | ||||||
|  | 	const global = this; | ||||||
|  |  | ||||||
|  | 	const TIMERS = new host.WeakMap(); // Contains map of timers created inside sandbox | ||||||
|  | 	const BUILTINS = {__proto__: null}; | ||||||
|  | 	const CACHE = {__proto__: null}; | ||||||
|  | 	const EXTENSIONS = { | ||||||
|  | 		__proto__: null, | ||||||
|  | 		['.json'](module, filename) { | ||||||
|  | 			try { | ||||||
|  | 				const code = fs.readFileSync(filename, 'utf8'); | ||||||
|  | 				module.exports = parseJSON(code); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		['.node'](module, filename) { | ||||||
|  | 			if (vm.options.require.context === 'sandbox') throw new VMError('Native modules can be required only with context set to \'host\'.'); | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				module.exports = Contextify.readonly(host.require(filename)); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	for (let i = 0; i < vm.options.sourceExtensions.length; i++) { | ||||||
|  | 		const ext = vm.options.sourceExtensions[i]; | ||||||
|  |  | ||||||
|  | 		EXTENSIONS['.' + ext] = (module, filename, dirname) => { | ||||||
|  | 			if (vm.options.require.context !== 'sandbox') { | ||||||
|  | 				try { | ||||||
|  | 					module.exports = Contextify.readonly(host.require(filename)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			} else { | ||||||
|  | 				let script; | ||||||
|  |  | ||||||
|  | 				try { | ||||||
|  | 					// Load module | ||||||
|  | 					let contents = fs.readFileSync(filename, 'utf8'); | ||||||
|  | 					contents = vm._compiler(contents, filename); | ||||||
|  |  | ||||||
|  | 					const code = host.STRICT_MODULE_PREFIX + contents + host.MODULE_SUFFIX; | ||||||
|  |  | ||||||
|  | 					const ccode = vm._hook('run', [code]); | ||||||
|  |  | ||||||
|  | 					// Precompile script | ||||||
|  | 					script = new Script(ccode, { | ||||||
|  | 						__proto__: null, | ||||||
|  | 						filename: filename || 'vm.js', | ||||||
|  | 						displayErrors: false, | ||||||
|  | 						importModuleDynamically | ||||||
|  | 					}); | ||||||
|  |  | ||||||
|  | 				} catch (ex) { | ||||||
|  | 					throw Contextify.value(ex); | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				const closure = script.runInContext(global, { | ||||||
|  | 					__proto__: null, | ||||||
|  | 					filename: filename || 'vm.js', | ||||||
|  | 					displayErrors: false, | ||||||
|  | 					importModuleDynamically | ||||||
|  | 				}); | ||||||
|  |  | ||||||
|  | 				// run the script | ||||||
|  | 				closure(module.exports, module.require, module, filename, dirname); | ||||||
|  | 			} | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	const _parseExternalOptions = (options) => { | ||||||
|  | 		if (host.Array.isArray(options)) { | ||||||
|  | 			return { | ||||||
|  | 				__proto__: null, | ||||||
|  | 				external: options, | ||||||
|  | 				transitive: false | ||||||
|  | 			}; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return { | ||||||
|  | 			__proto__: null, | ||||||
|  | 			external: options.modules, | ||||||
|  | 			transitive: options.transitive | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Resolve filename. | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	const _resolveFilename = (path) => { | ||||||
|  | 		if (!path) return null; | ||||||
|  | 		let hasPackageJson; | ||||||
|  | 		try { | ||||||
|  | 			path = pa.resolve(path); | ||||||
|  |  | ||||||
|  | 			const exists = fs.existsSync(path); | ||||||
|  | 			const isdir = exists ? fs.statSync(path).isDirectory() : false; | ||||||
|  |  | ||||||
|  | 			// direct file match | ||||||
|  | 			if (exists && !isdir) return path; | ||||||
|  |  | ||||||
|  | 			// load as file | ||||||
|  |  | ||||||
|  | 			for (let i = 0; i < vm.options.sourceExtensions.length; i++) { | ||||||
|  | 				const ext = vm.options.sourceExtensions[i]; | ||||||
|  | 				if (fs.existsSync(`${path}.${ext}`)) return `${path}.${ext}`; | ||||||
|  | 			} | ||||||
|  | 			if (fs.existsSync(`${path}.json`)) return `${path}.json`; | ||||||
|  | 			if (fs.existsSync(`${path}.node`)) return `${path}.node`; | ||||||
|  |  | ||||||
|  | 			// load as module | ||||||
|  |  | ||||||
|  | 			hasPackageJson = fs.existsSync(`${path}/package.json`); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if (hasPackageJson) { | ||||||
|  | 			let pkg; | ||||||
|  | 			try { | ||||||
|  | 				pkg = fs.readFileSync(`${path}/package.json`, 'utf8'); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 			try { | ||||||
|  | 				pkg = parseJSON(pkg); | ||||||
|  | 			} catch (ex) { | ||||||
|  | 				throw new VMError(`Module '${path}' has invalid package.json`, 'EMODULEINVALID'); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			let main; | ||||||
|  | 			if (pkg && pkg.main) { | ||||||
|  | 				main = _resolveFilename(`${path}/${pkg.main}`); | ||||||
|  | 				if (!main) main = _resolveFilename(`${path}/index`); | ||||||
|  | 			} else { | ||||||
|  | 				main = _resolveFilename(`${path}/index`); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return main; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		// load as directory | ||||||
|  |  | ||||||
|  | 		try { | ||||||
|  | 			for (let i = 0; i < vm.options.sourceExtensions.length; i++) { | ||||||
|  | 				const ext = vm.options.sourceExtensions[i]; | ||||||
|  | 				if (fs.existsSync(`${path}/index.${ext}`)) return `${path}/index.${ext}`; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (fs.existsSync(`${path}/index.json`)) return `${path}/index.json`; | ||||||
|  | 			if (fs.existsSync(`${path}/index.node`)) return `${path}/index.node`; | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return null; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Builtin require. | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	const _requireBuiltin = (moduleName) => { | ||||||
|  | 		if (moduleName === 'buffer') return ({Buffer}); | ||||||
|  | 		if (BUILTINS[moduleName]) return BUILTINS[moduleName].exports; // Only compiled builtins are stored here | ||||||
|  |  | ||||||
|  | 		if (moduleName === 'util') { | ||||||
|  | 			return Contextify.readonly(host.require(moduleName), { | ||||||
|  | 				// Allows VM context to use util.inherits | ||||||
|  | 				__proto__: null, | ||||||
|  | 				inherits: (ctor, superCtor) => { | ||||||
|  | 					ctor.super_ = superCtor; | ||||||
|  | 					Object.setPrototypeOf(ctor.prototype, superCtor.prototype); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if (moduleName === 'events' || moduleName === 'internal/errors') { | ||||||
|  | 			let script; | ||||||
|  | 			try { | ||||||
|  | 				script = new Script(`(function (exports, require, module, process, internalBinding) { | ||||||
|  | 						'use strict'; | ||||||
|  | 						const primordials = global; | ||||||
|  | 						${BUILTIN_MODULES[moduleName]} | ||||||
|  | 						\n | ||||||
|  | 					});`, { | ||||||
|  | 					filename: `${moduleName}.vm.js` | ||||||
|  | 				}); | ||||||
|  |  | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			// setup module scope | ||||||
|  | 			const module = BUILTINS[moduleName] = { | ||||||
|  | 				exports: {}, | ||||||
|  | 				require: _requireBuiltin | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			// run script | ||||||
|  | 			try { | ||||||
|  | 				// FIXME binding should be contextified | ||||||
|  | 				script.runInContext(global)(module.exports, module.require, module, host.process, host.process.binding); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				// e could be from inside or outside of sandbox | ||||||
|  | 				throw new VMError(`Error loading '${moduleName}'`); | ||||||
|  | 			} | ||||||
|  | 			return module.exports; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return Contextify.readonly(host.require(moduleName)); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Prepare require. | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	const _prepareRequire = (currentDirname, parentAllowsTransitive = false) => { | ||||||
|  | 		const _require = moduleName => { | ||||||
|  | 			let requireObj; | ||||||
|  | 			try { | ||||||
|  | 				const optionsObj = vm.options; | ||||||
|  | 				if (optionsObj.nesting && moduleName === 'vm2') return {VM: Contextify.readonly(host.VM), NodeVM: Contextify.readonly(host.NodeVM)}; | ||||||
|  | 				requireObj = optionsObj.require; | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (!requireObj) throw new VMError(`Access denied to require '${moduleName}'`, 'EDENIED'); | ||||||
|  | 			if (moduleName == null) throw new VMError("Module '' not found.", 'ENOTFOUND'); | ||||||
|  | 			if (typeof moduleName !== 'string') throw new VMError(`Invalid module name '${moduleName}'`, 'EINVALIDNAME'); | ||||||
|  |  | ||||||
|  | 			let filename; | ||||||
|  | 			let allowRequireTransitive = false; | ||||||
|  |  | ||||||
|  | 			// Mock? | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				const {mock} = requireObj; | ||||||
|  | 				if (mock) { | ||||||
|  | 					const mockModule = mock[moduleName]; | ||||||
|  | 					if (mockModule) { | ||||||
|  | 						return Contextify.readonly(mockModule); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			// Builtin? | ||||||
|  |  | ||||||
|  | 			if (BUILTIN_MODULES[moduleName]) { | ||||||
|  | 				let allowed; | ||||||
|  | 				try { | ||||||
|  | 					const builtinObj = requireObj.builtin; | ||||||
|  | 					if (host.Array.isArray(builtinObj)) { | ||||||
|  | 						if (builtinObj.indexOf('*') >= 0) { | ||||||
|  | 							allowed = builtinObj.indexOf(`-${moduleName}`) === -1; | ||||||
|  | 						} else { | ||||||
|  | 							allowed = builtinObj.indexOf(moduleName) >= 0; | ||||||
|  | 						} | ||||||
|  | 					} else if (builtinObj) { | ||||||
|  | 						allowed = builtinObj[moduleName]; | ||||||
|  | 					} else { | ||||||
|  | 						allowed = false; | ||||||
|  | 					} | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 				if (!allowed) throw new VMError(`Access denied to require '${moduleName}'`, 'EDENIED'); | ||||||
|  |  | ||||||
|  | 				return _requireBuiltin(moduleName); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			// External? | ||||||
|  |  | ||||||
|  | 			let externalObj; | ||||||
|  | 			try { | ||||||
|  | 				externalObj = requireObj.external; | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (!externalObj) throw new VMError(`Access denied to require '${moduleName}'`, 'EDENIED'); | ||||||
|  |  | ||||||
|  | 			if (/^(\.|\.\/|\.\.\/)/.exec(moduleName)) { | ||||||
|  | 				// Module is relative file, e.g. ./script.js or ../script.js | ||||||
|  |  | ||||||
|  | 				if (!currentDirname) throw new VMError('You must specify script path to load relative modules.', 'ENOPATH'); | ||||||
|  |  | ||||||
|  | 				filename = _resolveFilename(`${currentDirname}/${moduleName}`); | ||||||
|  | 			} else if (/^(\/|\\|[a-zA-Z]:\\)/.exec(moduleName)) { | ||||||
|  | 				// Module is absolute file, e.g. /script.js or //server/script.js or C:\script.js | ||||||
|  |  | ||||||
|  | 				filename = _resolveFilename(moduleName); | ||||||
|  | 			} else { | ||||||
|  | 				// Check node_modules in path | ||||||
|  |  | ||||||
|  | 				if (!currentDirname) throw new VMError('You must specify script path to load relative modules.', 'ENOPATH'); | ||||||
|  |  | ||||||
|  | 				if (typeof externalObj === 'object') { | ||||||
|  | 					let isWhitelisted; | ||||||
|  | 					try { | ||||||
|  | 						const { external, transitive } = _parseExternalOptions(externalObj); | ||||||
|  |  | ||||||
|  | 						isWhitelisted = external.some(ext => host.helpers.match(ext, moduleName)) || (transitive && parentAllowsTransitive); | ||||||
|  | 					} catch (e) { | ||||||
|  | 						throw Contextify.value(e); | ||||||
|  | 					} | ||||||
|  | 					if (!isWhitelisted) { | ||||||
|  | 						throw new VMError(`The module '${moduleName}' is not whitelisted in VM.`, 'EDENIED'); | ||||||
|  | 					} | ||||||
|  |  | ||||||
|  | 					allowRequireTransitive = true; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				// FIXME the paths array has side effects | ||||||
|  | 				const paths = currentDirname.split(pa.sep); | ||||||
|  |  | ||||||
|  | 				while (paths.length) { | ||||||
|  | 					const path = paths.join(pa.sep); | ||||||
|  |  | ||||||
|  | 					// console.log moduleName, "#{path}#{pa.sep}node_modules#{pa.sep}#{moduleName}" | ||||||
|  |  | ||||||
|  | 					filename = _resolveFilename(`${path}${pa.sep}node_modules${pa.sep}${moduleName}`); | ||||||
|  | 					if (filename) break; | ||||||
|  |  | ||||||
|  | 					paths.pop(); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (!filename) { | ||||||
|  | 				let resolveFunc; | ||||||
|  | 				try { | ||||||
|  | 					resolveFunc = requireObj.resolve; | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 				if (resolveFunc) { | ||||||
|  | 					let resolved; | ||||||
|  | 					try { | ||||||
|  | 						resolved = requireObj.resolve(moduleName, currentDirname); | ||||||
|  | 					} catch (e) { | ||||||
|  | 						throw Contextify.value(e); | ||||||
|  | 					} | ||||||
|  | 					filename = _resolveFilename(resolved); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			if (!filename) throw new VMError(`Cannot find module '${moduleName}'`, 'ENOTFOUND'); | ||||||
|  |  | ||||||
|  | 			// return cache whenever possible | ||||||
|  | 			if (CACHE[filename]) return CACHE[filename].exports; | ||||||
|  |  | ||||||
|  | 			const dirname = pa.dirname(filename); | ||||||
|  | 			const extname = pa.extname(filename); | ||||||
|  |  | ||||||
|  | 			let allowedModule = true; | ||||||
|  | 			try { | ||||||
|  | 				const rootObj = requireObj.root; | ||||||
|  | 				if (rootObj) { | ||||||
|  | 					const rootPaths = host.Array.isArray(rootObj) ? rootObj : host.Array.of(rootObj); | ||||||
|  | 					allowedModule = rootPaths.some(path => host.String.prototype.startsWith.call(dirname, pa.resolve(path))); | ||||||
|  | 				} | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (!allowedModule) { | ||||||
|  | 				throw new VMError(`Module '${moduleName}' is not allowed to be required. The path is outside the border!`, 'EDENIED'); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			const module = CACHE[filename] = { | ||||||
|  | 				filename, | ||||||
|  | 				exports: {}, | ||||||
|  | 				require: _prepareRequire(dirname, allowRequireTransitive) | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			// lookup extensions | ||||||
|  | 			if (EXTENSIONS[extname]) { | ||||||
|  | 				EXTENSIONS[extname](module, filename, dirname); | ||||||
|  | 				return module.exports; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			throw new VMError(`Failed to load '${moduleName}': Unknown type.`, 'ELOADFAIL'); | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		return _require; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Prepare sandbox. | ||||||
|  | 	 */ | ||||||
|  |  | ||||||
|  | 	// This is a function and not an arrow function, since the original is also a function | ||||||
|  | 	global.setTimeout = function setTimeout(callback, delay, ...args) { | ||||||
|  | 		if (typeof callback !== 'function') throw new TypeError('"callback" argument must be a function'); | ||||||
|  | 		let tmr; | ||||||
|  | 		try { | ||||||
|  | 			tmr = host.setTimeout(Decontextify.value(() => { | ||||||
|  | 				// FIXME ...args has side effects | ||||||
|  | 				callback(...args); | ||||||
|  | 			}), Decontextify.value(delay)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 		const local = Contextify.value(tmr); | ||||||
|  |  | ||||||
|  | 		TIMERS.set(local, tmr); | ||||||
|  | 		return local; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	global.setInterval = function setInterval(callback, interval, ...args) { | ||||||
|  | 		if (typeof callback !== 'function') throw new TypeError('"callback" argument must be a function'); | ||||||
|  | 		let tmr; | ||||||
|  | 		try { | ||||||
|  | 			tmr = host.setInterval(Decontextify.value(() => { | ||||||
|  | 				// FIXME ...args has side effects | ||||||
|  | 				callback(...args); | ||||||
|  | 			}), Decontextify.value(interval)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		const local = Contextify.value(tmr); | ||||||
|  |  | ||||||
|  | 		TIMERS.set(local, tmr); | ||||||
|  | 		return local; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	global.setImmediate = function setImmediate(callback, ...args) { | ||||||
|  | 		if (typeof callback !== 'function') throw new TypeError('"callback" argument must be a function'); | ||||||
|  | 		let tmr; | ||||||
|  | 		try { | ||||||
|  | 			tmr = host.setImmediate(Decontextify.value(() => { | ||||||
|  | 				// FIXME ...args has side effects | ||||||
|  | 				callback(...args); | ||||||
|  | 			})); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		const local = Contextify.value(tmr); | ||||||
|  |  | ||||||
|  | 		TIMERS.set(local, tmr); | ||||||
|  | 		return local; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	global.clearTimeout = function clearTimeout(local) { | ||||||
|  | 		try { | ||||||
|  | 			host.clearTimeout(TIMERS.get(local)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	global.clearInterval = function clearInterval(local) { | ||||||
|  | 		try { | ||||||
|  | 			host.clearInterval(TIMERS.get(local)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	global.clearImmediate = function clearImmediate(local) { | ||||||
|  | 		try { | ||||||
|  | 			host.clearImmediate(TIMERS.get(local)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	function addListener(name, handler) { | ||||||
|  | 		if (name !== 'beforeExit' && name !== 'exit') { | ||||||
|  | 			throw new Error(`Access denied to listen for '${name}' event.`); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		try { | ||||||
|  | 			host.process.on(name, Decontextify.value(handler)); | ||||||
|  | 		} catch (e) { | ||||||
|  | 			throw Contextify.value(e); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return this; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	const {argv: optionArgv, env: optionsEnv} = options; | ||||||
|  |  | ||||||
|  | 	// FIXME wrong class structure | ||||||
|  | 	global.process = { | ||||||
|  | 		argv: optionArgv !== undefined ? Contextify.value(optionArgv) : [], | ||||||
|  | 		title: host.process.title, | ||||||
|  | 		version: host.process.version, | ||||||
|  | 		versions: Contextify.readonly(host.process.versions), | ||||||
|  | 		arch: host.process.arch, | ||||||
|  | 		platform: host.process.platform, | ||||||
|  | 		env: optionsEnv !== undefined ? Contextify.value(optionsEnv) : {}, | ||||||
|  | 		pid: host.process.pid, | ||||||
|  | 		features: Contextify.readonly(host.process.features), | ||||||
|  | 		nextTick: function nextTick(callback, ...args) { | ||||||
|  | 			if (typeof callback !== 'function') { | ||||||
|  | 				throw new Error('Callback must be a function.'); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				host.process.nextTick(Decontextify.value(() => { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					callback(...args); | ||||||
|  | 				})); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		hrtime: function hrtime(time) { | ||||||
|  | 			try { | ||||||
|  | 				return Contextify.value(host.process.hrtime(Decontextify.value(time))); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		cwd: function cwd() { | ||||||
|  | 			try { | ||||||
|  | 				return Contextify.value(host.process.cwd()); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		addListener, | ||||||
|  | 		on: addListener, | ||||||
|  |  | ||||||
|  | 		once: function once(name, handler) { | ||||||
|  | 			if (name !== 'beforeExit' && name !== 'exit') { | ||||||
|  | 				throw new Error(`Access denied to listen for '${name}' event.`); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				host.process.once(name, Decontextify.value(handler)); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return this; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		listeners: function listeners(name) { | ||||||
|  | 			if (name !== 'beforeExit' && name !== 'exit') { | ||||||
|  | 				// Maybe add ({__proto__:null})[name] to throw when name fails in https://tc39.es/ecma262/#sec-topropertykey. | ||||||
|  | 				return []; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			// Filter out listeners, which were not created in this sandbox | ||||||
|  | 			try { | ||||||
|  | 				return Contextify.value(host.process.listeners(name).filter(listener => Contextify.isVMProxy(listener))); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		removeListener: function removeListener(name, handler) { | ||||||
|  | 			if (name !== 'beforeExit' && name !== 'exit') { | ||||||
|  | 				return this; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				host.process.removeListener(name, Decontextify.value(handler)); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return this; | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		umask: function umask() { | ||||||
|  | 			if (arguments.length) { | ||||||
|  | 				throw new Error('Access denied to set umask.'); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			try { | ||||||
|  | 				return Contextify.value(host.process.umask()); | ||||||
|  | 			} catch (e) { | ||||||
|  | 				throw Contextify.value(e); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	if (vm.options.console === 'inherit') { | ||||||
|  | 		global.console = Contextify.readonly(host.console); | ||||||
|  | 	} else if (vm.options.console === 'redirect') { | ||||||
|  | 		global.console = { | ||||||
|  | 			debug(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.debug', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			log(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.log', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			info(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.info', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			warn(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.warn', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			error(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.error', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			dir(...args) { | ||||||
|  | 				try { | ||||||
|  | 					vm.emit('console.dir', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			time() {}, | ||||||
|  | 			timeEnd() {}, | ||||||
|  | 			trace(...args) { | ||||||
|  | 				try { | ||||||
|  | 					// FIXME ...args has side effects | ||||||
|  | 					vm.emit('console.trace', ...Decontextify.arguments(args)); | ||||||
|  | 				} catch (e) { | ||||||
|  | 					throw Contextify.value(e); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	Return contextified require. | ||||||
|  | 	*/ | ||||||
|  |  | ||||||
|  | 	return _prepareRequire; | ||||||
|  | })(vm, host); | ||||||
							
								
								
									
										127
									
								
								lib/github.js
									
									
									
									
									
								
							
							
						
						
									
										127
									
								
								lib/github.js
									
									
									
									
									
								
							| @@ -1,127 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { |  | ||||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } |  | ||||||
|     return new (P || (P = Promise))(function (resolve, reject) { |  | ||||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } |  | ||||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } |  | ||||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } |  | ||||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); |  | ||||||
|     }); |  | ||||||
| }; |  | ||||||
| var __asyncValues = (this && this.__asyncValues) || function (o) { |  | ||||||
|     if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); |  | ||||||
|     var m = o[Symbol.asyncIterator], i; |  | ||||||
|     return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); |  | ||||||
|     function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } |  | ||||||
|     function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } |  | ||||||
| }; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const fs_1 = require("fs"); |  | ||||||
| const mime_1 = require("mime"); |  | ||||||
| const path_1 = require("path"); |  | ||||||
| class GitHubReleaser { |  | ||||||
|     constructor(github) { |  | ||||||
|         this.github = github; |  | ||||||
|     } |  | ||||||
|     getReleaseByTag(params) { |  | ||||||
|         return this.github.repos.getReleaseByTag(params); |  | ||||||
|     } |  | ||||||
|     createRelease(params) { |  | ||||||
|         return this.github.repos.createRelease(params); |  | ||||||
|     } |  | ||||||
|     allReleases(params) { |  | ||||||
|         return this.github.paginate.iterator(this.github.repos.listReleases.endpoint.merge(params)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| exports.GitHubReleaser = GitHubReleaser; |  | ||||||
| exports.asset = (path) => { |  | ||||||
|     return { |  | ||||||
|         name: path_1.basename(path), |  | ||||||
|         mime: exports.mimeOrDefault(path), |  | ||||||
|         size: fs_1.lstatSync(path).size, |  | ||||||
|         file: fs_1.readFileSync(path) |  | ||||||
|     }; |  | ||||||
| }; |  | ||||||
| exports.mimeOrDefault = (path) => { |  | ||||||
|     return mime_1.getType(path) || "application/octet-stream"; |  | ||||||
| }; |  | ||||||
| exports.upload = (gh, url, path) => __awaiter(void 0, void 0, void 0, function* () { |  | ||||||
|     let { name, size, mime, file } = exports.asset(path); |  | ||||||
|     console.log(`⬆️ Uploading ${name}...`); |  | ||||||
|     return yield gh.repos.uploadReleaseAsset({ |  | ||||||
|         url, |  | ||||||
|         headers: { |  | ||||||
|             "content-length": size, |  | ||||||
|             "content-type": mime |  | ||||||
|         }, |  | ||||||
|         name, |  | ||||||
|         file |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| exports.release = (config, releaser) => __awaiter(void 0, void 0, void 0, function* () { |  | ||||||
|     var e_1, _a; |  | ||||||
|     const [owner, repo] = config.github_repository.split("/"); |  | ||||||
|     const tag = config.github_ref.replace("refs/tags/", ""); |  | ||||||
|     try { |  | ||||||
|         // you can't get a an existing draft by tag |  | ||||||
|         // so we must find one in the list of all releases |  | ||||||
|         if (config.input_draft) { |  | ||||||
|             try { |  | ||||||
|                 for (var _b = __asyncValues(releaser.allReleases({ |  | ||||||
|                     owner, |  | ||||||
|                     repo |  | ||||||
|                 })), _c; _c = yield _b.next(), !_c.done;) { |  | ||||||
|                     const response = _c.value; |  | ||||||
|                     let release = response.data.find(release => release.tag_name === tag); |  | ||||||
|                     if (release) { |  | ||||||
|                         return release; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             catch (e_1_1) { e_1 = { error: e_1_1 }; } |  | ||||||
|             finally { |  | ||||||
|                 try { |  | ||||||
|                     if (_c && !_c.done && (_a = _b.return)) yield _a.call(_b); |  | ||||||
|                 } |  | ||||||
|                 finally { if (e_1) throw e_1.error; } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         let release = yield releaser.getReleaseByTag({ |  | ||||||
|             owner, |  | ||||||
|             repo, |  | ||||||
|             tag |  | ||||||
|         }); |  | ||||||
|         return release.data; |  | ||||||
|     } |  | ||||||
|     catch (error) { |  | ||||||
|         if (error.status === 404) { |  | ||||||
|             try { |  | ||||||
|                 const tag_name = tag; |  | ||||||
|                 const name = config.input_name || tag; |  | ||||||
|                 const body = config.input_body; |  | ||||||
|                 const draft = config.input_draft; |  | ||||||
|                 const prerelease = config.input_prerelease; |  | ||||||
|                 console.log(`👩🏭 Creating new GitHub release for tag ${tag_name}...`); |  | ||||||
|                 let release = yield releaser.createRelease({ |  | ||||||
|                     owner, |  | ||||||
|                     repo, |  | ||||||
|                     tag_name, |  | ||||||
|                     name, |  | ||||||
|                     body, |  | ||||||
|                     draft, |  | ||||||
|                     prerelease |  | ||||||
|                 }); |  | ||||||
|                 return release.data; |  | ||||||
|             } |  | ||||||
|             catch (error) { |  | ||||||
|                 // presume a race with competing metrix runs |  | ||||||
|                 console.log(`⚠️ GitHub release failed with status: ${error.status}, retrying...`); |  | ||||||
|                 return exports.release(config, releaser); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             console.log(`⚠️ Unexpected error fetching GitHub release for tag ${config.github_ref}: ${error}`); |  | ||||||
|             throw error; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
							
								
								
									
										38
									
								
								lib/main.js
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								lib/main.js
									
									
									
									
									
								
							| @@ -1,38 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { |  | ||||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } |  | ||||||
|     return new (P || (P = Promise))(function (resolve, reject) { |  | ||||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } |  | ||||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } |  | ||||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } |  | ||||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); |  | ||||||
|     }); |  | ||||||
| }; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const util_1 = require("./util"); |  | ||||||
| const github_1 = require("./github"); |  | ||||||
| const core_1 = require("@actions/core"); |  | ||||||
| const github_2 = require("@actions/github"); |  | ||||||
| const process_1 = require("process"); |  | ||||||
| function run() { |  | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |  | ||||||
|         try { |  | ||||||
|             const config = util_1.parseConfig(process_1.env); |  | ||||||
|             if (!util_1.isTag(config.github_ref)) { |  | ||||||
|                 throw new Error(`⚠️ GitHub Releases requires a tag`); |  | ||||||
|             } |  | ||||||
|             const gh = new github_2.GitHub(config.github_token); |  | ||||||
|             let rel = yield github_1.release(config, new github_1.GitHubReleaser(gh)); |  | ||||||
|             if (config.input_files) { |  | ||||||
|                 util_1.paths(config.input_files).forEach((path) => __awaiter(this, void 0, void 0, function* () { |  | ||||||
|                     yield github_1.upload(gh, rel.upload_url, path); |  | ||||||
|                 })); |  | ||||||
|             } |  | ||||||
|             console.log(`🎉 Release ready at ${rel.html_url}`); |  | ||||||
|         } |  | ||||||
|         catch (error) { |  | ||||||
|             core_1.setFailed(error.message); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| run(); |  | ||||||
							
								
								
									
										38
									
								
								lib/util.js
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								lib/util.js
									
									
									
									
									
								
							| @@ -1,38 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| var __importStar = (this && this.__importStar) || function (mod) { |  | ||||||
|     if (mod && mod.__esModule) return mod; |  | ||||||
|     var result = {}; |  | ||||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; |  | ||||||
|     result["default"] = mod; |  | ||||||
|     return result; |  | ||||||
| }; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const glob = __importStar(require("glob")); |  | ||||||
| const fs_1 = require("fs"); |  | ||||||
| exports.parseInputFiles = (files) => { |  | ||||||
|     return files.split(/\r?\n/).reduce((acc, line) => acc |  | ||||||
|         .concat(line.split(",")) |  | ||||||
|         .filter(pat => pat) |  | ||||||
|         .map(pat => pat.trim()), []); |  | ||||||
| }; |  | ||||||
| exports.parseConfig = (env) => { |  | ||||||
|     return { |  | ||||||
|         github_token: env.GITHUB_TOKEN || "", |  | ||||||
|         github_ref: env.GITHUB_REF || "", |  | ||||||
|         github_repository: env.GITHUB_REPOSITORY || "", |  | ||||||
|         input_name: env.INPUT_NAME, |  | ||||||
|         input_body: env.INPUT_BODY, |  | ||||||
|         input_body_path: env.INPUT_BODY_PATH, |  | ||||||
|         input_files: exports.parseInputFiles(env.INPUT_FILES || ""), |  | ||||||
|         input_draft: env.INPUT_DRAFT === "true", |  | ||||||
|         input_prerelease: env.INPUT_PRERELEASE == "true" |  | ||||||
|     }; |  | ||||||
| }; |  | ||||||
| exports.paths = (patterns) => { |  | ||||||
|     return patterns.reduce((acc, pattern) => { |  | ||||||
|         return acc.concat(glob.sync(pattern).filter(path => fs_1.lstatSync(path).isFile())); |  | ||||||
|     }, []); |  | ||||||
| }; |  | ||||||
| exports.isTag = (ref) => { |  | ||||||
|     return ref.startsWith("refs/tags/"); |  | ||||||
| }; |  | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/mime
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/mime
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| ../mime/cli.js |  | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/semver
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/semver
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| ../semver/bin/semver |  | ||||||
							
								
								
									
										1
									
								
								node_modules/.bin/which
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/.bin/which
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| ../which/bin/which |  | ||||||
							
								
								
									
										7
									
								
								node_modules/@actions/core/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/core/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,7 +0,0 @@ | |||||||
| Copyright 2019 GitHub |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |  | ||||||
							
								
								
									
										97
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										97
									
								
								node_modules/@actions/core/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,97 +0,0 @@ | |||||||
| # `@actions/core` |  | ||||||
|  |  | ||||||
| > Core functions for setting results, logging, registering secrets and exporting variables across actions |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| #### Inputs/Outputs |  | ||||||
|  |  | ||||||
| You can use this library to get inputs or set outputs: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| const myInput = core.getInput('inputName', { required: true }); |  | ||||||
|  |  | ||||||
| // Do stuff |  | ||||||
|  |  | ||||||
| core.setOutput('outputKey', 'outputVal'); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| #### Exporting variables |  | ||||||
|  |  | ||||||
| You can also export variables for future steps. Variables get set in the environment. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| // Do stuff |  | ||||||
|  |  | ||||||
| core.exportVariable('envVar', 'Val'); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| #### PATH Manipulation |  | ||||||
|  |  | ||||||
| You can explicitly add items to the path for all remaining steps in a workflow: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| core.addPath('pathToTool'); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| #### Exit codes |  | ||||||
|  |  | ||||||
| You should use this library to set the failing exit code for your action: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| try { |  | ||||||
|   // Do stuff |  | ||||||
| } |  | ||||||
| catch (err) { |  | ||||||
|   // setFailed logs the message and sets a failing exit code |  | ||||||
|   core.setFailed(`Action failed with error ${err}`); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| #### Logging |  | ||||||
|  |  | ||||||
| Finally, this library provides some utilities for logging. Note that debug logging is hidden from the logs by default. This behavior can be toggled by enabling the [Step Debug Logs](../../docs/action-debugging.md#step-debug-logs). |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| const myInput = core.getInput('input'); |  | ||||||
| try { |  | ||||||
|   core.debug('Inside try block'); |  | ||||||
|    |  | ||||||
|   if (!myInput) { |  | ||||||
|     core.warning('myInput was not set'); |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   // Do stuff |  | ||||||
| } |  | ||||||
| catch (err) { |  | ||||||
|   core.error(`Error ${err}, action may still succeed though`); |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| This library can also wrap chunks of output in foldable groups. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const core = require('@actions/core') |  | ||||||
|  |  | ||||||
| // Manually wrap output |  | ||||||
| core.startGroup('Do some function') |  | ||||||
| doSomeFunction() |  | ||||||
| core.endGroup() |  | ||||||
|  |  | ||||||
| // Wrap an asynchronous function call |  | ||||||
| const result = await core.group('Do something async', async () => { |  | ||||||
|   const response = await doSomeHTTPRequest() |  | ||||||
|   return response |  | ||||||
| }) |  | ||||||
| ``` |  | ||||||
							
								
								
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								node_modules/@actions/core/lib/command.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,16 +0,0 @@ | |||||||
| interface CommandProperties { |  | ||||||
|     [key: string]: string; |  | ||||||
| } |  | ||||||
| /** |  | ||||||
|  * Commands |  | ||||||
|  * |  | ||||||
|  * Command Format: |  | ||||||
|  *   ##[name key=value;key=value]message |  | ||||||
|  * |  | ||||||
|  * Examples: |  | ||||||
|  *   ##[warning]This is the user warning message |  | ||||||
|  *   ##[set-secret name=mypassword]definitelyNotAPassword! |  | ||||||
|  */ |  | ||||||
| export declare function issueCommand(command: string, properties: CommandProperties, message: string): void; |  | ||||||
| export declare function issue(name: string, message?: string): void; |  | ||||||
| export {}; |  | ||||||
							
								
								
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										66
									
								
								node_modules/@actions/core/lib/command.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,66 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const os = require("os"); |  | ||||||
| /** |  | ||||||
|  * Commands |  | ||||||
|  * |  | ||||||
|  * Command Format: |  | ||||||
|  *   ##[name key=value;key=value]message |  | ||||||
|  * |  | ||||||
|  * Examples: |  | ||||||
|  *   ##[warning]This is the user warning message |  | ||||||
|  *   ##[set-secret name=mypassword]definitelyNotAPassword! |  | ||||||
|  */ |  | ||||||
| function issueCommand(command, properties, message) { |  | ||||||
|     const cmd = new Command(command, properties, message); |  | ||||||
|     process.stdout.write(cmd.toString() + os.EOL); |  | ||||||
| } |  | ||||||
| exports.issueCommand = issueCommand; |  | ||||||
| function issue(name, message = '') { |  | ||||||
|     issueCommand(name, {}, message); |  | ||||||
| } |  | ||||||
| exports.issue = issue; |  | ||||||
| const CMD_PREFIX = '##['; |  | ||||||
| class Command { |  | ||||||
|     constructor(command, properties, message) { |  | ||||||
|         if (!command) { |  | ||||||
|             command = 'missing.command'; |  | ||||||
|         } |  | ||||||
|         this.command = command; |  | ||||||
|         this.properties = properties; |  | ||||||
|         this.message = message; |  | ||||||
|     } |  | ||||||
|     toString() { |  | ||||||
|         let cmdStr = CMD_PREFIX + this.command; |  | ||||||
|         if (this.properties && Object.keys(this.properties).length > 0) { |  | ||||||
|             cmdStr += ' '; |  | ||||||
|             for (const key in this.properties) { |  | ||||||
|                 if (this.properties.hasOwnProperty(key)) { |  | ||||||
|                     const val = this.properties[key]; |  | ||||||
|                     if (val) { |  | ||||||
|                         // safely append the val - avoid blowing up when attempting to |  | ||||||
|                         // call .replace() if message is not a string for some reason |  | ||||||
|                         cmdStr += `${key}=${escape(`${val || ''}`)};`; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         cmdStr += ']'; |  | ||||||
|         // safely append the message - avoid blowing up when attempting to |  | ||||||
|         // call .replace() if message is not a string for some reason |  | ||||||
|         const message = `${this.message || ''}`; |  | ||||||
|         cmdStr += escapeData(message); |  | ||||||
|         return cmdStr; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| function escapeData(s) { |  | ||||||
|     return s.replace(/\r/g, '%0D').replace(/\n/g, '%0A'); |  | ||||||
| } |  | ||||||
| function escape(s) { |  | ||||||
|     return s |  | ||||||
|         .replace(/\r/g, '%0D') |  | ||||||
|         .replace(/\n/g, '%0A') |  | ||||||
|         .replace(/]/g, '%5D') |  | ||||||
|         .replace(/;/g, '%3B'); |  | ||||||
| } |  | ||||||
| //# sourceMappingURL=command.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/command.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"command.js","sourceRoot":"","sources":["../src/command.ts"],"names":[],"mappings":";;AAAA,yBAAwB;AAQxB;;;;;;;;;GASG;AACH,SAAgB,YAAY,CAC1B,OAAe,EACf,UAA6B,EAC7B,OAAe;IAEf,MAAM,GAAG,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAA;IACrD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,CAAA;AAC/C,CAAC;AAPD,oCAOC;AAED,SAAgB,KAAK,CAAC,IAAY,EAAE,UAAkB,EAAE;IACtD,YAAY,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACjC,CAAC;AAFD,sBAEC;AAED,MAAM,UAAU,GAAG,KAAK,CAAA;AAExB,MAAM,OAAO;IAKX,YAAY,OAAe,EAAE,UAA6B,EAAE,OAAe;QACzE,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,iBAAiB,CAAA;SAC5B;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,OAAO,CAAA;QAEtC,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9D,MAAM,IAAI,GAAG,CAAA;YACb,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjC,IAAI,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;oBACvC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;oBAChC,IAAI,GAAG,EAAE;wBACP,8DAA8D;wBAC9D,6DAA6D;wBAC7D,MAAM,IAAI,GAAG,GAAG,IAAI,MAAM,CAAC,GAAG,GAAG,IAAI,EAAE,EAAE,CAAC,GAAG,CAAA;qBAC9C;iBACF;aACF;SACF;QAED,MAAM,IAAI,GAAG,CAAA;QAEb,kEAAkE;QAClE,6DAA6D;QAC7D,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,CAAA;QACvC,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,CAAA;QAE7B,OAAO,MAAM,CAAA;IACf,CAAC;CACF;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;AACtD,CAAC;AAED,SAAS,MAAM,CAAC,CAAS;IACvB,OAAO,CAAC;SACL,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC;SACrB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;AACzB,CAAC"} |  | ||||||
							
								
								
									
										94
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										94
									
								
								node_modules/@actions/core/lib/core.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,94 +0,0 @@ | |||||||
| /** |  | ||||||
|  * Interface for getInput options |  | ||||||
|  */ |  | ||||||
| export interface InputOptions { |  | ||||||
|     /** Optional. Whether the input is required. If required and not present, will throw. Defaults to false */ |  | ||||||
|     required?: boolean; |  | ||||||
| } |  | ||||||
| /** |  | ||||||
|  * The code to exit an action |  | ||||||
|  */ |  | ||||||
| export declare enum ExitCode { |  | ||||||
|     /** |  | ||||||
|      * A code indicating that the action was successful |  | ||||||
|      */ |  | ||||||
|     Success = 0, |  | ||||||
|     /** |  | ||||||
|      * A code indicating that the action was a failure |  | ||||||
|      */ |  | ||||||
|     Failure = 1 |  | ||||||
| } |  | ||||||
| /** |  | ||||||
|  * sets env variable for this action and future actions in the job |  | ||||||
|  * @param name the name of the variable to set |  | ||||||
|  * @param val the value of the variable |  | ||||||
|  */ |  | ||||||
| export declare function exportVariable(name: string, val: string): void; |  | ||||||
| /** |  | ||||||
|  * exports the variable and registers a secret which will get masked from logs |  | ||||||
|  * @param name the name of the variable to set |  | ||||||
|  * @param val value of the secret |  | ||||||
|  */ |  | ||||||
| export declare function exportSecret(name: string, val: string): void; |  | ||||||
| /** |  | ||||||
|  * Prepends inputPath to the PATH (for this action and future actions) |  | ||||||
|  * @param inputPath |  | ||||||
|  */ |  | ||||||
| export declare function addPath(inputPath: string): void; |  | ||||||
| /** |  | ||||||
|  * Gets the value of an input.  The value is also trimmed. |  | ||||||
|  * |  | ||||||
|  * @param     name     name of the input to get |  | ||||||
|  * @param     options  optional. See InputOptions. |  | ||||||
|  * @returns   string |  | ||||||
|  */ |  | ||||||
| export declare function getInput(name: string, options?: InputOptions): string; |  | ||||||
| /** |  | ||||||
|  * Sets the value of an output. |  | ||||||
|  * |  | ||||||
|  * @param     name     name of the output to set |  | ||||||
|  * @param     value    value to store |  | ||||||
|  */ |  | ||||||
| export declare function setOutput(name: string, value: string): void; |  | ||||||
| /** |  | ||||||
|  * Sets the action status to failed. |  | ||||||
|  * When the action exits it will be with an exit code of 1 |  | ||||||
|  * @param message add error issue message |  | ||||||
|  */ |  | ||||||
| export declare function setFailed(message: string): void; |  | ||||||
| /** |  | ||||||
|  * Writes debug message to user log |  | ||||||
|  * @param message debug message |  | ||||||
|  */ |  | ||||||
| export declare function debug(message: string): void; |  | ||||||
| /** |  | ||||||
|  * Adds an error issue |  | ||||||
|  * @param message error issue message |  | ||||||
|  */ |  | ||||||
| export declare function error(message: string): void; |  | ||||||
| /** |  | ||||||
|  * Adds an warning issue |  | ||||||
|  * @param message warning issue message |  | ||||||
|  */ |  | ||||||
| export declare function warning(message: string): void; |  | ||||||
| /** |  | ||||||
|  * Begin an output group. |  | ||||||
|  * |  | ||||||
|  * Output until the next `groupEnd` will be foldable in this group |  | ||||||
|  * |  | ||||||
|  * @param name The name of the output group |  | ||||||
|  */ |  | ||||||
| export declare function startGroup(name: string): void; |  | ||||||
| /** |  | ||||||
|  * End an output group. |  | ||||||
|  */ |  | ||||||
| export declare function endGroup(): void; |  | ||||||
| /** |  | ||||||
|  * Wrap an asynchronous function call in a group. |  | ||||||
|  * |  | ||||||
|  * Returns the same type as the function itself. |  | ||||||
|  * |  | ||||||
|  * @param name The name of the group |  | ||||||
|  * @param fn The function to wrap in the group |  | ||||||
|  */ |  | ||||||
| export declare function group<T>(name: string, fn: () => Promise<T>): Promise<T>; |  | ||||||
							
								
								
									
										168
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										168
									
								
								node_modules/@actions/core/lib/core.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,168 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { |  | ||||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } |  | ||||||
|     return new (P || (P = Promise))(function (resolve, reject) { |  | ||||||
|         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } |  | ||||||
|         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } |  | ||||||
|         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } |  | ||||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); |  | ||||||
|     }); |  | ||||||
| }; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const command_1 = require("./command"); |  | ||||||
| const path = require("path"); |  | ||||||
| /** |  | ||||||
|  * The code to exit an action |  | ||||||
|  */ |  | ||||||
| var ExitCode; |  | ||||||
| (function (ExitCode) { |  | ||||||
|     /** |  | ||||||
|      * A code indicating that the action was successful |  | ||||||
|      */ |  | ||||||
|     ExitCode[ExitCode["Success"] = 0] = "Success"; |  | ||||||
|     /** |  | ||||||
|      * A code indicating that the action was a failure |  | ||||||
|      */ |  | ||||||
|     ExitCode[ExitCode["Failure"] = 1] = "Failure"; |  | ||||||
| })(ExitCode = exports.ExitCode || (exports.ExitCode = {})); |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| // Variables |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| /** |  | ||||||
|  * sets env variable for this action and future actions in the job |  | ||||||
|  * @param name the name of the variable to set |  | ||||||
|  * @param val the value of the variable |  | ||||||
|  */ |  | ||||||
| function exportVariable(name, val) { |  | ||||||
|     process.env[name] = val; |  | ||||||
|     command_1.issueCommand('set-env', { name }, val); |  | ||||||
| } |  | ||||||
| exports.exportVariable = exportVariable; |  | ||||||
| /** |  | ||||||
|  * exports the variable and registers a secret which will get masked from logs |  | ||||||
|  * @param name the name of the variable to set |  | ||||||
|  * @param val value of the secret |  | ||||||
|  */ |  | ||||||
| function exportSecret(name, val) { |  | ||||||
|     exportVariable(name, val); |  | ||||||
|     // the runner will error with not implemented |  | ||||||
|     // leaving the function but raising the error earlier |  | ||||||
|     command_1.issueCommand('set-secret', {}, val); |  | ||||||
|     throw new Error('Not implemented.'); |  | ||||||
| } |  | ||||||
| exports.exportSecret = exportSecret; |  | ||||||
| /** |  | ||||||
|  * Prepends inputPath to the PATH (for this action and future actions) |  | ||||||
|  * @param inputPath |  | ||||||
|  */ |  | ||||||
| function addPath(inputPath) { |  | ||||||
|     command_1.issueCommand('add-path', {}, inputPath); |  | ||||||
|     process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`; |  | ||||||
| } |  | ||||||
| exports.addPath = addPath; |  | ||||||
| /** |  | ||||||
|  * Gets the value of an input.  The value is also trimmed. |  | ||||||
|  * |  | ||||||
|  * @param     name     name of the input to get |  | ||||||
|  * @param     options  optional. See InputOptions. |  | ||||||
|  * @returns   string |  | ||||||
|  */ |  | ||||||
| function getInput(name, options) { |  | ||||||
|     const val = process.env[`INPUT_${name.replace(' ', '_').toUpperCase()}`] || ''; |  | ||||||
|     if (options && options.required && !val) { |  | ||||||
|         throw new Error(`Input required and not supplied: ${name}`); |  | ||||||
|     } |  | ||||||
|     return val.trim(); |  | ||||||
| } |  | ||||||
| exports.getInput = getInput; |  | ||||||
| /** |  | ||||||
|  * Sets the value of an output. |  | ||||||
|  * |  | ||||||
|  * @param     name     name of the output to set |  | ||||||
|  * @param     value    value to store |  | ||||||
|  */ |  | ||||||
| function setOutput(name, value) { |  | ||||||
|     command_1.issueCommand('set-output', { name }, value); |  | ||||||
| } |  | ||||||
| exports.setOutput = setOutput; |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| // Results |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| /** |  | ||||||
|  * Sets the action status to failed. |  | ||||||
|  * When the action exits it will be with an exit code of 1 |  | ||||||
|  * @param message add error issue message |  | ||||||
|  */ |  | ||||||
| function setFailed(message) { |  | ||||||
|     process.exitCode = ExitCode.Failure; |  | ||||||
|     error(message); |  | ||||||
| } |  | ||||||
| exports.setFailed = setFailed; |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| // Logging Commands |  | ||||||
| //----------------------------------------------------------------------- |  | ||||||
| /** |  | ||||||
|  * Writes debug message to user log |  | ||||||
|  * @param message debug message |  | ||||||
|  */ |  | ||||||
| function debug(message) { |  | ||||||
|     command_1.issueCommand('debug', {}, message); |  | ||||||
| } |  | ||||||
| exports.debug = debug; |  | ||||||
| /** |  | ||||||
|  * Adds an error issue |  | ||||||
|  * @param message error issue message |  | ||||||
|  */ |  | ||||||
| function error(message) { |  | ||||||
|     command_1.issue('error', message); |  | ||||||
| } |  | ||||||
| exports.error = error; |  | ||||||
| /** |  | ||||||
|  * Adds an warning issue |  | ||||||
|  * @param message warning issue message |  | ||||||
|  */ |  | ||||||
| function warning(message) { |  | ||||||
|     command_1.issue('warning', message); |  | ||||||
| } |  | ||||||
| exports.warning = warning; |  | ||||||
| /** |  | ||||||
|  * Begin an output group. |  | ||||||
|  * |  | ||||||
|  * Output until the next `groupEnd` will be foldable in this group |  | ||||||
|  * |  | ||||||
|  * @param name The name of the output group |  | ||||||
|  */ |  | ||||||
| function startGroup(name) { |  | ||||||
|     command_1.issue('group', name); |  | ||||||
| } |  | ||||||
| exports.startGroup = startGroup; |  | ||||||
| /** |  | ||||||
|  * End an output group. |  | ||||||
|  */ |  | ||||||
| function endGroup() { |  | ||||||
|     command_1.issue('endgroup'); |  | ||||||
| } |  | ||||||
| exports.endGroup = endGroup; |  | ||||||
| /** |  | ||||||
|  * Wrap an asynchronous function call in a group. |  | ||||||
|  * |  | ||||||
|  * Returns the same type as the function itself. |  | ||||||
|  * |  | ||||||
|  * @param name The name of the group |  | ||||||
|  * @param fn The function to wrap in the group |  | ||||||
|  */ |  | ||||||
| function group(name, fn) { |  | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |  | ||||||
|         startGroup(name); |  | ||||||
|         let result; |  | ||||||
|         try { |  | ||||||
|             result = yield fn(); |  | ||||||
|         } |  | ||||||
|         finally { |  | ||||||
|             endGroup(); |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| exports.group = group; |  | ||||||
| //# sourceMappingURL=core.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/core/lib/core.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"core.js","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,uCAA6C;AAE7C,6BAA4B;AAU5B;;GAEG;AACH,IAAY,QAUX;AAVD,WAAY,QAAQ;IAClB;;OAEG;IACH,6CAAW,CAAA;IAEX;;OAEG;IACH,6CAAW,CAAA;AACb,CAAC,EAVW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAUnB;AAED,yEAAyE;AACzE,YAAY;AACZ,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,cAAc,CAAC,IAAY,EAAE,GAAW;IACtD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,CAAA;IACvB,sBAAY,CAAC,SAAS,EAAE,EAAC,IAAI,EAAC,EAAE,GAAG,CAAC,CAAA;AACtC,CAAC;AAHD,wCAGC;AAED;;;;GAIG;AACH,SAAgB,YAAY,CAAC,IAAY,EAAE,GAAW;IACpD,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;IAEzB,6CAA6C;IAC7C,qDAAqD;IACrD,sBAAY,CAAC,YAAY,EAAE,EAAE,EAAE,GAAG,CAAC,CAAA;IACnC,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;AACrC,CAAC;AAPD,oCAOC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,SAAiB;IACvC,sBAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;IACvC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAA;AAC7E,CAAC;AAHD,0BAGC;AAED;;;;;;GAMG;AACH,SAAgB,QAAQ,CAAC,IAAY,EAAE,OAAsB;IAC3D,MAAM,GAAG,GACP,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,IAAI,EAAE,CAAA;IACpE,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,GAAG,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,oCAAoC,IAAI,EAAE,CAAC,CAAA;KAC5D;IAED,OAAO,GAAG,CAAC,IAAI,EAAE,CAAA;AACnB,CAAC;AARD,4BAQC;AAED;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,IAAY,EAAE,KAAa;IACnD,sBAAY,CAAC,YAAY,EAAE,EAAC,IAAI,EAAC,EAAE,KAAK,CAAC,CAAA;AAC3C,CAAC;AAFD,8BAEC;AAED,yEAAyE;AACzE,UAAU;AACV,yEAAyE;AAEzE;;;;GAIG;AACH,SAAgB,SAAS,CAAC,OAAe;IACvC,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAA;IACnC,KAAK,CAAC,OAAO,CAAC,CAAA;AAChB,CAAC;AAHD,8BAGC;AAED,yEAAyE;AACzE,mBAAmB;AACnB,yEAAyE;AAEzE;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,sBAAY,CAAC,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,CAAA;AACpC,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,KAAK,CAAC,OAAe;IACnC,eAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;AACzB,CAAC;AAFD,sBAEC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,OAAe;IACrC,eAAK,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;AAC3B,CAAC;AAFD,0BAEC;AAED;;;;;;GAMG;AACH,SAAgB,UAAU,CAAC,IAAY;IACrC,eAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;AACtB,CAAC;AAFD,gCAEC;AAED;;GAEG;AACH,SAAgB,QAAQ;IACtB,eAAK,CAAC,UAAU,CAAC,CAAA;AACnB,CAAC;AAFD,4BAEC;AAED;;;;;;;GAOG;AACH,SAAsB,KAAK,CAAI,IAAY,EAAE,EAAoB;;QAC/D,UAAU,CAAC,IAAI,CAAC,CAAA;QAEhB,IAAI,MAAS,CAAA;QAEb,IAAI;YACF,MAAM,GAAG,MAAM,EAAE,EAAE,CAAA;SACpB;gBAAS;YACR,QAAQ,EAAE,CAAA;SACX;QAED,OAAO,MAAM,CAAA;IACf,CAAC;CAAA;AAZD,sBAYC"} |  | ||||||
							
								
								
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										67
									
								
								node_modules/@actions/core/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,67 +0,0 @@ | |||||||
| { |  | ||||||
|   "_args": [ |  | ||||||
|     [ |  | ||||||
|       "@actions/core@1.1.0", |  | ||||||
|       "/Users/dougtangren/code/rust/action-gh-release" |  | ||||||
|     ] |  | ||||||
|   ], |  | ||||||
|   "_from": "@actions/core@1.1.0", |  | ||||||
|   "_id": "@actions/core@1.1.0", |  | ||||||
|   "_inBundle": false, |  | ||||||
|   "_integrity": "sha512-KKpo3xzo0Zsikni9tbOsEQkxZBGDsYSJZNkTvmo0gPSXrc98TBOcdTvKwwjitjkjHkreTggWdB1ACiAFVgsuzA==", |  | ||||||
|   "_location": "/@actions/core", |  | ||||||
|   "_phantomChildren": {}, |  | ||||||
|   "_requested": { |  | ||||||
|     "type": "version", |  | ||||||
|     "registry": true, |  | ||||||
|     "raw": "@actions/core@1.1.0", |  | ||||||
|     "name": "@actions/core", |  | ||||||
|     "escapedName": "@actions%2fcore", |  | ||||||
|     "scope": "@actions", |  | ||||||
|     "rawSpec": "1.1.0", |  | ||||||
|     "saveSpec": null, |  | ||||||
|     "fetchSpec": "1.1.0" |  | ||||||
|   }, |  | ||||||
|   "_requiredBy": [ |  | ||||||
|     "/" |  | ||||||
|   ], |  | ||||||
|   "_resolved": "https://registry.npmjs.org/@actions/core/-/core-1.1.0.tgz", |  | ||||||
|   "_spec": "1.1.0", |  | ||||||
|   "_where": "/Users/dougtangren/code/rust/action-gh-release", |  | ||||||
|   "bugs": { |  | ||||||
|     "url": "https://github.com/actions/toolkit/issues" |  | ||||||
|   }, |  | ||||||
|   "description": "Actions core lib", |  | ||||||
|   "devDependencies": { |  | ||||||
|     "@types/node": "^12.0.2" |  | ||||||
|   }, |  | ||||||
|   "directories": { |  | ||||||
|     "lib": "lib", |  | ||||||
|     "test": "__tests__" |  | ||||||
|   }, |  | ||||||
|   "files": [ |  | ||||||
|     "lib" |  | ||||||
|   ], |  | ||||||
|   "gitHead": "a2ab4bcf78e4f7080f0d45856e6eeba16f0bbc52", |  | ||||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/core", |  | ||||||
|   "keywords": [ |  | ||||||
|     "github", |  | ||||||
|     "actions", |  | ||||||
|     "core" |  | ||||||
|   ], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "main": "lib/core.js", |  | ||||||
|   "name": "@actions/core", |  | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   }, |  | ||||||
|   "repository": { |  | ||||||
|     "type": "git", |  | ||||||
|     "url": "git+https://github.com/actions/toolkit.git" |  | ||||||
|   }, |  | ||||||
|   "scripts": { |  | ||||||
|     "test": "echo \"Error: run tests from root\" && exit 1", |  | ||||||
|     "tsc": "tsc" |  | ||||||
|   }, |  | ||||||
|   "version": "1.1.0" |  | ||||||
| } |  | ||||||
							
								
								
									
										7
									
								
								node_modules/@actions/github/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								node_modules/@actions/github/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,7 +0,0 @@ | |||||||
| Copyright 2019 GitHub |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |  | ||||||
							
								
								
									
										50
									
								
								node_modules/@actions/github/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										50
									
								
								node_modules/@actions/github/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,50 +0,0 @@ | |||||||
| # `@actions/github` |  | ||||||
|  |  | ||||||
| > A hydrated Octokit client. |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| Returns an Octokit client. See https://octokit.github.io/rest.js for the API. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const github = require('@actions/github'); |  | ||||||
| const core = require('@actions/core'); |  | ||||||
|  |  | ||||||
| // This should be a token with access to your repository scoped in as a secret. |  | ||||||
| const myToken = core.getInput('myToken'); |  | ||||||
|  |  | ||||||
| const octokit = new github.GitHub(myToken); |  | ||||||
|  |  | ||||||
| const { data: pullRequest } = await octokit.pulls.get({ |  | ||||||
|     owner: 'octokit', |  | ||||||
|     repo: 'rest.js', |  | ||||||
|     pull_number: 123, |  | ||||||
|     mediaType: { |  | ||||||
|       format: 'diff' |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| console.log(pullRequest); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| You can pass client options (except `auth`, which is handled by the token argument), as specified by [Octokit](https://octokit.github.io/rest.js/), as a second argument to the `GitHub` constructor. |  | ||||||
|  |  | ||||||
| You can also make GraphQL requests. See https://github.com/octokit/graphql.js for the API. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const result = await octokit.graphql(query, variables); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Finally, you can get the context of the current action: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const github = require('@actions/github'); |  | ||||||
|  |  | ||||||
| const context = github.context; |  | ||||||
|  |  | ||||||
| const newIssue = await octokit.issues.create({ |  | ||||||
|   ...context.repo, |  | ||||||
|   title: 'New issue!', |  | ||||||
|   body: 'Hello Universe!' |  | ||||||
| }); |  | ||||||
| ``` |  | ||||||
							
								
								
									
										26
									
								
								node_modules/@actions/github/lib/context.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								node_modules/@actions/github/lib/context.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,26 +0,0 @@ | |||||||
| import { WebhookPayload } from './interfaces'; |  | ||||||
| export declare class Context { |  | ||||||
|     /** |  | ||||||
|      * Webhook payload object that triggered the workflow |  | ||||||
|      */ |  | ||||||
|     payload: WebhookPayload; |  | ||||||
|     eventName: string; |  | ||||||
|     sha: string; |  | ||||||
|     ref: string; |  | ||||||
|     workflow: string; |  | ||||||
|     action: string; |  | ||||||
|     actor: string; |  | ||||||
|     /** |  | ||||||
|      * Hydrate the context from the environment |  | ||||||
|      */ |  | ||||||
|     constructor(); |  | ||||||
|     readonly issue: { |  | ||||||
|         owner: string; |  | ||||||
|         repo: string; |  | ||||||
|         number: number; |  | ||||||
|     }; |  | ||||||
|     readonly repo: { |  | ||||||
|         owner: string; |  | ||||||
|         repo: string; |  | ||||||
|     }; |  | ||||||
| } |  | ||||||
							
								
								
									
										45
									
								
								node_modules/@actions/github/lib/context.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								node_modules/@actions/github/lib/context.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,45 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| const fs_1 = require("fs"); |  | ||||||
| const os_1 = require("os"); |  | ||||||
| class Context { |  | ||||||
|     /** |  | ||||||
|      * Hydrate the context from the environment |  | ||||||
|      */ |  | ||||||
|     constructor() { |  | ||||||
|         this.payload = {}; |  | ||||||
|         if (process.env.GITHUB_EVENT_PATH) { |  | ||||||
|             if (fs_1.existsSync(process.env.GITHUB_EVENT_PATH)) { |  | ||||||
|                 this.payload = JSON.parse(fs_1.readFileSync(process.env.GITHUB_EVENT_PATH, { encoding: 'utf8' })); |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 process.stdout.write(`GITHUB_EVENT_PATH ${process.env.GITHUB_EVENT_PATH} does not exist${os_1.EOL}`); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         this.eventName = process.env.GITHUB_EVENT_NAME; |  | ||||||
|         this.sha = process.env.GITHUB_SHA; |  | ||||||
|         this.ref = process.env.GITHUB_REF; |  | ||||||
|         this.workflow = process.env.GITHUB_WORKFLOW; |  | ||||||
|         this.action = process.env.GITHUB_ACTION; |  | ||||||
|         this.actor = process.env.GITHUB_ACTOR; |  | ||||||
|     } |  | ||||||
|     get issue() { |  | ||||||
|         const payload = this.payload; |  | ||||||
|         return Object.assign(Object.assign({}, this.repo), { number: (payload.issue || payload.pullRequest || payload).number }); |  | ||||||
|     } |  | ||||||
|     get repo() { |  | ||||||
|         if (process.env.GITHUB_REPOSITORY) { |  | ||||||
|             const [owner, repo] = process.env.GITHUB_REPOSITORY.split('/'); |  | ||||||
|             return { owner, repo }; |  | ||||||
|         } |  | ||||||
|         if (this.payload.repository) { |  | ||||||
|             return { |  | ||||||
|                 owner: this.payload.repository.owner.login, |  | ||||||
|                 repo: this.payload.repository.name |  | ||||||
|             }; |  | ||||||
|         } |  | ||||||
|         throw new Error("context.repo requires a GITHUB_REPOSITORY environment variable like 'owner/repo'"); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| exports.Context = Context; |  | ||||||
| //# sourceMappingURL=context.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/github/lib/context.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/github/lib/context.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":";;AAEA,2BAA2C;AAC3C,2BAAsB;AAEtB,MAAa,OAAO;IAalB;;OAEG;IACH;QACE,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;QACjB,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE;YACjC,IAAI,eAAU,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,EAAE;gBAC7C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CACvB,iBAAY,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,EAAC,QAAQ,EAAE,MAAM,EAAC,CAAC,CAChE,CAAA;aACF;iBAAM;gBACL,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,qBACE,OAAO,CAAC,GAAG,CAAC,iBACd,kBAAkB,QAAG,EAAE,CACxB,CAAA;aACF;SACF;QACD,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,iBAA2B,CAAA;QACxD,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,UAAoB,CAAA;QAC3C,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,UAAoB,CAAA;QAC3C,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,eAAyB,CAAA;QACrD,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,aAAuB,CAAA;QACjD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,YAAsB,CAAA;IACjD,CAAC;IAED,IAAI,KAAK;QACP,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;QAE5B,uCACK,IAAI,CAAC,IAAI,KACZ,MAAM,EAAE,CAAC,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,CAAC,MAAM,IACjE;IACH,CAAC;IAED,IAAI,IAAI;QACN,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE;YACjC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAC9D,OAAO,EAAC,KAAK,EAAE,IAAI,EAAC,CAAA;SACrB;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;YAC3B,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK;gBAC1C,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI;aACnC,CAAA;SACF;QAED,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAA;IACH,CAAC;CACF;AAjED,0BAiEC"} |  | ||||||
							
								
								
									
										8
									
								
								node_modules/@actions/github/lib/github.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								node_modules/@actions/github/lib/github.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| import { GraphQlQueryResponse, Variables } from '@octokit/graphql'; |  | ||||||
| import Octokit from '@octokit/rest'; |  | ||||||
| import * as Context from './context'; |  | ||||||
| export declare const context: Context.Context; |  | ||||||
| export declare class GitHub extends Octokit { |  | ||||||
|     graphql: (query: string, variables?: Variables) => Promise<GraphQlQueryResponse>; |  | ||||||
|     constructor(token: string, opts?: Omit<Octokit.Options, 'auth'>); |  | ||||||
| } |  | ||||||
							
								
								
									
										29
									
								
								node_modules/@actions/github/lib/github.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										29
									
								
								node_modules/@actions/github/lib/github.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,29 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| var __importDefault = (this && this.__importDefault) || function (mod) { |  | ||||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; |  | ||||||
| }; |  | ||||||
| var __importStar = (this && this.__importStar) || function (mod) { |  | ||||||
|     if (mod && mod.__esModule) return mod; |  | ||||||
|     var result = {}; |  | ||||||
|     if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; |  | ||||||
|     result["default"] = mod; |  | ||||||
|     return result; |  | ||||||
| }; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| // Originally pulled from https://github.com/JasonEtco/actions-toolkit/blob/master/src/github.ts |  | ||||||
| const graphql_1 = require("@octokit/graphql"); |  | ||||||
| const rest_1 = __importDefault(require("@octokit/rest")); |  | ||||||
| const Context = __importStar(require("./context")); |  | ||||||
| // We need this in order to extend Octokit |  | ||||||
| rest_1.default.prototype = new rest_1.default(); |  | ||||||
| exports.context = new Context.Context(); |  | ||||||
| class GitHub extends rest_1.default { |  | ||||||
|     constructor(token, opts = {}) { |  | ||||||
|         super(Object.assign(Object.assign({}, opts), { auth: `token ${token}` })); |  | ||||||
|         this.graphql = graphql_1.defaults({ |  | ||||||
|             headers: { authorization: `token ${token}` } |  | ||||||
|         }); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| exports.GitHub = GitHub; |  | ||||||
| //# sourceMappingURL=github.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/github/lib/github.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/github/lib/github.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"github.js","sourceRoot":"","sources":["../src/github.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gGAAgG;AAChG,8CAA0E;AAC1E,yDAAmC;AACnC,mDAAoC;AAEpC,0CAA0C;AAC1C,cAAO,CAAC,SAAS,GAAG,IAAI,cAAO,EAAE,CAAA;AAEpB,QAAA,OAAO,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,CAAA;AAE5C,MAAa,MAAO,SAAQ,cAAO;IAMjC,YAAY,KAAa,EAAE,OAAsC,EAAE;QACjE,KAAK,iCAAK,IAAI,KAAE,IAAI,EAAE,SAAS,KAAK,EAAE,IAAE,CAAA;QACxC,IAAI,CAAC,OAAO,GAAG,kBAAQ,CAAC;YACtB,OAAO,EAAE,EAAC,aAAa,EAAE,SAAS,KAAK,EAAE,EAAC;SAC3C,CAAC,CAAA;IACJ,CAAC;CACF;AAZD,wBAYC"} |  | ||||||
							
								
								
									
										36
									
								
								node_modules/@actions/github/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										36
									
								
								node_modules/@actions/github/lib/interfaces.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,36 +0,0 @@ | |||||||
| export interface PayloadRepository { |  | ||||||
|     [key: string]: any; |  | ||||||
|     full_name?: string; |  | ||||||
|     name: string; |  | ||||||
|     owner: { |  | ||||||
|         [key: string]: any; |  | ||||||
|         login: string; |  | ||||||
|         name?: string; |  | ||||||
|     }; |  | ||||||
|     html_url?: string; |  | ||||||
| } |  | ||||||
| export interface WebhookPayload { |  | ||||||
|     [key: string]: any; |  | ||||||
|     repository?: PayloadRepository; |  | ||||||
|     issue?: { |  | ||||||
|         [key: string]: any; |  | ||||||
|         number: number; |  | ||||||
|         html_url?: string; |  | ||||||
|         body?: string; |  | ||||||
|     }; |  | ||||||
|     pull_request?: { |  | ||||||
|         [key: string]: any; |  | ||||||
|         number: number; |  | ||||||
|         html_url?: string; |  | ||||||
|         body?: string; |  | ||||||
|     }; |  | ||||||
|     sender?: { |  | ||||||
|         [key: string]: any; |  | ||||||
|         type: string; |  | ||||||
|     }; |  | ||||||
|     action?: string; |  | ||||||
|     installation?: { |  | ||||||
|         id: number; |  | ||||||
|         [key: string]: any; |  | ||||||
|     }; |  | ||||||
| } |  | ||||||
							
								
								
									
										4
									
								
								node_modules/@actions/github/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								node_modules/@actions/github/lib/interfaces.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,4 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| /* eslint-disable @typescript-eslint/no-explicit-any */ |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| //# sourceMappingURL=interfaces.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@actions/github/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@actions/github/lib/interfaces.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../src/interfaces.ts"],"names":[],"mappings":";AAAA,uDAAuD"} |  | ||||||
							
								
								
									
										71
									
								
								node_modules/@actions/github/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										71
									
								
								node_modules/@actions/github/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,71 +0,0 @@ | |||||||
| { |  | ||||||
|   "_args": [ |  | ||||||
|     [ |  | ||||||
|       "@actions/github@1.1.0", |  | ||||||
|       "/Users/dougtangren/code/rust/action-gh-release" |  | ||||||
|     ] |  | ||||||
|   ], |  | ||||||
|   "_from": "@actions/github@1.1.0", |  | ||||||
|   "_id": "@actions/github@1.1.0", |  | ||||||
|   "_inBundle": false, |  | ||||||
|   "_integrity": "sha512-cHf6PyoNMdei13jEdGPhKprIMFmjVVW/dnM5/9QmQDJ1ZTaGVyezUSCUIC/ySNLRvDUpeFwPYMdThSEJldSbUw==", |  | ||||||
|   "_location": "/@actions/github", |  | ||||||
|   "_phantomChildren": {}, |  | ||||||
|   "_requested": { |  | ||||||
|     "type": "version", |  | ||||||
|     "registry": true, |  | ||||||
|     "raw": "@actions/github@1.1.0", |  | ||||||
|     "name": "@actions/github", |  | ||||||
|     "escapedName": "@actions%2fgithub", |  | ||||||
|     "scope": "@actions", |  | ||||||
|     "rawSpec": "1.1.0", |  | ||||||
|     "saveSpec": null, |  | ||||||
|     "fetchSpec": "1.1.0" |  | ||||||
|   }, |  | ||||||
|   "_requiredBy": [ |  | ||||||
|     "/" |  | ||||||
|   ], |  | ||||||
|   "_resolved": "https://registry.npmjs.org/@actions/github/-/github-1.1.0.tgz", |  | ||||||
|   "_spec": "1.1.0", |  | ||||||
|   "_where": "/Users/dougtangren/code/rust/action-gh-release", |  | ||||||
|   "bugs": { |  | ||||||
|     "url": "https://github.com/actions/toolkit/issues" |  | ||||||
|   }, |  | ||||||
|   "dependencies": { |  | ||||||
|     "@octokit/graphql": "^2.0.1", |  | ||||||
|     "@octokit/rest": "^16.15.0" |  | ||||||
|   }, |  | ||||||
|   "description": "Actions github lib", |  | ||||||
|   "devDependencies": { |  | ||||||
|     "jest": "^24.7.1" |  | ||||||
|   }, |  | ||||||
|   "directories": { |  | ||||||
|     "lib": "lib", |  | ||||||
|     "test": "__tests__" |  | ||||||
|   }, |  | ||||||
|   "files": [ |  | ||||||
|     "lib" |  | ||||||
|   ], |  | ||||||
|   "gitHead": "a2ab4bcf78e4f7080f0d45856e6eeba16f0bbc52", |  | ||||||
|   "homepage": "https://github.com/actions/toolkit/tree/master/packages/github", |  | ||||||
|   "keywords": [ |  | ||||||
|     "github", |  | ||||||
|     "actions" |  | ||||||
|   ], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "main": "lib/github.js", |  | ||||||
|   "name": "@actions/github", |  | ||||||
|   "publishConfig": { |  | ||||||
|     "access": "public" |  | ||||||
|   }, |  | ||||||
|   "repository": { |  | ||||||
|     "type": "git", |  | ||||||
|     "url": "git+https://github.com/actions/toolkit.git" |  | ||||||
|   }, |  | ||||||
|   "scripts": { |  | ||||||
|     "build": "tsc", |  | ||||||
|     "test": "jest", |  | ||||||
|     "tsc": "tsc" |  | ||||||
|   }, |  | ||||||
|   "version": "1.1.0" |  | ||||||
| } |  | ||||||
							
								
								
									
										21
									
								
								node_modules/@octokit/endpoint/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								node_modules/@octokit/endpoint/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| The MIT License |  | ||||||
|  |  | ||||||
| Copyright (c) 2018 Octokit contributors |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy |  | ||||||
| of this software and associated documentation files (the "Software"), to deal |  | ||||||
| in the Software without restriction, including without limitation the rights |  | ||||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |  | ||||||
| copies of the Software, and to permit persons to whom the Software is |  | ||||||
| furnished to do so, subject to the following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in |  | ||||||
| all copies or substantial portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |  | ||||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |  | ||||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |  | ||||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |  | ||||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |  | ||||||
| THE SOFTWARE. |  | ||||||
							
								
								
									
										421
									
								
								node_modules/@octokit/endpoint/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										421
									
								
								node_modules/@octokit/endpoint/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,421 +0,0 @@ | |||||||
| # endpoint.js |  | ||||||
|  |  | ||||||
| > Turns GitHub REST API endpoints into generic request options |  | ||||||
|  |  | ||||||
| [](https://www.npmjs.com/package/@octokit/endpoint) |  | ||||||
| [](https://travis-ci.org/octokit/endpoint.js) |  | ||||||
| [](https://greenkeeper.io/) |  | ||||||
|  |  | ||||||
| `@octokit/endpoint` combines [GitHub REST API routes](https://developer.github.com/v3/) with your parameters and turns them into generic request options that can be used in any request library. |  | ||||||
|  |  | ||||||
| <!-- update table of contents by running `npx markdown-toc README.md -i` --> |  | ||||||
| <!-- toc --> |  | ||||||
|  |  | ||||||
| - [Usage](#usage) |  | ||||||
| - [API](#api) |  | ||||||
|   - [endpoint()](#endpoint) |  | ||||||
|   - [endpoint.defaults()](#endpointdefaults) |  | ||||||
|   - [endpoint.DEFAULTS](#endpointdefaults) |  | ||||||
|   - [endpoint.merge()](#endpointmerge) |  | ||||||
|   - [endpoint.parse()](#endpointparse) |  | ||||||
| - [Special cases](#special-cases) |  | ||||||
|   - [The `data` parameter – set request body directly](#the-data-parameter-%E2%80%93-set-request-body-directly) |  | ||||||
|   - [Set parameters for both the URL/query and the request body](#set-parameters-for-both-the-urlquery-and-the-request-body) |  | ||||||
| - [LICENSE](#license) |  | ||||||
|  |  | ||||||
| <!-- tocstop --> |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| <table> |  | ||||||
| <tbody valign=top align=left> |  | ||||||
| <tr><th> |  | ||||||
| Browsers |  | ||||||
| </th><td width=100%> |  | ||||||
| Load <code>@octokit/endpoint</code> directly from <a href="https://cdn.pika.dev">cdn.pika.dev</a> |  | ||||||
|          |  | ||||||
| ```html |  | ||||||
| <script type="module"> |  | ||||||
| import { endpoint } from "https://cdn.pika.dev/@octokit/endpoint"; |  | ||||||
| </script> |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </td></tr> |  | ||||||
| <tr><th> |  | ||||||
| Node |  | ||||||
| </th><td> |  | ||||||
|  |  | ||||||
| Install with <code>npm install @octokit/endpoint</code> |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const { endpoint } = require("@octokit/endpoint"); |  | ||||||
| // or: import { endpoint } from "@octokit/endpoint"; |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </td></tr> |  | ||||||
| </tbody> |  | ||||||
| </table> |  | ||||||
|  |  | ||||||
| Example for [List organization repositories](https://developer.github.com/v3/repos/#list-organization-repositories) |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const requestOptions = endpoint("GET /orgs/:org/repos", { |  | ||||||
|   headers: { |  | ||||||
|     authorization: "token 0000000000000000000000000000000000000001" |  | ||||||
|   }, |  | ||||||
|   org: "octokit", |  | ||||||
|   type: "private" |  | ||||||
| }); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The resulting `requestOptions` looks as follows |  | ||||||
|  |  | ||||||
| ```json |  | ||||||
| { |  | ||||||
|   "method": "GET", |  | ||||||
|   "url": "https://api.github.com/orgs/octokit/repos?type=private", |  | ||||||
|   "headers": { |  | ||||||
|     "accept": "application/vnd.github.v3+json", |  | ||||||
|     "authorization": "token 0000000000000000000000000000000000000001", |  | ||||||
|     "user-agent": "octokit/endpoint.js v1.2.3" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| You can pass `requestOptions` to commen request libraries |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const { url, ...options } = requestOptions; |  | ||||||
| // using with fetch (https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API) |  | ||||||
| fetch(url, options); |  | ||||||
| // using with request (https://github.com/request/request) |  | ||||||
| request(requestOptions); |  | ||||||
| // using with got (https://github.com/sindresorhus/got) |  | ||||||
| got[options.method](url, options); |  | ||||||
| // using with axios |  | ||||||
| axios(requestOptions); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## API |  | ||||||
|  |  | ||||||
| ### `endpoint(route, options)` or `endpoint(options)` |  | ||||||
|  |  | ||||||
| <table> |  | ||||||
|   <thead align=left> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         name |  | ||||||
|       </th> |  | ||||||
|       <th> |  | ||||||
|         type |  | ||||||
|       </th> |  | ||||||
|       <th width=100%> |  | ||||||
|         description |  | ||||||
|       </th> |  | ||||||
|     </tr> |  | ||||||
|   </thead> |  | ||||||
|   <tbody align=left valign=top> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>route</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         String |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         If set, it has to be a string consisting of URL and the request method, e.g., <code>GET /orgs/:org</code>. If it’s set to a URL, only the method defaults to <code>GET</code>. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.method</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         String |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         <strong>Required unless <code>route</code> is set.</strong> Any supported <a href="https://developer.github.com/v3/#http-verbs">http verb</a>. <em>Defaults to <code>GET</code></em>. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.url</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         String |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         <strong>Required unless <code>route</code> is set.</strong> A path or full URL which may contain <code>:variable</code> or <code>{variable}</code> placeholders, |  | ||||||
|         e.g., <code>/orgs/:org/repos</code>. The <code>url</code> is parsed using <a href="https://github.com/bramstein/url-template">url-template</a>. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.baseUrl</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         String |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         <em>Defaults to <code>https://api.github.com</code></em>. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.headers</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         Object |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         Custom headers. Passed headers are merged with defaults:<br> |  | ||||||
|         <em><code>headers['user-agent']</code> defaults to <code>octokit-endpoint.js/1.2.3</code> (where <code>1.2.3</code> is the released version)</em>.<br> |  | ||||||
|         <em><code>headers['accept']</code> defaults to <code>application/vnd.github.v3+json</code></em>.<br> |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.mediaType.format</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         String |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         Media type param, such as <code>raw</code>, <code>diff</code>, or <code>text+json</code>. See <a href="https://developer.github.com/v3/media/">Media Types</a>. Setting <code>options.mediaType.format</code> will amend the <code>headers.accept</code> value. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.mediaType.previews</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         Array of Strings |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         Name of previews, such as <code>mercy</code>, <code>symmetra</code>, or <code>scarlet-witch</code>. See <a href="https://developer.github.com/v3/previews/">API Previews</a>. If <code>options.mediaType.previews</code> was set as default, the new previews will be merged into the default ones. Setting <code>options.mediaType.previews</code> will amend the <code>headers.accept</code> value. <code>options.mediaType.previews</code> will be merged with an existing array set using <code>.defaults()</code>. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.data</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         Any |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         Set request body directly instead of setting it to JSON based on additional parameters. See <a href="#data-parameter">"The <code>data</code> parameter"</a> below. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         <code>options.request</code> |  | ||||||
|       </th> |  | ||||||
|       <td> |  | ||||||
|         Object |  | ||||||
|       </td> |  | ||||||
|       <td> |  | ||||||
|         Pass custom meta information for the request. The <code>request</code> object will be returned as is. |  | ||||||
|       </td> |  | ||||||
|     </tr> |  | ||||||
|   </tbody> |  | ||||||
| </table> |  | ||||||
|  |  | ||||||
| All other options will be passed depending on the `method` and `url` options. |  | ||||||
|  |  | ||||||
| 1. If the option key has a placeholder in the `url`, it will be used as the replacement. For example, if the passed options are `{url: '/orgs/:org/repos', org: 'foo'}` the returned `options.url` is `https://api.github.com/orgs/foo/repos`. |  | ||||||
| 2. If the `method` is `GET` or `HEAD`, the option is passed as a query parameter. |  | ||||||
| 3. Otherwise, the parameter is passed in the request body as a JSON key. |  | ||||||
|  |  | ||||||
| **Result** |  | ||||||
|  |  | ||||||
| `endpoint()` is a synchronous method and returns an object with the following keys: |  | ||||||
|  |  | ||||||
| <table> |  | ||||||
|   <thead align=left> |  | ||||||
|     <tr> |  | ||||||
|       <th> |  | ||||||
|         key |  | ||||||
|       </th> |  | ||||||
|       <th> |  | ||||||
|         type |  | ||||||
|       </th> |  | ||||||
|       <th width=100%> |  | ||||||
|         description |  | ||||||
|       </th> |  | ||||||
|     </tr> |  | ||||||
|   </thead> |  | ||||||
|   <tbody align=left valign=top> |  | ||||||
|     <tr> |  | ||||||
|       <th><code>method</code></th> |  | ||||||
|       <td>String</td> |  | ||||||
|       <td>The http method. Always lowercase.</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th><code>url</code></th> |  | ||||||
|       <td>String</td> |  | ||||||
|       <td>The url with placeholders replaced with passed parameters.</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th><code>headers</code></th> |  | ||||||
|       <td>Object</td> |  | ||||||
|       <td>All header names are lowercased.</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th><code>body</code></th> |  | ||||||
|       <td>Any</td> |  | ||||||
|       <td>The request body if one is present. Only for <code>PATCH</code>, <code>POST</code>, <code>PUT</code>, <code>DELETE</code> requests.</td> |  | ||||||
|     </tr> |  | ||||||
|     <tr> |  | ||||||
|       <th><code>request</code></th> |  | ||||||
|       <td>Object</td> |  | ||||||
|       <td>Request meta option, it will be returned as it was passed into <code>endpoint()</code></td> |  | ||||||
|     </tr> |  | ||||||
|   </tbody> |  | ||||||
| </table> |  | ||||||
|  |  | ||||||
| ### `endpoint.defaults()` |  | ||||||
|  |  | ||||||
| Override or set default options. Example: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const request = require("request"); |  | ||||||
| const myEndpoint = require("@octokit/endpoint").defaults({ |  | ||||||
|   baseUrl: "https://github-enterprise.acme-inc.com/api/v3", |  | ||||||
|   headers: { |  | ||||||
|     "user-agent": "myApp/1.2.3", |  | ||||||
|     authorization: `token 0000000000000000000000000000000000000001` |  | ||||||
|   }, |  | ||||||
|   org: "my-project", |  | ||||||
|   per_page: 100 |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| request(myEndpoint(`GET /orgs/:org/repos`)); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| You can call `.defaults()` again on the returned method, the defaults will cascade. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const myProjectEndpoint = endpoint.defaults({ |  | ||||||
|   baseUrl: "https://github-enterprise.acme-inc.com/api/v3", |  | ||||||
|   headers: { |  | ||||||
|     "user-agent": "myApp/1.2.3" |  | ||||||
|   }, |  | ||||||
|   org: "my-project" |  | ||||||
| }); |  | ||||||
| const myProjectEndpointWithAuth = myProjectEndpoint.defaults({ |  | ||||||
|   headers: { |  | ||||||
|     authorization: `token 0000000000000000000000000000000000000001` |  | ||||||
|   } |  | ||||||
| }); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| `myProjectEndpointWithAuth` now defaults the `baseUrl`, `headers['user-agent']`, |  | ||||||
| `org` and `headers['authorization']` on top of `headers['accept']` that is set |  | ||||||
| by the global default. |  | ||||||
|  |  | ||||||
| ### `endpoint.DEFAULTS` |  | ||||||
|  |  | ||||||
| The current default options. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| endpoint.DEFAULTS.baseUrl; // https://api.github.com |  | ||||||
| const myEndpoint = endpoint.defaults({ |  | ||||||
|   baseUrl: "https://github-enterprise.acme-inc.com/api/v3" |  | ||||||
| }); |  | ||||||
| myEndpoint.DEFAULTS.baseUrl; // https://github-enterprise.acme-inc.com/api/v3 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### `endpoint.merge(route, options)` or `endpoint.merge(options)` |  | ||||||
|  |  | ||||||
| Get the defaulted endpoint options, but without parsing them into request options: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const myProjectEndpoint = endpoint.defaults({ |  | ||||||
|   baseUrl: "https://github-enterprise.acme-inc.com/api/v3", |  | ||||||
|   headers: { |  | ||||||
|     "user-agent": "myApp/1.2.3" |  | ||||||
|   }, |  | ||||||
|   org: "my-project" |  | ||||||
| }); |  | ||||||
| myProjectEndpoint.merge("GET /orgs/:org/repos", { |  | ||||||
|   headers: { |  | ||||||
|     authorization: `token 0000000000000000000000000000000000000001` |  | ||||||
|   }, |  | ||||||
|   org: "my-secret-project", |  | ||||||
|   type: "private" |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| // { |  | ||||||
| //   baseUrl: 'https://github-enterprise.acme-inc.com/api/v3', |  | ||||||
| //   method: 'GET', |  | ||||||
| //   url: '/orgs/:org/repos', |  | ||||||
| //   headers: { |  | ||||||
| //     accept: 'application/vnd.github.v3+json', |  | ||||||
| //     authorization: `token 0000000000000000000000000000000000000001`, |  | ||||||
| //     'user-agent': 'myApp/1.2.3' |  | ||||||
| //   }, |  | ||||||
| //   org: 'my-secret-project', |  | ||||||
| //   type: 'private' |  | ||||||
| // } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### `endpoint.parse()` |  | ||||||
|  |  | ||||||
| Stateless method to turn endpoint options into request options. Calling |  | ||||||
| `endpoint(options)` is the same as calling `endpoint.parse(endpoint.merge(options))`. |  | ||||||
|  |  | ||||||
| ## Special cases |  | ||||||
|  |  | ||||||
| <a name="data-parameter"></a> |  | ||||||
|  |  | ||||||
| ### The `data` parameter – set request body directly |  | ||||||
|  |  | ||||||
| Some endpoints such as [Render a Markdown document in raw mode](https://developer.github.com/v3/markdown/#render-a-markdown-document-in-raw-mode) don’t have parameters that are sent as request body keys, instead, the request body needs to be set directly. In these cases, set the `data` parameter. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const options = endpoint("POST /markdown/raw", { |  | ||||||
|   data: "Hello world github/linguist#1 **cool**, and #1!", |  | ||||||
|   headers: { |  | ||||||
|     accept: "text/html;charset=utf-8", |  | ||||||
|     "content-type": "text/plain" |  | ||||||
|   } |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| // options is |  | ||||||
| // { |  | ||||||
| //   method: 'post', |  | ||||||
| //   url: 'https://api.github.com/markdown/raw', |  | ||||||
| //   headers: { |  | ||||||
| //     accept: 'text/html;charset=utf-8', |  | ||||||
| //     'content-type': 'text/plain', |  | ||||||
| //     'user-agent': userAgent |  | ||||||
| //   }, |  | ||||||
| //   body: 'Hello world github/linguist#1 **cool**, and #1!' |  | ||||||
| // } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Set parameters for both the URL/query and the request body |  | ||||||
|  |  | ||||||
| There are API endpoints that accept both query parameters as well as a body. In that case, you need to add the query parameters as templates to `options.url`, as defined in the [RFC 6570 URI Template specification](https://tools.ietf.org/html/rfc6570). |  | ||||||
|  |  | ||||||
| Example |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| endpoint( |  | ||||||
|   "POST https://uploads.github.com/repos/octocat/Hello-World/releases/1/assets{?name,label}", |  | ||||||
|   { |  | ||||||
|     name: "example.zip", |  | ||||||
|     label: "short description", |  | ||||||
|     headers: { |  | ||||||
|       "content-type": "text/plain", |  | ||||||
|       "content-length": 14, |  | ||||||
|       authorization: `token 0000000000000000000000000000000000000001` |  | ||||||
|     }, |  | ||||||
|     data: "Hello, world!" |  | ||||||
|   } |  | ||||||
| ); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## LICENSE |  | ||||||
|  |  | ||||||
| [MIT](LICENSE) |  | ||||||
							
								
								
									
										377
									
								
								node_modules/@octokit/endpoint/dist-node/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										377
									
								
								node_modules/@octokit/endpoint/dist-node/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,377 +0,0 @@ | |||||||
| 'use strict'; |  | ||||||
|  |  | ||||||
| Object.defineProperty(exports, '__esModule', { value: true }); |  | ||||||
|  |  | ||||||
| function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } |  | ||||||
|  |  | ||||||
| var isPlainObject = _interopDefault(require('is-plain-object')); |  | ||||||
| var universalUserAgent = require('universal-user-agent'); |  | ||||||
|  |  | ||||||
| function lowercaseKeys(object) { |  | ||||||
|   if (!object) { |  | ||||||
|     return {}; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return Object.keys(object).reduce((newObj, key) => { |  | ||||||
|     newObj[key.toLowerCase()] = object[key]; |  | ||||||
|     return newObj; |  | ||||||
|   }, {}); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function mergeDeep(defaults, options) { |  | ||||||
|   const result = Object.assign({}, defaults); |  | ||||||
|   Object.keys(options).forEach(key => { |  | ||||||
|     if (isPlainObject(options[key])) { |  | ||||||
|       if (!(key in defaults)) Object.assign(result, { |  | ||||||
|         [key]: options[key] |  | ||||||
|       });else result[key] = mergeDeep(defaults[key], options[key]); |  | ||||||
|     } else { |  | ||||||
|       Object.assign(result, { |  | ||||||
|         [key]: options[key] |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|   }); |  | ||||||
|   return result; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function merge(defaults, route, options) { |  | ||||||
|   if (typeof route === "string") { |  | ||||||
|     let [method, url] = route.split(" "); |  | ||||||
|     options = Object.assign(url ? { |  | ||||||
|       method, |  | ||||||
|       url |  | ||||||
|     } : { |  | ||||||
|       url: method |  | ||||||
|     }, options); |  | ||||||
|   } else { |  | ||||||
|     options = route || {}; |  | ||||||
|   } // lowercase header names before merging with defaults to avoid duplicates |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   options.headers = lowercaseKeys(options.headers); |  | ||||||
|   const mergedOptions = mergeDeep(defaults || {}, options); // mediaType.previews arrays are merged, instead of overwritten |  | ||||||
|  |  | ||||||
|   if (defaults && defaults.mediaType.previews.length) { |  | ||||||
|     mergedOptions.mediaType.previews = defaults.mediaType.previews.filter(preview => !mergedOptions.mediaType.previews.includes(preview)).concat(mergedOptions.mediaType.previews); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   mergedOptions.mediaType.previews = mergedOptions.mediaType.previews.map(preview => preview.replace(/-preview/, "")); |  | ||||||
|   return mergedOptions; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function addQueryParameters(url, parameters) { |  | ||||||
|   const separator = /\?/.test(url) ? "&" : "?"; |  | ||||||
|   const names = Object.keys(parameters); |  | ||||||
|  |  | ||||||
|   if (names.length === 0) { |  | ||||||
|     return url; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return url + separator + names.map(name => { |  | ||||||
|     if (name === "q") { |  | ||||||
|       return "q=" + parameters.q.split("+").map(encodeURIComponent).join("+"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return `${name}=${encodeURIComponent(parameters[name])}`; |  | ||||||
|   }).join("&"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| const urlVariableRegex = /\{[^}]+\}/g; |  | ||||||
|  |  | ||||||
| function removeNonChars(variableName) { |  | ||||||
|   return variableName.replace(/^\W+|\W+$/g, "").split(/,/); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function extractUrlVariableNames(url) { |  | ||||||
|   const matches = url.match(urlVariableRegex); |  | ||||||
|  |  | ||||||
|   if (!matches) { |  | ||||||
|     return []; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function omit(object, keysToOmit) { |  | ||||||
|   return Object.keys(object).filter(option => !keysToOmit.includes(option)).reduce((obj, key) => { |  | ||||||
|     obj[key] = object[key]; |  | ||||||
|     return obj; |  | ||||||
|   }, {}); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Based on https://github.com/bramstein/url-template, licensed under BSD |  | ||||||
| // TODO: create separate package. |  | ||||||
| // |  | ||||||
| // Copyright (c) 2012-2014, Bram Stein |  | ||||||
| // All rights reserved. |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions |  | ||||||
| // are met: |  | ||||||
| //  1. Redistributions of source code must retain the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer. |  | ||||||
| //  2. Redistributions in binary form must reproduce the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer in the |  | ||||||
| //     documentation and/or other materials provided with the distribution. |  | ||||||
| //  3. The name of the author may not be used to endorse or promote products |  | ||||||
| //     derived from this software without specific prior written permission. |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED |  | ||||||
| // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |  | ||||||
| // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |  | ||||||
| // EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, |  | ||||||
| // INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |  | ||||||
| // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, |  | ||||||
| // EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
|  |  | ||||||
| /* istanbul ignore file */ |  | ||||||
| function encodeReserved(str) { |  | ||||||
|   return str.split(/(%[0-9A-Fa-f]{2})/g).map(function (part) { |  | ||||||
|     if (!/%[0-9A-Fa-f]/.test(part)) { |  | ||||||
|       part = encodeURI(part).replace(/%5B/g, "[").replace(/%5D/g, "]"); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return part; |  | ||||||
|   }).join(""); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function encodeUnreserved(str) { |  | ||||||
|   return encodeURIComponent(str).replace(/[!'()*]/g, function (c) { |  | ||||||
|     return "%" + c.charCodeAt(0).toString(16).toUpperCase(); |  | ||||||
|   }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function encodeValue(operator, value, key) { |  | ||||||
|   value = operator === "+" || operator === "#" ? encodeReserved(value) : encodeUnreserved(value); |  | ||||||
|  |  | ||||||
|   if (key) { |  | ||||||
|     return encodeUnreserved(key) + "=" + value; |  | ||||||
|   } else { |  | ||||||
|     return value; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function isDefined(value) { |  | ||||||
|   return value !== undefined && value !== null; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function isKeyOperator(operator) { |  | ||||||
|   return operator === ";" || operator === "&" || operator === "?"; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function getValues(context, operator, key, modifier) { |  | ||||||
|   var value = context[key], |  | ||||||
|       result = []; |  | ||||||
|  |  | ||||||
|   if (isDefined(value) && value !== "") { |  | ||||||
|     if (typeof value === "string" || typeof value === "number" || typeof value === "boolean") { |  | ||||||
|       value = value.toString(); |  | ||||||
|  |  | ||||||
|       if (modifier && modifier !== "*") { |  | ||||||
|         value = value.substring(0, parseInt(modifier, 10)); |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|     } else { |  | ||||||
|       if (modifier === "*") { |  | ||||||
|         if (Array.isArray(value)) { |  | ||||||
|           value.filter(isDefined).forEach(function (value) { |  | ||||||
|             result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|           }); |  | ||||||
|         } else { |  | ||||||
|           Object.keys(value).forEach(function (k) { |  | ||||||
|             if (isDefined(value[k])) { |  | ||||||
|               result.push(encodeValue(operator, value[k], k)); |  | ||||||
|             } |  | ||||||
|           }); |  | ||||||
|         } |  | ||||||
|       } else { |  | ||||||
|         const tmp = []; |  | ||||||
|  |  | ||||||
|         if (Array.isArray(value)) { |  | ||||||
|           value.filter(isDefined).forEach(function (value) { |  | ||||||
|             tmp.push(encodeValue(operator, value)); |  | ||||||
|           }); |  | ||||||
|         } else { |  | ||||||
|           Object.keys(value).forEach(function (k) { |  | ||||||
|             if (isDefined(value[k])) { |  | ||||||
|               tmp.push(encodeUnreserved(k)); |  | ||||||
|               tmp.push(encodeValue(operator, value[k].toString())); |  | ||||||
|             } |  | ||||||
|           }); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (isKeyOperator(operator)) { |  | ||||||
|           result.push(encodeUnreserved(key) + "=" + tmp.join(",")); |  | ||||||
|         } else if (tmp.length !== 0) { |  | ||||||
|           result.push(tmp.join(",")); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } else { |  | ||||||
|     if (operator === ";") { |  | ||||||
|       if (isDefined(value)) { |  | ||||||
|         result.push(encodeUnreserved(key)); |  | ||||||
|       } |  | ||||||
|     } else if (value === "" && (operator === "&" || operator === "?")) { |  | ||||||
|       result.push(encodeUnreserved(key) + "="); |  | ||||||
|     } else if (value === "") { |  | ||||||
|       result.push(""); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return result; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function parseUrl(template) { |  | ||||||
|   return { |  | ||||||
|     expand: expand.bind(null, template) |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function expand(template, context) { |  | ||||||
|   var operators = ["+", "#", ".", "/", ";", "?", "&"]; |  | ||||||
|   return template.replace(/\{([^\{\}]+)\}|([^\{\}]+)/g, function (_, expression, literal) { |  | ||||||
|     if (expression) { |  | ||||||
|       let operator = ""; |  | ||||||
|       const values = []; |  | ||||||
|  |  | ||||||
|       if (operators.indexOf(expression.charAt(0)) !== -1) { |  | ||||||
|         operator = expression.charAt(0); |  | ||||||
|         expression = expression.substr(1); |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       expression.split(/,/g).forEach(function (variable) { |  | ||||||
|         var tmp = /([^:\*]*)(?::(\d+)|(\*))?/.exec(variable); |  | ||||||
|         values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3])); |  | ||||||
|       }); |  | ||||||
|  |  | ||||||
|       if (operator && operator !== "+") { |  | ||||||
|         var separator = ","; |  | ||||||
|  |  | ||||||
|         if (operator === "?") { |  | ||||||
|           separator = "&"; |  | ||||||
|         } else if (operator !== "#") { |  | ||||||
|           separator = operator; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return (values.length !== 0 ? operator : "") + values.join(separator); |  | ||||||
|       } else { |  | ||||||
|         return values.join(","); |  | ||||||
|       } |  | ||||||
|     } else { |  | ||||||
|       return encodeReserved(literal); |  | ||||||
|     } |  | ||||||
|   }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function parse(options) { |  | ||||||
|   // https://fetch.spec.whatwg.org/#methods |  | ||||||
|   let method = options.method.toUpperCase(); // replace :varname with {varname} to make it RFC 6570 compatible |  | ||||||
|  |  | ||||||
|   let url = options.url.replace(/:([a-z]\w+)/g, "{+$1}"); |  | ||||||
|   let headers = Object.assign({}, options.headers); |  | ||||||
|   let body; |  | ||||||
|   let parameters = omit(options, ["method", "baseUrl", "url", "headers", "request", "mediaType"]); // extract variable names from URL to calculate remaining variables later |  | ||||||
|  |  | ||||||
|   const urlVariableNames = extractUrlVariableNames(url); |  | ||||||
|   url = parseUrl(url).expand(parameters); |  | ||||||
|  |  | ||||||
|   if (!/^http/.test(url)) { |  | ||||||
|     url = options.baseUrl + url; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   const omittedParameters = Object.keys(options).filter(option => urlVariableNames.includes(option)).concat("baseUrl"); |  | ||||||
|   const remainingParameters = omit(parameters, omittedParameters); |  | ||||||
|   const isBinaryRequset = /application\/octet-stream/i.test(headers.accept); |  | ||||||
|  |  | ||||||
|   if (!isBinaryRequset) { |  | ||||||
|     if (options.mediaType.format) { |  | ||||||
|       // e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw |  | ||||||
|       headers.accept = headers.accept.split(/,/).map(preview => preview.replace(/application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/, `application/vnd$1$2.${options.mediaType.format}`)).join(","); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (options.mediaType.previews.length) { |  | ||||||
|       const previewsFromAcceptHeader = headers.accept.match(/[\w-]+(?=-preview)/g) || []; |  | ||||||
|       headers.accept = previewsFromAcceptHeader.concat(options.mediaType.previews).map(preview => { |  | ||||||
|         const format = options.mediaType.format ? `.${options.mediaType.format}` : "+json"; |  | ||||||
|         return `application/vnd.github.${preview}-preview${format}`; |  | ||||||
|       }).join(","); |  | ||||||
|     } |  | ||||||
|   } // for GET/HEAD requests, set URL query parameters from remaining parameters |  | ||||||
|   // for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   if (["GET", "HEAD"].includes(method)) { |  | ||||||
|     url = addQueryParameters(url, remainingParameters); |  | ||||||
|   } else { |  | ||||||
|     if ("data" in remainingParameters) { |  | ||||||
|       body = remainingParameters.data; |  | ||||||
|     } else { |  | ||||||
|       if (Object.keys(remainingParameters).length) { |  | ||||||
|         body = remainingParameters; |  | ||||||
|       } else { |  | ||||||
|         headers["content-length"] = 0; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } // default content-type for JSON if body is set |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   if (!headers["content-type"] && typeof body !== "undefined") { |  | ||||||
|     headers["content-type"] = "application/json; charset=utf-8"; |  | ||||||
|   } // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body. |  | ||||||
|   // fetch does not allow to set `content-length` header, but we can set body to an empty string |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   if (["PATCH", "PUT"].includes(method) && typeof body === "undefined") { |  | ||||||
|     body = ""; |  | ||||||
|   } // Only return body/request keys if present |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   return Object.assign({ |  | ||||||
|     method, |  | ||||||
|     url, |  | ||||||
|     headers |  | ||||||
|   }, typeof body !== "undefined" ? { |  | ||||||
|     body |  | ||||||
|   } : null, options.request ? { |  | ||||||
|     request: options.request |  | ||||||
|   } : null); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function endpointWithDefaults(defaults, route, options) { |  | ||||||
|   return parse(merge(defaults, route, options)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function withDefaults(oldDefaults, newDefaults) { |  | ||||||
|   const DEFAULTS = merge(oldDefaults, newDefaults); |  | ||||||
|   const endpoint = endpointWithDefaults.bind(null, DEFAULTS); |  | ||||||
|   return Object.assign(endpoint, { |  | ||||||
|     DEFAULTS, |  | ||||||
|     defaults: withDefaults.bind(null, DEFAULTS), |  | ||||||
|     merge: merge.bind(null, DEFAULTS), |  | ||||||
|     parse |  | ||||||
|   }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| const VERSION = "0.0.0-development"; |  | ||||||
|  |  | ||||||
| const userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`; |  | ||||||
| const DEFAULTS = { |  | ||||||
|   method: "GET", |  | ||||||
|   baseUrl: "https://api.github.com", |  | ||||||
|   headers: { |  | ||||||
|     accept: "application/vnd.github.v3+json", |  | ||||||
|     "user-agent": userAgent |  | ||||||
|   }, |  | ||||||
|   mediaType: { |  | ||||||
|     format: "", |  | ||||||
|     previews: [] |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| const endpoint = withDefaults(null, DEFAULTS); |  | ||||||
|  |  | ||||||
| exports.endpoint = endpoint; |  | ||||||
| //# sourceMappingURL=index.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-node/index.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-node/index.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										15
									
								
								node_modules/@octokit/endpoint/dist-src/defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								node_modules/@octokit/endpoint/dist-src/defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,15 +0,0 @@ | |||||||
| import { getUserAgent } from "universal-user-agent"; |  | ||||||
| import { VERSION } from "./version"; |  | ||||||
| const userAgent = `octokit-endpoint.js/${VERSION} ${getUserAgent()}`; |  | ||||||
| export const DEFAULTS = { |  | ||||||
|     method: "GET", |  | ||||||
|     baseUrl: "https://api.github.com", |  | ||||||
|     headers: { |  | ||||||
|         accept: "application/vnd.github.v3+json", |  | ||||||
|         "user-agent": userAgent |  | ||||||
|     }, |  | ||||||
|     mediaType: { |  | ||||||
|         format: "", |  | ||||||
|         previews: [] |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
							
								
								
									
										5
									
								
								node_modules/@octokit/endpoint/dist-src/endpoint-with-defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								node_modules/@octokit/endpoint/dist-src/endpoint-with-defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,5 +0,0 @@ | |||||||
| import { merge } from "./merge"; |  | ||||||
| import { parse } from "./parse"; |  | ||||||
| export function endpointWithDefaults(defaults, route, options) { |  | ||||||
|     return parse(merge(defaults, route, options)); |  | ||||||
| } |  | ||||||
							
								
								
									
										0
									
								
								node_modules/@octokit/endpoint/dist-src/generated/routes.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										0
									
								
								node_modules/@octokit/endpoint/dist-src/generated/routes.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
								
								
									
										3
									
								
								node_modules/@octokit/endpoint/dist-src/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@octokit/endpoint/dist-src/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| import { withDefaults } from "./with-defaults"; |  | ||||||
| import { DEFAULTS } from "./defaults"; |  | ||||||
| export const endpoint = withDefaults(null, DEFAULTS); |  | ||||||
							
								
								
									
										22
									
								
								node_modules/@octokit/endpoint/dist-src/merge.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								node_modules/@octokit/endpoint/dist-src/merge.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,22 +0,0 @@ | |||||||
| import { lowercaseKeys } from "./util/lowercase-keys"; |  | ||||||
| import { mergeDeep } from "./util/merge-deep"; |  | ||||||
| export function merge(defaults, route, options) { |  | ||||||
|     if (typeof route === "string") { |  | ||||||
|         let [method, url] = route.split(" "); |  | ||||||
|         options = Object.assign(url ? { method, url } : { url: method }, options); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         options = route || {}; |  | ||||||
|     } |  | ||||||
|     // lowercase header names before merging with defaults to avoid duplicates |  | ||||||
|     options.headers = lowercaseKeys(options.headers); |  | ||||||
|     const mergedOptions = mergeDeep(defaults || {}, options); |  | ||||||
|     // mediaType.previews arrays are merged, instead of overwritten |  | ||||||
|     if (defaults && defaults.mediaType.previews.length) { |  | ||||||
|         mergedOptions.mediaType.previews = defaults.mediaType.previews |  | ||||||
|             .filter(preview => !mergedOptions.mediaType.previews.includes(preview)) |  | ||||||
|             .concat(mergedOptions.mediaType.previews); |  | ||||||
|     } |  | ||||||
|     mergedOptions.mediaType.previews = mergedOptions.mediaType.previews.map((preview) => preview.replace(/-preview/, "")); |  | ||||||
|     return mergedOptions; |  | ||||||
| } |  | ||||||
							
								
								
									
										81
									
								
								node_modules/@octokit/endpoint/dist-src/parse.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										81
									
								
								node_modules/@octokit/endpoint/dist-src/parse.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,81 +0,0 @@ | |||||||
| import { addQueryParameters } from "./util/add-query-parameters"; |  | ||||||
| import { extractUrlVariableNames } from "./util/extract-url-variable-names"; |  | ||||||
| import { omit } from "./util/omit"; |  | ||||||
| import { parseUrl } from "./util/url-template"; |  | ||||||
| export function parse(options) { |  | ||||||
|     // https://fetch.spec.whatwg.org/#methods |  | ||||||
|     let method = options.method.toUpperCase(); |  | ||||||
|     // replace :varname with {varname} to make it RFC 6570 compatible |  | ||||||
|     let url = options.url.replace(/:([a-z]\w+)/g, "{+$1}"); |  | ||||||
|     let headers = Object.assign({}, options.headers); |  | ||||||
|     let body; |  | ||||||
|     let parameters = omit(options, [ |  | ||||||
|         "method", |  | ||||||
|         "baseUrl", |  | ||||||
|         "url", |  | ||||||
|         "headers", |  | ||||||
|         "request", |  | ||||||
|         "mediaType" |  | ||||||
|     ]); |  | ||||||
|     // extract variable names from URL to calculate remaining variables later |  | ||||||
|     const urlVariableNames = extractUrlVariableNames(url); |  | ||||||
|     url = parseUrl(url).expand(parameters); |  | ||||||
|     if (!/^http/.test(url)) { |  | ||||||
|         url = options.baseUrl + url; |  | ||||||
|     } |  | ||||||
|     const omittedParameters = Object.keys(options) |  | ||||||
|         .filter(option => urlVariableNames.includes(option)) |  | ||||||
|         .concat("baseUrl"); |  | ||||||
|     const remainingParameters = omit(parameters, omittedParameters); |  | ||||||
|     const isBinaryRequset = /application\/octet-stream/i.test(headers.accept); |  | ||||||
|     if (!isBinaryRequset) { |  | ||||||
|         if (options.mediaType.format) { |  | ||||||
|             // e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw |  | ||||||
|             headers.accept = headers.accept |  | ||||||
|                 .split(/,/) |  | ||||||
|                 .map(preview => preview.replace(/application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/, `application/vnd$1$2.${options.mediaType.format}`)) |  | ||||||
|                 .join(","); |  | ||||||
|         } |  | ||||||
|         if (options.mediaType.previews.length) { |  | ||||||
|             const previewsFromAcceptHeader = headers.accept.match(/[\w-]+(?=-preview)/g) || []; |  | ||||||
|             headers.accept = previewsFromAcceptHeader |  | ||||||
|                 .concat(options.mediaType.previews) |  | ||||||
|                 .map(preview => { |  | ||||||
|                 const format = options.mediaType.format |  | ||||||
|                     ? `.${options.mediaType.format}` |  | ||||||
|                     : "+json"; |  | ||||||
|                 return `application/vnd.github.${preview}-preview${format}`; |  | ||||||
|             }) |  | ||||||
|                 .join(","); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     // for GET/HEAD requests, set URL query parameters from remaining parameters |  | ||||||
|     // for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters |  | ||||||
|     if (["GET", "HEAD"].includes(method)) { |  | ||||||
|         url = addQueryParameters(url, remainingParameters); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         if ("data" in remainingParameters) { |  | ||||||
|             body = remainingParameters.data; |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             if (Object.keys(remainingParameters).length) { |  | ||||||
|                 body = remainingParameters; |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 headers["content-length"] = 0; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     // default content-type for JSON if body is set |  | ||||||
|     if (!headers["content-type"] && typeof body !== "undefined") { |  | ||||||
|         headers["content-type"] = "application/json; charset=utf-8"; |  | ||||||
|     } |  | ||||||
|     // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body. |  | ||||||
|     // fetch does not allow to set `content-length` header, but we can set body to an empty string |  | ||||||
|     if (["PATCH", "PUT"].includes(method) && typeof body === "undefined") { |  | ||||||
|         body = ""; |  | ||||||
|     } |  | ||||||
|     // Only return body/request keys if present |  | ||||||
|     return Object.assign({ method, url, headers }, typeof body !== "undefined" ? { body } : null, options.request ? { request: options.request } : null); |  | ||||||
| } |  | ||||||
							
								
								
									
										0
									
								
								node_modules/@octokit/endpoint/dist-src/types.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										0
									
								
								node_modules/@octokit/endpoint/dist-src/types.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
								
								
									
										21
									
								
								node_modules/@octokit/endpoint/dist-src/util/add-query-parameters.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								node_modules/@octokit/endpoint/dist-src/util/add-query-parameters.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| export function addQueryParameters(url, parameters) { |  | ||||||
|     const separator = /\?/.test(url) ? "&" : "?"; |  | ||||||
|     const names = Object.keys(parameters); |  | ||||||
|     if (names.length === 0) { |  | ||||||
|         return url; |  | ||||||
|     } |  | ||||||
|     return (url + |  | ||||||
|         separator + |  | ||||||
|         names |  | ||||||
|             .map(name => { |  | ||||||
|             if (name === "q") { |  | ||||||
|                 return ("q=" + |  | ||||||
|                     parameters |  | ||||||
|                         .q.split("+") |  | ||||||
|                         .map(encodeURIComponent) |  | ||||||
|                         .join("+")); |  | ||||||
|             } |  | ||||||
|             return `${name}=${encodeURIComponent(parameters[name])}`; |  | ||||||
|         }) |  | ||||||
|             .join("&")); |  | ||||||
| } |  | ||||||
							
								
								
									
										11
									
								
								node_modules/@octokit/endpoint/dist-src/util/extract-url-variable-names.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								node_modules/@octokit/endpoint/dist-src/util/extract-url-variable-names.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,11 +0,0 @@ | |||||||
| const urlVariableRegex = /\{[^}]+\}/g; |  | ||||||
| function removeNonChars(variableName) { |  | ||||||
|     return variableName.replace(/^\W+|\W+$/g, "").split(/,/); |  | ||||||
| } |  | ||||||
| export function extractUrlVariableNames(url) { |  | ||||||
|     const matches = url.match(urlVariableRegex); |  | ||||||
|     if (!matches) { |  | ||||||
|         return []; |  | ||||||
|     } |  | ||||||
|     return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []); |  | ||||||
| } |  | ||||||
							
								
								
									
										9
									
								
								node_modules/@octokit/endpoint/dist-src/util/lowercase-keys.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								node_modules/@octokit/endpoint/dist-src/util/lowercase-keys.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,9 +0,0 @@ | |||||||
| export function lowercaseKeys(object) { |  | ||||||
|     if (!object) { |  | ||||||
|         return {}; |  | ||||||
|     } |  | ||||||
|     return Object.keys(object).reduce((newObj, key) => { |  | ||||||
|         newObj[key.toLowerCase()] = object[key]; |  | ||||||
|         return newObj; |  | ||||||
|     }, {}); |  | ||||||
| } |  | ||||||
							
								
								
									
										16
									
								
								node_modules/@octokit/endpoint/dist-src/util/merge-deep.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								node_modules/@octokit/endpoint/dist-src/util/merge-deep.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,16 +0,0 @@ | |||||||
| import isPlainObject from "is-plain-object"; |  | ||||||
| export function mergeDeep(defaults, options) { |  | ||||||
|     const result = Object.assign({}, defaults); |  | ||||||
|     Object.keys(options).forEach(key => { |  | ||||||
|         if (isPlainObject(options[key])) { |  | ||||||
|             if (!(key in defaults)) |  | ||||||
|                 Object.assign(result, { [key]: options[key] }); |  | ||||||
|             else |  | ||||||
|                 result[key] = mergeDeep(defaults[key], options[key]); |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             Object.assign(result, { [key]: options[key] }); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
|     return result; |  | ||||||
| } |  | ||||||
							
								
								
									
										8
									
								
								node_modules/@octokit/endpoint/dist-src/util/omit.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								node_modules/@octokit/endpoint/dist-src/util/omit.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| export function omit(object, keysToOmit) { |  | ||||||
|     return Object.keys(object) |  | ||||||
|         .filter(option => !keysToOmit.includes(option)) |  | ||||||
|         .reduce((obj, key) => { |  | ||||||
|         obj[key] = object[key]; |  | ||||||
|         return obj; |  | ||||||
|     }, {}); |  | ||||||
| } |  | ||||||
							
								
								
									
										170
									
								
								node_modules/@octokit/endpoint/dist-src/util/url-template.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										170
									
								
								node_modules/@octokit/endpoint/dist-src/util/url-template.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,170 +0,0 @@ | |||||||
| // Based on https://github.com/bramstein/url-template, licensed under BSD |  | ||||||
| // TODO: create separate package. |  | ||||||
| // |  | ||||||
| // Copyright (c) 2012-2014, Bram Stein |  | ||||||
| // All rights reserved. |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions |  | ||||||
| // are met: |  | ||||||
| //  1. Redistributions of source code must retain the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer. |  | ||||||
| //  2. Redistributions in binary form must reproduce the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer in the |  | ||||||
| //     documentation and/or other materials provided with the distribution. |  | ||||||
| //  3. The name of the author may not be used to endorse or promote products |  | ||||||
| //     derived from this software without specific prior written permission. |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED |  | ||||||
| // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |  | ||||||
| // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |  | ||||||
| // EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, |  | ||||||
| // INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |  | ||||||
| // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, |  | ||||||
| // EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| /* istanbul ignore file */ |  | ||||||
| function encodeReserved(str) { |  | ||||||
|     return str |  | ||||||
|         .split(/(%[0-9A-Fa-f]{2})/g) |  | ||||||
|         .map(function (part) { |  | ||||||
|         if (!/%[0-9A-Fa-f]/.test(part)) { |  | ||||||
|             part = encodeURI(part) |  | ||||||
|                 .replace(/%5B/g, "[") |  | ||||||
|                 .replace(/%5D/g, "]"); |  | ||||||
|         } |  | ||||||
|         return part; |  | ||||||
|     }) |  | ||||||
|         .join(""); |  | ||||||
| } |  | ||||||
| function encodeUnreserved(str) { |  | ||||||
|     return encodeURIComponent(str).replace(/[!'()*]/g, function (c) { |  | ||||||
|         return ("%" + |  | ||||||
|             c |  | ||||||
|                 .charCodeAt(0) |  | ||||||
|                 .toString(16) |  | ||||||
|                 .toUpperCase()); |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| function encodeValue(operator, value, key) { |  | ||||||
|     value = |  | ||||||
|         operator === "+" || operator === "#" |  | ||||||
|             ? encodeReserved(value) |  | ||||||
|             : encodeUnreserved(value); |  | ||||||
|     if (key) { |  | ||||||
|         return encodeUnreserved(key) + "=" + value; |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         return value; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| function isDefined(value) { |  | ||||||
|     return value !== undefined && value !== null; |  | ||||||
| } |  | ||||||
| function isKeyOperator(operator) { |  | ||||||
|     return operator === ";" || operator === "&" || operator === "?"; |  | ||||||
| } |  | ||||||
| function getValues(context, operator, key, modifier) { |  | ||||||
|     var value = context[key], result = []; |  | ||||||
|     if (isDefined(value) && value !== "") { |  | ||||||
|         if (typeof value === "string" || |  | ||||||
|             typeof value === "number" || |  | ||||||
|             typeof value === "boolean") { |  | ||||||
|             value = value.toString(); |  | ||||||
|             if (modifier && modifier !== "*") { |  | ||||||
|                 value = value.substring(0, parseInt(modifier, 10)); |  | ||||||
|             } |  | ||||||
|             result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             if (modifier === "*") { |  | ||||||
|                 if (Array.isArray(value)) { |  | ||||||
|                     value.filter(isDefined).forEach(function (value) { |  | ||||||
|                         result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 else { |  | ||||||
|                     Object.keys(value).forEach(function (k) { |  | ||||||
|                         if (isDefined(value[k])) { |  | ||||||
|                             result.push(encodeValue(operator, value[k], k)); |  | ||||||
|                         } |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 const tmp = []; |  | ||||||
|                 if (Array.isArray(value)) { |  | ||||||
|                     value.filter(isDefined).forEach(function (value) { |  | ||||||
|                         tmp.push(encodeValue(operator, value)); |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 else { |  | ||||||
|                     Object.keys(value).forEach(function (k) { |  | ||||||
|                         if (isDefined(value[k])) { |  | ||||||
|                             tmp.push(encodeUnreserved(k)); |  | ||||||
|                             tmp.push(encodeValue(operator, value[k].toString())); |  | ||||||
|                         } |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 if (isKeyOperator(operator)) { |  | ||||||
|                     result.push(encodeUnreserved(key) + "=" + tmp.join(",")); |  | ||||||
|                 } |  | ||||||
|                 else if (tmp.length !== 0) { |  | ||||||
|                     result.push(tmp.join(",")); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         if (operator === ";") { |  | ||||||
|             if (isDefined(value)) { |  | ||||||
|                 result.push(encodeUnreserved(key)); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         else if (value === "" && (operator === "&" || operator === "?")) { |  | ||||||
|             result.push(encodeUnreserved(key) + "="); |  | ||||||
|         } |  | ||||||
|         else if (value === "") { |  | ||||||
|             result.push(""); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return result; |  | ||||||
| } |  | ||||||
| export function parseUrl(template) { |  | ||||||
|     return { |  | ||||||
|         expand: expand.bind(null, template) |  | ||||||
|     }; |  | ||||||
| } |  | ||||||
| function expand(template, context) { |  | ||||||
|     var operators = ["+", "#", ".", "/", ";", "?", "&"]; |  | ||||||
|     return template.replace(/\{([^\{\}]+)\}|([^\{\}]+)/g, function (_, expression, literal) { |  | ||||||
|         if (expression) { |  | ||||||
|             let operator = ""; |  | ||||||
|             const values = []; |  | ||||||
|             if (operators.indexOf(expression.charAt(0)) !== -1) { |  | ||||||
|                 operator = expression.charAt(0); |  | ||||||
|                 expression = expression.substr(1); |  | ||||||
|             } |  | ||||||
|             expression.split(/,/g).forEach(function (variable) { |  | ||||||
|                 var tmp = /([^:\*]*)(?::(\d+)|(\*))?/.exec(variable); |  | ||||||
|                 values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3])); |  | ||||||
|             }); |  | ||||||
|             if (operator && operator !== "+") { |  | ||||||
|                 var separator = ","; |  | ||||||
|                 if (operator === "?") { |  | ||||||
|                     separator = "&"; |  | ||||||
|                 } |  | ||||||
|                 else if (operator !== "#") { |  | ||||||
|                     separator = operator; |  | ||||||
|                 } |  | ||||||
|                 return (values.length !== 0 ? operator : "") + values.join(separator); |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 return values.join(","); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             return encodeReserved(literal); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-src/version.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-src/version.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export const VERSION = "0.0.0-development"; |  | ||||||
							
								
								
									
										13
									
								
								node_modules/@octokit/endpoint/dist-src/with-defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								node_modules/@octokit/endpoint/dist-src/with-defaults.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,13 +0,0 @@ | |||||||
| import { endpointWithDefaults } from "./endpoint-with-defaults"; |  | ||||||
| import { merge } from "./merge"; |  | ||||||
| import { parse } from "./parse"; |  | ||||||
| export function withDefaults(oldDefaults, newDefaults) { |  | ||||||
|     const DEFAULTS = merge(oldDefaults, newDefaults); |  | ||||||
|     const endpoint = endpointWithDefaults.bind(null, DEFAULTS); |  | ||||||
|     return Object.assign(endpoint, { |  | ||||||
|         DEFAULTS, |  | ||||||
|         defaults: withDefaults.bind(null, DEFAULTS), |  | ||||||
|         merge: merge.bind(null, DEFAULTS), |  | ||||||
|         parse |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
							
								
								
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | |||||||
| import { Defaults } from "./types"; |  | ||||||
| export declare const DEFAULTS: Defaults; |  | ||||||
							
								
								
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/endpoint-with-defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/endpoint-with-defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | |||||||
| import { Defaults, Endpoint, RequestOptions, Route, Parameters } from "./types"; |  | ||||||
| export declare function endpointWithDefaults(defaults: Defaults, route: Route | Endpoint, options?: Parameters): RequestOptions; |  | ||||||
							
								
								
									
										6745
									
								
								node_modules/@octokit/endpoint/dist-types/generated/routes.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										6745
									
								
								node_modules/@octokit/endpoint/dist-types/generated/routes.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export declare const endpoint: import("./types").endpoint; |  | ||||||
							
								
								
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/merge.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/merge.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | |||||||
| import { Defaults, Route, Parameters } from "./types"; |  | ||||||
| export declare function merge(defaults: Defaults | null, route?: Route | Parameters, options?: Parameters): Defaults; |  | ||||||
							
								
								
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/parse.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/parse.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | |||||||
| import { Defaults, RequestOptions } from "./types"; |  | ||||||
| export declare function parse(options: Defaults): RequestOptions; |  | ||||||
							
								
								
									
										150
									
								
								node_modules/@octokit/endpoint/dist-types/types.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										150
									
								
								node_modules/@octokit/endpoint/dist-types/types.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,150 +0,0 @@ | |||||||
| import { Routes as KnownRoutes } from "./generated/routes"; |  | ||||||
| export interface endpoint { |  | ||||||
|     /** |  | ||||||
|      * Transforms a GitHub REST API endpoint into generic request options |  | ||||||
|      * |  | ||||||
|      * @param {object} endpoint Must set `method` and `url`. Plus URL, query or body parameters, as well as `headers`, `mediaType.{format|previews}`, `request`, or `baseUrl`. |  | ||||||
|      */ |  | ||||||
|     (options: Endpoint): RequestOptions; |  | ||||||
|     /** |  | ||||||
|      * Transforms a GitHub REST API endpoint into generic request options |  | ||||||
|      * |  | ||||||
|      * @param {string} route Request method + URL. Example: `'GET /orgs/:org'` |  | ||||||
|      * @param {object} [parameters] URL, query or body parameters, as well as `headers`, `mediaType.{format|previews}`, `request`, or `baseUrl`. |  | ||||||
|      */ |  | ||||||
|     <R extends Route>(route: keyof KnownRoutes | R, options?: R extends keyof KnownRoutes ? KnownRoutes[R][0] & Parameters : Parameters): R extends keyof KnownRoutes ? KnownRoutes[R][1] : RequestOptions; |  | ||||||
|     /** |  | ||||||
|      * Object with current default route and parameters |  | ||||||
|      */ |  | ||||||
|     DEFAULTS: Defaults; |  | ||||||
|     /** |  | ||||||
|      * Returns a new `endpoint` with updated route and parameters |  | ||||||
|      */ |  | ||||||
|     defaults: (newDefaults: Parameters) => endpoint; |  | ||||||
|     merge: { |  | ||||||
|         /** |  | ||||||
|          * Merges current endpoint defaults with passed route and parameters, |  | ||||||
|          * without transforming them into request options. |  | ||||||
|          * |  | ||||||
|          * @param {string} route Request method + URL. Example: `'GET /orgs/:org'` |  | ||||||
|          * @param {object} [parameters] URL, query or body parameters, as well as `headers`, `mediaType.{format|previews}`, `request`, or `baseUrl`. |  | ||||||
|          * |  | ||||||
|          */ |  | ||||||
|         (route: Route, parameters?: Parameters): Defaults; |  | ||||||
|         /** |  | ||||||
|          * Merges current endpoint defaults with passed route and parameters, |  | ||||||
|          * without transforming them into request options. |  | ||||||
|          * |  | ||||||
|          * @param {object} endpoint Must set `method` and `url`. Plus URL, query or body parameters, as well as `headers`, `mediaType.{format|previews}`, `request`, or `baseUrl`. |  | ||||||
|          */ |  | ||||||
|         (options: Parameters): Defaults; |  | ||||||
|         /** |  | ||||||
|          * Returns current default options. |  | ||||||
|          * |  | ||||||
|          * @deprecated use endpoint.DEFAULTS instead |  | ||||||
|          */ |  | ||||||
|         (): Defaults; |  | ||||||
|     }; |  | ||||||
|     /** |  | ||||||
|      * Stateless method to turn endpoint options into request options. |  | ||||||
|      * Calling `endpoint(options)` is the same as calling `endpoint.parse(endpoint.merge(options))`. |  | ||||||
|      * |  | ||||||
|      * @param {object} options `method`, `url`. Plus URL, query or body parameters, as well as `headers`, `mediaType.{format|previews}`, `request`, or `baseUrl`. |  | ||||||
|      */ |  | ||||||
|     parse: (options: Defaults) => RequestOptions; |  | ||||||
| } |  | ||||||
| /** |  | ||||||
|  * Request method + URL. Example: `'GET /orgs/:org'` |  | ||||||
|  */ |  | ||||||
| export declare type Route = string; |  | ||||||
| /** |  | ||||||
|  * Relative or absolute URL. Examples: `'/orgs/:org'`, `https://example.com/foo/bar` |  | ||||||
|  */ |  | ||||||
| export declare type Url = string; |  | ||||||
| /** |  | ||||||
|  * Request method |  | ||||||
|  */ |  | ||||||
| export declare type Method = "DELETE" | "GET" | "HEAD" | "PATCH" | "POST" | "PUT"; |  | ||||||
| /** |  | ||||||
|  * Endpoint parameters |  | ||||||
|  */ |  | ||||||
| export declare type Parameters = { |  | ||||||
|     /** |  | ||||||
|      * Base URL to be used when a relative URL is passed, such as `/orgs/:org`. |  | ||||||
|      * If `baseUrl` is `https://enterprise.acme-inc.com/api/v3`, then the resulting |  | ||||||
|      * `RequestOptions.url` will be `https://enterprise.acme-inc.com/api/v3/orgs/:org`. |  | ||||||
|      */ |  | ||||||
|     baseUrl?: string; |  | ||||||
|     /** |  | ||||||
|      * HTTP headers. Use lowercase keys. |  | ||||||
|      */ |  | ||||||
|     headers?: Headers; |  | ||||||
|     /** |  | ||||||
|      * Media type options, see {@link https://developer.github.com/v3/media/|GitHub Developer Guide} |  | ||||||
|      */ |  | ||||||
|     mediaType?: { |  | ||||||
|         /** |  | ||||||
|          * `json` by default. Can be `raw`, `text`, `html`, `full`, `diff`, `patch`, `sha`, `base64`. Depending on endpoint |  | ||||||
|          */ |  | ||||||
|         format?: string; |  | ||||||
|         /** |  | ||||||
|          * Custom media type names of {@link https://developer.github.com/v3/media/|API Previews} without the `-preview` suffix. |  | ||||||
|          * Example for single preview: `['squirrel-girl']`. |  | ||||||
|          * Example for multiple previews: `['squirrel-girl', 'mister-fantastic']`. |  | ||||||
|          */ |  | ||||||
|         previews?: string[]; |  | ||||||
|     }; |  | ||||||
|     /** |  | ||||||
|      * Pass custom meta information for the request. The `request` object will be returned as is. |  | ||||||
|      */ |  | ||||||
|     request?: EndpointRequestOptions; |  | ||||||
|     /** |  | ||||||
|      * Any additional parameter will be passed as follows |  | ||||||
|      * 1. URL parameter if `':parameter'` or `{parameter}` is part of `url` |  | ||||||
|      * 2. Query parameter if `method` is `'GET'` or `'HEAD'` |  | ||||||
|      * 3. Request body if `parameter` is `'data'` |  | ||||||
|      * 4. JSON in the request body in the form of `body[parameter]` unless `parameter` key is `'data'` |  | ||||||
|      */ |  | ||||||
|     [parameter: string]: any; |  | ||||||
| }; |  | ||||||
| export declare type Endpoint = Parameters & { |  | ||||||
|     method: Method; |  | ||||||
|     url: Url; |  | ||||||
| }; |  | ||||||
| export declare type Defaults = Parameters & { |  | ||||||
|     method: Method; |  | ||||||
|     baseUrl: string; |  | ||||||
|     headers: Headers & { |  | ||||||
|         accept: string; |  | ||||||
|         "user-agent": string; |  | ||||||
|     }; |  | ||||||
|     mediaType: { |  | ||||||
|         format: string; |  | ||||||
|         previews: string[]; |  | ||||||
|     }; |  | ||||||
| }; |  | ||||||
| export declare type RequestOptions = { |  | ||||||
|     method: Method; |  | ||||||
|     url: Url; |  | ||||||
|     headers: Headers; |  | ||||||
|     body?: any; |  | ||||||
|     request?: EndpointRequestOptions; |  | ||||||
| }; |  | ||||||
| export declare type Headers = { |  | ||||||
|     /** |  | ||||||
|      * Avoid setting `accept`, use `mediaFormat.{format|previews}` instead. |  | ||||||
|      */ |  | ||||||
|     accept?: string; |  | ||||||
|     /** |  | ||||||
|      * Use `authorization` to send authenticated request, remember `token ` / `bearer ` prefixes. Example: `token 1234567890abcdef1234567890abcdef12345678` |  | ||||||
|      */ |  | ||||||
|     authorization?: string; |  | ||||||
|     /** |  | ||||||
|      * `user-agent` is set do a default and can be overwritten as needed. |  | ||||||
|      */ |  | ||||||
|     "user-agent"?: string; |  | ||||||
|     [header: string]: string | number | undefined; |  | ||||||
| }; |  | ||||||
| export declare type EndpointRequestOptions = { |  | ||||||
|     [option: string]: any; |  | ||||||
| }; |  | ||||||
							
								
								
									
										4
									
								
								node_modules/@octokit/endpoint/dist-types/util/add-query-parameters.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								node_modules/@octokit/endpoint/dist-types/util/add-query-parameters.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,4 +0,0 @@ | |||||||
| export declare function addQueryParameters(url: string, parameters: { |  | ||||||
|     [x: string]: string | undefined; |  | ||||||
|     q?: string; |  | ||||||
| }): string; |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/util/extract-url-variable-names.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/util/extract-url-variable-names.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export declare function extractUrlVariableNames(url: string): string[]; |  | ||||||
							
								
								
									
										5
									
								
								node_modules/@octokit/endpoint/dist-types/util/lowercase-keys.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								node_modules/@octokit/endpoint/dist-types/util/lowercase-keys.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,5 +0,0 @@ | |||||||
| export declare function lowercaseKeys(object?: { |  | ||||||
|     [key: string]: any; |  | ||||||
| }): { |  | ||||||
|     [key: string]: any; |  | ||||||
| }; |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/util/merge-deep.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/util/merge-deep.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export declare function mergeDeep(defaults: any, options: any): object; |  | ||||||
							
								
								
									
										5
									
								
								node_modules/@octokit/endpoint/dist-types/util/omit.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								node_modules/@octokit/endpoint/dist-types/util/omit.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,5 +0,0 @@ | |||||||
| export declare function omit(object: { |  | ||||||
|     [key: string]: any; |  | ||||||
| }, keysToOmit: string[]): { |  | ||||||
|     [key: string]: any; |  | ||||||
| }; |  | ||||||
							
								
								
									
										3
									
								
								node_modules/@octokit/endpoint/dist-types/util/url-template.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@octokit/endpoint/dist-types/util/url-template.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| export declare function parseUrl(template: string): { |  | ||||||
|     expand: (context: object) => string; |  | ||||||
| }; |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/version.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-types/version.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export declare const VERSION = "0.0.0-development"; |  | ||||||
							
								
								
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/with-defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								node_modules/@octokit/endpoint/dist-types/with-defaults.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | |||||||
| import { Defaults, endpoint, Parameters } from "./types"; |  | ||||||
| export declare function withDefaults(oldDefaults: Defaults | null, newDefaults: Parameters): endpoint; |  | ||||||
							
								
								
									
										377
									
								
								node_modules/@octokit/endpoint/dist-web/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										377
									
								
								node_modules/@octokit/endpoint/dist-web/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,377 +0,0 @@ | |||||||
| import isPlainObject from 'is-plain-object'; |  | ||||||
| import { getUserAgent } from 'universal-user-agent'; |  | ||||||
|  |  | ||||||
| function lowercaseKeys(object) { |  | ||||||
|     if (!object) { |  | ||||||
|         return {}; |  | ||||||
|     } |  | ||||||
|     return Object.keys(object).reduce((newObj, key) => { |  | ||||||
|         newObj[key.toLowerCase()] = object[key]; |  | ||||||
|         return newObj; |  | ||||||
|     }, {}); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function mergeDeep(defaults, options) { |  | ||||||
|     const result = Object.assign({}, defaults); |  | ||||||
|     Object.keys(options).forEach(key => { |  | ||||||
|         if (isPlainObject(options[key])) { |  | ||||||
|             if (!(key in defaults)) |  | ||||||
|                 Object.assign(result, { [key]: options[key] }); |  | ||||||
|             else |  | ||||||
|                 result[key] = mergeDeep(defaults[key], options[key]); |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             Object.assign(result, { [key]: options[key] }); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
|     return result; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function merge(defaults, route, options) { |  | ||||||
|     if (typeof route === "string") { |  | ||||||
|         let [method, url] = route.split(" "); |  | ||||||
|         options = Object.assign(url ? { method, url } : { url: method }, options); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         options = route || {}; |  | ||||||
|     } |  | ||||||
|     // lowercase header names before merging with defaults to avoid duplicates |  | ||||||
|     options.headers = lowercaseKeys(options.headers); |  | ||||||
|     const mergedOptions = mergeDeep(defaults || {}, options); |  | ||||||
|     // mediaType.previews arrays are merged, instead of overwritten |  | ||||||
|     if (defaults && defaults.mediaType.previews.length) { |  | ||||||
|         mergedOptions.mediaType.previews = defaults.mediaType.previews |  | ||||||
|             .filter(preview => !mergedOptions.mediaType.previews.includes(preview)) |  | ||||||
|             .concat(mergedOptions.mediaType.previews); |  | ||||||
|     } |  | ||||||
|     mergedOptions.mediaType.previews = mergedOptions.mediaType.previews.map((preview) => preview.replace(/-preview/, "")); |  | ||||||
|     return mergedOptions; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function addQueryParameters(url, parameters) { |  | ||||||
|     const separator = /\?/.test(url) ? "&" : "?"; |  | ||||||
|     const names = Object.keys(parameters); |  | ||||||
|     if (names.length === 0) { |  | ||||||
|         return url; |  | ||||||
|     } |  | ||||||
|     return (url + |  | ||||||
|         separator + |  | ||||||
|         names |  | ||||||
|             .map(name => { |  | ||||||
|             if (name === "q") { |  | ||||||
|                 return ("q=" + |  | ||||||
|                     parameters |  | ||||||
|                         .q.split("+") |  | ||||||
|                         .map(encodeURIComponent) |  | ||||||
|                         .join("+")); |  | ||||||
|             } |  | ||||||
|             return `${name}=${encodeURIComponent(parameters[name])}`; |  | ||||||
|         }) |  | ||||||
|             .join("&")); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| const urlVariableRegex = /\{[^}]+\}/g; |  | ||||||
| function removeNonChars(variableName) { |  | ||||||
|     return variableName.replace(/^\W+|\W+$/g, "").split(/,/); |  | ||||||
| } |  | ||||||
| function extractUrlVariableNames(url) { |  | ||||||
|     const matches = url.match(urlVariableRegex); |  | ||||||
|     if (!matches) { |  | ||||||
|         return []; |  | ||||||
|     } |  | ||||||
|     return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function omit(object, keysToOmit) { |  | ||||||
|     return Object.keys(object) |  | ||||||
|         .filter(option => !keysToOmit.includes(option)) |  | ||||||
|         .reduce((obj, key) => { |  | ||||||
|         obj[key] = object[key]; |  | ||||||
|         return obj; |  | ||||||
|     }, {}); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Based on https://github.com/bramstein/url-template, licensed under BSD |  | ||||||
| // TODO: create separate package. |  | ||||||
| // |  | ||||||
| // Copyright (c) 2012-2014, Bram Stein |  | ||||||
| // All rights reserved. |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions |  | ||||||
| // are met: |  | ||||||
| //  1. Redistributions of source code must retain the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer. |  | ||||||
| //  2. Redistributions in binary form must reproduce the above copyright |  | ||||||
| //     notice, this list of conditions and the following disclaimer in the |  | ||||||
| //     documentation and/or other materials provided with the distribution. |  | ||||||
| //  3. The name of the author may not be used to endorse or promote products |  | ||||||
| //     derived from this software without specific prior written permission. |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED |  | ||||||
| // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |  | ||||||
| // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |  | ||||||
| // EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, |  | ||||||
| // INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |  | ||||||
| // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |  | ||||||
| // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  | ||||||
| // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, |  | ||||||
| // EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| /* istanbul ignore file */ |  | ||||||
| function encodeReserved(str) { |  | ||||||
|     return str |  | ||||||
|         .split(/(%[0-9A-Fa-f]{2})/g) |  | ||||||
|         .map(function (part) { |  | ||||||
|         if (!/%[0-9A-Fa-f]/.test(part)) { |  | ||||||
|             part = encodeURI(part) |  | ||||||
|                 .replace(/%5B/g, "[") |  | ||||||
|                 .replace(/%5D/g, "]"); |  | ||||||
|         } |  | ||||||
|         return part; |  | ||||||
|     }) |  | ||||||
|         .join(""); |  | ||||||
| } |  | ||||||
| function encodeUnreserved(str) { |  | ||||||
|     return encodeURIComponent(str).replace(/[!'()*]/g, function (c) { |  | ||||||
|         return ("%" + |  | ||||||
|             c |  | ||||||
|                 .charCodeAt(0) |  | ||||||
|                 .toString(16) |  | ||||||
|                 .toUpperCase()); |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| function encodeValue(operator, value, key) { |  | ||||||
|     value = |  | ||||||
|         operator === "+" || operator === "#" |  | ||||||
|             ? encodeReserved(value) |  | ||||||
|             : encodeUnreserved(value); |  | ||||||
|     if (key) { |  | ||||||
|         return encodeUnreserved(key) + "=" + value; |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         return value; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| function isDefined(value) { |  | ||||||
|     return value !== undefined && value !== null; |  | ||||||
| } |  | ||||||
| function isKeyOperator(operator) { |  | ||||||
|     return operator === ";" || operator === "&" || operator === "?"; |  | ||||||
| } |  | ||||||
| function getValues(context, operator, key, modifier) { |  | ||||||
|     var value = context[key], result = []; |  | ||||||
|     if (isDefined(value) && value !== "") { |  | ||||||
|         if (typeof value === "string" || |  | ||||||
|             typeof value === "number" || |  | ||||||
|             typeof value === "boolean") { |  | ||||||
|             value = value.toString(); |  | ||||||
|             if (modifier && modifier !== "*") { |  | ||||||
|                 value = value.substring(0, parseInt(modifier, 10)); |  | ||||||
|             } |  | ||||||
|             result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             if (modifier === "*") { |  | ||||||
|                 if (Array.isArray(value)) { |  | ||||||
|                     value.filter(isDefined).forEach(function (value) { |  | ||||||
|                         result.push(encodeValue(operator, value, isKeyOperator(operator) ? key : "")); |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 else { |  | ||||||
|                     Object.keys(value).forEach(function (k) { |  | ||||||
|                         if (isDefined(value[k])) { |  | ||||||
|                             result.push(encodeValue(operator, value[k], k)); |  | ||||||
|                         } |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 const tmp = []; |  | ||||||
|                 if (Array.isArray(value)) { |  | ||||||
|                     value.filter(isDefined).forEach(function (value) { |  | ||||||
|                         tmp.push(encodeValue(operator, value)); |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 else { |  | ||||||
|                     Object.keys(value).forEach(function (k) { |  | ||||||
|                         if (isDefined(value[k])) { |  | ||||||
|                             tmp.push(encodeUnreserved(k)); |  | ||||||
|                             tmp.push(encodeValue(operator, value[k].toString())); |  | ||||||
|                         } |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|                 if (isKeyOperator(operator)) { |  | ||||||
|                     result.push(encodeUnreserved(key) + "=" + tmp.join(",")); |  | ||||||
|                 } |  | ||||||
|                 else if (tmp.length !== 0) { |  | ||||||
|                     result.push(tmp.join(",")); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         if (operator === ";") { |  | ||||||
|             if (isDefined(value)) { |  | ||||||
|                 result.push(encodeUnreserved(key)); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         else if (value === "" && (operator === "&" || operator === "?")) { |  | ||||||
|             result.push(encodeUnreserved(key) + "="); |  | ||||||
|         } |  | ||||||
|         else if (value === "") { |  | ||||||
|             result.push(""); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return result; |  | ||||||
| } |  | ||||||
| function parseUrl(template) { |  | ||||||
|     return { |  | ||||||
|         expand: expand.bind(null, template) |  | ||||||
|     }; |  | ||||||
| } |  | ||||||
| function expand(template, context) { |  | ||||||
|     var operators = ["+", "#", ".", "/", ";", "?", "&"]; |  | ||||||
|     return template.replace(/\{([^\{\}]+)\}|([^\{\}]+)/g, function (_, expression, literal) { |  | ||||||
|         if (expression) { |  | ||||||
|             let operator = ""; |  | ||||||
|             const values = []; |  | ||||||
|             if (operators.indexOf(expression.charAt(0)) !== -1) { |  | ||||||
|                 operator = expression.charAt(0); |  | ||||||
|                 expression = expression.substr(1); |  | ||||||
|             } |  | ||||||
|             expression.split(/,/g).forEach(function (variable) { |  | ||||||
|                 var tmp = /([^:\*]*)(?::(\d+)|(\*))?/.exec(variable); |  | ||||||
|                 values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3])); |  | ||||||
|             }); |  | ||||||
|             if (operator && operator !== "+") { |  | ||||||
|                 var separator = ","; |  | ||||||
|                 if (operator === "?") { |  | ||||||
|                     separator = "&"; |  | ||||||
|                 } |  | ||||||
|                 else if (operator !== "#") { |  | ||||||
|                     separator = operator; |  | ||||||
|                 } |  | ||||||
|                 return (values.length !== 0 ? operator : "") + values.join(separator); |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 return values.join(","); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             return encodeReserved(literal); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function parse(options) { |  | ||||||
|     // https://fetch.spec.whatwg.org/#methods |  | ||||||
|     let method = options.method.toUpperCase(); |  | ||||||
|     // replace :varname with {varname} to make it RFC 6570 compatible |  | ||||||
|     let url = options.url.replace(/:([a-z]\w+)/g, "{+$1}"); |  | ||||||
|     let headers = Object.assign({}, options.headers); |  | ||||||
|     let body; |  | ||||||
|     let parameters = omit(options, [ |  | ||||||
|         "method", |  | ||||||
|         "baseUrl", |  | ||||||
|         "url", |  | ||||||
|         "headers", |  | ||||||
|         "request", |  | ||||||
|         "mediaType" |  | ||||||
|     ]); |  | ||||||
|     // extract variable names from URL to calculate remaining variables later |  | ||||||
|     const urlVariableNames = extractUrlVariableNames(url); |  | ||||||
|     url = parseUrl(url).expand(parameters); |  | ||||||
|     if (!/^http/.test(url)) { |  | ||||||
|         url = options.baseUrl + url; |  | ||||||
|     } |  | ||||||
|     const omittedParameters = Object.keys(options) |  | ||||||
|         .filter(option => urlVariableNames.includes(option)) |  | ||||||
|         .concat("baseUrl"); |  | ||||||
|     const remainingParameters = omit(parameters, omittedParameters); |  | ||||||
|     const isBinaryRequset = /application\/octet-stream/i.test(headers.accept); |  | ||||||
|     if (!isBinaryRequset) { |  | ||||||
|         if (options.mediaType.format) { |  | ||||||
|             // e.g. application/vnd.github.v3+json => application/vnd.github.v3.raw |  | ||||||
|             headers.accept = headers.accept |  | ||||||
|                 .split(/,/) |  | ||||||
|                 .map(preview => preview.replace(/application\/vnd(\.\w+)(\.v3)?(\.\w+)?(\+json)?$/, `application/vnd$1$2.${options.mediaType.format}`)) |  | ||||||
|                 .join(","); |  | ||||||
|         } |  | ||||||
|         if (options.mediaType.previews.length) { |  | ||||||
|             const previewsFromAcceptHeader = headers.accept.match(/[\w-]+(?=-preview)/g) || []; |  | ||||||
|             headers.accept = previewsFromAcceptHeader |  | ||||||
|                 .concat(options.mediaType.previews) |  | ||||||
|                 .map(preview => { |  | ||||||
|                 const format = options.mediaType.format |  | ||||||
|                     ? `.${options.mediaType.format}` |  | ||||||
|                     : "+json"; |  | ||||||
|                 return `application/vnd.github.${preview}-preview${format}`; |  | ||||||
|             }) |  | ||||||
|                 .join(","); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     // for GET/HEAD requests, set URL query parameters from remaining parameters |  | ||||||
|     // for PATCH/POST/PUT/DELETE requests, set request body from remaining parameters |  | ||||||
|     if (["GET", "HEAD"].includes(method)) { |  | ||||||
|         url = addQueryParameters(url, remainingParameters); |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|         if ("data" in remainingParameters) { |  | ||||||
|             body = remainingParameters.data; |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             if (Object.keys(remainingParameters).length) { |  | ||||||
|                 body = remainingParameters; |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 headers["content-length"] = 0; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     // default content-type for JSON if body is set |  | ||||||
|     if (!headers["content-type"] && typeof body !== "undefined") { |  | ||||||
|         headers["content-type"] = "application/json; charset=utf-8"; |  | ||||||
|     } |  | ||||||
|     // GitHub expects 'content-length: 0' header for PUT/PATCH requests without body. |  | ||||||
|     // fetch does not allow to set `content-length` header, but we can set body to an empty string |  | ||||||
|     if (["PATCH", "PUT"].includes(method) && typeof body === "undefined") { |  | ||||||
|         body = ""; |  | ||||||
|     } |  | ||||||
|     // Only return body/request keys if present |  | ||||||
|     return Object.assign({ method, url, headers }, typeof body !== "undefined" ? { body } : null, options.request ? { request: options.request } : null); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function endpointWithDefaults(defaults, route, options) { |  | ||||||
|     return parse(merge(defaults, route, options)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function withDefaults(oldDefaults, newDefaults) { |  | ||||||
|     const DEFAULTS = merge(oldDefaults, newDefaults); |  | ||||||
|     const endpoint = endpointWithDefaults.bind(null, DEFAULTS); |  | ||||||
|     return Object.assign(endpoint, { |  | ||||||
|         DEFAULTS, |  | ||||||
|         defaults: withDefaults.bind(null, DEFAULTS), |  | ||||||
|         merge: merge.bind(null, DEFAULTS), |  | ||||||
|         parse |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| const VERSION = "0.0.0-development"; |  | ||||||
|  |  | ||||||
| const userAgent = `octokit-endpoint.js/${VERSION} ${getUserAgent()}`; |  | ||||||
| const DEFAULTS = { |  | ||||||
|     method: "GET", |  | ||||||
|     baseUrl: "https://api.github.com", |  | ||||||
|     headers: { |  | ||||||
|         accept: "application/vnd.github.v3+json", |  | ||||||
|         "user-agent": userAgent |  | ||||||
|     }, |  | ||||||
|     mediaType: { |  | ||||||
|         format: "", |  | ||||||
|         previews: [] |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| const endpoint = withDefaults(null, DEFAULTS); |  | ||||||
|  |  | ||||||
| export { endpoint }; |  | ||||||
| //# sourceMappingURL=index.js.map |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/dist-web/index.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/dist-web/index.js.map
									
									
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										21
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| The MIT License (MIT) |  | ||||||
|  |  | ||||||
| Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy |  | ||||||
| of this software and associated documentation files (the "Software"), to deal |  | ||||||
| in the Software without restriction, including without limitation the rights |  | ||||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |  | ||||||
| copies of the Software, and to permit persons to whom the Software is |  | ||||||
| furnished to do so, subject to the following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in |  | ||||||
| all copies or substantial portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |  | ||||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |  | ||||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |  | ||||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |  | ||||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |  | ||||||
| THE SOFTWARE. |  | ||||||
							
								
								
									
										119
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										119
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,119 +0,0 @@ | |||||||
| # is-plain-object [](https://www.npmjs.com/package/is-plain-object) [](https://npmjs.org/package/is-plain-object) [](https://npmjs.org/package/is-plain-object) [](https://travis-ci.org/jonschlinkert/is-plain-object) |  | ||||||
|  |  | ||||||
| > Returns true if an object was created by the `Object` constructor. |  | ||||||
|  |  | ||||||
| Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. |  | ||||||
|  |  | ||||||
| ## Install |  | ||||||
|  |  | ||||||
| Install with [npm](https://www.npmjs.com/): |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install --save is-plain-object |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Use [isobject](https://github.com/jonschlinkert/isobject) if you only want to check if the value is an object and not an array or null. |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| import isPlainObject from 'is-plain-object'; |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **true** when created by the `Object` constructor. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| isPlainObject(Object.create({})); |  | ||||||
| //=> true |  | ||||||
| isPlainObject(Object.create(Object.prototype)); |  | ||||||
| //=> true |  | ||||||
| isPlainObject({foo: 'bar'}); |  | ||||||
| //=> true |  | ||||||
| isPlainObject({}); |  | ||||||
| //=> true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **false** when not created by the `Object` constructor. |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| isPlainObject(1); |  | ||||||
| //=> false |  | ||||||
| isPlainObject(['foo', 'bar']); |  | ||||||
| //=> false |  | ||||||
| isPlainObject([]); |  | ||||||
| //=> false |  | ||||||
| isPlainObject(new Foo); |  | ||||||
| //=> false |  | ||||||
| isPlainObject(null); |  | ||||||
| //=> false |  | ||||||
| isPlainObject(Object.create(null)); |  | ||||||
| //=> false |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## About |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Contributing</strong></summary> |  | ||||||
|  |  | ||||||
| Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Running Tests</strong></summary> |  | ||||||
|  |  | ||||||
| Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install && npm test |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Building docs</strong></summary> |  | ||||||
|  |  | ||||||
| _(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ |  | ||||||
|  |  | ||||||
| To generate the readme, run the following command: |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install -g verbose/verb#dev verb-generate-readme && verb |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| ### Related projects |  | ||||||
|  |  | ||||||
| You might also be interested in these projects: |  | ||||||
|  |  | ||||||
| * [is-number](https://www.npmjs.com/package/is-number): Returns true if a number or string value is a finite number. Useful for regex… [more](https://github.com/jonschlinkert/is-number) | [homepage](https://github.com/jonschlinkert/is-number "Returns true if a number or string value is a finite number. Useful for regex matches, parsing, user input, etc.") |  | ||||||
| * [isobject](https://www.npmjs.com/package/isobject): Returns true if the value is an object and not an array or null. | [homepage](https://github.com/jonschlinkert/isobject "Returns true if the value is an object and not an array or null.") |  | ||||||
| * [kind-of](https://www.npmjs.com/package/kind-of): Get the native type of a value. | [homepage](https://github.com/jonschlinkert/kind-of "Get the native type of a value.") |  | ||||||
|  |  | ||||||
| ### Contributors |  | ||||||
|  |  | ||||||
| | **Commits** | **Contributor** |   |  | ||||||
| | --- | --- |   |  | ||||||
| | 19 | [jonschlinkert](https://github.com/jonschlinkert) |   |  | ||||||
| | 6  | [TrySound](https://github.com/TrySound) |   |  | ||||||
| | 6  | [stevenvachon](https://github.com/stevenvachon) |   |  | ||||||
| | 3  | [onokumus](https://github.com/onokumus) |   |  | ||||||
| | 1  | [wtgtybhertgeghgtwtg](https://github.com/wtgtybhertgeghgtwtg) |   |  | ||||||
|  |  | ||||||
| ### Author |  | ||||||
|  |  | ||||||
| **Jon Schlinkert** |  | ||||||
|  |  | ||||||
| * [GitHub Profile](https://github.com/jonschlinkert) |  | ||||||
| * [Twitter Profile](https://twitter.com/jonschlinkert) |  | ||||||
| * [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) |  | ||||||
|  |  | ||||||
| ### License |  | ||||||
|  |  | ||||||
| Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). |  | ||||||
| Released under the [MIT License](LICENSE). |  | ||||||
|  |  | ||||||
| *** |  | ||||||
|  |  | ||||||
| _This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on April 28, 2019._ |  | ||||||
							
								
								
									
										48
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.cjs.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										48
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.cjs.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,48 +0,0 @@ | |||||||
| 'use strict'; |  | ||||||
|  |  | ||||||
| /*! |  | ||||||
|  * isobject <https://github.com/jonschlinkert/isobject> |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  * Released under the MIT License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| function isObject(val) { |  | ||||||
|   return val != null && typeof val === 'object' && Array.isArray(val) === false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /*! |  | ||||||
|  * is-plain-object <https://github.com/jonschlinkert/is-plain-object> |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  * Released under the MIT License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| function isObjectObject(o) { |  | ||||||
|   return isObject(o) === true |  | ||||||
|     && Object.prototype.toString.call(o) === '[object Object]'; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function isPlainObject(o) { |  | ||||||
|   var ctor,prot; |  | ||||||
|  |  | ||||||
|   if (isObjectObject(o) === false) return false; |  | ||||||
|  |  | ||||||
|   // If has modified constructor |  | ||||||
|   ctor = o.constructor; |  | ||||||
|   if (typeof ctor !== 'function') return false; |  | ||||||
|  |  | ||||||
|   // If has modified prototype |  | ||||||
|   prot = ctor.prototype; |  | ||||||
|   if (isObjectObject(prot) === false) return false; |  | ||||||
|  |  | ||||||
|   // If constructor does not have an Object-specific method |  | ||||||
|   if (prot.hasOwnProperty('isPrototypeOf') === false) { |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // Most likely a plain Object |  | ||||||
|   return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| module.exports = isPlainObject; |  | ||||||
							
								
								
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| declare function isPlainObject(o: any): boolean; |  | ||||||
|  |  | ||||||
| export default isPlainObject; |  | ||||||
							
								
								
									
										35
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										35
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,35 +0,0 @@ | |||||||
| /*! |  | ||||||
|  * is-plain-object <https://github.com/jonschlinkert/is-plain-object> |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  * Released under the MIT License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import isObject from 'isobject'; |  | ||||||
|  |  | ||||||
| function isObjectObject(o) { |  | ||||||
|   return isObject(o) === true |  | ||||||
|     && Object.prototype.toString.call(o) === '[object Object]'; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export default function isPlainObject(o) { |  | ||||||
|   var ctor,prot; |  | ||||||
|  |  | ||||||
|   if (isObjectObject(o) === false) return false; |  | ||||||
|  |  | ||||||
|   // If has modified constructor |  | ||||||
|   ctor = o.constructor; |  | ||||||
|   if (typeof ctor !== 'function') return false; |  | ||||||
|  |  | ||||||
|   // If has modified prototype |  | ||||||
|   prot = ctor.prototype; |  | ||||||
|   if (isObjectObject(prot) === false) return false; |  | ||||||
|  |  | ||||||
|   // If constructor does not have an Object-specific method |  | ||||||
|   if (prot.hasOwnProperty('isPrototypeOf') === false) { |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // Most likely a plain Object |  | ||||||
|   return true; |  | ||||||
| }; |  | ||||||
							
								
								
									
										127
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										127
									
								
								node_modules/@octokit/endpoint/node_modules/is-plain-object/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,127 +0,0 @@ | |||||||
| { |  | ||||||
|   "_args": [ |  | ||||||
|     [ |  | ||||||
|       "is-plain-object@3.0.0", |  | ||||||
|       "/Users/dougtangren/code/rust/action-gh-release" |  | ||||||
|     ] |  | ||||||
|   ], |  | ||||||
|   "_from": "is-plain-object@3.0.0", |  | ||||||
|   "_id": "is-plain-object@3.0.0", |  | ||||||
|   "_inBundle": false, |  | ||||||
|   "_integrity": "sha512-tZIpofR+P05k8Aocp7UI/2UTa9lTJSebCXpFFoR9aibpokDj/uXBsJ8luUu0tTVYKkMU6URDUuOfJZ7koewXvg==", |  | ||||||
|   "_location": "/@octokit/endpoint/is-plain-object", |  | ||||||
|   "_phantomChildren": {}, |  | ||||||
|   "_requested": { |  | ||||||
|     "type": "version", |  | ||||||
|     "registry": true, |  | ||||||
|     "raw": "is-plain-object@3.0.0", |  | ||||||
|     "name": "is-plain-object", |  | ||||||
|     "escapedName": "is-plain-object", |  | ||||||
|     "rawSpec": "3.0.0", |  | ||||||
|     "saveSpec": null, |  | ||||||
|     "fetchSpec": "3.0.0" |  | ||||||
|   }, |  | ||||||
|   "_requiredBy": [ |  | ||||||
|     "/@octokit/endpoint" |  | ||||||
|   ], |  | ||||||
|   "_resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-3.0.0.tgz", |  | ||||||
|   "_spec": "3.0.0", |  | ||||||
|   "_where": "/Users/dougtangren/code/rust/action-gh-release", |  | ||||||
|   "author": { |  | ||||||
|     "name": "Jon Schlinkert", |  | ||||||
|     "url": "https://github.com/jonschlinkert" |  | ||||||
|   }, |  | ||||||
|   "bugs": { |  | ||||||
|     "url": "https://github.com/jonschlinkert/is-plain-object/issues" |  | ||||||
|   }, |  | ||||||
|   "contributors": [ |  | ||||||
|     { |  | ||||||
|       "name": "Jon Schlinkert", |  | ||||||
|       "url": "http://twitter.com/jonschlinkert" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Osman Nuri Okumuş", |  | ||||||
|       "url": "http://onokumus.com" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Steven Vachon", |  | ||||||
|       "url": "https://svachon.com" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "url": "https://github.com/wtgtybhertgeghgtwtg" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "dependencies": { |  | ||||||
|     "isobject": "^4.0.0" |  | ||||||
|   }, |  | ||||||
|   "description": "Returns true if an object was created by the `Object` constructor.", |  | ||||||
|   "devDependencies": { |  | ||||||
|     "chai": "^4.2.0", |  | ||||||
|     "esm": "^3.2.22", |  | ||||||
|     "gulp-format-md": "^1.0.0", |  | ||||||
|     "mocha": "^6.1.4", |  | ||||||
|     "mocha-headless-chrome": "^2.0.2", |  | ||||||
|     "rollup": "^1.10.1", |  | ||||||
|     "rollup-plugin-node-resolve": "^4.2.3" |  | ||||||
|   }, |  | ||||||
|   "engines": { |  | ||||||
|     "node": ">=0.10.0" |  | ||||||
|   }, |  | ||||||
|   "files": [ |  | ||||||
|     "index.d.ts", |  | ||||||
|     "index.js", |  | ||||||
|     "index.cjs.js" |  | ||||||
|   ], |  | ||||||
|   "homepage": "https://github.com/jonschlinkert/is-plain-object", |  | ||||||
|   "keywords": [ |  | ||||||
|     "check", |  | ||||||
|     "is", |  | ||||||
|     "is-object", |  | ||||||
|     "isobject", |  | ||||||
|     "javascript", |  | ||||||
|     "kind", |  | ||||||
|     "kind-of", |  | ||||||
|     "object", |  | ||||||
|     "plain", |  | ||||||
|     "type", |  | ||||||
|     "typeof", |  | ||||||
|     "value" |  | ||||||
|   ], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "main": "index.cjs.js", |  | ||||||
|   "module": "index.js", |  | ||||||
|   "name": "is-plain-object", |  | ||||||
|   "repository": { |  | ||||||
|     "type": "git", |  | ||||||
|     "url": "git+https://github.com/jonschlinkert/is-plain-object.git" |  | ||||||
|   }, |  | ||||||
|   "scripts": { |  | ||||||
|     "build": "rollup -c", |  | ||||||
|     "prepare": "rollup -c", |  | ||||||
|     "test": "npm run test_node && npm run build && npm run test_browser", |  | ||||||
|     "test_browser": "mocha-headless-chrome --args=disable-web-security -f test/browser.html", |  | ||||||
|     "test_node": "mocha -r esm" |  | ||||||
|   }, |  | ||||||
|   "types": "index.d.ts", |  | ||||||
|   "verb": { |  | ||||||
|     "toc": false, |  | ||||||
|     "layout": "default", |  | ||||||
|     "tasks": [ |  | ||||||
|       "readme" |  | ||||||
|     ], |  | ||||||
|     "plugins": [ |  | ||||||
|       "gulp-format-md" |  | ||||||
|     ], |  | ||||||
|     "related": { |  | ||||||
|       "list": [ |  | ||||||
|         "is-number", |  | ||||||
|         "isobject", |  | ||||||
|         "kind-of" |  | ||||||
|       ] |  | ||||||
|     }, |  | ||||||
|     "lint": { |  | ||||||
|       "reflinks": true |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "version": "3.0.0" |  | ||||||
| } |  | ||||||
							
								
								
									
										21
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| The MIT License (MIT) |  | ||||||
|  |  | ||||||
| Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy |  | ||||||
| of this software and associated documentation files (the "Software"), to deal |  | ||||||
| in the Software without restriction, including without limitation the rights |  | ||||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |  | ||||||
| copies of the Software, and to permit persons to whom the Software is |  | ||||||
| furnished to do so, subject to the following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in |  | ||||||
| all copies or substantial portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |  | ||||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |  | ||||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |  | ||||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |  | ||||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |  | ||||||
| THE SOFTWARE. |  | ||||||
							
								
								
									
										127
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										127
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,127 +0,0 @@ | |||||||
| # isobject [](https://www.npmjs.com/package/isobject) [](https://npmjs.org/package/isobject) [](https://npmjs.org/package/isobject) [](https://travis-ci.org/jonschlinkert/isobject) |  | ||||||
|  |  | ||||||
| > Returns true if the value is an object and not an array or null. |  | ||||||
|  |  | ||||||
| Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. |  | ||||||
|  |  | ||||||
| ## Install |  | ||||||
|  |  | ||||||
| Install with [npm](https://www.npmjs.com/): |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install --save isobject |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Use [is-plain-object](https://github.com/jonschlinkert/is-plain-object) if you want only objects that are created by the `Object` constructor. |  | ||||||
|  |  | ||||||
| ## Install |  | ||||||
|  |  | ||||||
| Install with [npm](https://www.npmjs.com/): |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install isobject |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| import isObject from 'isobject'; |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **True** |  | ||||||
|  |  | ||||||
| All of the following return `true`: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| isObject({}); |  | ||||||
| isObject(Object.create({})); |  | ||||||
| isObject(Object.create(Object.prototype)); |  | ||||||
| isObject(Object.create(null)); |  | ||||||
| isObject({}); |  | ||||||
| isObject(new Foo); |  | ||||||
| isObject(/foo/); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **False** |  | ||||||
|  |  | ||||||
| All of the following return `false`: |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| isObject(); |  | ||||||
| isObject(function () {}); |  | ||||||
| isObject(1); |  | ||||||
| isObject([]); |  | ||||||
| isObject(undefined); |  | ||||||
| isObject(null); |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## About |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Contributing</strong></summary> |  | ||||||
|  |  | ||||||
| Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Running Tests</strong></summary> |  | ||||||
|  |  | ||||||
| Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install && npm test |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| <details> |  | ||||||
| <summary><strong>Building docs</strong></summary> |  | ||||||
|  |  | ||||||
| _(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ |  | ||||||
|  |  | ||||||
| To generate the readme, run the following command: |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| $ npm install -g verbose/verb#dev verb-generate-readme && verb |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| </details> |  | ||||||
|  |  | ||||||
| ### Related projects |  | ||||||
|  |  | ||||||
| You might also be interested in these projects: |  | ||||||
|  |  | ||||||
| * [extend-shallow](https://www.npmjs.com/package/extend-shallow): Extend an object with the properties of additional objects. node.js/javascript util. | [homepage](https://github.com/jonschlinkert/extend-shallow "Extend an object with the properties of additional objects. node.js/javascript util.") |  | ||||||
| * [is-plain-object](https://www.npmjs.com/package/is-plain-object): Returns true if an object was created by the `Object` constructor. | [homepage](https://github.com/jonschlinkert/is-plain-object "Returns true if an object was created by the `Object` constructor.") |  | ||||||
| * [kind-of](https://www.npmjs.com/package/kind-of): Get the native type of a value. | [homepage](https://github.com/jonschlinkert/kind-of "Get the native type of a value.") |  | ||||||
| * [merge-deep](https://www.npmjs.com/package/merge-deep): Recursively merge values in a javascript object. | [homepage](https://github.com/jonschlinkert/merge-deep "Recursively merge values in a javascript object.") |  | ||||||
|  |  | ||||||
| ### Contributors |  | ||||||
|  |  | ||||||
| | **Commits** | **Contributor** |   |  | ||||||
| | --- | --- |   |  | ||||||
| | 30 | [jonschlinkert](https://github.com/jonschlinkert) |   |  | ||||||
| | 8  | [doowb](https://github.com/doowb) |   |  | ||||||
| | 7  | [TrySound](https://github.com/TrySound) |   |  | ||||||
| | 3  | [onokumus](https://github.com/onokumus) |   |  | ||||||
| | 1  | [LeSuisse](https://github.com/LeSuisse) |   |  | ||||||
| | 1  | [tmcw](https://github.com/tmcw) |   |  | ||||||
| | 1  | [ZhouHansen](https://github.com/ZhouHansen) |   |  | ||||||
|  |  | ||||||
| ### Author |  | ||||||
|  |  | ||||||
| **Jon Schlinkert** |  | ||||||
|  |  | ||||||
| * [GitHub Profile](https://github.com/jonschlinkert) |  | ||||||
| * [Twitter Profile](https://twitter.com/jonschlinkert) |  | ||||||
| * [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) |  | ||||||
|  |  | ||||||
| ### License |  | ||||||
|  |  | ||||||
| Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). |  | ||||||
| Released under the [MIT License](LICENSE). |  | ||||||
|  |  | ||||||
| *** |  | ||||||
|  |  | ||||||
| _This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on April 28, 2019._ |  | ||||||
							
								
								
									
										14
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.cjs.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.cjs.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,14 +0,0 @@ | |||||||
| 'use strict'; |  | ||||||
|  |  | ||||||
| /*! |  | ||||||
|  * isobject <https://github.com/jonschlinkert/isobject> |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  * Released under the MIT License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| function isObject(val) { |  | ||||||
|   return val != null && typeof val === 'object' && Array.isArray(val) === false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| module.exports = isObject; |  | ||||||
							
								
								
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.d.ts
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| declare function isObject(val: any): boolean; |  | ||||||
|  |  | ||||||
| export default isObject; |  | ||||||
							
								
								
									
										10
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,10 +0,0 @@ | |||||||
| /*! |  | ||||||
|  * isobject <https://github.com/jonschlinkert/isobject> |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2014-2017, Jon Schlinkert. |  | ||||||
|  * Released under the MIT License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| export default function isObject(val) { |  | ||||||
|   return val != null && typeof val === 'object' && Array.isArray(val) === false; |  | ||||||
| }; |  | ||||||
							
								
								
									
										128
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										128
									
								
								node_modules/@octokit/endpoint/node_modules/isobject/package.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,128 +0,0 @@ | |||||||
| { |  | ||||||
|   "_args": [ |  | ||||||
|     [ |  | ||||||
|       "isobject@4.0.0", |  | ||||||
|       "/Users/dougtangren/code/rust/action-gh-release" |  | ||||||
|     ] |  | ||||||
|   ], |  | ||||||
|   "_from": "isobject@4.0.0", |  | ||||||
|   "_id": "isobject@4.0.0", |  | ||||||
|   "_inBundle": false, |  | ||||||
|   "_integrity": "sha512-S/2fF5wH8SJA/kmwr6HYhK/RI/OkhD84k8ntalo0iJjZikgq1XFvR5M8NPT1x5F7fBwCG3qHfnzeP/Vh/ZxCUA==", |  | ||||||
|   "_location": "/@octokit/endpoint/isobject", |  | ||||||
|   "_phantomChildren": {}, |  | ||||||
|   "_requested": { |  | ||||||
|     "type": "version", |  | ||||||
|     "registry": true, |  | ||||||
|     "raw": "isobject@4.0.0", |  | ||||||
|     "name": "isobject", |  | ||||||
|     "escapedName": "isobject", |  | ||||||
|     "rawSpec": "4.0.0", |  | ||||||
|     "saveSpec": null, |  | ||||||
|     "fetchSpec": "4.0.0" |  | ||||||
|   }, |  | ||||||
|   "_requiredBy": [ |  | ||||||
|     "/@octokit/endpoint/is-plain-object" |  | ||||||
|   ], |  | ||||||
|   "_resolved": "https://registry.npmjs.org/isobject/-/isobject-4.0.0.tgz", |  | ||||||
|   "_spec": "4.0.0", |  | ||||||
|   "_where": "/Users/dougtangren/code/rust/action-gh-release", |  | ||||||
|   "author": { |  | ||||||
|     "name": "Jon Schlinkert", |  | ||||||
|     "url": "https://github.com/jonschlinkert" |  | ||||||
|   }, |  | ||||||
|   "bugs": { |  | ||||||
|     "url": "https://github.com/jonschlinkert/isobject/issues" |  | ||||||
|   }, |  | ||||||
|   "contributors": [ |  | ||||||
|     { |  | ||||||
|       "url": "https://github.com/LeSuisse" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Brian Woodward", |  | ||||||
|       "url": "https://twitter.com/doowb" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Jon Schlinkert", |  | ||||||
|       "url": "http://twitter.com/jonschlinkert" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Magnús Dæhlen", |  | ||||||
|       "url": "https://github.com/magnudae" |  | ||||||
|     }, |  | ||||||
|     { |  | ||||||
|       "name": "Tom MacWright", |  | ||||||
|       "url": "https://macwright.org" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "dependencies": {}, |  | ||||||
|   "description": "Returns true if the value is an object and not an array or null.", |  | ||||||
|   "devDependencies": { |  | ||||||
|     "esm": "^3.2.22", |  | ||||||
|     "gulp-format-md": "^0.1.9", |  | ||||||
|     "mocha": "^2.4.5", |  | ||||||
|     "rollup": "^1.10.1" |  | ||||||
|   }, |  | ||||||
|   "engines": { |  | ||||||
|     "node": ">=0.10.0" |  | ||||||
|   }, |  | ||||||
|   "files": [ |  | ||||||
|     "index.d.ts", |  | ||||||
|     "index.cjs.js", |  | ||||||
|     "index.js" |  | ||||||
|   ], |  | ||||||
|   "homepage": "https://github.com/jonschlinkert/isobject", |  | ||||||
|   "keywords": [ |  | ||||||
|     "check", |  | ||||||
|     "is", |  | ||||||
|     "is-object", |  | ||||||
|     "isobject", |  | ||||||
|     "kind", |  | ||||||
|     "kind-of", |  | ||||||
|     "kindof", |  | ||||||
|     "native", |  | ||||||
|     "object", |  | ||||||
|     "type", |  | ||||||
|     "typeof", |  | ||||||
|     "value" |  | ||||||
|   ], |  | ||||||
|   "license": "MIT", |  | ||||||
|   "main": "index.cjs.js", |  | ||||||
|   "module": "index.js", |  | ||||||
|   "name": "isobject", |  | ||||||
|   "repository": { |  | ||||||
|     "type": "git", |  | ||||||
|     "url": "git+https://github.com/jonschlinkert/isobject.git" |  | ||||||
|   }, |  | ||||||
|   "scripts": { |  | ||||||
|     "build": "rollup -i index.js -o index.cjs.js -f cjs", |  | ||||||
|     "prepublish": "npm run build", |  | ||||||
|     "test": "mocha -r esm" |  | ||||||
|   }, |  | ||||||
|   "types": "index.d.ts", |  | ||||||
|   "verb": { |  | ||||||
|     "related": { |  | ||||||
|       "list": [ |  | ||||||
|         "extend-shallow", |  | ||||||
|         "is-plain-object", |  | ||||||
|         "kind-of", |  | ||||||
|         "merge-deep" |  | ||||||
|       ] |  | ||||||
|     }, |  | ||||||
|     "toc": false, |  | ||||||
|     "layout": "default", |  | ||||||
|     "tasks": [ |  | ||||||
|       "readme" |  | ||||||
|     ], |  | ||||||
|     "plugins": [ |  | ||||||
|       "gulp-format-md" |  | ||||||
|     ], |  | ||||||
|     "lint": { |  | ||||||
|       "reflinks": true |  | ||||||
|     }, |  | ||||||
|     "reflinks": [ |  | ||||||
|       "verb" |  | ||||||
|     ] |  | ||||||
|   }, |  | ||||||
|   "version": "4.0.0" |  | ||||||
| } |  | ||||||
							
								
								
									
										7
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/LICENSE.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,7 +0,0 @@ | |||||||
| # [ISC License](https://spdx.org/licenses/ISC) |  | ||||||
|  |  | ||||||
| Copyright (c) 2018, Gregor Martynus (https://github.com/gr2m) |  | ||||||
|  |  | ||||||
| Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |  | ||||||
							
								
								
									
										25
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,25 +0,0 @@ | |||||||
| # universal-user-agent |  | ||||||
|  |  | ||||||
| > Get a user agent string in both browser and node |  | ||||||
|  |  | ||||||
| [](https://www.npmjs.com/package/universal-user-agent) |  | ||||||
| [](https://travis-ci.com/gr2m/universal-user-agent) |  | ||||||
| [](https://greenkeeper.io/) |  | ||||||
|  |  | ||||||
| ```js |  | ||||||
| const { getUserAgent } = require("universal-user-agent"); |  | ||||||
| // or import { getUserAgent } from "universal-user-agent"; |  | ||||||
|  |  | ||||||
| const userAgent = getUserAgent(); |  | ||||||
| // userAgent will look like this |  | ||||||
| // in browser: "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:61.0) Gecko/20100101 Firefox/61.0" |  | ||||||
| // in node: Node.js/v8.9.4 (macOS High Sierra; x64) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Credits |  | ||||||
|  |  | ||||||
| The Node implementation was originally inspired by [default-user-agent](https://www.npmjs.com/package/default-user-agent). |  | ||||||
|  |  | ||||||
| ## License |  | ||||||
|  |  | ||||||
| [ISC](LICENSE.md) |  | ||||||
							
								
								
									
										22
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-node/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-node/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,22 +0,0 @@ | |||||||
| 'use strict'; |  | ||||||
|  |  | ||||||
| Object.defineProperty(exports, '__esModule', { value: true }); |  | ||||||
|  |  | ||||||
| function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } |  | ||||||
|  |  | ||||||
| var osName = _interopDefault(require('os-name')); |  | ||||||
|  |  | ||||||
| function getUserAgent() { |  | ||||||
|   try { |  | ||||||
|     return `Node.js/${process.version.substr(1)} (${osName()}; ${process.arch})`; |  | ||||||
|   } catch (error) { |  | ||||||
|     if (/wmic os get Caption/.test(error.message)) { |  | ||||||
|       return "Windows <version undetectable>"; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     throw error; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| exports.getUserAgent = getUserAgent; |  | ||||||
| //# sourceMappingURL=index.js.map |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| {"version":3,"file":"index.js","sources":["../dist-src/node.js"],"sourcesContent":["import osName from \"os-name\";\nexport function getUserAgent() {\n    try {\n        return `Node.js/${process.version.substr(1)} (${osName()}; ${process.arch})`;\n    }\n    catch (error) {\n        if (/wmic os get Caption/.test(error.message)) {\n            return \"Windows <version undetectable>\";\n        }\n        throw error;\n    }\n}\n"],"names":["getUserAgent","process","version","substr","osName","arch","error","test","message"],"mappings":";;;;;;;;AACO,SAASA,YAAT,GAAwB;MACvB;WACQ,WAAUC,OAAO,CAACC,OAAR,CAAgBC,MAAhB,CAAuB,CAAvB,CAA0B,KAAIC,MAAM,EAAG,KAAIH,OAAO,CAACI,IAAK,GAA1E;GADJ,CAGA,OAAOC,KAAP,EAAc;QACN,sBAAsBC,IAAtB,CAA2BD,KAAK,CAACE,OAAjC,CAAJ,EAA+C;aACpC,gCAAP;;;UAEEF,KAAN;;;;;;"} |  | ||||||
							
								
								
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/browser.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/browser.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,3 +0,0 @@ | |||||||
| export function getUserAgent() { |  | ||||||
|     return navigator.userAgent; |  | ||||||
| } |  | ||||||
							
								
								
									
										1
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1 +0,0 @@ | |||||||
| export { getUserAgent } from "./node"; |  | ||||||
							
								
								
									
										12
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/node.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-src/node.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,12 +0,0 @@ | |||||||
| import osName from "os-name"; |  | ||||||
| export function getUserAgent() { |  | ||||||
|     try { |  | ||||||
|         return `Node.js/${process.version.substr(1)} (${osName()}; ${process.arch})`; |  | ||||||
|     } |  | ||||||
|     catch (error) { |  | ||||||
|         if (/wmic os get Caption/.test(error.message)) { |  | ||||||
|             return "Windows <version undetectable>"; |  | ||||||
|         } |  | ||||||
|         throw error; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| export declare function getUserAgent(): string; |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| export { getUserAgent } from "./node"; |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| export declare function getUserAgent(): string; |  | ||||||
							
								
								
									
										6
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-web/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								node_modules/@octokit/endpoint/node_modules/universal-user-agent/dist-web/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							| @@ -1,6 +0,0 @@ | |||||||
| function getUserAgent() { |  | ||||||
|     return navigator.userAgent; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export { getUserAgent }; |  | ||||||
| //# sourceMappingURL=index.js.map |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user