-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Is using CognitoSync Possible? #2
Comments
@MattyK14 I can look into it. Right now I'm double checking everything on the storage front and Cognito Sync is on my radar as well. |
@MattyK14 I just wrote this up, but haven't tested it. Can you try this code out? The cognito sync has its own memory store, but it should be fine if you use it with the sync method if you're refreshing the app: //AWS
import AWS from 'aws-sdk/dist/aws-sdk-react-native';
import 'react-native-aws-cognito-js';
import 'amazon-cognito-js';
export const appConfig = {
region: '',
IdentityPoolId: '',
UserPoolId: '',
ClientId: '',
};
//- for federated identities
appConfig.LoginId = `cognito-idp.${appConfig.region}.amazonaws.com/${appConfig.UserPoolId}`;
AWS.config.region = appConfig.region;
//- for federated identities
AWS.config.credentials = new AWS.CognitoIdentityCredentials({
IdentityPoolId: appConfig.IdentityPoolId,
});
export const poolData = {
UserPoolId: appConfig.UserPoolId,
ClientId: appConfig.ClientId,
};
export const userPool = new AWS.CognitoIdentityServiceProvider.CognitoUserPool(poolData);
export default AWS; //App
import AWS, { userPool } from './AWS';
const myDataset = 'myDataSet';
state = {
client: null,
}
componentDidMount() {
userPool.storage.sync((err, result) => {
this.setState({ client: new AWS.CognitoSyncManager() });
});
}
putValue = (key, value) => {
const { client } = this.state;
client.openOrCreateDataset(myDataset, (err, dataset) => {
if (err) return console.log(err);
dataset.put(key, value, (dataError, record) => {
if (dataError) return console.log(dataError);
console.log('record', record);
});
});
}
syncList = () => {
const { client } = this.state;
client.openOrCreateDataset(myDataset, (err, dataset) => {
if (err) return console.log(err);
dataset.getAllRecords((dataError, records) => {
if (dataError) return console.log(dataError);
console.log(records);
});
});
}
syncStore = () => {
const { client } = this.state;
client.openOrCreateDataset(myDataset, (err, dataset) => {
if (err) return console.log(err);
dataset.synchronize({
onSuccess: (data, newRecords) => {
console.log('records', newRecords);
},
onFailure: (dataError) => {
console.log('error', dataError);
}
});
});
} |
@jmparsons work good man! |
@MattyK14 Awesome great to hear! |
For me, the above AWS.js breaks the packager on a fresh react-native project. Added dependencies:
Copied Imported into index.ios.js like this:
And the packager bombs with:
(the module does exist in that directory!) using: |
@anthonyjoeseph leave off the "yarn add aws-sdk" it's already included in this library and points to the correct react native version, so by adding it you're pointing to the wrong one. |
Thanks @jmparsons, that helped. I got it to work, but not satisfactorily. In my own code, I initialized CognitoSyncManager with a parameter to make it explicitly use in-memory storage, as opposed to a web browser's LocalStorage:
I also found that node_modules/amazon-cognito-js/dist/amazon-cognito.min.js requires the wrong version of aws-sdk on line 11:
It worked when I changed it to:
Since, for my project, it's not ideal to modify code in node_modules, I've submitted an issue to amazon-cognito-js and posted about it on amazon forums. I'll post when I hear back, although hopefully that the amazon team is more focused on supporting aws-sdk-react-native than resolving little amazon-cognito-js issues. |
@anthonyjoeseph If those changes are necessary I'd recommend doing a fork, then pulling your package in via git. It's a pretty common use case where you might want to fork your entire package environment to freeze builds, then change what is necessary for a production app. I haven't used cognito sync outside of web, so the snippet I pasted was from testing on web. I do all my testing on the web cognito, then transition it to mobile. |
I was wondering if using CognitoSync was possible with this module?
The text was updated successfully, but these errors were encountered: