![Malicious npm Package Typosquats react-login-page to Deploy Keylogger](https://cdn.sanity.io/images/cgdhsj6q/production/007b21d9cf9e03ae0bb3f577d1bd59b9d715645a-1024x1024.webp?w=400&fit=max&auto=format)
Research
Security News
Malicious npm Package Typosquats react-login-page to Deploy Keylogger
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
react-native-rsa-native
Advanced tools
Readme
A native implementation of RSA key generation and encryption/decryption, sign/verify. Keychain implementation Implementation is in PKCS1
iOS 10+ android 4.1+ (API 16)
Features: Generation, Encryption, Decryption, Sign, Verify, Keychain support
$ yarn add react-native-rsa-native
or:
$ npm install react-native-rsa-native --save
$ react-native link react-native-rsa-native
In your React Native Xcode project, right click on your project and go 'Add Files to ...', then navigate to /node_modules/react-native-rsa-native/ios and select the RNRSA.xcodeproj file. Then in the build settings for your target under 'Link Binary With Libraries', add libRNRSA.a.
import {RSA, RSAKeychain} from 'react-native-rsa-native';
RSA.generateKeys(4096) // set key size
.then(keys => {
console.log('4096 private:', keys.private) // the private key
console.log('4096 public:', keys.public) // the public key
})
RSA.generate()
.then(keys => {
console.log(keys.private) // the private key
console.log(keys.public) // the public key
RSA.encrypt('1234', keys.public)
.then(encodedMessage => {
RSA.decrypt(encodedMessage, keys.private)
.then(message => {
console.log(message);
})
})
RSA.sign(secret, keys.private)
.then(signature => {
console.log(signature);
RSA.verify(signature, secret, keys.public)
.then(valid => {
console.log(valid);
})
})
})
// Example utilizing the keychain for private key secure storage
let keyTag = 'com.domain.mykey';
let secret = "secret message";
RSAKeychain.generate(keyTag)
.then(keys => {
console.log(keys.public);
console.log(secret);
return RSAKeychain.encrypt(secret, keyTag)
.then(encodedMessage => {
console.log(encodedMessage);
RSAKeychain.decrypt(encodedMessage, keyTag)
.then(message => {
console.log(message);
})
})
})
.then(() => {
return RSAKeychain.sign(secret, keyTag)
.then(signature => {
console.log('signature', signature);
RSAKeychain.verify(signature, secret, keyTag)
.then(valid => {
console.log('verified', valid);
})
})
})
.then(() => {
RSAKeychain.deletePrivateKey(keyTag)
.then( success => {
console.log('delete success', success)
})
});
Check out example App.js for a full example
ETH: 0xDc2F8D78098749EB3ECdF79Fe32Efda86fEEFc3c
FAQs
Unknown package
The npm package react-native-rsa-native receives a total of 10,089 weekly downloads. As such, react-native-rsa-native popularity was classified as popular.
We found that react-native-rsa-native demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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
Security News
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
Security News
The JavaScript community has launched the e18e initiative to improve ecosystem performance by cleaning up dependency trees, speeding up critical parts of the ecosystem, and documenting lighter alternatives to established tools.
Product
Socket now supports four distinct alert actions instead of the previous two, and alert triaging allows users to override the actions taken for all individual alerts.