Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rainbow-me/react-native-cloud-fs
https://github.com/rainbow-me/react-native-cloud-fs
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/rainbow-me/react-native-cloud-fs
- Owner: rainbow-me
- Fork: true (npomfret/react-native-cloud-fs)
- Created: 2020-07-15T04:15:42.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-04-19T07:53:07.000Z (over 1 year ago)
- Last Synced: 2024-07-11T18:14:50.328Z (2 months ago)
- Language: Java
- Size: 331 KB
- Stars: 7
- Watchers: 3
- Forks: 16
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# react-native-cloud-fs
A react-native library for reading and writing files to _iCloud Drive_ (iOS) and _Google Drive_ (Android).
[Getting started](./docs/getting-started.md)
## Usage
```javascript
import RNCloudFs from 'react-native-cloud-fs';
```### fileExists (options)
Returns a promise which when resolved returns a boolean value indicating if the specified path already exists.```javascript
const destinationPath = "foo-bar/docs/info.pdf";
const scope = 'visible';RNCloudFs.fileExists({
targetPath: destinationPath,
scope: scope
})
.then((exists) => {
console.log(exists ? "this file exists" : "this file does not exist");
})
.catch((err) => {
console.warn("it failed", err);
})
```
_targetPath_: a path_scope_: determines if the user-visible documents (`visible`) or the app-visible documents (`hidden`) are searched for the specified path
### copyToCloud (options)
Copies the content of a file (or uri) to the target file system. The files will appear in a either a user visible
directory, or a dectory that only the app can see. The directory is named after `destinationPath`. The directory
hierarchy for the destination path will be created if it doesn't already exist. If the target file already exists
it a new filename is chosen and returned when the promise is resolved.```javascript
const sourceUri = {uri: 'https://foo.com/bar.pdf'};
const destinationPath = "foo-bar/docs/info.pdf";
const mimeType = null;
const scope = 'visible';RNCloudFs.copyToCloud({
sourcePath: sourceUri,
targetPath: destinationPath,
mimeType: mimeType,
scope: scope
})
.then((path) => {
console.log("it worked", path);
})
.catch((err) => {
console.warn("it failed", err);
})
```_sourceUri_: object with any uri or an **absolute** file path and optional http headers, e.g:
* `{path: '/foo/bar/file.txt'}`
* `{uri: 'file://foo/bar/file.txt'}`
* `{uri: 'http://www.files.com/foo/bar/file.txt', 'http-headers': {user: 'foo', password: 'bar'}}` (http-headers are android only)
* `{uri: 'content://media/external/images/media/296'}` (android only)
* `{uri: 'assets-library://asset/asset.JPG?id=106E99A1-4F6A-45A2-B320-B0AD4A8E8473&ext=JPG'}` (iOS only)
_targetPath_: a **relative** path including a filename under which the file will be placed, e.g:
* `my-cloud-text-file.txt`
* `foo/bar/my-cloud-text-file.txt`
_mimeType_: a mime type to store the file with **or null** (android only) , e.g:
* `text/plain`
* `application/json`
* `image/jpeg`_scope_: a string to specify if the user can access the document (`visible`) or not (`hidden`)
### listFiles (options)
Lists files in a directory along with some file metadata. The scope determines if the file listing takes place in the app folder or the public user documents folder.```javascript
const path = "dirA/dirB";
const scope = 'hidden';RNCloudFs.listFiles({targetPath: path, scope: scope})
.then((res) => {
console.log("it worked", res);
})
.catch((err) => {
console.warn("it failed", err);
})
```_targetPath_: a path representing a folder to list files from
_scope_: a string to specify if the files are the user-visible documents (`visible`) or the app-visible documents (`hidden`)
## Android
After following the instructions in [Getting started](./docs/getting-started.md) I recommend using [react-native-google-signin](https://github.com/react-native-google-signin/google-signin) to authenticate the user, especially if you need additional scopes besides `auth/drive.file` which is the only scope this package requests, and let that package handle auth.
Example of usage on Android:
```js
import { Platform } from 'react-native';
import { GoogleSignin, statusCodes } from '@react-native-community/google-signin';
import RNCloudFS from 'react-native-cloud-fs';if (Platform.OS === 'android') {
GoogleSignin.configure({
scopes: [
'https://www.googleapis.com/auth/userinfo.profile',
'https://www.googleapis.com/auth/userinfo.email',
'https://www.googleapis.com/auth/drive.file',
// other scopes your app needs
],
webClientId: '...' // you may not need this depending on scopes,
offlineAccess: true,
forceConsentPrompt: true,
});// Ensure play services exist. Cannot sign in otherwise. If unavailable, this
// will show a modal asking the user to get play services before continuing.
await GoogleSignin.hasPlayServices({
showPlayServicesUpdateDialog: true
});// If user is already signed in, don't need to call signIn again
const isSignedIn = await GoogleSignin.isSignedIn();
if (!isSignedIn) {
await GoogleSignin.signIn();
}// Syncs signed in state to RNCloudFS
await RNCloudFS.loginIfNeeded();
// Now you can copy to cloud
await RNCloudFS.copyToCloud({
sourcePath: { path: 'some/path.txt' },
targetPath: `some/path.txt`,
scope: 'visible'
});
}
```