diff --git a/.env b/.env index db14633d..471ea57b 100644 --- a/.env +++ b/.env @@ -2,7 +2,8 @@ ACCESS_KEY_B2= SECRET_KEY_B2= BUCKET_B2= API_KEY_LASTFM= -API_KEY_PLAUSIBLE= +SITE_ID= +API_KEY_NETLIFY= API_KEY_TRAKT= API_KEY_MOVIEDB= API_TOKEN_READWISE= diff --git a/_redirects b/_redirects index 235ca203..de75734f 100644 --- a/_redirects +++ b/_redirects @@ -2,12 +2,6 @@ /.well-known/host-meta* https://social.lol/.well-known/host-meta:splat 301 /.well-known/nodeinfo* https://social.lol/.well-known/nodeinfo:splat 301 -# rewrites -/favicon.ico /assets/img/favicon/favicon.ico 200! -/apple-touch-icon.png /assets/img/favicon/apple-touch-icon.png 200! -/apple-touch-icon-precomposed.png /assets/img/favicon/apple-touch-icon.png 200! -/static/favicons/apple-touch-icon.png /assets/img/favicon/apple-touch-icon.png 200! - # blog posts /blog/fixing-safari-icloud-syncing /posts/2022/fixing-safari-icloud-syncing/ 301! /blog/migrating-to-fastmail /posts/2022/migrating-to-fastmail/ 301! @@ -27,30 +21,22 @@ /posts/2023/webmentions-in-eleventy/null /posts/2023/webmentions-in-eleventy/ 301! /posts/2023/a-safari-specific-guide-to-making-the-modern-web-suck-less/null /posts/2023/a-safari-specific-guide-to-making-the-modern-web-suck-less/ 301! /posts/2023/hacking-together-a-tweeklyfm-replacement/ /posts/2023/hacking-together-a-tweeklyfm-repalcement/ -/tags/.env /tags/env 301! # 404s +/robot.txt /robots.txt 301! /sitemap.txt /sitemap.xml 301! -/assets/img/social-preview/adding-a-light/dark-theme-toggle-preview.jpeg /assets/img/social-preview/adding-a-light-dark-theme-toggle-preview.jpeg 301! -/assets/img/social-card.jpg /assets/img/ogi/default.jpg 301! /posts / 301! /blog / 301! /posts/2024 / 301! -/blog/digital-privacy-tools /posts/2021/digital-privacy-tools/ 301! -/assets/img/social-preview/your-site-your-home-your-web- /assets/img/social-preview/your-site-your-home-your-web-preview.jpeg 301! -/assets/img/social-preview/go-ahead-and-block-ai-web- /assets/img/social-preview/go-ahead-and-block-ai-web-crawlers-preview.jpeg 301! +/tags/.env /tags/env 301! /tags/chatgpt/ /tags/ai/ 301! /tags/socialmedia /tags/social%20media/ 301! -/robot.txt /robots.txt 301! +/blog/digital-privacy-tools /posts/2021/digital-privacy-tools/ 301! +/assets/img/social-card.jpg /assets/img/ogi/default.jpg 301! +/assets/img/social-preview/your-site-your-home-your-web- /assets/img/social-preview/your-site-your-home-your-web-preview.jpeg 301! +/assets/img/social-preview/adding-a-light/dark-theme-toggle-preview.jpeg /assets/img/social-preview/adding-a-light-dark-theme-toggle-preview.jpeg 301! +/assets/img/social-preview/go-ahead-and-block-ai-web- /assets/img/social-preview/go-ahead-and-block-ai-web-crawlers-preview.jpeg 301! /-want-anything-your-ai-generates/ /posts/2024/i-dont-want-anything-your-ai-generates/ 301! -/static/images/avatar.png /assets/img/avatar.png 301! -/assets/img/logo.webp /assets/img/avatar.webp 301! -/apple-touch-icon-precomposed.png /assets/icons/apple-touch-icon.png 301! -/apple-touch-icon /assets/icons/apple-touch-icon.png 301! -/static/favicons/apple-touch-icon.png /assets/icons/apple-touch-icon.png 301! -/favicon.ico /assets/icons/favicon.ico 301! -/assets/img/cache/avatar-800w.webp /assets/img/cache/avatar-880w.webp 301! -/assets/img/ogi/default.jpg /assets/img/avatar.webp 301! # 400s /wp-* /400/ 400 @@ -70,13 +56,19 @@ //test/ /400/ 400 # assets +/favicon.ico /assets/icons/favicon.ico 200! +/apple-touch-icon.png /assets/icons/apple-touch-icon.png 200! +/apple-touch-icon /assets/icons/apple-touch-icon.png 200! +/apple-touch-icon-precomposed.png /assets/icons/apple-touch-icon.png 200! +/static/favicons/apple-touch-icon.png /assets/icons/apple-touch-icon.png 200! +/static/images/avatar.png /assets/img/avatar.png 301! /static/images/avatar.webp /assets/img/avatar.webp 301! +/assets/img/cache/avatar-800w.webp /assets/img/cache/avatar-880w.webp 301! /assets/img/favicon/apple-touch-icon.png /assets/icons/apple-touch-icon.png 301! -/apple-touch-icon.png /assets/icons/apple-touch-icon.png 301! -/apple-touch-icon-precomposed.png /assets/icons/apple-touch-icon.png 301! -/favicon.ico /assets/icons/favicon.ico 301! /assets/img/favicon/favicon-32x32.png /assets/icons/favicon.ico 301! /assets/img/favicon/favicon-16x16.png /assets/icons/favicon.ico 301! +/assets/img/logo.webp /assets/img/avatar.webp 301! +/assets/img/ogi/default.jpg /assets/img/avatar.webp 301! # general /articles/ / 301! @@ -101,8 +93,4 @@ https://cdme.netlify.app https://coryd.dev 301! /links.xml https://feedpress.me/coryd-links /links.json https://feedpress.me/coryd-links.json /follow.xml https://feedpress.me/coryd-follow -/follow.json https://feedpress.me/coryd-follow.json - -# analytics -/js/script.js https://plausible.io/js/script.outbound-links.tagged-events.js 200 -/api/event https://plausible.io/api/event 200 \ No newline at end of file +/follow.json https://feedpress.me/coryd-follow.json \ No newline at end of file diff --git a/config/filters/index.js b/config/filters/index.js index 4793cd39..6f9bb6a9 100644 --- a/config/filters/index.js +++ b/config/filters/index.js @@ -47,11 +47,11 @@ export default { getPopularPosts: (posts, analytics) => { return posts .filter((post) => { - if (analytics.find((p) => p.page === post.url)) return true + if (analytics.find((p) => p.resource === post.url)) return true }) .sort((a, b) => { - const visitors = (page) => analytics.filter((p) => p.page === page.url).pop().visitors - return visitors(b) - visitors(a) + const count = (page) => analytics.filter((p) => p.resource === page.url).pop().count + return count(b) - count(a) }) }, diff --git a/package.json b/package.json index d19a5010..60e70a5e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "coryd.dev", - "version": "8.4.6", + "version": "8.5.0", "description": "The source for my personal site. Built using 11ty.", "type": "module", "scripts": { diff --git a/src/_data/analytics.js b/src/_data/analytics.js index 36109006..18661548 100644 --- a/src/_data/analytics.js +++ b/src/_data/analytics.js @@ -1,18 +1,23 @@ import EleventyFetch from '@11ty/eleventy-fetch' export default async function () { - const API_KEY_PLAUSIBLE = process.env.API_KEY_PLAUSIBLE + const API_KEY_NETLIFY = process.env.API_KEY_NETLIFY + const SITE_ID = process.env.SITE_ID + const endDate = new Date(); + const startDate = new Date(new Date().setDate(endDate.getDate() - 30)); + const timezoneOffset = new Date().getTimezoneOffset() / 60; const url = - 'https://plausible.io/api/v1/stats/breakdown?site_id=coryd.dev&period=6mo&property=event:page&limit=30' + `https://analytics.services.netlify.com/v2/${SITE_ID}/ranking/pages?from=${startDate.getTime()}&to=${endDate.getTime()}&timezone=-0${timezoneOffset}00&limit=50` const res = EleventyFetch(url, { duration: '1h', type: 'json', fetchOptions: { headers: { - Authorization: `Bearer ${API_KEY_PLAUSIBLE}`, + Authorization: `Bearer ${API_KEY_NETLIFY}`, }, }, }).catch() - const pages = await res - return pages.results.filter((p) => p.page.includes('posts')) + const responseObject = await res + const pages = responseObject['data'] + return pages.filter((p) => p.resource.includes('posts')) } diff --git a/src/_includes/base.liquid b/src/_includes/base.liquid index 530a2541..6e1e2ed1 100644 --- a/src/_includes/base.liquid +++ b/src/_includes/base.liquid @@ -6,8 +6,6 @@
You can download an OPML file containing all of these feeds and import them into your RSS reader.
+You can download an OPML file containing all of these feeds and import them into your RSS reader.