-
Notifications
You must be signed in to change notification settings - Fork 119
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: checks for indexer and keychain compatibility
- Loading branch information
1 parent
9af3ad3
commit 6382ce6
Showing
7 changed files
with
181 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
import { indexerHeartbeatAtom } from "atoms/settings"; | ||
import { useNamadaKeychain } from "hooks/useNamadaKeychain"; | ||
import { useAtomValue } from "jotai"; | ||
import { ReactNode, useEffect, useState } from "react"; | ||
import { IoWarning } from "react-icons/io5"; | ||
import { | ||
checkIndexerCompatibilityErrors, | ||
checkKeychainCompatibilityError, | ||
} from "utils/compatibility"; | ||
|
||
export const FixedWarningBanner = (): JSX.Element => { | ||
const [errorMessage, setErrorMessage] = useState<ReactNode | undefined>(); | ||
const indexerHealth = useAtomValue(indexerHeartbeatAtom); | ||
const keychain = useNamadaKeychain(); | ||
|
||
const verifyKeychainVersion = async (): Promise<void> => { | ||
const namadaKeychain = await keychain.namadaKeychain.get(); | ||
if (namadaKeychain) { | ||
const version = namadaKeychain.version(); | ||
const versionErrorMessage = checkKeychainCompatibilityError(version); | ||
if (versionErrorMessage) { | ||
setErrorMessage(versionErrorMessage); | ||
} | ||
} | ||
}; | ||
|
||
const verifyIndexerVersion = async (): Promise<void> => { | ||
const versionErrorMessage = checkIndexerCompatibilityErrors( | ||
indexerHealth.data?.version || "" | ||
); | ||
if (versionErrorMessage) { | ||
setErrorMessage(versionErrorMessage); | ||
} | ||
}; | ||
|
||
useEffect(() => { | ||
verifyKeychainVersion(); | ||
}, [keychain]); | ||
|
||
useEffect(() => { | ||
indexerHealth.isSuccess && verifyIndexerVersion(); | ||
}, [indexerHealth]); | ||
|
||
if (!errorMessage) return <></>; | ||
|
||
return ( | ||
<div className="fixed bottom-0 left-0 w-full bg-yellow z-[9999]"> | ||
<div className="flex flex-row justify-center items-center gap-1 px-12 py-3 text-sm [&_a]:underline"> | ||
<strong className="inline-flex items-center"> | ||
<IoWarning /> WARNING:{" "} | ||
</strong> | ||
<div>{errorMessage}</div> | ||
</div> | ||
</div> | ||
); | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
{ | ||
"keychain": "0.3.x", | ||
"indexer": "1.1.x" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
import { routes } from "App/routes"; | ||
import compatibilty from "compatibility.json"; | ||
import { wallets } from "integrations"; | ||
import { Link } from "react-router-dom"; | ||
import semverSatisfies from "semver/functions/satisfies"; | ||
import semverLtr from "semver/ranges/ltr"; | ||
|
||
// Checks if the versions are compatible using semantic versioning (semver). | ||
// Returns true if the versions are compatible, -1 if the version is outdated, | ||
// or 1 if a required version is lower than the version provided. | ||
const checkVersionsCompatible = ( | ||
currentVersion: string, | ||
requiredVersion: string | ||
): -1 | 1 | boolean => { | ||
if (semverSatisfies(currentVersion, requiredVersion)) { | ||
return true; | ||
} | ||
return semverLtr(currentVersion, requiredVersion) ? -1 : 1; | ||
}; | ||
|
||
export const checkIndexerCompatibilityErrors = ( | ||
indexerVersion: string | ||
): React.ReactNode => { | ||
const requiredVersion = compatibilty.indexer; | ||
const checkResult = checkVersionsCompatible(indexerVersion, requiredVersion); | ||
|
||
if (checkResult === -1) { | ||
return ( | ||
<> | ||
You're using an outdated version of Namada Indexer. Please update | ||
your indexer URL in the{" "} | ||
<Link to={routes.settingsAdvanced}>Advanced Settings</Link> section. | ||
</> | ||
); | ||
} | ||
|
||
if (checkResult === 1) { | ||
return ( | ||
<> | ||
Your Namadillo version is not compatible with the current Namada | ||
Indexer. Please upgrade your web interface or pick a different one from | ||
the <a href="https://namada.net/apps#interfaces">Namada Apps</a> list. | ||
</> | ||
); | ||
} | ||
|
||
return ""; | ||
}; | ||
|
||
export const checkKeychainCompatibilityError = ( | ||
keychainVersion: string | ||
): React.ReactNode => { | ||
const targetKeychainVersion = compatibilty.keychain; | ||
const checkResult = checkVersionsCompatible( | ||
keychainVersion, | ||
targetKeychainVersion | ||
); | ||
|
||
if (checkResult === -1) { | ||
return ( | ||
<> | ||
Your Namada Keychain version is outdated. Please upgrade it using{" "} | ||
<a | ||
href={wallets.namada.downloadUrl.chrome} | ||
target="_blank" | ||
rel="nofollow noreferrer" | ||
> | ||
Chrome store | ||
</a>{" "} | ||
or{" "} | ||
<a | ||
href={wallets.namada.downloadUrl.firefox} | ||
target="_blank" | ||
rel="nofollow noreferrer" | ||
> | ||
Firefox addons | ||
</a>{" "} | ||
websites. | ||
</> | ||
); | ||
} | ||
|
||
if (checkResult === 1) { | ||
return ( | ||
<> | ||
Your Namadillo version is not compatible with the keychain installed. | ||
Please upgrade your web interface or pick a different one from the{" "} | ||
<a href="https://namada.net/apps#interfaces">Namada Apps</a> list. | ||
</> | ||
); | ||
} | ||
|
||
return ""; | ||
}; |