Generate local keys before starting any connectivity.
This commit is contained in:
parent
7bc8532732
commit
998f2676e0
2 changed files with 12 additions and 8 deletions
|
@ -81,7 +81,7 @@ class ChatService extends Service {
|
||||||
private val AddressDeviceMap = HashBiMap.create[Address, Device.ID]()
|
private val AddressDeviceMap = HashBiMap.create[Address, Device.ID]()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes BroadcastReceiver for discovery, starts discovery and listens for connections.
|
* Sets up bluetooth connectivity.
|
||||||
*/
|
*/
|
||||||
override def onCreate(): Unit = {
|
override def onCreate(): Unit = {
|
||||||
super.onCreate()
|
super.onCreate()
|
||||||
|
@ -92,15 +92,13 @@ class ChatService extends Service {
|
||||||
registerReceiver(BluetoothStateReceiver, new IntentFilter(BluetoothAdapter.ACTION_STATE_CHANGED))
|
registerReceiver(BluetoothStateReceiver, new IntentFilter(BluetoothAdapter.ACTION_STATE_CHANGED))
|
||||||
registerReceiver(DiscoveryFinishedReceiver,
|
registerReceiver(DiscoveryFinishedReceiver,
|
||||||
new IntentFilter(BluetoothAdapter.ACTION_DISCOVERY_FINISHED))
|
new IntentFilter(BluetoothAdapter.ACTION_DISCOVERY_FINISHED))
|
||||||
if (bluetoothAdapter.isEnabled) {
|
|
||||||
startBluetoothConnections()
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!Crypto.localKeysExist)
|
Future {
|
||||||
Future(Crypto.generateLocalKeys())
|
Crypto.generateLocalKeys()
|
||||||
else
|
startBluetoothConnections()
|
||||||
Log.i(Tag, "Service started, address is " + Crypto.getLocalAddress)
|
Log.i(Tag, "Service started, address is " + Crypto.getLocalAddress)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
override def onStartCommand(intent: Intent, flags: Int, startId: Int) = Service.START_STICKY
|
override def onStartCommand(intent: Intent, flags: Int, startId: Int) = Service.START_STICKY
|
||||||
|
|
||||||
|
@ -167,6 +165,7 @@ class ChatService extends Service {
|
||||||
override def onReceive(context: Context, intent: Intent): Unit = {
|
override def onReceive(context: Context, intent: Intent): Unit = {
|
||||||
intent.getIntExtra(BluetoothAdapter.EXTRA_STATE, -1) match {
|
intent.getIntExtra(BluetoothAdapter.EXTRA_STATE, -1) match {
|
||||||
case BluetoothAdapter.STATE_ON =>
|
case BluetoothAdapter.STATE_ON =>
|
||||||
|
if (Crypto.localKeysExist)
|
||||||
startBluetoothConnections()
|
startBluetoothConnections()
|
||||||
case BluetoothAdapter.STATE_TURNING_OFF =>
|
case BluetoothAdapter.STATE_TURNING_OFF =>
|
||||||
connections.foreach(d => d._2.close())
|
connections.foreach(d => d._2.close())
|
||||||
|
|
|
@ -73,8 +73,13 @@ class Crypto(Context: Context) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generates a new key pair using [[KeyAlgorithm]] with [[KeySize]] bits and stores the keys.
|
* Generates a new key pair using [[KeyAlgorithm]] with [[KeySize]] bits and stores the keys.
|
||||||
|
*
|
||||||
|
* Does nothing if the key pair already exists.
|
||||||
*/
|
*/
|
||||||
def generateLocalKeys(): Unit = {
|
def generateLocalKeys(): Unit = {
|
||||||
|
if (localKeysExist)
|
||||||
|
return
|
||||||
|
|
||||||
var address: Address = null
|
var address: Address = null
|
||||||
var keyPair: KeyPair = null
|
var keyPair: KeyPair = null
|
||||||
do {
|
do {
|
||||||
|
|
Reference in a new issue