const fs = require('fs-extra')
const {chdir} = require('process')
const path = require('path')
const exec = require('./lib').exec
const escapeStringRegexp = require('escape-string-regexp');
module.exports = async function (context) {
//console.log(context)
const originalDir = process.cwd()
const dirname = context.outDir
chdir(dirname)
const packageDir = 'squashfs-root'
let downloaded = false
const appimagetool = 'appimagetool';
const assetsUploads = [
// 'latest-linux.yml',
// 'latest-linux-ia32.yml',
]
for(let artifact of context.artifactPaths) {
if (artifact.toLowerCase().endsWith('appimage')) {
if (downloaded === false) {
await exec(
"curl",
[
"--fail",
"--location",
"--output", appimagetool,
`https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage`,
],
);
await exec("chmod", ["+x", appimagetool]);
downloaded = true
}
artifact = artifact.replace(/(\s+)/g, '\\$1')
await exec('rm', ['-rf', packageDir])
// await exec('chmod', ['+x', artifact])
await exec(artifact, ['--appimage-extract'])
const shFile = path.join(packageDir, "./AppRun");
const shContentOriginal = fs.readFileSync(shFile).toString();
const searchValue = `exec "$BIN"`;
const replaceWith = `${searchValue} --no-sandbox`;
let count = 0;
const content = shContentOriginal.replace(
new RegExp(escapeStringRegexp(searchValue), "g"),
() => (count++, replaceWith),
);
if (content === shContentOriginal || count !== 2) {
throw new Error(`Failed to patch content of the "${shFile}" file`);
}
fs.writeFileSync(shFile, content);
// await exec('rm', ['-rf', artifact])
const uploadArtifact = artifact.replace(/ /g, '-')
await exec(dirname + '/' + appimagetool, [
'-n',
'--comp',
'xz',
packageDir,
uploadArtifact,
])
assetsUploads.unshift(
path.basename(uploadArtifact)
)
}
}
await exec('find',[
`-iname "* *.AppImage"`,
`-delete`
])
const githubToken = fs.readFileSync(`${originalDir}/secure/token.txt`)
const GitHub = require('github-api');
var gh = new GitHub({
username: 'p3x-robot',
token: githubToken
/* also acceptable:
token: 'MY_OAUTH_TOKEN'
*/
});
const pkg = require('../../package')
const repo = await gh.getRepo('patrikx3', pkg.corifeus.reponame)
const result = await repo.createRelease({
"tag_name": 'v' + pkg.version,
"target_commitish": "master",
"name": pkg.version,
"body": `
https://github.com/patrikx3/${pkg.corifeus.reponame}/blob/master/changelog.md#v${pkg.version.replace(/\./g, '')}
[![Snapcraft](https://snapcraft.io/static/images/badges/en/snap-store-white.svg)](https://snapcraft.io/${pkg.name}#cory-non-external)
`,
"draft": true,
"prerelease": false
})
const upload_url = result.data.upload_url.replace('{?name,label}', '')
/// console.log('results', result)
for (let uploadAsset of assetsUploads) {
const args = [
`--request POST`,
`--data-binary @${dirname + '/' + uploadAsset}`,
`-H "Authorization: token ${githubToken}"`,
`-H "Content-Type: application/octet-stream"`,
`${upload_url}?name=${uploadAsset}`,
//``,
]
if (uploadAsset.endsWith('yml')) {
await exec('cat', [
dirname + '/' + uploadAsset
])
}
console.info('curl args', args)
await exec('curl', args)
}
await exec('rm', ['-rf', packageDir])
chdir(originalDir)
}