* updater: cut 'v' prefix when comparing SelfUpdateMinVersion
Fix #1908 * commit '1e5419714ddcaab0913162460474dea8959529be': * (ui): fix the version check - strip the v prefix * updater: cut 'v' prefix when comparing SelfUpdateMinVersion
This commit is contained in:
commit
01957bf503
2
Makefile
2
Makefile
@ -196,7 +196,7 @@ define write_version_file
|
|||||||
echo " \"version\": \"$(version)\"," >> $(DIST_DIR)/version.json
|
echo " \"version\": \"$(version)\"," >> $(DIST_DIR)/version.json
|
||||||
echo " \"announcement\": \"AdGuard Home $(version) is now available!\"," >> $(DIST_DIR)/version.json
|
echo " \"announcement\": \"AdGuard Home $(version) is now available!\"," >> $(DIST_DIR)/version.json
|
||||||
echo " \"announcement_url\": \"https://github.com/AdguardTeam/AdGuardHome/releases\"," >> $(DIST_DIR)/version.json
|
echo " \"announcement_url\": \"https://github.com/AdguardTeam/AdGuardHome/releases\"," >> $(DIST_DIR)/version.json
|
||||||
echo " \"selfupdate_min_version\": \"v0.0\"," >> $(DIST_DIR)/version.json
|
echo " \"selfupdate_min_version\": \"0.0\"," >> $(DIST_DIR)/version.json
|
||||||
|
|
||||||
# Windows builds
|
# Windows builds
|
||||||
echo " \"download_windows_amd64\": \"$(BASE_URL)/AdGuardHome_windows_amd64.zip\"," >> $(DIST_DIR)/version.json
|
echo " \"download_windows_amd64\": \"$(BASE_URL)/AdGuardHome_windows_amd64.zip\"," >> $(DIST_DIR)/version.json
|
||||||
|
@ -12,7 +12,7 @@ module.exports = {
|
|||||||
"scope",
|
"scope",
|
||||||
"subject",
|
"subject",
|
||||||
"body",
|
"body",
|
||||||
"issues"
|
"issues",
|
||||||
],
|
],
|
||||||
"scopes": [
|
"scopes": [
|
||||||
"",
|
"",
|
||||||
|
@ -4,6 +4,7 @@ import axios from 'axios';
|
|||||||
|
|
||||||
import { splitByNewLine, sortClients } from '../helpers/helpers';
|
import { splitByNewLine, sortClients } from '../helpers/helpers';
|
||||||
import { CHECK_TIMEOUT, SETTINGS_NAMES } from '../helpers/constants';
|
import { CHECK_TIMEOUT, SETTINGS_NAMES } from '../helpers/constants';
|
||||||
|
import { areEqualVersions } from '../helpers/version';
|
||||||
import { getTlsStatus } from './encryption';
|
import { getTlsStatus } from './encryption';
|
||||||
import apiClient from '../api/Api';
|
import apiClient from '../api/Api';
|
||||||
import { addErrorToast, addNoticeToast, addSuccessToast } from './toasts';
|
import { addErrorToast, addNoticeToast, addSuccessToast } from './toasts';
|
||||||
@ -121,7 +122,7 @@ export const getVersion = (recheck = false) => async (dispatch, getState) => {
|
|||||||
const { dnsVersion } = getState().dashboard;
|
const { dnsVersion } = getState().dashboard;
|
||||||
const currentVersion = dnsVersion === 'undefined' ? 0 : dnsVersion;
|
const currentVersion = dnsVersion === 'undefined' ? 0 : dnsVersion;
|
||||||
|
|
||||||
if (data && currentVersion !== data.new_version) {
|
if (data && !areEqualVersions(currentVersion, data.new_version)) {
|
||||||
dispatch(addSuccessToast('updates_checked'));
|
dispatch(addSuccessToast('updates_checked'));
|
||||||
} else {
|
} else {
|
||||||
dispatch(addSuccessToast('updates_version_equal'));
|
dispatch(addSuccessToast('updates_version_equal'));
|
||||||
|
17
client/src/helpers/version.js
Normal file
17
client/src/helpers/version.js
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/**
|
||||||
|
* Checks if versions are equal.
|
||||||
|
* Please note, that this method strips the "v" prefix.
|
||||||
|
*
|
||||||
|
* @param left {string} - left version
|
||||||
|
* @param right {string} - right version
|
||||||
|
* @return {boolean} true if versions are equal
|
||||||
|
*/
|
||||||
|
export const areEqualVersions = (left, right) => {
|
||||||
|
if (!left || !right) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const leftVersion = left.replace(/^v/, '');
|
||||||
|
const rightVersion = right.replace(/^v/, '');
|
||||||
|
return leftVersion === rightVersion;
|
||||||
|
};
|
@ -14,6 +14,7 @@ import stats from './stats';
|
|||||||
import queryLogs from './queryLogs';
|
import queryLogs from './queryLogs';
|
||||||
import dnsConfig from './dnsConfig';
|
import dnsConfig from './dnsConfig';
|
||||||
import filtering from './filtering';
|
import filtering from './filtering';
|
||||||
|
import { areEqualVersions } from '../helpers/version';
|
||||||
|
|
||||||
const settings = handleActions(
|
const settings = handleActions(
|
||||||
{
|
{
|
||||||
@ -81,7 +82,7 @@ const dashboard = handleActions(
|
|||||||
[actions.getVersionSuccess]: (state, { payload }) => {
|
[actions.getVersionSuccess]: (state, { payload }) => {
|
||||||
const currentVersion = state.dnsVersion === 'undefined' ? 0 : state.dnsVersion;
|
const currentVersion = state.dnsVersion === 'undefined' ? 0 : state.dnsVersion;
|
||||||
|
|
||||||
if (!payload.disabled && currentVersion !== payload.new_version) {
|
if (!payload.disabled && !areEqualVersions(currentVersion, payload.new_version)) {
|
||||||
const {
|
const {
|
||||||
announcement_url: announcementUrl,
|
announcement_url: announcementUrl,
|
||||||
new_version: newVersion,
|
new_version: newVersion,
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -66,7 +67,7 @@ func (u *Updater) parseVersionResponse(data []byte) (VersionInfo, error) {
|
|||||||
|
|
||||||
if ok &&
|
if ok &&
|
||||||
info.NewVersion != u.VersionString &&
|
info.NewVersion != u.VersionString &&
|
||||||
u.VersionString >= info.SelfUpdateMinVersion {
|
strings.TrimPrefix(u.VersionString, "v") >= strings.TrimPrefix(info.SelfUpdateMinVersion, "v") {
|
||||||
info.CanAutoUpdate = true
|
info.CanAutoUpdate = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user