2018-03-01 15:42:47 +01:00
/ * *
* Project - HomeFlix
*
* Copyright 2018 < @Seil0 >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston ,
* MA 02110 - 1301 , USA .
* /
package kellerkinder.HomeFlix.controller ;
import java.io.BufferedReader ;
import java.io.File ;
import java.io.IOException ;
import java.io.InputStreamReader ;
import java.net.HttpURLConnection ;
import java.net.URL ;
import javax.swing.ProgressMonitor ;
import javax.swing.ProgressMonitorInputStream ;
import org.apache.commons.io.FileUtils ;
import org.apache.logging.log4j.LogManager ;
import org.apache.logging.log4j.Logger ;
import com.eclipsesource.json.Json ;
import com.eclipsesource.json.JsonArray ;
import com.eclipsesource.json.JsonObject ;
import com.eclipsesource.json.JsonValue ;
import javafx.application.Platform ;
import kellerkinder.HomeFlix.application.MainWindowController ;
public class UpdateController implements Runnable {
private MainWindowController mainWindowController ;
2018-11-16 17:39:38 +01:00
private int buildNumber ;
private int updateBuildNumber ; // tag_name from gitea
2018-03-01 15:42:47 +01:00
private String apiOutput ;
2018-05-16 23:05:59 +02:00
@SuppressWarnings ( " unused " )
private String updateName ;
@SuppressWarnings ( " unused " )
private String updateChanges ;
2018-11-16 17:39:38 +01:00
private String browserDownloadUrl ; // update download link
private String giteaApiRelease = " https://git.mosad.xyz/api/v1/repos/Seil0/Project-HomeFlix/releases " ;
private URL giteaApiUrl ;
2018-03-01 15:42:47 +01:00
private boolean useBeta ;
private static final Logger LOGGER = LogManager . getLogger ( UpdateController . class . getName ( ) ) ;
/ * *
* updater for Project HomeFlix based on cemu_UIs , checks for Updates and download it
2018-04-19 12:13:18 +02:00
* @param mwc the MainWindowController object
* @param buildNumber the buildNumber of the used HomeFlix version
* @param useBeta if the updater should query the beta channel
2018-03-01 15:42:47 +01:00
* /
public UpdateController ( MainWindowController mwc , String buildNumber , boolean useBeta ) {
mainWindowController = mwc ;
2018-11-16 17:39:38 +01:00
this . buildNumber = Integer . parseInt ( buildNumber ) ;
2018-03-01 15:42:47 +01:00
this . useBeta = useBeta ;
}
@Override
public void run ( ) {
LOGGER . info ( " beta: " + useBeta + " ; checking for updates ... " ) ;
Platform . runLater ( ( ) - > {
mainWindowController . getUpdateBtn ( ) . setText ( mainWindowController . getBundle ( ) . getString ( " updateBtnChecking " ) ) ;
} ) ;
try {
2018-11-16 17:39:38 +01:00
giteaApiUrl = new URL ( giteaApiRelease ) ;
BufferedReader ina = new BufferedReader ( new InputStreamReader ( giteaApiUrl . openStream ( ) ) ) ;
2018-03-01 15:42:47 +01:00
apiOutput = ina . readLine ( ) ;
ina . close ( ) ;
2018-11-16 17:39:38 +01:00
} catch ( Exception e ) {
2018-03-01 15:42:47 +01:00
Platform . runLater ( ( ) - > {
LOGGER . error ( " could not check update version " , e ) ;
} ) ;
}
2018-11-16 17:39:38 +01:00
JsonArray objectArray = Json . parse ( " { \" items \" : " + apiOutput + " } " ) . asObject ( ) . get ( " items " ) . asArray ( ) ;
JsonValue object = objectArray . get ( 0 ) . asObject ( ) ; // set to the latest release as default
JsonObject objectAsset = object . asObject ( ) . get ( " assets " ) . asArray ( ) . get ( 0 ) . asObject ( ) ;
for ( JsonValue objectIt : objectArray ) {
if ( objectIt . asObject ( ) . getBoolean ( " prerelease " , false ) = = useBeta ) {
// we found the needed release either beta or not
object = objectIt ;
objectAsset = objectIt . asObject ( ) . get ( " assets " ) . asArray ( ) . get ( 0 ) . asObject ( ) ;
break ;
2018-03-01 15:42:47 +01:00
}
}
2018-11-16 17:39:38 +01:00
updateBuildNumber = Integer . parseInt ( object . asObject ( ) . getString ( " tag_name " , " " ) ) ;
updateName = object . asObject ( ) . getString ( " name " , " " ) ;
updateChanges = object . asObject ( ) . getString ( " body " , " " ) ;
2018-03-01 15:42:47 +01:00
LOGGER . info ( " Build: " + buildNumber + " , Update: " + updateBuildNumber ) ;
2018-11-16 17:39:38 +01:00
/ * *
* Compare the program BuildNumber with the current BuildNumber
* if buildNumber < updateBuildNumber then perform a update
* /
if ( buildNumber > = updateBuildNumber ) {
2018-03-01 15:42:47 +01:00
Platform . runLater ( ( ) - > {
mainWindowController . getUpdateBtn ( ) . setText ( mainWindowController . getBundle ( ) . getString ( " updateBtnNoUpdateAvailable " ) ) ;
} ) ;
LOGGER . info ( " no update available " ) ;
} else {
Platform . runLater ( ( ) - > {
mainWindowController . getUpdateBtn ( ) . setText ( mainWindowController . getBundle ( ) . getString ( " updateBtnUpdateAvailable " ) ) ;
} ) ;
LOGGER . info ( " update available " ) ;
2018-11-16 17:39:38 +01:00
browserDownloadUrl = objectAsset . getString ( " browser_download_url " , " " ) ;
2018-03-01 15:42:47 +01:00
LOGGER . info ( " download link: " + browserDownloadUrl ) ;
try {
2018-11-16 17:39:38 +01:00
// open new HTTP connection, ProgressMonitorInputStream for downloading the data
// FIXME the download progress dialog is not showing!
2018-03-01 15:42:47 +01:00
HttpURLConnection connection = ( HttpURLConnection ) new URL ( browserDownloadUrl ) . openConnection ( ) ;
ProgressMonitorInputStream pmis = new ProgressMonitorInputStream ( null , " Downloading... " , connection . getInputStream ( ) ) ;
ProgressMonitor pm = pmis . getProgressMonitor ( ) ;
pm . setMillisToDecideToPopup ( 0 ) ;
pm . setMillisToPopup ( 0 ) ;
pm . setMinimum ( 0 ) ; // set beginning of the progress bar to 0
pm . setMaximum ( connection . getContentLength ( ) ) ; // set the end to the file length
FileUtils . copyInputStreamToFile ( pmis , new File ( " ProjectHomeFlix_update.jar " ) ) ; // download update
2018-11-16 17:39:38 +01:00
LOGGER . info ( " update download successful, restarting ... " ) ;
2018-03-01 15:42:47 +01:00
org . apache . commons . io . FileUtils . copyFile ( new File ( " ProjectHomeFlix_update.jar " ) , new File ( " ProjectHomeFlix.jar " ) ) ;
org . apache . commons . io . FileUtils . deleteQuietly ( new File ( " ProjectHomeFlix_update.jar " ) ) ; // delete update
2018-04-08 13:31:27 +02:00
new ProcessBuilder ( " java " , " -jar " , " ProjectHomeFlix.jar " ) . start ( ) ; // start the new application
System . exit ( 0 ) ; // close the current application
2018-03-01 15:42:47 +01:00
} catch ( IOException e ) {
Platform . runLater ( ( ) - > {
LOGGER . info ( " could not download update files " , e ) ;
} ) ;
}
}
}
}