2022-10-24 19:51:26 +08:00
import { version } from "../version.ts" ;
export async function upgradeCommand() {
2022-10-29 22:06:18 +08:00
console . log ( "Now going to attempt an upgrade..." ) ;
2022-10-24 19:51:26 +08:00
const p = Deno . run ( {
cmd : [ "deno" , "cache" , "--reload" , Deno . mainModule ] ,
} ) ;
const exitCode = await p . status ( ) ;
if ( ! exitCode . success ) {
console . error ( "Something went wrong there..." ) ;
Deno . exit ( 1 ) ;
}
console . log (
"So, that's done. Now let's see if this actually did anything..." ,
) ;
const vp = Deno . run ( {
cmd : [ "deno" , "run" , "-A" , "--unstable" , Deno . mainModule , "version" ] ,
stdout : "piped" ,
} ) ;
const versionStatus = await vp . status ( ) ;
if ( ! versionStatus . success ) {
console . error ( "Could not run version command, something is wrong." ) ;
Deno . exit ( 1 ) ;
}
const rawVersion = await vp . output ( ) ;
const newVersion = new TextDecoder ( ) . decode ( rawVersion ) . trim ( ) ;
if ( newVersion === version ) {
console . log (
2022-12-13 13:04:28 +08:00
` Nope. I hate to tell you this, but it looks like we're still running ${ newVersion } . This was a bit of a futile exercise. Let's try again soon some time. ` ,
2022-10-24 19:51:26 +08:00
) ;
} else {
console . log (
2022-12-13 13:04:28 +08:00
` Congrats, we've upgraded you from ${ version } to ${ newVersion } . Seems like quite a bump, enjoy! https://silverbullet.md/CHANGELOG may give you more hints on what's new. ` ,
2022-10-24 19:51:26 +08:00
) ;
}
}
2023-07-02 21:43:02 +08:00
// WIP: This is not yet working, but it's a start
import { dirname } from "https://deno.land/std@0.186.0/path/mod.ts" ;
const silverBulletReleases =
"https://github.com/silverbulletmd/silverbullet/releases" ;
export async function compiledUpgradeCommand() {
console . log ( "Now going to attempt an upgrade..." ) ;
const resp = await fetch ( ` ${ silverBulletReleases } /latest ` , {
redirect : "manual" ,
} ) ;
const versionedUrl = resp . headers . get ( "location" ) ! ;
const latestVersion = /([^\/]+)$/ . exec ( versionedUrl ) ;
if ( ! latestVersion ) {
console . error ( "Could not fetch latest version" ) ;
}
if ( version === latestVersion ! [ 0 ] ) {
console . log ( "No version available, we're done here!" ) ;
return ;
}
console . log (
"New version available:" ,
latestVersion ! [ 0 ] ,
"which I will now personally download. Hang on..." ,
) ;
const installDir = dirname ( new URL ( Deno . mainModule ) . pathname ) ;
const tmpDir = Deno . makeTempDirSync ( ) ;
// const zipUrl = "https://github.com/silverbulletmd/silverbullet/releases/download/test-release/silverbullet-server-apple-aarch64.zip";
const zipUrl =
` ${ versionedUrl } /download/silverbullet-server- ${ Deno . build . os } - ${ Deno . build . arch } .zip ` ;
const zipPath = ` ${ tmpDir } /silverbullet.zip ` ;
const command = new Deno . Command ( "curl" , {
args : [
"-L" ,
"-o" ,
zipPath ,
zipUrl ,
] ,
} ) ;
const curlOutput = await command . output ( ) ;
console . log (
"Now going to replace the existing silverbullet binary in" ,
installDir ,
) ;
if ( curlOutput . code !== 0 ) {
console . error (
"Download failed" ,
new TextDecoder ( ) . decode ( curlOutput . stderr ) ,
) ;
return ;
}
const unzipCommand = new Deno . Command ( "unzip" , {
args : [
"-o" ,
"-d" ,
installDir ,
` ${ tmpDir } /silverbullet.zip ` ,
] ,
} ) ;
const zipOutput = await unzipCommand . output ( ) ;
if ( zipOutput . code !== 0 ) {
console . error (
"Download failed" ,
new TextDecoder ( ) . decode ( curlOutput . stderr ) ,
) ;
return ;
}
await Deno . chmod ( ` ${ installDir } /silverbullet ` , 0 o755 ) ;
await Deno . remove ( zipPath ) ;
console . log ( "And done! Restart your server to get the latest and greatest!" ) ;
}