From 9c48ff884c0073faad6383ea34f80d6a72afe23c Mon Sep 17 00:00:00 2001 From: Kevin Kandlbinder Date: Tue, 28 Sep 2021 14:14:08 +0200 Subject: [PATCH 1/4] Add matrix-URI parsing support using matrix-uri-parser --- package.json | 3 +++ src/Link.js | 24 ++++++++++++++++++++++++ yarn.lock | 4 ++++ 3 files changed, 31 insertions(+) diff --git a/package.json b/package.json index 5a879c31..23b31787 100644 --- a/package.json +++ b/package.json @@ -33,5 +33,8 @@ "rollup-plugin-terser": "^7.0.2", "serve-static": "^1.14.1", "xxhashjs": "^0.2.2" + }, + "dependencies": { + "matrix-uri-parser": "https://github.com/matrix-org/matrix-uri-parser-js" } } diff --git a/src/Link.js b/src/Link.js index 47270778..119e6de0 100644 --- a/src/Link.js +++ b/src/Link.js @@ -16,6 +16,7 @@ limitations under the License. import {createEnum} from "./utils/enum.js"; import {orderedUnique} from "./utils/unique.js"; +import {MatrixURL} from "matrix-uri-parser"; const ROOMALIAS_PATTERN = /^#([^:]*):(.+)$/; const ROOMID_PATTERN = /^!([^:]*):(.+)$/; @@ -111,6 +112,29 @@ export class Link { return null; } linkStr = linkStr.substr(2); + + const linkStrMatrixUrl = fragment.substr(2).startsWith("matrix:") ? fragment.substr(2) : "matrix:"+fragment.substr(2); + + try { + const parsedUrl = new MatrixURL(linkStrMatrixUrl); // Try to parse URL as matrix-URL + + let [localPart, server] = parsedUrl.id.split(":"); // Split ID into local and server part + + if(!server) server = parsedUrl.authority; // If no server part is present, try to use authority + if(!server) return null; // Reject if we can't figure out the server + + const webInstances = getWebInstanceMap(parsedUrl.unknownParams); + + let clientId; + + const clientParam = parsedUrl.unknownParams.find(([key]) => key === "client"); + if(clientParam) clientId = clientParam[1]; + + const link = new Link(clientId, parsedUrl.via, parsedUrl.kind, localPart, server, webInstances, parsedUrl.eventId); + + return link; + } catch(e) {} // The fragment was no matrix-URL. + const [identifier, eventId] = linkStr.split("/"); let viaServers = []; diff --git a/yarn.lock b/yarn.lock index e253b400..dd87f7fe 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1418,6 +1418,10 @@ matched@^5.0.0: glob "^7.1.6" picomatch "^2.2.1" +"matrix-uri-parser@https://github.com/matrix-org/matrix-uri-parser-js": + version "0.1.0" + resolved "https://github.com/matrix-org/matrix-uri-parser-js#506c2545dae5e0d05633bc905a937731a1e69104" + mdn-polyfills@^5.20.0: version "5.20.0" resolved "https://registry.yarnpkg.com/mdn-polyfills/-/mdn-polyfills-5.20.0.tgz#ca8247edf20a4f60dec6804372229812b348260b" From 4bba67b51042c9c70a3a508c07c31dcbe931a674 Mon Sep 17 00:00:00 2001 From: Kevin Kandlbinder Date: Tue, 28 Sep 2021 15:05:18 +0200 Subject: [PATCH 2/4] Switch to `vite` for development server --- package.json | 5 ++-- scripts/serve-local.js | 48 -------------------------------- yarn.lock | 63 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 66 insertions(+), 50 deletions(-) delete mode 100644 scripts/serve-local.js diff --git a/package.json b/package.json index 23b31787..a680dace 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "node": ">= 14.0.0" }, "scripts": { - "start": "node scripts/serve-local.js", + "start": "vite", "build": "node scripts/build.js" }, "devDependencies": { @@ -35,6 +35,7 @@ "xxhashjs": "^0.2.2" }, "dependencies": { - "matrix-uri-parser": "https://github.com/matrix-org/matrix-uri-parser-js" + "matrix-uri-parser": "https://github.com/matrix-org/matrix-uri-parser-js", + "vite": "^2.5.10" } } diff --git a/scripts/serve-local.js b/scripts/serve-local.js deleted file mode 100644 index b1b77e83..00000000 --- a/scripts/serve-local.js +++ /dev/null @@ -1,48 +0,0 @@ -/* -Copyright 2020 Bruno Windels - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -import finalhandler from "finalhandler" -import http from "http" -import serveStatic from "serve-static" -import path from "path" -import { fileURLToPath } from "url"; -const projectDir = path.resolve(path.dirname(fileURLToPath(import.meta.url)), "../"); - -// Serve up parent directory with cache disabled -const serve = serveStatic( - projectDir, - { - etag: false, - setHeaders: res => { - res.setHeader("Pragma", "no-cache"); - res.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); - res.setHeader("Expires", "Wed, 21 Oct 2015 07:28:00 GMT"); - // same CSP as matrix.to server is using, so local testing happens under similar environment - res.setHeader("Content-Security-Policy", "default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; img-src * data:; connect-src *; font-src 'self'; manifest-src 'self'; form-action 'self'; navigate-to *;"); - }, - index: ['index.html', 'index.htm'] - } -); - -// Create server -const server = http.createServer(function onRequest (req, res) { - console.log(req.method, req.url); - serve(req, res, finalhandler(req, res)) -}); - -// Listen -server.listen(5000); -console.log("Listening on port 5000"); diff --git a/yarn.lock b/yarn.lock index dd87f7fe..9151b4dc 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1181,6 +1181,11 @@ entities@^2.0.0: resolved "https://registry.yarnpkg.com/entities/-/entities-2.1.0.tgz#992d3129cf7df6870b96c57858c249a120f8b8b5" integrity sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w== +esbuild@^0.12.17: + version "0.12.29" + resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.12.29.tgz#be602db7c4dc78944a9dbde0d1ea19d36c1f882d" + integrity sha512-w/XuoBCSwepyiZtIRsKsetiLDUVGPVw1E/R3VTFSecIy8UR7Cq3SOtwKHJMFoVqqVG36aGkzh4e8BvpO1Fdc7g== + escalade@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" @@ -1254,6 +1259,11 @@ fsevents@~2.1.2: resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.3.tgz#fb738703ae8d2f9fe900c33836ddebee8b97f23e" integrity sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ== +fsevents@~2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + function-bind@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" @@ -1355,6 +1365,13 @@ is-core-module@^2.1.0: dependencies: has "^1.0.3" +is-core-module@^2.2.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.7.0.tgz#3c0ef7d31b4acfc574f80c58409d568a836848e3" + integrity sha512-ByY+tjCciCr+9nLryBYcSD50EOGWt95c7tIsKTG1J2ixKKXPvF7Ej3AVd+UfDydAJom3biBGDBALaO79ktwgEQ== + dependencies: + has "^1.0.3" + is-module@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-module/-/is-module-1.0.0.tgz#3258fb69f78c14d5b815d664336b4cffb6441591" @@ -1476,11 +1493,21 @@ ms@2.1.2: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== +nanocolors@^0.2.2: + version "0.2.11" + resolved "https://registry.yarnpkg.com/nanocolors/-/nanocolors-0.2.11.tgz#f2573e6872f1b70067423fc68bbc9d0de2f3bbee" + integrity sha512-83ttyvfJj66dKMadWfBkEUOEDFfRc8FpzTJvh1MySR/pzWFmFikTQZGOV6kHZRz7yR/heiQ1y/MHBBN5P/e7WQ== + nanoid@^3.1.23: version "3.1.23" resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.23.tgz#f744086ce7c2bc47ee0a8472574d5c78e4183a81" integrity sha512-FiB0kzdP0FFVGDKlRLEQ1BgDzU87dy5NnzjeW9YZNt+/c3+q82EQDUwniSAUxp/F0gFNI1ZhKU1FqYsMuqZVnw== +nanoid@^3.1.25: + version "3.1.28" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.28.tgz#3c01bac14cb6c5680569014cc65a2f26424c6bd4" + integrity sha512-gSu9VZ2HtmoKYe/lmyPFES5nknFrHa+/DT9muUFWFMi6Jh9E1I7bkvlQ8xxf1Kos9pi9o8lBnIOkatMhKX/YUw== + node-releases@^1.1.71: version "1.1.72" resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.72.tgz#14802ab6b1039a79a0c7d662b610a5bbd76eacbe" @@ -1634,6 +1661,15 @@ postcss@^8.2.10: nanoid "^3.1.23" source-map-js "^0.6.2" +postcss@^8.3.6: + version "8.3.8" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.3.8.tgz#9ebe2a127396b4b4570ae9f7770e7fb83db2bac1" + integrity sha512-GT5bTjjZnwDifajzczOC+r3FI3Cu+PgPvrsjhQdRqa2kTJ4968/X9CUce9xttIB0xOs5c6xf0TCWZo/y9lF6bA== + dependencies: + nanocolors "^0.2.2" + nanoid "^3.1.25" + source-map-js "^0.6.2" + randombytes@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" @@ -1718,6 +1754,14 @@ resolve@^1.1.7, resolve@^1.17.0, resolve@^1.3.2: is-core-module "^2.1.0" path-parse "^1.0.6" +resolve@^1.20.0: + version "1.20.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975" + integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A== + dependencies: + is-core-module "^2.2.0" + path-parse "^1.0.6" + rollup-plugin-terser@^7.0.2: version "7.0.2" resolved "https://registry.yarnpkg.com/rollup-plugin-terser/-/rollup-plugin-terser-7.0.2.tgz#e8fbba4869981b2dc35ae7e8a502d5c6c04d324d" @@ -1735,6 +1779,13 @@ rollup@^2.26.4: optionalDependencies: fsevents "~2.1.2" +rollup@^2.38.5: + version "2.57.0" + resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.57.0.tgz#c1694475eb22e1022477c0f4635fd0ac80713173" + integrity sha512-bKQIh1rWKofRee6mv8SrF2HdP6pea5QkwBZSMImJysFj39gQuiV8MEPBjXOCpzk3wSYp63M2v2wkWBmFC8O/rg== + optionalDependencies: + fsevents "~2.3.2" + safe-buffer@^5.1.0, safe-buffer@~5.2.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" @@ -1914,6 +1965,18 @@ util-deprecate@^1.0.1: resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= +vite@^2.5.10: + version "2.5.10" + resolved "https://registry.yarnpkg.com/vite/-/vite-2.5.10.tgz#c598e3b5a7e1956ffc52eb3b3420d177fc2ed2a5" + integrity sha512-0ObiHTi5AHyXdJcvZ67HMsDgVpjT5RehvVKv6+Q0jFZ7zDI28PF5zK9mYz2avxdA+4iJMdwCz6wnGNnn4WX5Gg== + dependencies: + esbuild "^0.12.17" + postcss "^8.3.6" + resolve "^1.20.0" + rollup "^2.38.5" + optionalDependencies: + fsevents "~2.3.2" + wrappy@1: version "1.0.2" resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" From 07918b406fdc4fc5799f4332113dce1915d224b6 Mon Sep 17 00:00:00 2001 From: Kevin Kandlbinder Date: Mon, 12 Sep 2022 02:03:15 +0200 Subject: [PATCH 3/4] Update Link.js --- src/Link.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/Link.js b/src/Link.js index 623e2690..80a49255 100644 --- a/src/Link.js +++ b/src/Link.js @@ -111,7 +111,7 @@ export class Link { if (!linkStr.startsWith("#/")) { return null; } - linkStr = linkStr.substr(2); + linkStr = linkStr.slice(2); const linkStrMatrixUrl = fragment.substr(2).startsWith("matrix:") ? fragment.substr(2) : "matrix:"+fragment.substr(2); @@ -134,6 +134,8 @@ export class Link { return link; } catch(e) {} // The fragment was no matrix-URL. + + linkStr = linkStr.substr(2); const [identifier, eventId] = linkStr.split("/"); From 4a6715be21a6144b8ab962c5b2bfe47a29e79836 Mon Sep 17 00:00:00 2001 From: Kevin Kandlbinder Date: Mon, 12 Sep 2022 02:04:42 +0200 Subject: [PATCH 4/4] Fix double slicing --- src/Link.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/Link.js b/src/Link.js index 80a49255..d01cb5f5 100644 --- a/src/Link.js +++ b/src/Link.js @@ -111,7 +111,6 @@ export class Link { if (!linkStr.startsWith("#/")) { return null; } - linkStr = linkStr.slice(2); const linkStrMatrixUrl = fragment.substr(2).startsWith("matrix:") ? fragment.substr(2) : "matrix:"+fragment.substr(2); @@ -135,7 +134,7 @@ export class Link { return link; } catch(e) {} // The fragment was no matrix-URL. - linkStr = linkStr.substr(2); + linkStr = linkStr.slice(2); const [identifier, eventId] = linkStr.split("/");