1
0
Fork 0
mirror of https://github.com/openstf/stf synced 2025-10-04 02:09:32 +02:00

Show a dialog for new ADB key if using device.

This commit is contained in:
Simo Kinnunen 2014-10-01 21:33:47 +09:00
parent e6c1de5194
commit 95347d91f0
9 changed files with 152 additions and 109 deletions

View file

@ -58,6 +58,7 @@ dbapi.resetUserSettings = function(email) {
}
dbapi.insertUserAdbKey = function(email, key) {
console.log('insertUserAdbKey', email, key)
return db.run(r.table('users').get(email).update({
adbKeys: r.row('adbKeys').default([]).append({
title: key.title

View file

@ -10,13 +10,11 @@ var csrf = require('csurf')
var Promise = require('bluebird')
var httpProxy = require('http-proxy')
var compression = require('compression')
var adbkit = require('adbkit')
var logger = require('../../util/logger')
var pathutil = require('../../util/pathutil')
var dbapi = require('../../db/api')
var datautil = require('../../util/datautil')
var requtil = require('../../util/requtil')
var auth = require('./middleware/auth')
var deviceIconMiddleware = require('./middleware/device-icons')
@ -149,78 +147,6 @@ module.exports = function(options) {
})
})
app.post('/api/v1/app/user/keys/adb', function(req, res) {
requtil.validate(req, function() {
req.checkBody('title').notEmpty().len(1, 100)
req.checkBody('key').notEmpty()
})
.then(function() {
return adbkit.util.parsePublicKey(req.body.key)
})
.then(function(key) {
return dbapi.lookupUsersByAdbKey(key.fingerprint)
.then(function(users) {
if (users.length) {
throw new dbapi.DuplicateSecondaryIndexError()
}
else {
// Well, this doesn't guarantee that no one else inserts the
// same key before we do, but it's hardly a big enough problem
// to consider right now.
return dbapi.insertUserAdbKey(req.user.email, {
title: req.body.title
, fingerprint: key.fingerprint
})
.then(function() {
res.send({
success: true
, key: {
title: req.body.title
, fingerprint: key.fingerprint
}
})
})
}
})
})
.catch(requtil.ValidationError, function(err) {
res.status(400).send({
success: false
, error: 'ValidationError'
, validationErrors: err.errors
})
})
.catch(dbapi.DuplicateSecondaryIndexError, function() {
res.status(400).send({
success: false
, error: 'DuplicateKeyError'
})
})
.catch(function(err) {
log.error('Failed to insert ADB key: ', err.stack)
res.status(500).send({
success: false
, error: 'ServerError'
})
})
})
app.delete('/api/v1/app/user/keys/adb/:id', function(req, res) {
dbapi.deleteUserAdbKey(req.user.email, req.params.id)
.then(function() {
res.send({
success: true
})
})
.catch(function(err) {
log.error('Failed to delete ADB key: ', err.stack)
res.status(500).send({
success: false
, error: 'ServerError'
})
})
})
app.get('/api/v1/app/group', function(req, res) {
dbapi.loadGroup(req.user.email)
.then(function(cursor) {

View file

@ -4,6 +4,7 @@ var syrup = require('syrup')
var Promise = require('bluebird')
var logger = require('../../../util/logger')
var grouputil = require('../../../util/grouputil')
var wire = require('../../../wire')
var wireutil = require('../../../wire/util')
var lifecycle = require('../../../util/lifecycle')
@ -33,6 +34,19 @@ module.exports = syrup.serial()
var resolver = Promise.defer()
function notify() {
group.get()
.then(function(currentGroup) {
push.send([
solo.channel
, wireutil.envelope(new wire.JoinGroupByAdbFingerprintMessage(
options.serial
, key.fingerprint
, key.comment
, currentGroup.group
))
])
})
.catch(grouputil.NoGroupError, function() {
push.send([
solo.channel
, wireutil.envelope(new wire.JoinGroupByAdbFingerprintMessage(
@ -41,6 +55,7 @@ module.exports = syrup.serial()
, key.comment
))
])
})
}
function joinListener(group, identifier) {

View file

@ -86,9 +86,15 @@ module.exports = function(options) {
))
])
}
else {
/* ask user */
log.debug('ask user')
else if (message.currentGroup) {
appDealer.send([
message.currentGroup
, wireutil.envelope(new wire.JoinGroupByAdbFingerprintMessage(
message.serial
, message.fingerprint
, message.comment
))
])
}
})
.catch(function(err) {

View file

@ -7,6 +7,7 @@ var zmq = require('zmq')
var Promise = require('bluebird')
var _ = require('lodash')
var request = Promise.promisifyAll(require('request'))
var adbkit = require('adbkit')
var logger = require('../../util/logger')
var wire = require('../../wire')
@ -133,6 +134,12 @@ module.exports = function(options) {
)
})
})
.on(wire.JoinGroupByAdbFingerprintMessage, function(channel, message) {
socket.emit('user.keys.adb.confirm', {
title: message.comment
, fingerprint: message.fingerprint
})
})
.on(wire.LeaveGroupMessage, function(channel, message) {
socket.emit('device.change', {
important: true
@ -254,6 +261,79 @@ module.exports = function(options) {
.on('user.settings.reset', function() {
dbapi.resetUserSettings(user.email)
})
.on('user.keys.adb.add', function(data) {
return adbkit.util.parsePublicKey(data.key)
.then(function(key) {
return dbapi.lookupUsersByAdbKey(key.fingerprint)
.then(function(cursor) {
return cursor.toArray()
})
.then(function(users) {
if (users.length) {
throw new dbapi.DuplicateSecondaryIndexError()
}
else {
return dbapi.insertUserAdbKey(user.email, {
title: data.title
, fingerprint: key.fingerprint
})
}
})
.then(function() {
socket.emit('user.keys.adb.added', {
title: data.title
, fingerprint: key.fingerprint
})
})
})
.then(function() {
push.send([
wireutil.global
, wireutil.envelope(new wire.AdbKeysUpdatedMessage())
])
})
.catch(dbapi.DuplicateSecondaryIndexError, function() {
// No-op
})
})
.on('user.keys.adb.accept', function(data) {
return dbapi.lookupUsersByAdbKey(data.fingerprint)
.then(function(cursor) {
return cursor.toArray()
})
.then(function(users) {
if (users.length) {
throw new dbapi.DuplicateSecondaryIndexError()
}
else {
return dbapi.insertUserAdbKey(user.email, {
title: data.title
, fingerprint: data.fingerprint
})
}
})
.then(function() {
socket.emit('user.keys.adb.added', {
title: data.title
, fingerprint: data.fingerprint
})
})
.then(function() {
push.send([
user.group
, wireutil.envelope(new wire.AdbKeysUpdatedMessage())
])
})
.catch(dbapi.DuplicateSecondaryIndexError, function() {
// No-op
})
})
.on('user.keys.adb.remove', function(data) {
return dbapi.deleteUserAdbKey(user.email, data.fingerprint)
.then(function() {
socket.emit('user.keys.adb.removed', data)
})
})
// Touch events
.on('input.touchDown', function(channel, data) {
push.send([

View file

@ -251,6 +251,7 @@ message JoinGroupByAdbFingerprintMessage {
required string serial = 1;
required string fingerprint = 2;
optional string comment = 3;
optional string currentGroup = 4;
}
message AdbKeysUpdatedMessage {

View file

@ -9,11 +9,9 @@ module.exports =
$scope.modal.title = data.title
$scope.ok = function () {
console.log('add key')
$modalInstance.close(true)
}
$scope.$watch('modal.showAdd', function (newValue) {
if (newValue === false) {
$scope.ok()
@ -36,9 +34,7 @@ module.exports =
}
})
modalInstance.result.then(function () {
}, function () {
})
return modalInstance.result
}
return service

View file

@ -1,4 +1,9 @@
module.exports = function UserServiceFactory($http, AppState) {
module.exports = function UserServiceFactory(
$rootScope
, socket
, AppState
, AddAdbKeyModalService
) {
var UserService = {}
var user = UserService.currentUser = AppState.user
@ -8,20 +13,38 @@ module.exports = function UserServiceFactory($http, AppState) {
}
UserService.addAdbKey = function(key) {
return $http.post('/api/v1/app/user/keys/adb', key)
.success(function(data) {
UserService.getAdbKeys().push(data.key)
})
socket.emit('user.keys.adb.add', key)
}
UserService.acceptAdbKey = function(key) {
socket.emit('user.keys.adb.accept', key)
}
UserService.removeAdbKey = function(key) {
return $http.delete('/api/v1/app/user/keys/adb/' + key.fingerprint)
.success(function() {
socket.emit('user.keys.adb.remove', key)
}
socket.on('user.keys.adb.added', function(key) {
UserService.getAdbKeys().push(key)
$rootScope.$broadcast('user.keys.adb.updated', user.adbKeys)
$rootScope.$apply()
})
socket.on('user.keys.adb.removed', function(key) {
user.adbKeys = UserService.getAdbKeys().filter(function(someKey) {
return someKey.fingerprint !== key.fingerprint
})
$rootScope.$broadcast('user.keys.adb.updated', user.adbKeys)
$rootScope.$apply()
})
socket.on('user.keys.adb.confirm', function(data) {
AddAdbKeyModalService.open(data).then(function(result) {
if (result) {
UserService.acceptAdbKey(data)
}
})
})
return UserService
}

View file

@ -1,10 +1,4 @@
module.exports = function AdbKeysCtrl($scope, $http, UserService, AddAdbKeyModalService) {
//AddAdbKeyModalService.open({
// title: 'PC1264',
// fingerprint: 'bb:86:60:39:d7:a2:e3:09:93:09:cc:f6:e8:37:99:3f'
//})
module.exports = function AdbKeysCtrl($scope, $http, UserService) {
$scope.adbKeys = []
function updateKeys() {
@ -12,8 +6,9 @@ module.exports = function AdbKeysCtrl($scope, $http, UserService, AddAdbKeyModal
}
$scope.removeKey = function (key) {
UserService.removeAdbKey(key).then(updateKeys)
UserService.removeAdbKey(key)
}
$scope.$on('user.keys.adb.updated', updateKeys)
updateKeys()
}