访问Samsung Gear S3边界上的心率监视器的“权限被拒绝” Web应用程序错误

时间:2019-04-26 19:12:31

标签: javascript tizen tizen-web-app samsung-gear

我正在尝试为我的Samsung Gear S3前沿创建一个Tizen网络应用程序。但是,我收到了“权限被拒绝”安全错误。

我有:

<tizen:privilege name="http://developer.samsung.com/privilege/healthinfo"/>

<tizen:privilege name="http://tizen.org/privilege/healthinfo"/>
在我的config.xml中启用了

如果我在设置中启用了该应用程序的传感器权限,则可以获取心率读数,但是每次我编译并上传较新的版本时,它都会重置。

这是我的JS代码,按Retrieving Data from GEAR S3 Heart Rate Monitor (HRM) to Mobile or Server排序:

window.onload = function () {
    // add eventListener for tizenhwkey
    document.addEventListener('tizenhwkey', function(e) {
        if(e.keyName === "back") {
            try {
                tizen.application.getCurrentApplication().exit();
            } catch (ignore) {
            }
        }
    });

    // Sample code
    var textbox = document.querySelector('.contents');
    var box = document.querySelector('#textbox');

    textbox.addEventListener("click", function(){
        console.log('have box');

        if (fetch === undefined) {
            box.innerHTML = 'No such thing as fetch';
        } else {
            box.innerHTML = "We have fetch";            
        }
    });

    var sensors = tizen.sensorservice.getAvailableSensors();
    console.log('Available sensors: ' + sensors.toString());

    var heartRateData=0;

    function onsuccessCB(hrmInfo) {

        box.innerHTML = 'Heart rate: ' + hrmInfo.heartRate;
        heartRateData = hrmInfo.heartRate;
        // holding 15 seconds as HRM sensor needs some time 
    }

    function onerrorCB(error) {
        tizen.humanactivitymonitor.stop('HRM');
        console.log('Error occurred: ' + error.message);
    }

    function onchangedCB(hrmInfo) {
        //alert("onChanged...");
        tizen.humanactivitymonitor.getHumanActivityData('HRM', onsuccessCB, onerrorCB);

    }

    tizen.humanactivitymonitor.start('HRM', onchangedCB);
};

我希望config.xml设置能够照顾到权限,但是显然不会。该手表运行的是Tizen 4.0.0.2,并且运行的是“ HRM_RAW”传感器,如果不手动设置权限,我也无法访问该传感器。

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

经过一些更具创造性的网络搜索,我想自己找到了答案。使用tizen.ppm.requestPermission()(在https://developer.tizen.org/forums/web-application-development/security-exception-while-accessing-hrm

之后

这将导致预期的行为。该应用程序在安装时通过可穿戴用户界面询问是否应授予该权限,以及该决定是否应为默认决定。

但是,我做了一些重构,因为您经常在应用中需要几个权限,而回调地狱就在附近。所以我围绕着tizen调用写了一个Promise包装器:

function requestPermit(uri) {
  return new Promise(function(resolve, reject) {
    tizen.ppm.requestPermission(uri,
      function(success) => { resolve(success); },
      function(error) => { reject(error); });
  });
}

这允许我

function main() {
  return permitRequester('http://tizen.org/privilege/healthinfo')
    .then(function() { return permitRequester('http://developer.samsung.com/privilege/healthinfo'); })
    .then(function() { return permitRequester('http://developer.samsung.com/privilege/medicalinfo'); })
    .then(function() { return displayHeartRate(); })
    .catch(function(err) { return console.log(err); });
}

window.onload = main();

您确实需要在项目中包含Promise库。我这样做是通过包括Promise polyfill来完成的,因为tizen Web应用程序本身并不支持此功能。希望这对任何人都有帮助。如果您需要更多信息,可以在https://github.com/reinvantveer/Axyll

上创建一个ES2016 npm / webpack项目。