diff --git a/src/extensions/scratch3_ev3/index.js b/src/extensions/scratch3_ev3/index.js index ed47ffb5c..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); + this._bt.connectPeripheral(id, Ev3PairingPin); } } diff --git a/src/io/bt.js b/src/io/bt.js index b962d3c59..213930c11 100644 --- a/src/io/bt.js +++ b/src/io/bt.js @@ -57,9 +57,14 @@ class BT extends JSONRPC { * 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) { + 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);