From 8e302ac90c35178316aa44c85ee05d87290b81f8 Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Fri, 31 May 2019 11:10:13 -0400 Subject: [PATCH 1/3] Add optional pin parameter to peripheral connection. --- src/extensions/scratch3_ev3/index.js | 2 +- src/io/bt.js | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index ed47ffb5c..7de53ae06 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -571,7 +571,7 @@ class EV3 { */ connect (id) { if (this._bt) { - this._bt.connectPeripheral(id); + this._bt.connectPeripheral(id, '1234'); } } diff --git a/src/io/bt.js b/src/io/bt.js index a2056209c..39d570b68 100644 --- a/src/io/bt.js +++ b/src/io/bt.js @@ -58,9 +58,10 @@ class BT extends JSONRPCWebSocket { * Try connecting to the input peripheral id, and then call the connect * callback if connection is successful. * @param {number} id - the id of the peripheral to connect to + * @param {string} pin - an optional pin for pairing */ - connectPeripheral (id) { - this.sendRemoteRequest('connect', {peripheralId: id}) + connectPeripheral (id, pin = null) { + this.sendRemoteRequest('connect', {peripheralId: id, pin: pin}) .then(() => { this._connected = true; this._runtime.emit(this._runtime.constructor.PERIPHERAL_CONNECTED); From b6913b78281696de903d26147cdf34a85cc00e6a Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Fri, 31 May 2019 11:14:32 -0400 Subject: [PATCH 2/3] Move EV3 pin to a static var. --- src/extensions/scratch3_ev3/index.js | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index 7de53ae06..e9eda2c63 100644 --- a/src/extensions/scratch3_ev3/index.js +++ b/src/extensions/scratch3_ev3/index.js @@ -15,6 +15,12 @@ const log = require('../../util/log'); // eslint-disable-next-line max-len const blockIconURI = ''; +/** + * String with Ev3 expected pairing pin. + * @readonly + */ +const Ev3PairingPin = '1234'; + /** * Enum for Ev3 direct command types. * Found in the 'EV3 Communication Developer Kit', section 4, page 24, at @@ -571,7 +577,7 @@ class EV3 { */ connect (id) { if (this._bt) { - this._bt.connectPeripheral(id, '1234'); + this._bt.connectPeripheral(id, Ev3PairingPin); } } From ae791b3f2661592d2dec4aeaa8584918d81d4d0a Mon Sep 17 00:00:00 2001 From: Evelyn Eastmond Date: Fri, 31 May 2019 11:27:20 -0400 Subject: [PATCH 3/3] Don't send null pin. --- src/io/bt.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/io/bt.js b/src/io/bt.js index 39d570b68..37b2c3a5e 100644 --- a/src/io/bt.js +++ b/src/io/bt.js @@ -61,7 +61,11 @@ class BT extends JSONRPCWebSocket { * @param {string} pin - an optional pin for pairing */ connectPeripheral (id, pin = null) { - this.sendRemoteRequest('connect', {peripheralId: id, pin: pin}) + const params = {peripheralId: id}; + if (pin) { + params.pin = pin; + } + this.sendRemoteRequest('connect', params) .then(() => { this._connected = true; this._runtime.emit(this._runtime.constructor.PERIPHERAL_CONNECTED);