Skip to content

Commit

Permalink
custom attributes for signup
Browse files Browse the repository at this point in the history
  • Loading branch information
powerful23 committed Jan 16, 2018
1 parent 286a72b commit 3f72b77
Show file tree
Hide file tree
Showing 3 changed files with 85 additions and 9 deletions.
9 changes: 8 additions & 1 deletion media/authentication_guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,14 @@ Auth.confirmSignIn(user, code)
```js
import { Auth } from 'aws-amplify';

Auth.signUp(username, password, email, phone)
Auth.signUp({
username,
password,
email, // optional
phone, // optional
// other custom attributes if has been set in Cognito
// myAttr: ...
})
.then(data => console.log(data))
.catch(err => console.log(err));

Expand Down
52 changes: 49 additions & 3 deletions packages/aws-amplify/__tests__/Auth/auth-unit-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ const session = new CognitoUserSession({

describe('auth unit test', () => {
describe('signUp', () => {
test('happy case', async () => {
test('happy case with string attrs', async () => {
const spyon = jest.spyOn(CognitoUserPool.prototype, "signUp");
const auth = new Auth(authOptions);

Expand All @@ -170,6 +170,41 @@ describe('auth unit test', () => {
spyon.mockClear();
});

test('happy case with object attr', async () => {
const spyon = jest.spyOn(CognitoUserPool.prototype, "signUp");
const auth = new Auth(authOptions);

const attrs = {
username: 'username',
password: 'password',
email: 'email',
phone_number: 'phone_number',
otherAttrs: 'otherAttrs'
}
expect.assertions(1);
expect(await auth.signUp(attrs)).toBe('signUpResult');

spyon.mockClear();
});

test('object attr with null username', async () => {
const auth = new Auth(authOptions);

const attrs = {
username: null,
password: 'password',
email: 'email',
phone_number: 'phone_number',
otherAttrs: 'otherAttrs'
}
expect.assertions(1);
try {
await auth.signUp(attrs);
} catch (e) {
expect(e).not.toBeNull();
}
});

test('callback error', async () => {
const spyon = jest.spyOn(CognitoUserPool.prototype, "signUp")
.mockImplementationOnce((username, password, signUpAttributeList, validationData, callback) => {
Expand Down Expand Up @@ -200,7 +235,7 @@ describe('auth unit test', () => {
});

test('no username', async () => {
const auth = new Auth(authOptionsWithNoUserPoolId);
const auth = new Auth(authOptions);

expect.assertions(1);
try {
Expand All @@ -211,7 +246,7 @@ describe('auth unit test', () => {
});

test('no password', async () => {
const auth = new Auth(authOptionsWithNoUserPoolId);
const auth = new Auth(authOptions);

expect.assertions(1);
try {
Expand All @@ -220,6 +255,17 @@ describe('auth unit test', () => {
expect(e).not.toBeNull();
}
});

test('only username', async () => {
const auth = new Auth(authOptions);

expect.assertions(1);
try {
await auth.signUp('username');
} catch (e) {
expect(e).not.toBeNull();
}
});
});

describe('confirmSignUp', () => {
Expand Down
33 changes: 28 additions & 5 deletions packages/aws-amplify/src/Auth/Auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -97,15 +97,38 @@ export default class AuthClass {
* @param {Object} attributeList - Other attributes
* @return - A promise resolves callback data if success
*/
public signUp(username: string, password: string, email: string, phone_number: string): Promise<any> {
//public signUp(username: string, password: string, attrs?: string | object, phone_number?: string): Promise<any> {
public signUp(attrs: string | object, ...restOfAttrs: string[]): Promise<any> {
if (!this.userPool) { return Promise.reject('No userPool'); }
if (!username) { return Promise.reject('Username cannot be empty'); }
if (!password) { return Promise.reject('Password cannot be empty'); }

let username = null;
let password = null;
const attributes = [];
if (email) { attributes.push({Name: 'email', Value: email}); }
if (phone_number) { attributes.push({Name: 'phone_number', Value: phone_number}); }
if (attrs && typeof attrs === 'string') {
username = attrs;
password = restOfAttrs? restOfAttrs[0] : null;
const email = restOfAttrs? restOfAttrs[1] : null;
const phone_number = restOfAttrs? restOfAttrs[2] : null;
if (email) attributes.push({Name: 'email', Value: email});
if (phone_number) attributes.push({Name: 'phone_number', Value: phone_number});
} else if (attrs && typeof attrs === 'object') {
username = attrs['username'];
password = attrs['password'];
Object.keys(attrs).map(key => {
if (key === 'username' || key === 'password') return;
const ele = { Name: key, Value: attrs[key] };
attributes.push(ele);
});
} else {
return Promise.reject('The first parameter should either be non-null string or object');
}

if (!username) { return Promise.reject('Username cannot be empty'); }
if (!password) { return Promise.reject('Password cannot be empty'); }

logger.debug('signUp attrs:');
logger.debug(attributes);

return new Promise((resolve, reject) => {
this.userPool.signUp(username, password, attributes, null, function(err, data) {
if (err) {
Expand Down

0 comments on commit 3f72b77

Please sign in to comment.