From 1ace0b3156f02176492a141a544f384512f315cf Mon Sep 17 00:00:00 2001 From: Shawn Date: Sun, 16 Dec 2018 22:28:35 -0600 Subject: [PATCH 1/6] Add short hash when serving bundles --- package-lock.json | 6 ++++++ package.json | 1 + server/render/renderFullPage.js | 9 ++++++++- 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/package-lock.json b/package-lock.json index febbadf7..c09d0b2f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7650,6 +7650,12 @@ "integrity": "sha512-6qE4B9deFBIa9YSpOc9O0Sgc43zTeVYbgDT5veRKSlB2+ZuHNoVVxA1L/ckMUayV9Ay9y7Z/SZCLcGteW9i7bg==", "dev": true }, + "md5-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/md5-file/-/md5-file-4.0.0.tgz", + "integrity": "sha512-UC0qFwyAjn4YdPpKaDNw6gNxRf7Mcx7jC1UGCY4boCzgvU2Aoc1mOGzTtrjjLKhM5ivsnhoKpQVxKPp+1j1qwg==", + "dev": true + }, "md5.js": { "version": "1.3.5", "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", diff --git a/package.json b/package.json index 3b5d9f17..8f7701b6 100644 --- a/package.json +++ b/package.json @@ -104,6 +104,7 @@ "file-loader": "^2.0.0", "har-validator": "^5.1.3", "husky": "^1.1.3", + "md5-file": "^4.0.0", "mini-css-extract-plugin": "^0.5.0", "mocha": "^5.2.0", "ndb": "^1.0.26", diff --git a/server/render/renderFullPage.js b/server/render/renderFullPage.js index 12e39214..a35a0c1e 100644 --- a/server/render/renderFullPage.js +++ b/server/render/renderFullPage.js @@ -1,3 +1,10 @@ +const md5File = require('md5-file'); +const path = require('path'); + +const bundlePath = path.resolve('./public/bundle/bundle.js'); +const bundleHash = md5File.sync(bundlePath); +const shortBundleHash = bundleHash.substring(0,4); + module.exports = (helmet, html, preloadedState) => { // take the html and preloadedState and return the full page return ` @@ -22,7 +29,7 @@ module.exports = (helmet, html, preloadedState) => { - + `; From ae2283911ea722ac54a5f09bfad817e9d6679062 Mon Sep 17 00:00:00 2001 From: jessop Date: Mon, 17 Dec 2018 17:16:29 -0500 Subject: [PATCH 2/6] fixes channel claim issue introduced by file extension fix --- server/utils/getClaimData.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/utils/getClaimData.js b/server/utils/getClaimData.js index e0ab2433..5e26aad4 100644 --- a/server/utils/getClaimData.js +++ b/server/utils/getClaimData.js @@ -22,7 +22,7 @@ module.exports = async (data) => { let lbrynetFileExt = null; if (!data.fileExt) { lbrynetClaimResult = await getClaim(lbrynetUri).catch(() => { return 'invalid URI' }); - lbrynetFileExt = lbrynetClaimResult && lbrynetClaimResult.file_name.split('.').slice(-1).pop(); + lbrynetFileExt = lbrynetClaimResult && lbrynetClaimResult.file_name && lbrynetClaimResult.file_name.split('.').slice(-1).pop(); } // TODO verify that "generated_x" does anything at all From cbb94d5e557c4ffdb6b4244888648479212cad2c Mon Sep 17 00:00:00 2001 From: jessop Date: Mon, 17 Dec 2018 19:16:19 -0500 Subject: [PATCH 3/6] app sends 404 code for /fallback and failing canonical --- server/render/handleShowRender.jsx | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/server/render/handleShowRender.jsx b/server/render/handleShowRender.jsx index 4f43a400..0fe19d24 100644 --- a/server/render/handleShowRender.jsx +++ b/server/render/handleShowRender.jsx @@ -49,9 +49,11 @@ export default (req, res) => { action = false, saga = false, } = httpContext.get('routeData'); + if (action === 'fallback') { + res.status(404); + } const runSaga = (action !== false && saga !== false); - const renderPage = (store) => { // Workaround, remove when a solution for async httpContext exists @@ -63,10 +65,10 @@ export default (req, res) => { } else { const channelKeys = Object.keys(showState.channelList); - if(channelKeys.length !== 0) { + if (channelKeys.length !== 0) { res.claimId = showState.channelList[channelKeys[0]].longId; res.isChannel = true; - } + } } // render component to a string @@ -115,6 +117,9 @@ export default (req, res) => { .then(() => { // redirect if request does not use canonical url const canonicalUrl = getCanonicalUrlFromShow(store.getState().show); + if (!canonicalUrl) { + res.status(404); + } if (canonicalUrl && canonicalUrl !== req.originalUrl) { console.log(`redirecting ${req.originalUrl} to ${canonicalUrl}`); res.redirect(canonicalUrl); From ebe928c1588a970257de99250e69c9f82ffc88b4 Mon Sep 17 00:00:00 2001 From: jessop Date: Mon, 17 Dec 2018 19:33:42 -0500 Subject: [PATCH 4/6] clarity changes to ubuntu docs --- docs/ubuntuinstall.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/docs/ubuntuinstall.md b/docs/ubuntuinstall.md index 454cb327..54c83e7f 100644 --- a/docs/ubuntuinstall.md +++ b/docs/ubuntuinstall.md @@ -132,13 +132,14 @@ Log in as username@domainname or username@ip_address `sudo apt-get install mysql-server -y` - ( enter blank password each time if prompted) + ( During install, enter blank password each time if prompted. We'll set one during secure setup.) `sudo systemctl status mysql` (q to exit) ## Secure Setup `sudo mysql_secure_installation` + * Password your_mysql_password * No to password validation * Y to all other options @@ -223,13 +224,10 @@ tmux allows you to run multiple things in different sessions. Useful for manuall Once your wallet has a balance, run this: - `npm run configure` - - (once your wallet balance has cleared) - - `npm run configure` - + `npm run configure` + The script will ask for the following values: + * Database: lbry * Username: root * Password: your_mysql_password @@ -237,6 +235,8 @@ tmux allows you to run multiple things in different sessions. Useful for manuall * Site Title: Your Site Name * Enter your site's domain name: https://example.com or http://localhost:3000 * Enter a directory where uploads should be stored: (/home/lbry/Uploads) + + `npm run build` (or `npm run dev` to build for developing) `npm run start` From c3358109787bac305289e59995a2ffe27bd9229d Mon Sep 17 00:00:00 2001 From: Shawn K Date: Mon, 17 Dec 2018 19:52:51 -0600 Subject: [PATCH 5/6] Add line breaks --- server/render/handleShowRender.jsx | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/server/render/handleShowRender.jsx b/server/render/handleShowRender.jsx index 0fe19d24..ca0082f1 100644 --- a/server/render/handleShowRender.jsx +++ b/server/render/handleShowRender.jsx @@ -49,6 +49,7 @@ export default (req, res) => { action = false, saga = false, } = httpContext.get('routeData'); + if (action === 'fallback') { res.status(404); } @@ -117,13 +118,16 @@ export default (req, res) => { .then(() => { // redirect if request does not use canonical url const canonicalUrl = getCanonicalUrlFromShow(store.getState().show); + if (!canonicalUrl) { res.status(404); } + if (canonicalUrl && canonicalUrl !== req.originalUrl) { console.log(`redirecting ${req.originalUrl} to ${canonicalUrl}`); res.redirect(canonicalUrl); } + return renderPage(store) }); } else { From 4c4f1d0e63c70871e02c11314b66402447ad6474 Mon Sep 17 00:00:00 2001 From: Shawn Date: Tue, 18 Dec 2018 14:59:36 -0600 Subject: [PATCH 6/6] Fix custom alias extensions --- utils/createModuleAliases.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utils/createModuleAliases.js b/utils/createModuleAliases.js index f80fee87..eea3edb4 100644 --- a/utils/createModuleAliases.js +++ b/utils/createModuleAliases.js @@ -19,7 +19,7 @@ const addAliasesForCustomComponentFolder = (name, aliasObject) => { for (let i = 0; i < components.length; i++) { let folderName = components[i]; let aliasName = `@${name}/${folderName}`; - aliasObject[aliasName] = resolve(`${CUSTOM_ROOT}/${name}/${folderName}/index.js`); + aliasObject[aliasName] = resolve(`${CUSTOM_ROOT}/${name}/${folderName}/`); } return aliasObject; };