From e00cf7eddc7508611aaeeca22dc7d0cc5c283809 Mon Sep 17 00:00:00 2001 From: cwxia0s Date: Sun, 18 Feb 2024 09:36:34 +0800 Subject: [PATCH] Fix: Register Handler Key Reset --- exapmles/lunar_birthday_reminder/main.js | 2 +- main.js | 54 +++++++++--------------- test.sh | 33 ++++++++++++--- 3 files changed, 49 insertions(+), 40 deletions(-) diff --git a/exapmles/lunar_birthday_reminder/main.js b/exapmles/lunar_birthday_reminder/main.js index 1dd7b7e..36ca1c6 100644 --- a/exapmles/lunar_birthday_reminder/main.js +++ b/exapmles/lunar_birthday_reminder/main.js @@ -31,7 +31,7 @@ async function handleEvent(event, env, ctx) { // 使用Bark-Server // return await fetch(`${serverURL}/${title}/${matchingEvent[1]}`) - // 如果使用Bark-Worker, 同一帐号同一域名下Wroker间相互调用使用Worker Binding, 否则会报错, 这里可以随便填个域名, 但path要遵循规范 + // 如果使用Bark-Worker, 同一帐号同一域名下Worker间相互调用使用Worker Binding, 否则会报错, 这里可以随便填个域名, 但path要遵循规范 return await env.APNs.fetch(`${serverURL}/${title}/${matchingEvent[1]}`) } diff --git a/main.js b/main.js index 11f8c57..efc72ca 100644 --- a/main.js +++ b/main.js @@ -44,9 +44,13 @@ async function handleRequest(request, env, ctx) { if (pathParts.length === 3) { requestBody.body = pathParts[2] - } else { + } else if (pathParts.length === 4) { requestBody.title = pathParts[2] requestBody.body = pathParts[3] + } else if (pathParts.length === 5){ + requestBody.category = pathParts[2] + requestBody.body = pathParts[3] + requestBody.title = pathParts[4] } } } catch (err) { @@ -79,18 +83,17 @@ async function handleRequest(request, env, ctx) { class Handler { constructor(env) { this.version = "v2.0.1" - this.build = "2024-02-17 17:39:51" + this.build = "2024-02-18 09:36:34" this.arch = "js" - this.commit = "8cfe3bb848353a775529d884d37240e42410d409" + this.commit = "29bf5aca3fb004d1861f36a1ed85b07ca5cceb87" const db = new Database(env) this.register = async (parameters) => { + const deviceToken = parameters.get('devicetoken') + let key = parameters.get('key') - const param_devicetoken = parameters.get('devicetoken') - let param_key = parameters.get('key') - - if (!param_devicetoken) { + if (!deviceToken) { return new Response(JSON.stringify({ 'message': 'device token is empty', 'code': 400, @@ -98,10 +101,9 @@ class Handler { }), { status: 400 }) } - if (!param_key) { + if (!(key && await db.deviceTokenByKey(key))){ if (isAllowNewDevice) { - param_key = util.newShortUUID() - await db.saveDeviceTokenByKey(param_key, param_devicetoken) + key = util.newShortUUID() } else { return new Response(JSON.stringify({ 'message': "device registration failed: register disabled", @@ -110,27 +112,16 @@ class Handler { } } - const deviceToken = await db.deviceTokenByKey(param_key) - if (await deviceToken != param_devicetoken) { - if (isAllowNewDevice) { - param_key = util.newShortUUID() - await db.saveDeviceTokenByKey(param_key, param_devicetoken) - } else { - return new Response(JSON.stringify({ - 'message': "device registration failed: register disabled", - 'code': 500, - }), { status: 500 }) - } - } + await db.saveDeviceTokenByKey(key, deviceToken) return new Response(JSON.stringify({ 'message': 'success', 'code': 200, 'timestamp': util.getTimestamp(), 'data': { - 'key': param_key, - 'device_key': param_key, - 'device_token': param_devicetoken, + 'key': key, + 'device_key': key, + 'device_token': deviceToken, }, }), { status: 200 }) } @@ -192,11 +183,10 @@ class Handler { const level = parameters.level || undefined const copy = parameters.copy || undefined const badge = parameters.badge || 0 - const autoCopy = parameters.autoCopy || undefined - - let ciphertext = parameters.ciphertext || undefined + const autoCopy = parameters.autoCopy || undefined + const ciphertext = parameters.ciphertext || undefined - let aps = { + const aps = { 'aps': { 'alert': { 'action': undefined, @@ -279,14 +269,11 @@ class APNs { // Parse private key const privateKeyPEM = TOKEN_KEY.replace('-----BEGIN PRIVATE KEY-----', '').replace('-----END PRIVATE KEY-----', '').replace(/\s/g, '') - // Decode private key const privateKeyArrayBuffer = util.base64ToArrayBuffer(privateKeyPEM) const privateKey = await crypto.subtle.importKey('pkcs8', privateKeyArrayBuffer, { name: 'ECDSA', namedCurve: 'P-256', }, false, ['sign']) - const TEAM_ID = '5U8LBRXG3A' const AUTH_KEY_ID = 'LH4T9V5U4R' - // Generate the JWT token const JWT_ISSUE_TIME = util.getTimestamp() const JWT_HEADER = btoa(JSON.stringify({ alg: 'ES256', kid: AUTH_KEY_ID })).replace('+', '-').replace('/', '_').replace(/=+$/, '') @@ -329,7 +316,6 @@ class APNs { body: pushData, }) } - } } @@ -382,7 +368,7 @@ class Util { const length = 22 const randomArray = new Uint8Array(length) crypto.getRandomValues(randomArray) - + const characters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' let customUUID = '' diff --git a/test.sh b/test.sh index b5ca49e..e6406ca 100644 --- a/test.sh +++ b/test.sh @@ -4,14 +4,16 @@ SERVER_ADDRESS="" DEVICE_KEY="" BAD_DEVICE_KEY="" -DEVICE_TOKEN="" +DEVICE_TOKEN="0000test0device0token0000" +echo -e "\e[1;32m" echo "Testing $SERVER_ADDRESS/$DEVICE_KEY" echo "" echo "---------------------------------------------------------------------" echo "Test URL/KEY With Body" echo "---------------------------------------------------------------------" echo "" +echo -e "\e[0m" curl -X "POST" "$SERVER_ADDRESS/$DEVICE_KEY" \ -H 'Content-Type: application/json; charset=utf-8' \ @@ -24,7 +26,7 @@ curl -X "POST" "$SERVER_ADDRESS/$DEVICE_KEY" \ "icon": "https://day.app/assets/images/avatar.jpg", "group": "test", "url": "https://mritd.com", - "isArchive": 0 + "isArchive": "0" }' echo "" @@ -40,34 +42,41 @@ curl -X "POST" "$SERVER_ADDRESS/push" \ "icon": "https://day.app/assets/images/avatar.jpg", "group": "test", "url": "https://mritd.com", - "isArchive": 0 + "isArchive": "0" }' +echo -e "\e[1;32m" echo "" echo "---------------------------------------------------------------------" echo "Test URL/KEY With Message In URL" echo "---------------------------------------------------------------------" echo "" +echo -e "\e[0m" -ENCODED_TITLE=Test%20Title%20In%20URL -ENCODED_MESSAGE=Test%20Message%20In%20URL +ENCODED_TITLE="Test%20Title%20In%20URL" +ENCODED_MESSAGE="Test%20Message%20In%20URL" curl -X "POST" "$SERVER_ADDRESS/$DEVICE_KEY/$ENCODED_MESSAGE?isArchive=0" echo "" curl -X "POST" "$SERVER_ADDRESS/$DEVICE_KEY/$ENCODED_TITLE/$ENCODED_MESSAGE?isArchive=0" +echo "" +curl -X "POST" "$SERVER_ADDRESS/$DEVICE_KEY/category/$ENCODED_TITLE/$ENCODED_MESSAGE?isArchive=0" + # echo "" # echo "---------------------------------------------------------------------" # echo "Test URL/KEY With Message In Form" # echo "---------------------------------------------------------------------" # echo "" +echo -e "\e[1;32m" echo "" echo "---------------------------------------------------------------------" echo "Test ciphertext" echo "---------------------------------------------------------------------" echo "" +echo -e "\e[0m" set -e json='{"body": "test", "sound": "birdsong"}' @@ -87,20 +96,34 @@ echo $ciphertext # URL encoding the ciphertext, there may be special characters. curl --data-urlencode "ciphertext=$ciphertext" $SERVER_ADDRESS/$DEVICE_KEY?isArchive=0 +echo -e "\e[1;32m" echo "" echo "---------------------------------------------------------------------" echo "Test Bad Device Token" echo "---------------------------------------------------------------------" echo "" +echo -e "\e[0m" curl -X "POST" "$SERVER_ADDRESS/$BAD_DEVICE_KEY" +echo -e "\e[1;32m" echo "" echo "---------------------------------------------------------------------" echo "Test Device Registeration" echo "---------------------------------------------------------------------" echo "" +echo -e "\e[0m" curl "$SERVER_ADDRESS/register?devicetoken=$DEVICE_TOKEN&key=" +echo -e "\e[1;32m" echo "" +echo "---------------------------------------------------------------------" +echo "Test Reset Device Key" +echo "---------------------------------------------------------------------" +echo "" +echo -e "\e[0m" + +curl "$SERVER_ADDRESS/register?devicetoken=deleted&key=$BAD_DEVICE_KEY" + +echo "" \ No newline at end of file