Add prerelease and body options
This commit is contained in:
parent
fdd8502475
commit
806b0b0631
4
.github/workflows/ci.yml
vendored
4
.github/workflows/ci.yml
vendored
@ -30,6 +30,8 @@ jobs:
|
|||||||
asset_name: TEST.md
|
asset_name: TEST.md
|
||||||
tag: ci-test-${{ matrix.os }}
|
tag: ci-test-${{ matrix.os }}
|
||||||
overwrite: true
|
overwrite: true
|
||||||
|
prerelease: true
|
||||||
|
body: "rofl lol test"
|
||||||
- name: Check that the uploaded asset is readable
|
- name: Check that the uploaded asset is readable
|
||||||
uses: actions/github-script@v2
|
uses: actions/github-script@v2
|
||||||
with:
|
with:
|
||||||
@ -44,6 +46,8 @@ jobs:
|
|||||||
...context.repo,
|
...context.repo,
|
||||||
tag: "ci-test-${{ matrix.os }}",
|
tag: "ci-test-${{ matrix.os }}",
|
||||||
})
|
})
|
||||||
|
assert.deepStrictEqual(release.data.prerelease, true)
|
||||||
|
assert.deepStrictEqual(release.data.body, "rofl lol test")
|
||||||
const actual = child_process.execSync(`curl -Ls ${release.data.assets[0].browser_download_url}`)
|
const actual = child_process.execSync(`curl -Ls ${release.data.assets[0].browser_download_url}`)
|
||||||
assert.deepStrictEqual(expected, actual)
|
assert.deepStrictEqual(expected, actual)
|
||||||
- name: Clean up
|
- name: Clean up
|
||||||
|
13
README.md
13
README.md
@ -7,15 +7,21 @@ It runs on all operating systems types offered by GitHub.
|
|||||||
|
|
||||||
You must provide:
|
You must provide:
|
||||||
|
|
||||||
- `repo_token`: Usually you'll want to set this to `${{ secrets.GITHUB_TOKEN }}`
|
- `repo_token`: Usually you'll want to set this to `${{ secrets.GITHUB_TOKEN }}`.
|
||||||
- `file`: A local file to be uploaded as the asset.
|
- `file`: A local file to be uploaded as the asset.
|
||||||
- `asset_name`: The name the file gets as an asset on a release. Use `$tag` to include the tag name.
|
- `asset_name`: The name the file gets as an asset on a release. Use `$tag` to include the tag name.
|
||||||
- `tag`: The tag to upload into. If you want the current event's tag, use `${{ github.ref }}` (the `refs/tags/` prefix will be automatically stripped).
|
- `tag`: The tag to upload into. If you want the current event's tag, use `${{ github.ref }}` (the `refs/tags/` prefix will be automatically stripped).
|
||||||
- `overwrite`: If an asset with the same name already exists, overwrite it.
|
|
||||||
|
|
||||||
Optional Arguments
|
Optional Arguments
|
||||||
|
|
||||||
- `file_glob`: If set to true, the file argument can be a glob pattern (`asset_name` is ignored in this case)
|
- `file_glob`: If set to true, the file argument can be a glob pattern (`asset_name` is ignored in this case) (Default: `false`)
|
||||||
|
- `overwrite`: If an asset with the same name already exists, overwrite it (Default: `false`).
|
||||||
|
- `prerelease`: Mark the release as a pre-release (Default: `false`).
|
||||||
|
- `body`: Content of the release text (Defaut: `""`).
|
||||||
|
|
||||||
|
## Output variables
|
||||||
|
|
||||||
|
- `browser_download_url`: The publicly available URL of the asset.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
@ -49,6 +55,7 @@ jobs:
|
|||||||
asset_name: mything
|
asset_name: mything
|
||||||
tag: ${{ github.ref }}
|
tag: ${{ github.ref }}
|
||||||
overwrite: true
|
overwrite: true
|
||||||
|
body: "This is my release text"
|
||||||
```
|
```
|
||||||
|
|
||||||
Complex example with more operating systems:
|
Complex example with more operating systems:
|
||||||
|
28
dist/index.js
vendored
28
dist/index.js
vendored
@ -2201,7 +2201,7 @@ const core = __importStar(__webpack_require__(470));
|
|||||||
const github = __importStar(__webpack_require__(469));
|
const github = __importStar(__webpack_require__(469));
|
||||||
const path = __importStar(__webpack_require__(622));
|
const path = __importStar(__webpack_require__(622));
|
||||||
const glob = __importStar(__webpack_require__(402));
|
const glob = __importStar(__webpack_require__(402));
|
||||||
function get_release_by_tag(tag, octokit) {
|
function get_release_by_tag(tag, prerelease, body, octokit) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
try {
|
try {
|
||||||
core.debug(`Getting release by tag ${tag}.`);
|
core.debug(`Getting release by tag ${tag}.`);
|
||||||
@ -2211,7 +2211,7 @@ function get_release_by_tag(tag, octokit) {
|
|||||||
// If this returns 404, we need to create the release first.
|
// If this returns 404, we need to create the release first.
|
||||||
if (error.status === 404) {
|
if (error.status === 404) {
|
||||||
core.debug(`Release for tag ${tag} doesn't exist yet so we'll create it now.`);
|
core.debug(`Release for tag ${tag} doesn't exist yet so we'll create it now.`);
|
||||||
return yield octokit.repos.createRelease(Object.assign(Object.assign({}, github.context.repo), { tag_name: tag, draft: false, prerelease: true }));
|
return yield octokit.repos.createRelease(Object.assign(Object.assign({}, github.context.repo), { tag_name: tag, prerelease: prerelease, body: body }));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
throw error;
|
throw error;
|
||||||
@ -2232,20 +2232,20 @@ function upload_to_release(release, file, asset_name, tag, overwrite, octokit) {
|
|||||||
const assets = yield octokit.repos.listReleaseAssets(Object.assign(Object.assign({}, github.context.repo), { release_id: release.data.id }));
|
const assets = yield octokit.repos.listReleaseAssets(Object.assign(Object.assign({}, github.context.repo), { release_id: release.data.id }));
|
||||||
const duplicate_asset = assets.data.find(a => a.name === asset_name);
|
const duplicate_asset = assets.data.find(a => a.name === asset_name);
|
||||||
if (duplicate_asset !== undefined) {
|
if (duplicate_asset !== undefined) {
|
||||||
if (overwrite === 'true') {
|
if (overwrite) {
|
||||||
core.debug(`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`);
|
core.debug(`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`);
|
||||||
yield octokit.repos.deleteReleaseAsset(Object.assign(Object.assign({}, github.context.repo), { asset_id: duplicate_asset.id }));
|
yield octokit.repos.deleteReleaseAsset(Object.assign(Object.assign({}, github.context.repo), { asset_id: duplicate_asset.id }));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.setFailed(`An asset called ${asset_name} already exists.`);
|
core.setFailed(`An asset called ${asset_name} already exists.`);
|
||||||
return;
|
return duplicate_asset.browser_download_url;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.debug(`No pre-existing asset called ${asset_name} found in release ${tag}. All good.`);
|
core.debug(`No pre-existing asset called ${asset_name} found in release ${tag}. All good.`);
|
||||||
}
|
}
|
||||||
core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`);
|
core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`);
|
||||||
yield octokit.repos.uploadReleaseAsset({
|
const uploaded_asset = yield octokit.repos.uploadReleaseAsset({
|
||||||
url: release.data.upload_url,
|
url: release.data.upload_url,
|
||||||
name: asset_name,
|
name: asset_name,
|
||||||
data: file_bytes,
|
data: file_bytes,
|
||||||
@ -2254,24 +2254,29 @@ function upload_to_release(release, file, asset_name, tag, overwrite, octokit) {
|
|||||||
'content-length': file_size
|
'content-length': file_size
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
return uploaded_asset.data.browser_download_url;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
function run() {
|
function run() {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
try {
|
try {
|
||||||
|
// Get the inputs from the workflow file: https://github.com/actions/toolkit/tree/master/packages/core#inputsoutputs
|
||||||
const token = core.getInput('repo_token', { required: true });
|
const token = core.getInput('repo_token', { required: true });
|
||||||
const file = core.getInput('file', { required: true });
|
const file = core.getInput('file', { required: true });
|
||||||
const file_glob = core.getInput('file_glob');
|
|
||||||
const tag = core.getInput('tag', { required: true }).replace('refs/tags/', '');
|
const tag = core.getInput('tag', { required: true }).replace('refs/tags/', '');
|
||||||
const overwrite = core.getInput('overwrite');
|
const file_glob = core.getInput('file_glob') == 'true' ? true : false;
|
||||||
|
const overwrite = core.getInput('overwrite') == 'true' ? true : false;
|
||||||
|
const prerelease = core.getInput('prerelease') == 'true' ? true : false;
|
||||||
|
const body = core.getInput('body');
|
||||||
const octokit = github.getOctokit(token);
|
const octokit = github.getOctokit(token);
|
||||||
const release = yield get_release_by_tag(tag, octokit);
|
const release = yield get_release_by_tag(tag, prerelease, body, octokit);
|
||||||
if (file_glob === 'true') {
|
if (file_glob) {
|
||||||
const files = glob.sync(file);
|
const files = glob.sync(file);
|
||||||
if (files.length > 0) {
|
if (files.length > 0) {
|
||||||
for (const file of files) {
|
for (const file of files) {
|
||||||
const asset_name = path.basename(file);
|
const asset_name = path.basename(file);
|
||||||
yield upload_to_release(release, file, asset_name, tag, overwrite, octokit);
|
const asset_download_url = yield upload_to_release(release, file, asset_name, tag, overwrite, octokit);
|
||||||
|
core.setOutput('browser_download_url', asset_download_url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -2282,7 +2287,8 @@ function run() {
|
|||||||
const asset_name = core
|
const asset_name = core
|
||||||
.getInput('asset_name', { required: true })
|
.getInput('asset_name', { required: true })
|
||||||
.replace(/\$tag/g, tag);
|
.replace(/\$tag/g, tag);
|
||||||
yield upload_to_release(release, file, asset_name, tag, overwrite, octokit);
|
const asset_download_url = yield upload_to_release(release, file, asset_name, tag, overwrite, octokit);
|
||||||
|
core.setOutput('browser_download_url', asset_download_url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (error) {
|
catch (error) {
|
||||||
|
40
src/main.ts
40
src/main.ts
@ -9,9 +9,12 @@ import * as glob from 'glob'
|
|||||||
type RepoAssetsResp = Endpoints['GET /repos/:owner/:repo/releases/:release_id/assets']['response']
|
type RepoAssetsResp = Endpoints['GET /repos/:owner/:repo/releases/:release_id/assets']['response']
|
||||||
type ReleaseByTagResp = Endpoints['GET /repos/:owner/:repo/releases/tags/:tag']['response']
|
type ReleaseByTagResp = Endpoints['GET /repos/:owner/:repo/releases/tags/:tag']['response']
|
||||||
type CreateReleaseResp = Endpoints['POST /repos/:owner/:repo/releases']['response']
|
type CreateReleaseResp = Endpoints['POST /repos/:owner/:repo/releases']['response']
|
||||||
|
type UploadAssetResp = Endpoints['POST /repos/:owner/:repo/releases/:release_id/assets{?name,label}']['response']
|
||||||
|
|
||||||
async function get_release_by_tag(
|
async function get_release_by_tag(
|
||||||
tag: string,
|
tag: string,
|
||||||
|
prerelease: boolean,
|
||||||
|
body: string,
|
||||||
octokit: Octokit
|
octokit: Octokit
|
||||||
): Promise<ReleaseByTagResp | CreateReleaseResp> {
|
): Promise<ReleaseByTagResp | CreateReleaseResp> {
|
||||||
try {
|
try {
|
||||||
@ -29,8 +32,8 @@ async function get_release_by_tag(
|
|||||||
return await octokit.repos.createRelease({
|
return await octokit.repos.createRelease({
|
||||||
...github.context.repo,
|
...github.context.repo,
|
||||||
tag_name: tag,
|
tag_name: tag,
|
||||||
draft: false,
|
prerelease: prerelease,
|
||||||
prerelease: true
|
body: body
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
throw error
|
throw error
|
||||||
@ -43,9 +46,9 @@ async function upload_to_release(
|
|||||||
file: string,
|
file: string,
|
||||||
asset_name: string,
|
asset_name: string,
|
||||||
tag: string,
|
tag: string,
|
||||||
overwrite: string,
|
overwrite: boolean,
|
||||||
octokit: Octokit
|
octokit: Octokit
|
||||||
): Promise<void> {
|
): Promise<undefined | string> {
|
||||||
const stat = fs.statSync(file)
|
const stat = fs.statSync(file)
|
||||||
if (!stat.isFile()) {
|
if (!stat.isFile()) {
|
||||||
core.debug(`Skipping ${file}, since its not a file`)
|
core.debug(`Skipping ${file}, since its not a file`)
|
||||||
@ -61,7 +64,7 @@ async function upload_to_release(
|
|||||||
})
|
})
|
||||||
const duplicate_asset = assets.data.find(a => a.name === asset_name)
|
const duplicate_asset = assets.data.find(a => a.name === asset_name)
|
||||||
if (duplicate_asset !== undefined) {
|
if (duplicate_asset !== undefined) {
|
||||||
if (overwrite === 'true') {
|
if (overwrite) {
|
||||||
core.debug(
|
core.debug(
|
||||||
`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`
|
`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`
|
||||||
)
|
)
|
||||||
@ -71,7 +74,7 @@ async function upload_to_release(
|
|||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
core.setFailed(`An asset called ${asset_name} already exists.`)
|
core.setFailed(`An asset called ${asset_name} already exists.`)
|
||||||
return
|
return duplicate_asset.browser_download_url
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
core.debug(
|
core.debug(
|
||||||
@ -80,7 +83,8 @@ async function upload_to_release(
|
|||||||
}
|
}
|
||||||
|
|
||||||
core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`)
|
core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`)
|
||||||
await octokit.repos.uploadReleaseAsset({
|
const uploaded_asset: UploadAssetResp = await octokit.repos.uploadReleaseAsset(
|
||||||
|
{
|
||||||
url: release.data.upload_url,
|
url: release.data.upload_url,
|
||||||
name: asset_name,
|
name: asset_name,
|
||||||
data: file_bytes,
|
data: file_bytes,
|
||||||
@ -88,26 +92,32 @@ async function upload_to_release(
|
|||||||
'content-type': 'binary/octet-stream',
|
'content-type': 'binary/octet-stream',
|
||||||
'content-length': file_size
|
'content-length': file_size
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
)
|
||||||
|
return uploaded_asset.data.browser_download_url
|
||||||
}
|
}
|
||||||
|
|
||||||
async function run(): Promise<void> {
|
async function run(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
|
// Get the inputs from the workflow file: https://github.com/actions/toolkit/tree/master/packages/core#inputsoutputs
|
||||||
const token = core.getInput('repo_token', {required: true})
|
const token = core.getInput('repo_token', {required: true})
|
||||||
const file = core.getInput('file', {required: true})
|
const file = core.getInput('file', {required: true})
|
||||||
const file_glob = core.getInput('file_glob')
|
|
||||||
const tag = core.getInput('tag', {required: true}).replace('refs/tags/', '')
|
const tag = core.getInput('tag', {required: true}).replace('refs/tags/', '')
|
||||||
const overwrite = core.getInput('overwrite')
|
|
||||||
|
const file_glob = core.getInput('file_glob') == 'true' ? true : false
|
||||||
|
const overwrite = core.getInput('overwrite') == 'true' ? true : false
|
||||||
|
const prerelease = core.getInput('prerelease') == 'true' ? true : false
|
||||||
|
const body = core.getInput('body')
|
||||||
|
|
||||||
const octokit: Octokit = github.getOctokit(token)
|
const octokit: Octokit = github.getOctokit(token)
|
||||||
const release = await get_release_by_tag(tag, octokit)
|
const release = await get_release_by_tag(tag, prerelease, body, octokit)
|
||||||
|
|
||||||
if (file_glob === 'true') {
|
if (file_glob) {
|
||||||
const files = glob.sync(file)
|
const files = glob.sync(file)
|
||||||
if (files.length > 0) {
|
if (files.length > 0) {
|
||||||
for (const file of files) {
|
for (const file of files) {
|
||||||
const asset_name = path.basename(file)
|
const asset_name = path.basename(file)
|
||||||
await upload_to_release(
|
const asset_download_url = await upload_to_release(
|
||||||
release,
|
release,
|
||||||
file,
|
file,
|
||||||
asset_name,
|
asset_name,
|
||||||
@ -115,6 +125,7 @@ async function run(): Promise<void> {
|
|||||||
overwrite,
|
overwrite,
|
||||||
octokit
|
octokit
|
||||||
)
|
)
|
||||||
|
core.setOutput('browser_download_url', asset_download_url)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
core.setFailed('No files matching the glob pattern found.')
|
core.setFailed('No files matching the glob pattern found.')
|
||||||
@ -123,7 +134,7 @@ async function run(): Promise<void> {
|
|||||||
const asset_name = core
|
const asset_name = core
|
||||||
.getInput('asset_name', {required: true})
|
.getInput('asset_name', {required: true})
|
||||||
.replace(/\$tag/g, tag)
|
.replace(/\$tag/g, tag)
|
||||||
await upload_to_release(
|
const asset_download_url = await upload_to_release(
|
||||||
release,
|
release,
|
||||||
file,
|
file,
|
||||||
asset_name,
|
asset_name,
|
||||||
@ -131,6 +142,7 @@ async function run(): Promise<void> {
|
|||||||
overwrite,
|
overwrite,
|
||||||
octokit
|
octokit
|
||||||
)
|
)
|
||||||
|
core.setOutput('browser_download_url', asset_download_url)
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message)
|
core.setFailed(error.message)
|
||||||
|
Loading…
Reference in New Issue
Block a user