chore: change building target to .deb for Linux (#1103)

It was decided to rollback to Debian builds for Linux due to how inconvenient it is to launch an AppImage build.
This commit is contained in:
Igor Gassmann 2018-03-14 20:22:54 -04:00 committed by GitHub
parent 6497b46344
commit 40ab6e1b38
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 111 additions and 54 deletions

View file

@ -45,6 +45,6 @@ addons:
artifacts: artifacts:
working_dir: dist working_dir: dist
paths: paths:
- $(git ls-files -o dist/{*.dmg,*.exe,*.AppImage} | tr "\n" ":") - $(git ls-files -o dist/{*.dmg,*.exe,*.deb} | tr "\n" ":")
target_paths: target_paths:
- /app/build-${TRAVIS_BUILD_NUMBER}_commit-${TRAVIS_COMMIT:0:7}$([ ! -z ${TRAVIS_TAG} ] && echo "_tag-${TRAVIS_TAG}") - /app/build-${TRAVIS_BUILD_NUMBER}_commit-${TRAVIS_COMMIT:0:7}$([ ! -z ${TRAVIS_TAG} ] && echo "_tag-${TRAVIS_TAG}")

View file

@ -19,7 +19,6 @@ Web UI version numbers should always match the corresponding version of LBRY App
### Changed ### Changed
* Improved privacy by allowing users to turn off the file view counter and better understand privacy settings ([#1074](https://github.com/lbryio/lbry-app/pull/1074)) * Improved privacy by allowing users to turn off the file view counter and better understand privacy settings ([#1074](https://github.com/lbryio/lbry-app/pull/1074))
* Disabled auto dark mode if dark mode is selected ([#1006](https://github.com/lbryio/lbry-app/pull/1006)) * Disabled auto dark mode if dark mode is selected ([#1006](https://github.com/lbryio/lbry-app/pull/1006))
* AppImage support for Linux instead of .deb ([#1010](https://github.com/lbryio/lbry-app/pull/1010))
* Refactor Electron's main process ([#951](https://github.com/lbryio/lbry-app/pull/951)) * Refactor Electron's main process ([#951](https://github.com/lbryio/lbry-app/pull/951))
* Refactor lbryuri.js into separate named exports ([#957](https://github.com/lbryio/lbry-app/pull/957)) * Refactor lbryuri.js into separate named exports ([#957](https://github.com/lbryio/lbry-app/pull/957))
* Keep node_modules up-to-date when yarn.lock changes due to git ([#955](https://github.com/lbryio/lbry-app/pull/955)) * Keep node_modules up-to-date when yarn.lock changes due to git ([#955](https://github.com/lbryio/lbry-app/pull/955))

View file

@ -1,12 +1,15 @@
{ {
"appId": "io.lbry.LBRY", "appId": "io.lbry.LBRY",
"productName": "LBRY", "productName": "LBRY",
"publish": [{ "publish": [
"provider": "s3", {
"bucket": "build.lbry.io", "provider": "s3",
"path": "app/release", "bucket": "build.lbry.io",
"region": "us-east-1" "path": "app/release",
}, "github"], "region": "us-east-1"
},
"github"
],
"mac": { "mac": {
"target": "dmg", "target": "dmg",
"category": "public.app-category.entertainment" "category": "public.app-category.entertainment"
@ -41,12 +44,23 @@
} }
], ],
"linux": { "linux": {
"target": "AppImage", "target": "deb",
"category": "AudioVideo;Video", "category": "AudioVideo;Video",
"desktop": { "desktop": {
"MimeType": "x-scheme-handler/lbry;" "MimeType": "x-scheme-handler/lbry;"
} }
}, },
"deb": {
"depends": [
"gconf2",
"gconf-service",
"libnotify4",
"libappindicator1",
"libxtst6",
"libnss3",
"libsecret-1-0"
]
},
"nsis": { "nsis": {
"perMachine": true "perMachine": true
}, },

View file

@ -100,17 +100,18 @@ const init = () => {
app.store.dispatch(doAutoUpdate()); app.store.dispatch(doAutoUpdate());
}); });
autoUpdater.on('update-available', () => { if (['win32', 'darwin'].includes(process.platform)) {
console.log('Update available'); autoUpdater.on('update-available', () => {
}); console.log('Update available');
autoUpdater.on('update-not-available', () => { });
console.log('Update not available'); autoUpdater.on('update-not-available', () => {
}); console.log('Update not available');
autoUpdater.on('update-downloaded', () => { });
console.log('Update downloaded'); autoUpdater.on('update-downloaded', () => {
app.store.dispatch(doAutoUpdate()); console.log('Update downloaded');
}); app.store.dispatch(doAutoUpdate());
});
}
app.store.dispatch(doUpdateIsNightAsync()); app.store.dispatch(doUpdateIsNightAsync());
app.store.dispatch(doDownloadLanguages()); app.store.dispatch(doDownloadLanguages());

View file

@ -21,6 +21,7 @@ import {
selectUpgradeDownloadPath, selectUpgradeDownloadPath,
selectUpgradeFilename, selectUpgradeFilename,
selectAutoUpdateDeclined, selectAutoUpdateDeclined,
selectRemoteVersion,
} from 'redux/selectors/app'; } from 'redux/selectors/app';
import { lbrySettings as config } from 'package.json'; import { lbrySettings as config } from 'package.json';
@ -70,37 +71,6 @@ export function doStartUpgrade() {
}; };
} }
export function doDownloadUpgradeRequested() {
// This means the user requested an upgrade by clicking the "upgrade" button in the navbar.
// If on Mac and Windows, we do some new behavior for the auto-update system.
// This will probably be reorganized once we get auto-update going on Linux and remove
// the old logic.
return (dispatch, getState) => {
const state = getState();
// Pause video if needed
dispatch(doPause());
const autoUpdateDeclined = selectAutoUpdateDeclined(state);
if (autoUpdateDeclined) {
// The user declined an update before, so show the "confirm" dialog
dispatch({
type: ACTIONS.OPEN_MODAL,
data: { modal: MODALS.AUTO_UPDATE_CONFIRM },
});
} else {
// The user was never shown the original update dialog (e.g. because they were
// watching a video). So show the initial "update downloaded" dialog.
dispatch({
type: ACTIONS.OPEN_MODAL,
data: { modal: MODALS.AUTO_UPDATE_DOWNLOADED },
});
}
};
}
export function doDownloadUpgrade() { export function doDownloadUpgrade() {
return (dispatch, getState) => { return (dispatch, getState) => {
const state = getState(); const state = getState();
@ -140,6 +110,43 @@ export function doDownloadUpgrade() {
}; };
} }
export function doDownloadUpgradeRequested() {
// This means the user requested an upgrade by clicking the "upgrade" button in the navbar.
// If on Mac and Windows, we do some new behavior for the auto-update system.
// This will probably be reorganized once we get auto-update going on Linux and remove
// the old logic.
return (dispatch, getState) => {
const state = getState();
// Pause video if needed
dispatch(doPause());
const autoUpdateDeclined = selectAutoUpdateDeclined(state);
if (['win32', 'darwin'].includes(process.platform)) {
// electron-updater behavior
if (autoUpdateDeclined) {
// The user declined an update before, so show the "confirm" dialog
dispatch({
type: ACTIONS.OPEN_MODAL,
data: { modal: MODALS.AUTO_UPDATE_CONFIRM },
});
} else {
// The user was never shown the original update dialog (e.g. because they were
// watching a video). So show the inital "update downloaded" dialog.
dispatch({
type: ACTIONS.OPEN_MODAL,
data: { modal: MODALS.AUTO_UPDATE_DOWNLOADED },
});
}
} else {
// Old behavior for Linux
dispatch(doDownloadUpgrade());
}
};
}
export function doAutoUpdate() { export function doAutoUpdate() {
return dispatch => { return dispatch => {
dispatch({ dispatch({
@ -192,11 +199,47 @@ export function doCheckUpgradeAvailable() {
type: ACTIONS.CHECK_UPGRADE_START, type: ACTIONS.CHECK_UPGRADE_START,
}); });
const autoUpdateDeclined = selectAutoUpdateDeclined(state); if (['win32', 'darwin'].includes(process.platform)) {
// On Windows and Mac, updates happen silently through
// electron-updater.
const autoUpdateDeclined = selectAutoUpdateDeclined(state);
if (!autoUpdateDeclined && !isDev) { if (!autoUpdateDeclined && !isDev) {
autoUpdater.checkForUpdates(); autoUpdater.checkForUpdates();
}
return;
} }
const success = ({ remoteVersion, upgradeAvailable }) => {
dispatch({
type: ACTIONS.CHECK_UPGRADE_SUCCESS,
data: {
upgradeAvailable,
remoteVersion,
},
});
if (
upgradeAvailable &&
!selectCurrentModal(state) &&
(!selectIsUpgradeSkipped(state) || remoteVersion !== selectRemoteVersion(state))
) {
dispatch({
type: ACTIONS.OPEN_MODAL,
data: {
modal: MODALS.UPGRADE,
},
});
}
};
const fail = () => {
dispatch({
type: ACTIONS.CHECK_UPGRADE_FAIL,
});
};
Lbry.getAppVersionInfo().then(success, fail);
}; };
} }