2016-06-22 09:29:58 +08:00
|
|
|
const crypto = require('crypto');
|
2016-07-01 08:04:13 +08:00
|
|
|
const {JSONType, JSONARRAYType} = require('../../database-types');
|
2016-06-22 09:29:58 +08:00
|
|
|
|
2016-06-28 01:28:43 +08:00
|
|
|
const {DB_ENCRYPTION_ALGORITHM, DB_ENCRYPTION_PASSWORD} = process.env;
|
2016-06-22 09:29:58 +08:00
|
|
|
|
2016-06-19 18:02:32 +08:00
|
|
|
module.exports = (sequelize, Sequelize) => {
|
2016-06-30 03:04:22 +08:00
|
|
|
const Account = sequelize.define('account', {
|
2016-06-23 08:19:48 +08:00
|
|
|
name: Sequelize.STRING,
|
2016-06-28 01:28:43 +08:00
|
|
|
provider: Sequelize.STRING,
|
2016-06-19 18:02:32 +08:00
|
|
|
emailAddress: Sequelize.STRING,
|
2016-06-22 09:29:58 +08:00
|
|
|
connectionSettings: JSONType('connectionSettings'),
|
|
|
|
connectionCredentials: Sequelize.STRING,
|
|
|
|
syncPolicy: JSONType('syncPolicy'),
|
2016-06-28 07:01:21 +08:00
|
|
|
syncError: JSONType('syncError', {defaultValue: null}),
|
2016-07-02 04:15:49 +08:00
|
|
|
firstSyncCompletedAt: Sequelize.INTEGER,
|
2016-07-01 08:04:13 +08:00
|
|
|
lastSyncCompletions: JSONARRAYType('lastSyncCompletions'),
|
2016-06-19 18:02:32 +08:00
|
|
|
}, {
|
|
|
|
classMethods: {
|
|
|
|
associate: ({AccountToken}) => {
|
|
|
|
Account.hasMany(AccountToken, {as: 'tokens'})
|
|
|
|
},
|
|
|
|
},
|
|
|
|
instanceMethods: {
|
|
|
|
toJSON: function toJSON() {
|
|
|
|
return {
|
|
|
|
id: this.id,
|
2016-06-29 09:14:54 +08:00
|
|
|
object: 'account',
|
2016-06-30 03:02:31 +08:00
|
|
|
organization_unit: (this.provider === 'gmail') ? 'label' : 'folder',
|
|
|
|
provider: this.provider,
|
2016-06-19 18:02:32 +08:00
|
|
|
email_address: this.emailAddress,
|
2016-06-23 05:17:45 +08:00
|
|
|
connection_settings: this.connectionSettings,
|
|
|
|
sync_policy: this.syncPolicy,
|
2016-06-28 07:01:21 +08:00
|
|
|
sync_error: this.syncError,
|
2016-07-02 04:15:49 +08:00
|
|
|
first_sync_completed_at: this.firstSyncCompletedAt,
|
|
|
|
last_sync_completions: this.lastSyncCompletions,
|
2016-06-19 18:02:32 +08:00
|
|
|
}
|
|
|
|
},
|
2016-06-22 09:29:58 +08:00
|
|
|
|
2016-06-28 01:27:38 +08:00
|
|
|
errored: function errored() {
|
2016-06-28 07:01:21 +08:00
|
|
|
return this.syncError != null
|
2016-06-28 01:27:38 +08:00
|
|
|
},
|
|
|
|
|
2016-06-22 09:29:58 +08:00
|
|
|
setCredentials: function setCredentials(json) {
|
|
|
|
if (!(json instanceof Object)) {
|
2016-06-28 07:01:21 +08:00
|
|
|
throw new NylasError("Call setCredentials with JSON!")
|
2016-06-22 09:29:58 +08:00
|
|
|
}
|
2016-06-28 01:28:43 +08:00
|
|
|
const cipher = crypto.createCipher(DB_ENCRYPTION_ALGORITHM, DB_ENCRYPTION_PASSWORD)
|
2016-06-22 09:29:58 +08:00
|
|
|
let crypted = cipher.update(JSON.stringify(json), 'utf8', 'hex')
|
|
|
|
crypted += cipher.final('hex');
|
|
|
|
|
|
|
|
this.connectionCredentials = crypted;
|
|
|
|
},
|
|
|
|
|
|
|
|
decryptedCredentials: function decryptedCredentials() {
|
2016-06-28 01:28:43 +08:00
|
|
|
const decipher = crypto.createDecipher(DB_ENCRYPTION_ALGORITHM, DB_ENCRYPTION_PASSWORD)
|
2016-06-22 09:29:58 +08:00
|
|
|
let dec = decipher.update(this.connectionCredentials, 'hex', 'utf8')
|
|
|
|
dec += decipher.final('utf8');
|
|
|
|
|
|
|
|
try {
|
|
|
|
return JSON.parse(dec);
|
|
|
|
} catch (err) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
},
|
2016-06-19 18:02:32 +08:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
return Account;
|
|
|
|
};
|