Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nicolaslopezj/meteor-apollo-accounts
Meteor accounts in GraphQL
https://github.com/nicolaslopezj/meteor-apollo-accounts
accounts apollo authentication graphql javascript meteor react
Last synced: 13 days ago
JSON representation
Meteor accounts in GraphQL
- Host: GitHub
- URL: https://github.com/nicolaslopezj/meteor-apollo-accounts
- Owner: nicolaslopezj
- License: mit
- Created: 2016-10-17T19:01:54.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2019-04-08T08:06:36.000Z (over 5 years ago)
- Last Synced: 2024-08-20T13:02:22.975Z (3 months ago)
- Topics: accounts, apollo, authentication, graphql, javascript, meteor, react
- Language: JavaScript
- Size: 1.28 MB
- Stars: 146
- Watchers: 11
- Forks: 37
- Open Issues: 38
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Meteor Apollo Accounts
A implementation of Meteor Accounts only in GraphQL with Apollo.
This package uses the Meteor Accounts methods in GraphQL, it's compatible with the accounts you have saved in your database and you may use apollo-accounts and Meteor's DPP accounts at the same time.
> Project sponsored by [Orion Hosting](https://orion.hosting/?utm_source=github-apollo-accounts) - Hosting for Meteor
## Installing
### Install on Meteor server
```sh
meteor add nicolaslopezj:apollo-accounts
yarn add graphql-loader
```Initialize the package.
```js
import {makeExecutableSchema} from 'graphql-tools'
import {loadSchema, getSchema} from 'graphql-loader'
import {initAccounts} from 'meteor/nicolaslopezj:apollo-accounts'
import typeDefs from './schema'
import resolvers from './resolvers'// Load all accounts related resolvers and type definitions into graphql-loader
initAccounts({
loginWithFacebook: false,
loginWithGoogle: false,
loginWithLinkedIn: false,
loginWithPassword: true
})// Load all your resolvers and type definitions into graphql-loader
loadSchema({typeDefs, resolvers})// Gets all the resolvers and type definitions loaded in graphql-loader
const schema = getSchema()
const executableSchema = makeExecutableSchema(schema)
```### Install on your apollo app
May or may not be the same app.
```sh
npm install meteor-apollo-accounts
```## Examples
- [janikvonrotz/meteor-apollo-accounts-example](https://github.com/janikvonrotz/meteor-apollo-accounts-example): Meteor client and server side.
- [orionsoft/server-boilerplate](https://github.com/orionsoft/server-boilerplate): Large Meteor server side only starter app.## Tutorials
- [Using Meteor With Apollo and React](https://blog.orionsoft.io/using-meteor-accounts-with-apollo-and-react-df3c89b46b17#.znozw2zbd)## Methods
Meteor accounts methods, client side only. All methods are promises.
#### loginWithPassword
Log the user in with a password.
```js
import { loginWithPassword } from 'meteor-apollo-accounts'loginWithPassword({username, email, password}, apollo)
```- ```username```: Optional. The user's username.
- ```email```: Optional. The user's email.
- ```password```: The user's password. The library will hash the string before it sends it to the server.
- ```apollo```: Apollo client instance.
#### changePassword
Change the current user's password. Must be logged in.
```js
import { changePassword } from 'meteor-apollo-accounts'changePassword({oldPassword, newPassword}, apollo)
```- ```oldPassword```: The user's current password. This is not sent in plain text over the wire.
- ```newPassword```: A new password for the user. This is not sent in plain text over the wire.
- ```apollo```: Apollo client instance.
#### logout
Log the user out.
```js
import { logout } from 'meteor-apollo-accounts'logout(apollo)
```- ```apollo```: Apollo client instance.
#### createUser
Create a new user.
```js
import { createUser } from 'meteor-apollo-accounts'createUser({username, email, password, profile}, apollo)
```- ```username```: A unique name for this user.
- ```email```: The user's email address.
- ```password```: The user's password. This is not sent in plain text over the wire.
- ```profile```: The profile object based on the ```UserProfileInput``` input type.
- ```apollo```: Apollo client instance.
#### verifyEmail
Marks the user's email address as verified. Logs the user in afterwards.
```js
import { verifyEmail } from 'meteor-apollo-accounts'verifyEmail({token}, apollo)
```- ```token```: The token retrieved from the verification URL.
- ```apollo```: Apollo client instance.
#### forgotPassword
Request a forgot password email.
```js
import { forgotPassword } from 'meteor-apollo-accounts'forgotPassword({email}, apollo)
```- ```email```: The email address to send a password reset link.
- ```apollo```: Apollo client instance.
#### resetPassword
Reset the password for a user using a token received in email. Logs the user in afterwards.
```js
import { resetPassword } from 'meteor-apollo-accounts'resetPassword({newPassword, token}, apollo)
```- ```newPassword```: A new password for the user. This is not sent in plain text over the wire.
- ```token```: The token retrieved from the reset password URL.
- ```apollo```: Apollo client instance.
#### loginWithFacebook
Logins the user with a facebook accessToken
```js
import { loginWithFacebook } from 'meteor-apollo-accounts'loginWithFacebook({accessToken}, apollo)
```- ```accessToken```: A Facebook accessToken. It's recommended to use
https://github.com/keppelen/react-facebook-login to fetch the accessToken.- ```apollo```: Apollo client instance.
#### loginWithGoogle
Logins the user with a google accessToken
```js
import { loginWithGoogle } from 'meteor-apollo-accounts'loginWithGoogle({accessToken}, apollo)
```- ```accessToken```: A Google accessToken. It's recommended to use
https://github.com/anthonyjgrove/react-google-login to fetch the accessToken.- ```apollo```: Apollo client instance.
#### onTokenChange
Register a function to be called when a user is logged in or out.
```js
import { onTokenChange } from 'meteor-apollo-accounts'onTokenChange(function () {
console.log('token did change')
apollo.resetStore()
})
```#### userId
Returns the id of the logged in user.
```js
import { userId } from 'meteor-apollo-accounts'async function () {
console.log('The user id is:', await userId())
}```
### React-Native usage
```js
//First you'll need to import the Storage library that you'll use to store the user details (userId, tokens...),
// AsyncStorage is highly recommended.import {
...
AsyncStorage
} from 'react-native';import { loginWithPassword, userId, setTokenStore} from 'meteor-apollo-accounts'
// Then you'll have to define a TokenStore for your user data using setTokenStore
// (for instance when your component is mounted):
setTokenStore({
set: async function ({userId, token, tokenExpires}) {
await AsyncStorage.setItem('Meteor.userId', userId)
await AsyncStorage.setItem('Meteor.loginToken', token)
// AsyncStorage doesn't support Date type so we'll store it as a String
await AsyncStorage.setItem('Meteor.loginTokenExpires', tokenExpires.toString())
},
get: async function () {
return {
userId: await AsyncStorage.getItem('Meteor.userId'),
token: await AsyncStorage.getItem('Meteor.loginToken'),
tokenExpires: await AsyncStorage.getItem('Meteor.loginTokenExpires')
}
}
})// Finally, you'll be able to use asynchronously any method from the library:
async login (event) {
event.preventDefault();try {
const id_ = await loginWithPassword({ "email", "password" }, this.client)
this.client.resetStore()
} catch (error) {}
}```
## Contributors
- [@nicolaslopezj](https://github.com/nicolaslopezj)
- [@janikvonrotz](https://github.com/janikvonrotz)
- [@dbrrt](https://github.com/dbrrt)
- [@hammadj](https://github.com/hammadj)