
Research
Two Malicious Rust Crates Impersonate Popular Logger to Steal Wallet Keys
Socket uncovers malicious Rust crates impersonating fast_log to steal Solana and Ethereum wallet keys from source code.
@nativescript/appavailability
Advanced tools
A NativeScript plugin to check for availability of other apps on the device.
A plugin to check for availability of other apps on the device.
ns plugin add @nativescript/appavailability
Note that version 1.3.0 added a synchronous version of this method that doesn't return a Promise. Need that? Use
availableSync
instead ofavailable
.
const isAppAvailable = require("@nativescript/appavailability").available;
// examples of what to pass:
// - for iOS: "maps://", "twitter://", "fb://"
// - for Android: "com.facebook.katana"
appavailability.available("twitter://").then((avail: boolean) => {
console.log("App available? " + avail);
})
import * as appavailability from "@nativescript/appavailability";
// examples of what to pass:
// - for iOS: "maps://", "twitter://", "fb://"
// - for Android: "com.facebook.katana"
appavailability.available("twitter://").then((avail: boolean) => {
console.log("App available? " + avail);
})
var appAvailability = require("@nativescript/appavailability");
// examples of what to pass:
// - for iOS: "maps://", "twitter://", "fb://"
// - for Android: "com.facebook.katana"
appAvailability.available("com.facebook.katana").then(function(avail) {
console.log("App available? " + avail);
})
Now that you know whether an app is installed or not, you probably want to launch it. Here's a snippet that opens the mobile Twitter app and falls back to the website if it's not installed.
import { available } from "@nativescript/appavailability";
import { Utils } from "@nativescript/core";
const twitterScheme = "twitter://";
available(twitterScheme).then(available => {
if (available) {
// open in the app
Utils.openUrl(twitterScheme + (isIOS ? "/user?screen_name=" : "user?user_id=") + "eddyverbruggen");
} else {
// open in the default browser
Utils.openUrl("https://twitter.com/eddyverbruggen");
}
})
And a more concise, synchronous way would be:
import { availableSync } from "@nativescript/appavailability";
import { Utils } from "@nativescript/core";
if (availableSync("twitter://")) {
Utils.openUrl("twitter://" + (isIOS ? "/user?screen_name=" : "user?user_id=") + "eddyverbruggen");
} else {
Utils.openUrl("https://twitter.com/eddyverbruggen");
}
To get useful results on iOS 9 and up you need to whitelist the URL Scheme
you're querying in the application's .plist
.
Luckily NativeScript made this pretty easy. Just open app/App_ResourcesiOS/Info.plist
and add this if you want to query for both twitter://
and fb://
:
<key>LSApplicationQueriesSchemes</key>
<array>
<string>fb</string>
<string>twitter</string>
</array>
You may wonder how one would determine the correct identifier for an app.
Android: simply search the Play Store and use the id in the URL. For Twitter this is com.twitter.android because the URL is https://play.google.com/store/apps/details?id=com.twitter.android.
iOS: this one is a bit harder but this site should cover most apps you're interested in. When in doubt you can always fire up Safari on your iPhone and type for example 'twitter://' in the address bar, if the app launches you're good.
Apache License Version 2.0
FAQs
A NativeScript plugin to check for availability of other apps on the device.
We found that @nativescript/appavailability demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 14 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Socket uncovers malicious Rust crates impersonating fast_log to steal Solana and Ethereum wallet keys from source code.
Research
A malicious package uses a QR code as steganography in an innovative technique.
Research
/Security News
Socket identified 80 fake candidates targeting engineering roles, including suspected North Korean operators, exposing the new reality of hiring as a security function.