react-native-ssl-pin
v0.2.0
Published
React-Native Ssl pinning using OkHttp 3 in Android, and AFNetworking on iOS.
Downloads
11
Readme
react-native-ssl-pinning
React-Native Ssl pinning using OkHttp 3 in Android, and AFNetworking on iOS.
Getting started
$ npm install react-native-ssl-pinning --save
Mostly automatic installation
$ react-native link react-native-ssl-pinning
Manual installation
iOS is not working yet
- In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
- Go to
node_modules
➜react-native-ssl-pinning
and addRNSslPinning.xcodeproj
- In XCode, in the project navigator, select your project. Add
libRNSslPinning.a
to your project'sBuild Phases
➜Link Binary With Libraries
- Run your project (
Cmd+R
)<
Android
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import com.hosseinmd.RNSslPinningPackage;
to the imports at the top of the file - Add
new RNSslPinningPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-ssl-pinning' project(':react-native-ssl-pinning').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-ssl-pinning/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-ssl-pinning')
Usage
Create the certificates:
openssl s_client -showcerts -connect google.com:443 (replace google with your domain)
Copy the certificate (Usally the first one in the chain), and paste it using nano or other editor like so , nano mycert.pem
convert it to .cer with this command openssl x509 -in mycert.pem -outform der -out mycert.cer
iOS is not working yet
- drag mycert.cer to Xcode project, mark your target and 'Copy items if needed'
Android
- Place your .cer files under src/main/assets/.
import {fetch, SSLPinning, cancel, removeCookieByName} from 'react-native-ssl-pinning';
SSLPinning(url, { trust: true })
//or
SSLPinning(url, { certs: [ "cert1", "cert2" ] })
await fetch(url, {
method: "POST" ,
timeoutInterval: communication_timeout,
body: body,
headers: {
Accept: "application/json; charset=utf-8", "Access-Control-Allow-Origin": "*", "e_platform": "mobile",
}
tag:"cancel_tag",
})
await cancel("cancel_tag")
removeCookieByName('cookieName')
.then(res =>{
console.log('removeCookieByName');
})
getCookies('domain')
.then(cookies => {
// do what you need with your cookies
})
Multipart request (FormData)
let formData = new FormData()
//You could add a key/value pair to this using #FormData.append:
formData.append('username', 'Chris');
// Adding a file to the request
formData.append('file', {
name: encodeURIComponent(response.fileName),
fileName: encodeURIComponent(response.fileName),
type: this._extractFileType(response.fileName),
uri: response.uri,
data: response.data // needed for ios in base64
})
await fetch(url, {
method: "POST" ,
timeoutInterval: communication_timeout,
body: {
formData,
},
headers: {
'content-type': 'multipart/form-data; charset=UTF-8',
accept: 'application/json, text/plain, /',
}
})
License
This project is licensed under the terms of the MIT license.