mirror of
https://github.com/moparisthebest/mail
synced 2024-12-22 07:18:49 -05:00
login to imap and smtp via chrome identity api works
This commit is contained in:
parent
6623379a2c
commit
2186d20a7c
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,2 +1,3 @@
|
||||
node_modules
|
||||
.DS_Store
|
||||
*-browserified.js
|
||||
|
@ -10,11 +10,13 @@
|
||||
"start": "grunt prod"
|
||||
},
|
||||
"dependencies": {
|
||||
"grunt": "~0.4.1",
|
||||
"grunt-contrib-connect": "~0.3.0",
|
||||
"crypto-lib": "https://github.com/whiteout-io/crypto-lib/tarball/master"
|
||||
"crypto-lib": "https://github.com/whiteout-io/crypto-lib/tarball/master",
|
||||
"imap-client": "git+ssh://git@github.com:whiteout-io/imap-client.git#master",
|
||||
"smtp-client": "git+ssh://git@github.com:whiteout-io/smtp-client.git#master"
|
||||
},
|
||||
"devDependencies": {
|
||||
"grunt": "~0.4.1",
|
||||
"grunt-contrib-connect": "~0.3.0",
|
||||
"grunt-contrib-jshint": "~0.5.3",
|
||||
"grunt-contrib-qunit": "~0.2.1"
|
||||
}
|
||||
|
@ -6,5 +6,19 @@ echo "--> copying dependencies to src\n"
|
||||
cd `dirname $0`
|
||||
cd ..
|
||||
|
||||
# copy crypto lib
|
||||
cp ./node_modules/crypto-lib/src/*.js ./src/js/crypto/
|
||||
cp ./node_modules/crypto-lib/node_modules/node-forge/js/*.js ./src/lib/
|
||||
cp ./node_modules/crypto-lib/node_modules/node-forge/js/*.js ./src/lib/
|
||||
|
||||
# build imap/smtp modules and copy
|
||||
cd ./node_modules/imap-client/
|
||||
npm install && node build.js
|
||||
cp ./src-gen/*.js ../../src/lib/
|
||||
cd ../../
|
||||
|
||||
cd ./node_modules/smtp-client/
|
||||
npm install && node build.js
|
||||
cp ./src-gen/*.js ../../src/lib/
|
||||
cd ../../
|
||||
|
||||
echo "\n--> finished copying dependencies.\n"
|
11
src/index.js
11
src/index.js
@ -1,20 +1,11 @@
|
||||
require(['jquery', 'js/app-controller', 'js/app-config'], function($, controller, app) {
|
||||
'use strict';
|
||||
|
||||
chrome.identity.getAuthToken({
|
||||
'interactive': true
|
||||
}, function(token) {
|
||||
console.log(token);
|
||||
// Use the token.
|
||||
});
|
||||
|
||||
/**
|
||||
* Load templates and start the application
|
||||
*/
|
||||
$(document).ready(function() {
|
||||
controller.init(function() {
|
||||
controller.start(startApp);
|
||||
});
|
||||
controller.start(startApp);
|
||||
});
|
||||
|
||||
function startApp() {
|
||||
|
@ -1,23 +1,13 @@
|
||||
/**
|
||||
* The main application controller
|
||||
*/
|
||||
define(['jquery', 'js/dao/email-dao', 'js/dao/keychain-dao', 'js/dao/cloudstorage-dao',
|
||||
'js/app-config', 'cordova'
|
||||
], function($, EmailDAO, KeychainDAO, cloudstorage, app) {
|
||||
define(['jquery', 'ImapClient', 'SmtpClient', 'js/dao/email-dao', 'js/dao/keychain-dao',
|
||||
'js/dao/cloudstorage-dao', 'js/app-config', 'cordova'
|
||||
], function($, ImapClient, SmtpClient, EmailDAO, KeychainDAO, cloudstorage, app) {
|
||||
'use strict';
|
||||
|
||||
var self = {};
|
||||
|
||||
var emailDao;
|
||||
|
||||
/**
|
||||
* Initializes modules through dependecy injection
|
||||
*/
|
||||
self.init = function(callback) {
|
||||
var keychain = new KeychainDAO(cloudstorage);
|
||||
emailDao = new EmailDAO(cloudstorage, keychain);
|
||||
callback();
|
||||
};
|
||||
var self = {},
|
||||
emailDao;
|
||||
|
||||
/**
|
||||
* Start the application by loading the view templates
|
||||
@ -25,7 +15,7 @@ define(['jquery', 'js/dao/email-dao', 'js/dao/keychain-dao', 'js/dao/cloudstorag
|
||||
self.start = function(callback) {
|
||||
// the views to load
|
||||
var views = ['login', 'compose', 'folderlist', 'messagelist',
|
||||
'messagelistitem', 'read'
|
||||
'messagelistitem', 'read'
|
||||
];
|
||||
|
||||
// are we running in native app or in browser?
|
||||
@ -49,7 +39,7 @@ define(['jquery', 'js/dao/email-dao', 'js/dao/keychain-dao', 'js/dao/cloudstorag
|
||||
self.execute = function(cmd, args, callback) {
|
||||
if (cmd === 'login') {
|
||||
// login user
|
||||
login(args.userId, args.password, function(err) {
|
||||
fetchOAuthToken(args.userId, args.password, function(err) {
|
||||
callback({
|
||||
err: err
|
||||
});
|
||||
@ -102,8 +92,52 @@ define(['jquery', 'js/dao/email-dao', 'js/dao/keychain-dao', 'js/dao/cloudstorag
|
||||
// Helper methods
|
||||
//
|
||||
|
||||
function login(userId, password, callback) {
|
||||
function fetchOAuthToken(userId, password, callback) {
|
||||
// get OAuth Token from chrome
|
||||
chrome.identity.getAuthToken({
|
||||
'interactive': true
|
||||
},
|
||||
function(token) {
|
||||
login(userId, password, token, callback);
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
function login(userId, password, token, callback) {
|
||||
var auth, imapOptions, smtpOptions,
|
||||
keychain, imapClient, smtpClient;
|
||||
|
||||
// create mail credentials objects for imap/smtp
|
||||
auth = {
|
||||
XOAuth2: {
|
||||
user: userId,
|
||||
clientId: '440907777130.apps.googleusercontent.com',
|
||||
accessToken: token
|
||||
}
|
||||
};
|
||||
imapOptions = {
|
||||
secure: true,
|
||||
port: 993,
|
||||
host: 'imap.gmail.com',
|
||||
auth: auth
|
||||
};
|
||||
smtpOptions = {
|
||||
secure: true,
|
||||
port: 465,
|
||||
host: 'smtp.gmail.com',
|
||||
auth: auth
|
||||
};
|
||||
|
||||
// init objects and inject dependencies
|
||||
keychain = new KeychainDAO(cloudstorage);
|
||||
imapClient = new ImapClient(imapOptions);
|
||||
smtpClient = new SmtpClient(smtpOptions);
|
||||
emailDao = new EmailDAO(cloudstorage, keychain, imapClient, smtpClient);
|
||||
|
||||
// init email dao
|
||||
var account = new app.model.Account({
|
||||
imapOptions: imapOptions,
|
||||
smtpOptions: smtpOptions,
|
||||
emailAddress: userId,
|
||||
symKeySize: app.config.symKeySize,
|
||||
symIvSize: app.config.symIvSize,
|
||||
|
@ -3,11 +3,11 @@
|
||||
* between the cloud service and the device's local storage
|
||||
*/
|
||||
define(['underscore', 'cryptoLib/util', 'js/crypto/crypto', 'js/dao/lawnchair-dao',
|
||||
'js/dao/devicestorage-dao', 'js/app-config', 'js/model/account-model'
|
||||
'js/dao/devicestorage-dao', 'js/app-config', 'js/model/account-model'
|
||||
], function(_, util, crypto, jsonDB, devicestorage, app) {
|
||||
'use strict';
|
||||
|
||||
var EmailDAO = function(cloudstorage, keychain) {
|
||||
var EmailDAO = function(cloudstorage, keychain, imapClient, smtpClient) {
|
||||
var self = this;
|
||||
|
||||
/**
|
||||
@ -25,18 +25,30 @@ define(['underscore', 'cryptoLib/util', 'js/crypto/crypto', 'js/dao/lawnchair-da
|
||||
return;
|
||||
}
|
||||
|
||||
// init user's local database
|
||||
jsonDB.init(emailAddress);
|
||||
// login IMAP client if existent
|
||||
if (imapClient) {
|
||||
imapClient.login(function() {
|
||||
console.log('logged into imap.');
|
||||
initKeychain();
|
||||
});
|
||||
} else {
|
||||
initKeychain();
|
||||
}
|
||||
|
||||
// call getUserKeyPair to read/sync keypair with devicestorage/cloud
|
||||
keychain.getUserKeyPair(emailAddress, function(err, storedKeypair) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
// init crypto
|
||||
initCrypto(storedKeypair);
|
||||
});
|
||||
function initKeychain() {
|
||||
// init user's local database
|
||||
jsonDB.init(emailAddress);
|
||||
|
||||
// call getUserKeyPair to read/sync keypair with devicestorage/cloud
|
||||
keychain.getUserKeyPair(emailAddress, function(err, storedKeypair) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
// init crypto
|
||||
initCrypto(storedKeypair);
|
||||
});
|
||||
}
|
||||
|
||||
function initCrypto(storedKeypair) {
|
||||
crypto.init({
|
||||
@ -300,10 +312,15 @@ define(['underscore', 'cryptoLib/util', 'js/crypto/crypto', 'js/dao/lawnchair-da
|
||||
}
|
||||
|
||||
function send(email) {
|
||||
// send email to cloud service
|
||||
cloudstorage.deliverEmail(email, userId, recipient, function(err) {
|
||||
callback(err);
|
||||
});
|
||||
if (smtpClient) {
|
||||
// send email directly client side
|
||||
smtpClient.send(email, callback);
|
||||
} else {
|
||||
// send email via cloud service
|
||||
cloudstorage.deliverEmail(email, userId, recipient, function(err) {
|
||||
callback(err);
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
};
|
||||
|
@ -23,7 +23,7 @@ define(['jquery', 'underscore', 'backbone', 'js/app-config'], function($, _, Bac
|
||||
|
||||
login: function() {
|
||||
var page = $(this.el),
|
||||
userId = page.find('#userId').val() + '@mail.whiteout.io',
|
||||
userId = page.find('#userId').val(),
|
||||
password = page.find('#password').val();
|
||||
|
||||
// show loading msg during init
|
||||
|
@ -8,14 +8,16 @@
|
||||
"128": "css/images/mail-128.png"
|
||||
},
|
||||
"permissions": [
|
||||
"https://storage.whiteout.io/",
|
||||
"identity"
|
||||
"https://storage.whiteout.io/",
|
||||
"identity", {
|
||||
"socket": ["tcp-connect"]
|
||||
}
|
||||
],
|
||||
"key": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDBXqC3/oX5fP/gLORcVN62Pf3Ph+pO4qEB+FynSMWMoqWUt7FDoaKuHrsP/KInuP/0PUZcqpij9kB9MytLTqYzGIoRsUd37i1Dt6R69fnNsIqAISgoWIRg4VyRdon9cTIniv3DVV45PPyNCvN+oQoBMv9NbojWnlL9W05bKYkABQIDAQAB",
|
||||
"oauth2": {
|
||||
"client_id": "440907777130.apps.googleusercontent.com",
|
||||
"scopes": [
|
||||
"https://mail.google.com/"
|
||||
"https://mail.google.com/"
|
||||
]
|
||||
},
|
||||
"app": {
|
||||
|
@ -14,7 +14,9 @@
|
||||
lawnchair: 'lawnchair/lawnchair-git',
|
||||
lawnchairSQL: 'lawnchair/lawnchair-adapter-webkit-sqlite-git',
|
||||
lawnchairIDB: 'lawnchair/lawnchair-adapter-indexed-db-git',
|
||||
cordova: 'cordova-2.5.0'
|
||||
cordova: 'cordova-2.5.0',
|
||||
ImapClient: 'imap-client-browserified',
|
||||
SmtpClient: 'smtp-client-browserified'
|
||||
},
|
||||
shim: {
|
||||
lawnchair: {
|
||||
|
@ -7,9 +7,9 @@
|
||||
<div id="loginForm">
|
||||
<h3>Please sign in</h3>
|
||||
<label for="userId" class="ui-hidden-accessible">Username:</label>
|
||||
<input type="email" name="user" id="userId" value="" placeholder="user" data-theme="a">
|
||||
<input type="email" name="user" id="userId" value="safewithme.testuser@gmail.com" placeholder="user" data-theme="a">
|
||||
<label for="password" class="ui-hidden-accessible">Password:</label>
|
||||
<input type="password" name="pass" id="password" value="" placeholder="password" data-theme="a">
|
||||
<input type="password" name="pass" id="password" value="passphrase" placeholder="password" data-theme="a">
|
||||
<input type="button" data-theme="b" data-icon="check" id="loginBtn" value="Sign in">
|
||||
</div>
|
||||
</div><!-- /content -->
|
Loading…
Reference in New Issue
Block a user