Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
create-react-native-module
Advanced tools
Tool to create a React Native library module or view module with a single command
Tool to create a React Native library module or native view component, with a single command.
See below for command-line usage, example with no view, and example with an extremely simple native view.
This tool based on react-native-create-library
, with working example callbacks, optional native view, and some other updates added by @brodybits (Christoper J. Brody aka Chris Brody).
LICENSE: MIT
If you are looking to create a native module for React Native, you need some native code for each platform you want to support and then some JavaScript code to bind it all together. Setting this up by yourself can be time-consuming.
This is where this tool comes in. It creates a boilerplate with all current best practices in mind.
Why not use react-native new-library
? Unfortunately that command doesn't create an up-to-date library, requires an already initialized React Native project and only sets up the iOS side of things.
Requirements: Node 6.0+
Packages required to be installed globally if the recommended example app is generated:
$ npm install -g react-native-cli yarn
To install this package:
$ npm install -g create-react-native-module
Navigate into an empty directory to execute the command.
$ create-react-native-module MyFancyLibrary
This will create the folder MyFancyLibrary
in which the library will be created in.
Now install dependencies by running this command in the newly created library.
$ npm install
Usage: create-react-native-module [options] <name>
Options:
-h, --help output usage information
-V, --version output the version number
-p, --prefix <prefix> The prefix for the library (Default: `RN`)
--module-prefix <modulePrefix> The module prefix for the library (Default: `react-native`)
--package-identifier <packageIdentifier> (Android only!) The package name for the Android module (Default: `com.reactlibrary`)
--platforms <platforms> Platforms the library will be created for. (comma separated; default: `ios,android`)
--github-account <github_account> The github account where the library is hosted (Default: `github_account`)
--author-name <name> The author's name (Default: `Your Name`)
--author-email <email> The author's email (Default: `yourname@email.com`)
--license <license> The license type of this library (Default: `Apache-2.0`)
--view Generate the module as a very simple native view component (Default: `false`)
--generate-example <shouldGenerate> Generate an example project and links the library module to it, requires both react-native-cli and yarn to be installed globally (Default: `false`)
const createLibrary = require('create-react-native-module');
createLibrary({
name: 'MyFancyLibrary'
}).then(() => {
console.log('Oh yay! My library has been created!');
})
{
name: String, /* The name of the library (Default: Library) */
prefix: String, /* The prefix for the library (Default: RN) */
modulePrefix: String, /* The module prefix for the library (Default: react-native) */
platforms: Array, /* Platforms the library will be created for. (Default: ['ios', 'android']) */
packageIdentifier: String, /* (Android only!) The package name for the Android module (Default: com.reactlibrary) */
githubAccount: String, /* The github account where the library is hosted (Default: `github_account`) */
authorName: String, /* The author's name (Default: `Your Name`) */
authorEmail: String, /* The author's email (Default: `yourname@email.com`) */
license: String, /* The license type of this library (Default: `Apache-2.0`) */
view: Boolean, /* Generate the module as a very simple native view component (Default: `false`) */
generateExample: Boolean, /* Generate an example project and links the library module to it, requires both react-native-cli and yarn to be installed globally (Default: `false`) */
}
Create the module with no view:
create-react-native-module --prefix CB --package-identifier io.mylibrary --generate-example AliceHelper
The module would be generated in the react-native-alice-helper
subdirectory, and the example test app would be in react-native-alice-helper/example
. (Note that this tool will show an incorrect project name when it is finished.)
Then go into the example app subdirectory:
cd react-native-alice-helper/example
Within the example test app subdirectory:
It is recommended to start the Metro Bundler manually (within react-native-alice-helper/example
), which would run in the foreground:
npm start
Otherwise, React Native will open its own window to run the Metro Bundler.
To run on Android, do the following command (within react-native-alice-helper/example
):
react-native run-android
This assumes that the ANDROID_HOME
environmental variable is set properly. Here is a sample command that does not make such an assumption on a mac:
ANDROID_HOME=~/Library/Android/sdk react-native run-android
To run on iOS:
react-native run-ios
or do the following command to open the iOS project in Xcode:
open ios/example.xcodeproj
Expected result:
The example app shows the following indications:
Create the module with an extremely simple view:
create-react-native-module --prefix CB --package-identifier io.mylibrary --view --generate-example CarolWidget
The module would be generated in the react-native-alice-helper
subdirectory, and the example test app would be in react-native-alice-helper/example
. (Note that this tool will show an incorrect project name when it is finished.)
Then go into the example app subdirectory:
cd react-native-carol-widget/example
Within the example test app subdirectory:
It is recommended to start the Metro Bundler manually as described above (within react-native-carol-widget/example
):
npm start
To run on Android, do react-native run-android
as described for the other example above.
To run on iOS, do react-native run-ios
or open ios/example.xcodeproj
as described for the other example above.
Expected result:
react-native-create-library
- original basis of this projectreact-native-share
- was acknowledged as "a great source of inspiration" for react-native-create-library
0.1.0
based on react-native-create-library commit e08c03cad
#if __has_include
condition on iOSexamples_postinstall.js
FAQs
Tool to create a React Native library module or view module with a single command
The npm package create-react-native-module receives a total of 401 weekly downloads. As such, create-react-native-module popularity was classified as not popular.
We found that create-react-native-module 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.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.