summaryrefslogtreecommitdiff
path: root/src/web/app/common
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2017-11-21 03:40:09 +0900
committersyuilo <syuilotan@yahoo.co.jp>2017-11-21 03:40:09 +0900
commit1436617aab030fa5b3760a3eeae37a1cdeeba2df (patch)
tree5ac701a811de8be79e8e83643752818ee4b2cd1d /src/web/app/common
parentv3165 (diff)
downloadsharkey-1436617aab030fa5b3760a3eeae37a1cdeeba2df.tar.gz
sharkey-1436617aab030fa5b3760a3eeae37a1cdeeba2df.tar.bz2
sharkey-1436617aab030fa5b3760a3eeae37a1cdeeba2df.zip
wip
Diffstat (limited to 'src/web/app/common')
-rw-r--r--src/web/app/common/mios.ts49
-rw-r--r--src/web/app/common/scripts/config.ts10
2 files changed, 55 insertions, 4 deletions
diff --git a/src/web/app/common/mios.ts b/src/web/app/common/mios.ts
index 9704e92af8..4a36d6375f 100644
--- a/src/web/app/common/mios.ts
+++ b/src/web/app/common/mios.ts
@@ -37,6 +37,11 @@ export default class MiOS extends EventEmitter {
*/
public stream: HomeStreamManager;
+ /**
+ * A registration of service worker
+ */
+ private swRegistration: ServiceWorkerRegistration = null;
+
constructor() {
super();
@@ -44,6 +49,7 @@ export default class MiOS extends EventEmitter {
this.init = this.init.bind(this);
this.api = this.api.bind(this);
this.getMeta = this.getMeta.bind(this);
+ this.swSubscribe = this.swSubscribe.bind(this);
//#endregion
}
@@ -126,6 +132,25 @@ export default class MiOS extends EventEmitter {
// Finish init
callback();
+
+ //#region Service worker
+ const isSwSupported =
+ ('serviceWorker' in navigator) && ('PushManager' in window);
+
+ if (isSwSupported && this.isSignedin) {
+ // When service worker activated
+ navigator.serviceWorker.ready.then(this.swSubscribe);
+
+ // Register service worker
+ navigator.serviceWorker.register('/sw.js').then(registration => {
+ // 登録成功
+ console.info('ServiceWorker registration successful with scope: ', registration.scope);
+ }).catch(err => {
+ // 登録失敗 :(
+ console.error('ServiceWorker registration failed: ', err);
+ });
+ }
+ //#endregion
};
// Get cached account data
@@ -147,6 +172,30 @@ export default class MiOS extends EventEmitter {
}
}
+ private async swSubscribe(swRegistration: ServiceWorkerRegistration) {
+ this.swRegistration = swRegistration;
+
+ // Subscribe
+ this.swRegistration.pushManager.subscribe({
+ // A boolean indicating that the returned push subscription
+ // will only be used for messages whose effect is made visible to the user.
+ userVisibleOnly: true
+ }).then(subscription => {
+ console.log('Subscribe OK:', subscription);
+
+ // Register
+ this.api('sw/register', {
+ endpoint: subscription.endpoint,
+ auth: subscription.getKey('auth') ? btoa(String.fromCharCode.apply(null, new Uint8Array(subscription.getKey('auth')))) : '',
+ publickey: subscription.getKey('p256dh') ? btoa(String.fromCharCode.apply(null, new Uint8Array(subscription.getKey('p256dh')))) : ''
+ });
+ }).then(() => {
+ console.log('Server Stored Subscription.');
+ }).catch(err => {
+ console.error('Subscribe Error:', err);
+ });
+ }
+
/**
* Misskey APIにリクエストします
* @param endpoint エンドポイント名
diff --git a/src/web/app/common/scripts/config.ts b/src/web/app/common/scripts/config.ts
index c5015622f0..b4801a44de 100644
--- a/src/web/app/common/scripts/config.ts
+++ b/src/web/app/common/scripts/config.ts
@@ -1,9 +1,11 @@
-const Url = new URL(location.href);
+const _url = new URL(location.href);
-const isRoot = Url.host.split('.')[0] == 'misskey';
+const isRoot = _url.host == 'localhost'
+ ? true
+ : _url.host.split('.')[0] == 'misskey';
-const host = isRoot ? Url.host : Url.host.substring(Url.host.indexOf('.') + 1, Url.host.length);
-const scheme = Url.protocol;
+const host = isRoot ? _url.host : _url.host.substring(_url.host.indexOf('.') + 1, _url.host.length);
+const scheme = _url.protocol;
const url = `${scheme}//${host}`;
const apiUrl = `${scheme}//api.${host}`;
const chUrl = `${scheme}//ch.${host}`;