2016-06-30 13:21:47 +03:00
import Route from 'ember-route' ;
import RSVP from 'rsvp' ;
import injectService from 'ember-service/inject' ;
import EmberObject from 'ember-object' ;
2015-07-08 12:56:07 +03:00
import DS from 'ember-data' ;
2017-03-14 19:04:46 +03:00
import UnauthenticatedRouteMixin from 'ghost-admin/mixins/unauthenticated-route-mixin' ;
2016-05-24 15:06:59 +03:00
import styleBody from 'ghost-admin/mixins/style-body' ;
2014-03-10 07:44:08 +04:00
2016-06-30 13:21:47 +03:00
const { Promise } = RSVP ;
2015-10-28 14:36:45 +03:00
const { Errors } = DS ;
2017-02-10 13:34:37 +03:00
export default Route . extend ( styleBody , UnauthenticatedRouteMixin , {
2014-07-03 19:06:07 +04:00
classNames : [ 'ghost-signup' ] ,
2015-05-13 08:27:59 +03:00
2016-06-30 13:21:47 +03:00
ghostPaths : injectService ( ) ,
notifications : injectService ( ) ,
session : injectService ( ) ,
ajax : injectService ( ) ,
2015-05-26 05:10:50 +03:00
2015-10-28 14:36:45 +03:00
beforeModel ( ) {
2015-10-18 21:17:02 +03:00
if ( this . get ( 'session.isAuthenticated' ) ) {
2015-10-07 17:44:23 +03:00
this . get ( 'notifications' ) . showAlert ( 'You need to sign out to register as a new user.' , { type : 'warn' , delayed : true , key : 'signup.create.already-authenticated' } ) ;
2014-07-03 19:06:07 +04:00
}
2017-02-10 13:34:37 +03:00
this . _super ( ... arguments ) ;
2014-07-03 19:06:07 +04:00
} ,
2014-09-19 08:50:15 +04:00
2015-10-28 14:36:45 +03:00
model ( params ) {
2016-06-11 19:52:36 +03:00
let model = EmberObject . create ( ) ;
2015-10-28 14:36:45 +03:00
let re = /^(?:[A-Za-z0-9_\-]{4})*(?:[A-Za-z0-9_\-]{2}|[A-Za-z0-9_\-]{3})?$/ ;
let email ,
tokenText ;
2014-09-19 08:50:15 +04:00
2016-01-19 16:03:27 +03:00
return new Promise ( ( resolve ) => {
2014-09-19 08:50:15 +04:00
if ( ! re . test ( params . token ) ) {
2015-10-28 14:36:45 +03:00
this . get ( 'notifications' ) . showAlert ( 'Invalid token.' , { type : 'error' , delayed : true , key : 'signup.create.invalid-token' } ) ;
2014-09-19 08:50:15 +04:00
2015-10-28 14:36:45 +03:00
return resolve ( this . transitionTo ( 'signin' ) ) ;
2014-08-06 19:08:02 +04:00
}
2014-08-25 06:34:26 +04:00
2014-09-19 08:50:15 +04:00
tokenText = atob ( params . token ) ;
email = tokenText . split ( '|' ) [ 1 ] ;
2015-01-12 06:15:13 +03:00
model . set ( 'email' , email ) ;
model . set ( 'token' , params . token ) ;
2015-10-28 14:36:45 +03:00
model . set ( 'errors' , Errors . create ( ) ) ;
2014-09-19 08:50:15 +04:00
2016-01-18 18:37:14 +03:00
let authUrl = this . get ( 'ghostPaths.url' ) . api ( 'authentication' , 'invitation' ) ;
return this . get ( 'ajax' ) . request ( authUrl , {
2014-08-25 06:34:26 +04:00
dataType : 'json' ,
data : {
2015-10-28 14:36:45 +03:00
email
2014-08-25 06:34:26 +04:00
}
2015-10-28 14:36:45 +03:00
} ) . then ( ( response ) => {
2014-08-25 06:34:26 +04:00
if ( response && response . invitation && response . invitation [ 0 ] . valid === false ) {
2015-10-28 14:36:45 +03:00
this . get ( 'notifications' ) . showAlert ( 'The invitation does not exist or is no longer valid.' , { type : 'warn' , delayed : true , key : 'signup.create.invalid-invitation' } ) ;
2014-09-19 08:50:15 +04:00
2015-10-28 14:36:45 +03:00
return resolve ( this . transitionTo ( 'signin' ) ) ;
2014-08-25 06:34:26 +04:00
}
2014-09-19 08:50:15 +04:00
2016-09-30 14:43:40 +03:00
model . set ( 'invitedBy' , response . invitation [ 0 ] . invitedBy ) ;
2014-09-19 08:50:15 +04:00
resolve ( model ) ;
2015-10-28 14:36:45 +03:00
} ) . catch ( ( ) => {
2014-09-19 08:50:15 +04:00
resolve ( model ) ;
2014-08-25 06:34:26 +04:00
} ) ;
2014-09-19 08:50:15 +04:00
} ) ;
} ,
2014-08-25 06:34:26 +04:00
2015-10-28 14:36:45 +03:00
deactivate ( ) {
this . _super ( ... arguments ) ;
2014-09-19 08:50:15 +04:00
// clear the properties that hold the sensitive data from the controller
2014-10-25 01:09:50 +04:00
this . controllerFor ( 'signup' ) . setProperties ( { email : '' , password : '' , token : '' } ) ;
2014-07-03 19:06:07 +04:00
}
2014-03-10 07:44:08 +04:00
} ) ;