diff --git a/.github/workflows/deploy-worker.yaml b/.github/workflows/deploy-worker.yaml deleted file mode 100644 index 3c765aac..00000000 --- a/.github/workflows/deploy-worker.yaml +++ /dev/null @@ -1,45 +0,0 @@ -name: Deploy Cloudflare Worker -on: - workflow_dispatch: - inputs: - worker-folder: - description: 'Select the folder containing the worker to deploy' - required: true - type: choice - options: - - analytics - - contact - - now-playing - - rebuild - - scrobble -jobs: - deploy: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - - name: Setup Node.js - uses: actions/setup-node@v2 - with: - node-version: '16' - - - name: Install Wrangler - run: npm install -g wrangler - - - name: Inject environment variables into wrangler.toml - run: | - cd workers/${{ github.event.inputs.worker-folder }} - sed -i 's/^zone_id =.*/zone_id = "${{ secrets.CLOUDFLARE_ZONE_ID }}"/' wrangler.toml - sed -i 's/^account_id =.*/account_id = "${{ secrets.CLOUDFLARE_ACCOUNT_ID }}"/' wrangler.toml - - - name: Install dependencies - run: | - cd workers/${{ github.event.inputs.worker-folder }} - npm i - - - name: Deploy to Cloudflare Worker - run: | - cd workers/${{ github.event.inputs.worker-folder }} - wrangler deploy --env production - env: - CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_API_TOKEN }} \ No newline at end of file diff --git a/src/_data/nav.js b/src/_data/nav.js index 60c04e67..aa2ecf5f 100644 --- a/src/_data/nav.js +++ b/src/_data/nav.js @@ -3,7 +3,6 @@ export default async function () { footer: [ { name: 'Now' }, { name: 'Uses' }, - { name: 'Save' }, { name: 'Blogroll' }, ], menu: [ diff --git a/src/pages/secondary/save.html b/src/pages/secondary/save.html deleted file mode 100644 index 4b1a6ba7..00000000 --- a/src/pages/secondary/save.html +++ /dev/null @@ -1,17 +0,0 @@ ---- -title: Save -layout: default -permalink: /save.html -description: Save a little bit on services that I also use. ---- - -

Referral links for services I use. I save some money, and you do as well if you choose to use them.

- diff --git a/workers/analytics/README.md b/workers/analytics/README.md deleted file mode 100644 index e209d51f..00000000 --- a/workers/analytics/README.md +++ /dev/null @@ -1,5 +0,0 @@ -# analytics worker - -```bash -wrangler deploy --env production -``` diff --git a/workers/analytics/index.js b/workers/analytics/index.js deleted file mode 100644 index f7a95e65..00000000 --- a/workers/analytics/index.js +++ /dev/null @@ -1,36 +0,0 @@ -const ScriptName = '/js/script.js'; -const Endpoint = '/api/event'; - -const ScriptWithoutExtension = ScriptName.replace('.js', '') - -addEventListener('fetch', event => { - event.passThroughOnException(); - event.respondWith(handleRequest(event)); -}) - -async function handleRequest(event) { - const pathname = new URL(event.request.url).pathname - const [baseUri, ...extensions] = pathname.split('.') - - if (baseUri.endsWith(ScriptWithoutExtension)) { - return getScript(event, extensions) - } else if (pathname.endsWith(Endpoint)) { - return postData(event) - } - return new Response(null, { status: 404 }) -} - -async function getScript(event, extensions) { - let response = await caches.default.match(event.request); - if (!response) { - response = await fetch("https://plausible.io/js/plausible." + extensions.join(".")); - event.waitUntil(caches.default.put(event.request, response.clone())); - } - return response; -} - -async function postData(event) { - const request = new Request(event.request); - request.headers.delete('cookie'); - return await fetch("https://plausible.io/api/event", request); -} \ No newline at end of file diff --git a/workers/analytics/wrangler.toml b/workers/analytics/wrangler.toml deleted file mode 100644 index 6cdffb79..00000000 --- a/workers/analytics/wrangler.toml +++ /dev/null @@ -1,13 +0,0 @@ -name = "analytics-worker" -main = "./index.js" -compatibility_date = "2023-01-01" - -account_id = "" -workers_dev = true - -[env.production] -name = "analytics-worker-production" -routes = [ - { pattern = "coryd.dev/js/*", zone_id = "" }, - { pattern = "coryd.dev/api/event", zone_id = "" } -] \ No newline at end of file diff --git a/workers/contact/README.md b/workers/contact/README.md deleted file mode 100644 index c6e87323..00000000 --- a/workers/contact/README.md +++ /dev/null @@ -1,8 +0,0 @@ -# contact worker - -```bash -wrangler deploy --env production - -wrangler secret put SUPABASE_URL --env production -wrangler secret put SUPABASE_KEY --env production -``` diff --git a/workers/contact/index.js b/workers/contact/index.js deleted file mode 100644 index f2f8feb0..00000000 --- a/workers/contact/index.js +++ /dev/null @@ -1,57 +0,0 @@ -import { createClient } from '@supabase/supabase-js'; - -const RATE_LIMIT = 5; -const TIME_FRAME = 60 * 60 * 1000; - -const ipSubmissions = new Map(); - -export default { - async fetch(request, env) { - if (request.method === 'POST') { - const ip = request.headers.get('CF-Connecting-IP') || request.headers.get('X-Forwarded-For') || request.headers.get('Remote-Addr'); - const currentTime = Date.now(); - - if (!ipSubmissions.has(ip)) { - ipSubmissions.set(ip, []); - } - - const submissions = ipSubmissions.get(ip).filter(time => currentTime - time < TIME_FRAME); - - if (submissions.length >= RATE_LIMIT) { - return new Response('Rate limit exceeded', { status: 429 }); - } - - submissions.push(currentTime); - ipSubmissions.set(ip, submissions); - - try { - const formData = await request.formData(); - const name = formData.get('name'); - const email = formData.get('email'); - const message = formData.get('message'); - const hpName = formData.get('hp_name'); - - // check the honeypot field - if (hpName) return new Response('Spam detected', { status: 400 }); - - // validate input - if (!name || !email || !message) return new Response('Invalid input', { status: 400 }); - - const supabaseUrl = env.SUPABASE_URL; - const supabaseKey = env.SUPABASE_KEY; - const supabase = createClient(supabaseUrl, supabaseKey); - const { error } = await supabase.from('contacts').insert([ - { name, email, message, replied: false } - ]); - - if (error) throw error; - - return Response.redirect('https://coryd.dev/contact/success', 303); - } catch (error) { - return new Response(error.message, { status: 500 }); - } - } else { - return new Response('Method not allowed', { status: 405 }); - } - } -}; \ No newline at end of file diff --git a/workers/contact/package-lock.json b/workers/contact/package-lock.json deleted file mode 100644 index d718a041..00000000 --- a/workers/contact/package-lock.json +++ /dev/null @@ -1,159 +0,0 @@ -{ - "name": "contact-worker", - "lockfileVersion": 3, - "requires": true, - "packages": { - "": { - "dependencies": { - "@supabase/supabase-js": "^2.43.4" - } - }, - "node_modules/@supabase/auth-js": { - "version": "2.64.2", - "resolved": "https://registry.npmjs.org/@supabase/auth-js/-/auth-js-2.64.2.tgz", - "integrity": "sha512-s+lkHEdGiczDrzXJ1YWt2y3bxRi+qIUnXcgkpLSrId7yjBeaXBFygNjTaoZLG02KNcYwbuZ9qkEIqmj2hF7svw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/functions-js": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/@supabase/functions-js/-/functions-js-2.3.1.tgz", - "integrity": "sha512-QyzNle/rVzlOi4BbVqxLSH828VdGY1RElqGFAj+XeVypj6+PVtMlD21G8SDnsPQDtlqqTtoGRgdMlQZih5hTuw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/node-fetch": { - "version": "2.6.15", - "resolved": "https://registry.npmjs.org/@supabase/node-fetch/-/node-fetch-2.6.15.tgz", - "integrity": "sha512-1ibVeYUacxWYi9i0cf5efil6adJ9WRyZBLivgjs+AUpewx1F3xPi7gLgaASI2SmIQxPoCEjAsLAzKPgMJVgOUQ==", - "license": "MIT", - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - } - }, - "node_modules/@supabase/postgrest-js": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/@supabase/postgrest-js/-/postgrest-js-1.15.2.tgz", - "integrity": "sha512-9/7pUmXExvGuEK1yZhVYXPZnLEkDTwxgMQHXLrN5BwPZZm4iUCL1YEyep/Z2lIZah8d8M433mVAUEGsihUj5KQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/realtime-js": { - "version": "2.9.5", - "resolved": "https://registry.npmjs.org/@supabase/realtime-js/-/realtime-js-2.9.5.tgz", - "integrity": "sha512-TEHlGwNGGmKPdeMtca1lFTYCedrhTAv3nZVoSjrKQ+wkMmaERuCe57zkC5KSWFzLYkb5FVHW8Hrr+PX1DDwplQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14", - "@types/phoenix": "^1.5.4", - "@types/ws": "^8.5.10", - "ws": "^8.14.2" - } - }, - "node_modules/@supabase/storage-js": { - "version": "2.5.5", - "resolved": "https://registry.npmjs.org/@supabase/storage-js/-/storage-js-2.5.5.tgz", - "integrity": "sha512-OpLoDRjFwClwc2cjTJZG8XviTiQH4Ik8sCiMK5v7et0MDu2QlXjCAW3ljxJB5+z/KazdMOTnySi+hysxWUPu3w==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/supabase-js": { - "version": "2.43.4", - "resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.43.4.tgz", - "integrity": "sha512-/pLPaxiIsn5Vaz3s32HC6O/VNwfeddnzS0bZRpOW0AKcPuXroD8pT9G8mpiBlZfpKsMmq6k7tlhW7Sr1PAQ1lw==", - "license": "MIT", - "dependencies": { - "@supabase/auth-js": "2.64.2", - "@supabase/functions-js": "2.3.1", - "@supabase/node-fetch": "2.6.15", - "@supabase/postgrest-js": "1.15.2", - "@supabase/realtime-js": "2.9.5", - "@supabase/storage-js": "2.5.5" - } - }, - "node_modules/@types/node": { - "version": "20.14.2", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.2.tgz", - "integrity": "sha512-xyu6WAMVwv6AKFLB+e/7ySZVr/0zLCzOa7rSpq6jNwpqOrUbcACDWC+53d4n2QHOnDou0fbIsg8wZu/sxrnI4Q==", - "license": "MIT", - "dependencies": { - "undici-types": "~5.26.4" - } - }, - "node_modules/@types/phoenix": { - "version": "1.6.4", - "resolved": "https://registry.npmjs.org/@types/phoenix/-/phoenix-1.6.4.tgz", - "integrity": "sha512-B34A7uot1Cv0XtaHRYDATltAdKx0BvVKNgYNqE4WjtPUa4VQJM7kxeXcVKaH+KS+kCmZ+6w+QaUdcljiheiBJA==", - "license": "MIT" - }, - "node_modules/@types/ws": { - "version": "8.5.10", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.10.tgz", - "integrity": "sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==", - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", - "license": "MIT" - }, - "node_modules/undici-types": { - "version": "5.26.5", - "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", - "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", - "license": "MIT" - }, - "node_modules/webidl-conversions": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", - "license": "BSD-2-Clause" - }, - "node_modules/whatwg-url": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", - "license": "MIT", - "dependencies": { - "tr46": "~0.0.3", - "webidl-conversions": "^3.0.0" - } - }, - "node_modules/ws": { - "version": "8.17.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.0.tgz", - "integrity": "sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow==", - "license": "MIT", - "engines": { - "node": ">=10.0.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": ">=5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - } - } -} diff --git a/workers/contact/package.json b/workers/contact/package.json deleted file mode 100644 index 2f6edacc..00000000 --- a/workers/contact/package.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "dependencies": { - "@supabase/supabase-js": "^2.43.4" - } -} diff --git a/workers/contact/wrangler.toml b/workers/contact/wrangler.toml deleted file mode 100644 index bad56b78..00000000 --- a/workers/contact/wrangler.toml +++ /dev/null @@ -1,12 +0,0 @@ -name = "contact-form-worker" -main = "./index.js" -compatibility_date = "2023-01-01" - -account_id = "" -workers_dev = true - -[env.production] -name = "contact-form-worker-production" -routes = [ - { pattern = "coryd.dev/api/contact", zone_id = "" } -] \ No newline at end of file diff --git a/workers/now-playing/README.md b/workers/now-playing/README.md deleted file mode 100644 index de6e67c0..00000000 --- a/workers/now-playing/README.md +++ /dev/null @@ -1,7 +0,0 @@ -# now-playing worker - -```bash -wrangler deploy --env production -wrangler secret put SUPABASE_URL --env production -wrangler secret put SUPABASE_KEY --env production -``` diff --git a/workers/now-playing/index.js b/workers/now-playing/index.js deleted file mode 100644 index bbc04a46..00000000 --- a/workers/now-playing/index.js +++ /dev/null @@ -1,85 +0,0 @@ -import { createClient } from '@supabase/supabase-js'; -import slugify from 'slugify'; - -const sanitizeMediaString = (str) => { - const sanitizedString = str.normalize('NFD').replace(/[\u0300-\u036f\u2010—\.\?\(\)\[\]\{\}]/g, '').replace(/\.{3}/g, ''); - - return slugify(sanitizedString, { - replacement: '-', - remove: /[#,&,+()$~%.'":*?<>{}]/g, - lower: true, - }); -}; - -const regionNames = new Intl.DisplayNames(['en'], { type: 'region' }); -const getCountryName = (countryCode) => regionNames.of(countryCode.trim()) || countryCode.trim(); -const parseCountryField = (countryField) => { - if (!countryField) return null; - - const delimiters = [',', '/', '&', 'and']; - let countries = [countryField]; - - delimiters.forEach(delimiter => { - countries = countries.flatMap(country => country.split(delimiter)); - }); - - return countries.map(getCountryName).join(', '); -}; - -const fetchGenreById = async (supabase, genreId) => { - const { data, error } = await supabase - .from('genres') - .select('emoji') - .eq('id', genreId) - .single(); - - if (error) { - console.error('Error fetching genre:', error); - return null; - } - - return data.emoji; -}; - -export default { - async fetch(request, env) { - const SUPABASE_URL = env.SUPABASE_URL; - const SUPABASE_KEY = env.SUPABASE_KEY; - const supabase = createClient(SUPABASE_URL, SUPABASE_KEY); - - const { data, error } = await supabase - .from('listens') - .select(` - track_name, - artist_name, - listened_at, - artists (mbid, genres, country, emoji) - `) - .order('listened_at', { ascending: false }) - .range(0, 1); - - const headers = { - "Content-Type": "application/json", - "Cache-Control": "public, s-maxage=360, stale-while-revalidate=1080", - }; - - if (error) { - console.error('Error fetching data:', error); - return new Response(JSON.stringify({ error: "Failed to fetch the latest track" }), { headers }); - } - - if (data.length === 0) { - return new Response(JSON.stringify({ message: "No recent tracks found" }), { headers }); - } - - const scrobbleData = data[0]; - const genreEmoji = await fetchGenreById(supabase, scrobbleData.artists.genres); - const emoji = scrobbleData.artists.emoji || genreEmoji; - - return new Response(JSON.stringify({ - content: `${emoji || '🎧'} ${scrobbleData.track_name} by ${ - scrobbleData.artist_name - }`, - }), { headers }); - } -}; \ No newline at end of file diff --git a/workers/now-playing/package-lock.json b/workers/now-playing/package-lock.json deleted file mode 100644 index dfcd75e1..00000000 --- a/workers/now-playing/package-lock.json +++ /dev/null @@ -1,169 +0,0 @@ -{ - "name": "now-playing-worker", - "lockfileVersion": 3, - "requires": true, - "packages": { - "": { - "dependencies": { - "@supabase/supabase-js": "^2.43.4", - "slugify": "^1.6.6" - } - }, - "node_modules/@supabase/auth-js": { - "version": "2.64.2", - "resolved": "https://registry.npmjs.org/@supabase/auth-js/-/auth-js-2.64.2.tgz", - "integrity": "sha512-s+lkHEdGiczDrzXJ1YWt2y3bxRi+qIUnXcgkpLSrId7yjBeaXBFygNjTaoZLG02KNcYwbuZ9qkEIqmj2hF7svw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/functions-js": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/@supabase/functions-js/-/functions-js-2.3.1.tgz", - "integrity": "sha512-QyzNle/rVzlOi4BbVqxLSH828VdGY1RElqGFAj+XeVypj6+PVtMlD21G8SDnsPQDtlqqTtoGRgdMlQZih5hTuw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/node-fetch": { - "version": "2.6.15", - "resolved": "https://registry.npmjs.org/@supabase/node-fetch/-/node-fetch-2.6.15.tgz", - "integrity": "sha512-1ibVeYUacxWYi9i0cf5efil6adJ9WRyZBLivgjs+AUpewx1F3xPi7gLgaASI2SmIQxPoCEjAsLAzKPgMJVgOUQ==", - "license": "MIT", - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - } - }, - "node_modules/@supabase/postgrest-js": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/@supabase/postgrest-js/-/postgrest-js-1.15.2.tgz", - "integrity": "sha512-9/7pUmXExvGuEK1yZhVYXPZnLEkDTwxgMQHXLrN5BwPZZm4iUCL1YEyep/Z2lIZah8d8M433mVAUEGsihUj5KQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/realtime-js": { - "version": "2.9.5", - "resolved": "https://registry.npmjs.org/@supabase/realtime-js/-/realtime-js-2.9.5.tgz", - "integrity": "sha512-TEHlGwNGGmKPdeMtca1lFTYCedrhTAv3nZVoSjrKQ+wkMmaERuCe57zkC5KSWFzLYkb5FVHW8Hrr+PX1DDwplQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14", - "@types/phoenix": "^1.5.4", - "@types/ws": "^8.5.10", - "ws": "^8.14.2" - } - }, - "node_modules/@supabase/storage-js": { - "version": "2.5.5", - "resolved": "https://registry.npmjs.org/@supabase/storage-js/-/storage-js-2.5.5.tgz", - "integrity": "sha512-OpLoDRjFwClwc2cjTJZG8XviTiQH4Ik8sCiMK5v7et0MDu2QlXjCAW3ljxJB5+z/KazdMOTnySi+hysxWUPu3w==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/supabase-js": { - "version": "2.43.4", - "resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.43.4.tgz", - "integrity": "sha512-/pLPaxiIsn5Vaz3s32HC6O/VNwfeddnzS0bZRpOW0AKcPuXroD8pT9G8mpiBlZfpKsMmq6k7tlhW7Sr1PAQ1lw==", - "license": "MIT", - "dependencies": { - "@supabase/auth-js": "2.64.2", - "@supabase/functions-js": "2.3.1", - "@supabase/node-fetch": "2.6.15", - "@supabase/postgrest-js": "1.15.2", - "@supabase/realtime-js": "2.9.5", - "@supabase/storage-js": "2.5.5" - } - }, - "node_modules/@types/node": { - "version": "20.14.2", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.2.tgz", - "integrity": "sha512-xyu6WAMVwv6AKFLB+e/7ySZVr/0zLCzOa7rSpq6jNwpqOrUbcACDWC+53d4n2QHOnDou0fbIsg8wZu/sxrnI4Q==", - "license": "MIT", - "dependencies": { - "undici-types": "~5.26.4" - } - }, - "node_modules/@types/phoenix": { - "version": "1.6.4", - "resolved": "https://registry.npmjs.org/@types/phoenix/-/phoenix-1.6.4.tgz", - "integrity": "sha512-B34A7uot1Cv0XtaHRYDATltAdKx0BvVKNgYNqE4WjtPUa4VQJM7kxeXcVKaH+KS+kCmZ+6w+QaUdcljiheiBJA==", - "license": "MIT" - }, - "node_modules/@types/ws": { - "version": "8.5.10", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.10.tgz", - "integrity": "sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==", - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/slugify": { - "version": "1.6.6", - "resolved": "https://registry.npmjs.org/slugify/-/slugify-1.6.6.tgz", - "integrity": "sha512-h+z7HKHYXj6wJU+AnS/+IH8Uh9fdcX1Lrhg1/VMdf9PwoBQXFcXiAdsy2tSK0P6gKwJLXp02r90ahUCqHk9rrw==", - "license": "MIT", - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", - "license": "MIT" - }, - "node_modules/undici-types": { - "version": "5.26.5", - "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", - "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", - "license": "MIT" - }, - "node_modules/webidl-conversions": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", - "license": "BSD-2-Clause" - }, - "node_modules/whatwg-url": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", - "license": "MIT", - "dependencies": { - "tr46": "~0.0.3", - "webidl-conversions": "^3.0.0" - } - }, - "node_modules/ws": { - "version": "8.17.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.0.tgz", - "integrity": "sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow==", - "license": "MIT", - "engines": { - "node": ">=10.0.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": ">=5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - } - } -} diff --git a/workers/now-playing/package.json b/workers/now-playing/package.json deleted file mode 100644 index 86b04bcf..00000000 --- a/workers/now-playing/package.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "dependencies": { - "@supabase/supabase-js": "^2.43.4", - "slugify": "^1.6.6" - } -} diff --git a/workers/now-playing/wrangler.toml b/workers/now-playing/wrangler.toml deleted file mode 100644 index 07d66a35..00000000 --- a/workers/now-playing/wrangler.toml +++ /dev/null @@ -1,12 +0,0 @@ -name = "now-playing-worker" -main = "./index.js" # Specify the entry point -compatibility_date = "2023-01-01" - -account_id = "" -workers_dev = true - -[env.production] -name = "now-playing-worker-production" -routes = [ - { pattern = "coryd.dev/api/now-playing", zone_id = "" } -] \ No newline at end of file diff --git a/workers/rebuild/README.md b/workers/rebuild/README.md deleted file mode 100644 index 4d33cdec..00000000 --- a/workers/rebuild/README.md +++ /dev/null @@ -1,7 +0,0 @@ -# rebuild worker - -```bash -wrangler deploy --env production - -wrangler secret put DEPLOY_HOOK_URL --env production -``` diff --git a/workers/rebuild/index.js b/workers/rebuild/index.js deleted file mode 100644 index 89293986..00000000 --- a/workers/rebuild/index.js +++ /dev/null @@ -1,17 +0,0 @@ -export default { - async scheduled(event, env, ctx) { - const deployHookUrl = env.DEPLOY_HOOK_URL; - - const response = await fetch(deployHookUrl, { - method: 'POST', - }); - - if (!response.ok) { - const errorText = await response.text(); - console.error(`Error triggering deploy: ${response.statusText}`, errorText); - return; - } - - console.log('Deploy triggered successfully'); - } -}; \ No newline at end of file diff --git a/workers/rebuild/wrangler.toml b/workers/rebuild/wrangler.toml deleted file mode 100644 index a0b580d7..00000000 --- a/workers/rebuild/wrangler.toml +++ /dev/null @@ -1,10 +0,0 @@ -name = "scheduled-rebuild-worker" -main = "./index.js" -compatibility_date = "2023-01-01" - -account_id = "" -workers_dev = true - -[env.production] -name = "scheduled-rebuild-worker-production" -triggers = {crons = ["0 * * * *"]} \ No newline at end of file diff --git a/workers/scrobble/README.md b/workers/scrobble/README.md deleted file mode 100644 index 550eaea5..00000000 --- a/workers/scrobble/README.md +++ /dev/null @@ -1,8 +0,0 @@ -# Scrobble worker - -```bash -wrangler deploy --env production -wrangler secret put SUPABASE_URL --env production -wrangler secret put SUPABASE_KEY --env production -wrangler secret put ACCOUNT_ID_PLEX --env production -``` diff --git a/workers/scrobble/index.js b/workers/scrobble/index.js deleted file mode 100644 index f5bebecf..00000000 --- a/workers/scrobble/index.js +++ /dev/null @@ -1,129 +0,0 @@ -import { createClient } from '@supabase/supabase-js'; -import { DateTime } from 'luxon'; -import slugify from 'slugify'; - -const sanitizeMediaString = (str) => { - const sanitizedString = str.normalize('NFD').replace(/[\u0300-\u036f\u2010\-\.\?\(\)\[\]\{\}]/g, '').replace(/\.{3}/g, ''); - return slugify(sanitizedString, { - replacement: '-', - remove: /[#,&,+()$~%.'":*?<>{}]/g, - lower: true, - }); -}; - -export default { - async fetch(request, env) { - const SUPABASE_URL = env.SUPABASE_URL; - const SUPABASE_KEY = env.SUPABASE_KEY; - const ACCOUNT_ID_PLEX = env.ACCOUNT_ID_PLEX; - const supabase = createClient(SUPABASE_URL, SUPABASE_KEY); - - const url = new URL(request.url); - const params = url.searchParams; - const id = params.get('id'); - - if (!id) { - return new Response(JSON.stringify({ status: 'Bad request' }), { headers: { "Content-Type": "application/json" } }); - } - if (id !== ACCOUNT_ID_PLEX) { - return new Response(JSON.stringify({ status: 'Forbidden' }), { headers: { "Content-Type": "application/json" } }); - } - - const contentType = request.headers.get("Content-Type") || ''; - if (!contentType.includes("multipart/form-data")) { - return new Response(JSON.stringify({ status: 'Bad request', message: 'Invalid Content-Type. Expected multipart/form-data.' }), { headers: { "Content-Type": "application/json" } }); - } - - try { - const data = await request.formData(); - const payload = JSON.parse(data.get('payload')); - - if (payload?.event === 'media.scrobble') { - const artist = payload['Metadata']['grandparentTitle']; - const album = payload['Metadata']['parentTitle']; - const track = payload['Metadata']['title']; - const listenedAt = Math.floor(DateTime.now().toSeconds()); - const artistKey = sanitizeMediaString(artist); - const albumKey = `${artistKey}-${sanitizeMediaString(album)}`; - - let { data: artistData, error: artistError } = await supabase - .from('artists') - .select('*') - .ilike('name_string', artist) - .single(); - - if (artistError && artistError.code === 'PGRST116') { - const { error: insertArtistError } = await supabase.from('artists').insert([ - { - mbid: null, - image: `/artists/${artistKey}.jpg`, - key: artistKey, - name: artist, - tentative: true - } - ]); - - if (insertArtistError) { - return new Response(JSON.stringify({ status: 'error', message: insertArtistError.message }), { headers: { "Content-Type": "application/json" } }); - } - - ({ data: artistData, error: artistError } = await supabase - .from('artists') - .select('*') - .ilike('name_string', artist) - .single()); - } else if (artistError) { - return new Response(JSON.stringify({ status: 'error', message: artistError.message }), { headers: { "Content-Type": "application/json" } }); - } - - let { data: albumData, error: albumError } = await supabase - .from('albums') - .select('*') - .ilike('key', albumKey) - .single(); - - if (albumError && albumError.code === 'PGRST116') { - const { error: insertAlbumError } = await supabase.from('albums').insert([ - { - mbid: null, - image: `/albums/${albumKey}.jpg`, - key: albumKey, - name: album, - tentative: true - } - ]); - - if (insertAlbumError) { - return new Response(JSON.stringify({ status: 'error', message: insertAlbumError.message }), { headers: { "Content-Type": "application/json" } }); - } - - ({ data: albumData, error: albumError } = await supabase - .from('albums') - .select('*') - .ilike('key', albumKey) - .single()); - } else if (albumError) { - return new Response(JSON.stringify({ status: 'error', message: albumError.message }), { headers: { "Content-Type": "application/json" } }); - } - - const { error: listenError } = await supabase.from('listens').insert([ - { - artist_name: artistData.name_string, - album_name: albumData.name, - track_name: track, - listened_at: listenedAt, - album_key: albumKey - } - ]); - - if (listenError) { - return new Response(JSON.stringify({ status: 'error', message: listenError.message }), { headers: { "Content-Type": "application/json" } }); - } - } - - return new Response(JSON.stringify({ status: 'success' }), { headers: { "Content-Type": "application/json" } }); - } catch (e) { - return new Response(JSON.stringify({ status: 'error', message: e.message }), { headers: { "Content-Type": "application/json" } }); - } - } -}; \ No newline at end of file diff --git a/workers/scrobble/package-lock.json b/workers/scrobble/package-lock.json deleted file mode 100644 index e12fd0a3..00000000 --- a/workers/scrobble/package-lock.json +++ /dev/null @@ -1,179 +0,0 @@ -{ - "name": "scrobble-worker", - "lockfileVersion": 3, - "requires": true, - "packages": { - "": { - "dependencies": { - "@supabase/supabase-js": "^2.43.4", - "luxon": "^3.4.4", - "slugify": "^1.6.6" - } - }, - "node_modules/@supabase/auth-js": { - "version": "2.64.2", - "resolved": "https://registry.npmjs.org/@supabase/auth-js/-/auth-js-2.64.2.tgz", - "integrity": "sha512-s+lkHEdGiczDrzXJ1YWt2y3bxRi+qIUnXcgkpLSrId7yjBeaXBFygNjTaoZLG02KNcYwbuZ9qkEIqmj2hF7svw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/functions-js": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/@supabase/functions-js/-/functions-js-2.3.1.tgz", - "integrity": "sha512-QyzNle/rVzlOi4BbVqxLSH828VdGY1RElqGFAj+XeVypj6+PVtMlD21G8SDnsPQDtlqqTtoGRgdMlQZih5hTuw==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/node-fetch": { - "version": "2.6.15", - "resolved": "https://registry.npmjs.org/@supabase/node-fetch/-/node-fetch-2.6.15.tgz", - "integrity": "sha512-1ibVeYUacxWYi9i0cf5efil6adJ9WRyZBLivgjs+AUpewx1F3xPi7gLgaASI2SmIQxPoCEjAsLAzKPgMJVgOUQ==", - "license": "MIT", - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - } - }, - "node_modules/@supabase/postgrest-js": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/@supabase/postgrest-js/-/postgrest-js-1.15.2.tgz", - "integrity": "sha512-9/7pUmXExvGuEK1yZhVYXPZnLEkDTwxgMQHXLrN5BwPZZm4iUCL1YEyep/Z2lIZah8d8M433mVAUEGsihUj5KQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/realtime-js": { - "version": "2.9.5", - "resolved": "https://registry.npmjs.org/@supabase/realtime-js/-/realtime-js-2.9.5.tgz", - "integrity": "sha512-TEHlGwNGGmKPdeMtca1lFTYCedrhTAv3nZVoSjrKQ+wkMmaERuCe57zkC5KSWFzLYkb5FVHW8Hrr+PX1DDwplQ==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14", - "@types/phoenix": "^1.5.4", - "@types/ws": "^8.5.10", - "ws": "^8.14.2" - } - }, - "node_modules/@supabase/storage-js": { - "version": "2.5.5", - "resolved": "https://registry.npmjs.org/@supabase/storage-js/-/storage-js-2.5.5.tgz", - "integrity": "sha512-OpLoDRjFwClwc2cjTJZG8XviTiQH4Ik8sCiMK5v7et0MDu2QlXjCAW3ljxJB5+z/KazdMOTnySi+hysxWUPu3w==", - "license": "MIT", - "dependencies": { - "@supabase/node-fetch": "^2.6.14" - } - }, - "node_modules/@supabase/supabase-js": { - "version": "2.43.4", - "resolved": "https://registry.npmjs.org/@supabase/supabase-js/-/supabase-js-2.43.4.tgz", - "integrity": "sha512-/pLPaxiIsn5Vaz3s32HC6O/VNwfeddnzS0bZRpOW0AKcPuXroD8pT9G8mpiBlZfpKsMmq6k7tlhW7Sr1PAQ1lw==", - "license": "MIT", - "dependencies": { - "@supabase/auth-js": "2.64.2", - "@supabase/functions-js": "2.3.1", - "@supabase/node-fetch": "2.6.15", - "@supabase/postgrest-js": "1.15.2", - "@supabase/realtime-js": "2.9.5", - "@supabase/storage-js": "2.5.5" - } - }, - "node_modules/@types/node": { - "version": "20.14.2", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.2.tgz", - "integrity": "sha512-xyu6WAMVwv6AKFLB+e/7ySZVr/0zLCzOa7rSpq6jNwpqOrUbcACDWC+53d4n2QHOnDou0fbIsg8wZu/sxrnI4Q==", - "license": "MIT", - "dependencies": { - "undici-types": "~5.26.4" - } - }, - "node_modules/@types/phoenix": { - "version": "1.6.4", - "resolved": "https://registry.npmjs.org/@types/phoenix/-/phoenix-1.6.4.tgz", - "integrity": "sha512-B34A7uot1Cv0XtaHRYDATltAdKx0BvVKNgYNqE4WjtPUa4VQJM7kxeXcVKaH+KS+kCmZ+6w+QaUdcljiheiBJA==", - "license": "MIT" - }, - "node_modules/@types/ws": { - "version": "8.5.10", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.10.tgz", - "integrity": "sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==", - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/luxon": { - "version": "3.4.4", - "resolved": "https://registry.npmjs.org/luxon/-/luxon-3.4.4.tgz", - "integrity": "sha512-zobTr7akeGHnv7eBOXcRgMeCP6+uyYsczwmeRCauvpvaAltgNyTbLH/+VaEAPUeWBT+1GuNmz4wC/6jtQzbbVA==", - "license": "MIT", - "engines": { - "node": ">=12" - } - }, - "node_modules/slugify": { - "version": "1.6.6", - "resolved": "https://registry.npmjs.org/slugify/-/slugify-1.6.6.tgz", - "integrity": "sha512-h+z7HKHYXj6wJU+AnS/+IH8Uh9fdcX1Lrhg1/VMdf9PwoBQXFcXiAdsy2tSK0P6gKwJLXp02r90ahUCqHk9rrw==", - "license": "MIT", - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", - "license": "MIT" - }, - "node_modules/undici-types": { - "version": "5.26.5", - "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", - "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", - "license": "MIT" - }, - "node_modules/webidl-conversions": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", - "license": "BSD-2-Clause" - }, - "node_modules/whatwg-url": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", - "license": "MIT", - "dependencies": { - "tr46": "~0.0.3", - "webidl-conversions": "^3.0.0" - } - }, - "node_modules/ws": { - "version": "8.17.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.0.tgz", - "integrity": "sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow==", - "license": "MIT", - "engines": { - "node": ">=10.0.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": ">=5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - } - } -} diff --git a/workers/scrobble/package.json b/workers/scrobble/package.json deleted file mode 100644 index 5e88d1de..00000000 --- a/workers/scrobble/package.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "dependencies": { - "@supabase/supabase-js": "^2.43.4", - "luxon": "^3.4.4", - "slugify": "^1.6.6" - } -} diff --git a/workers/scrobble/wrangler.toml b/workers/scrobble/wrangler.toml deleted file mode 100644 index c338cfbc..00000000 --- a/workers/scrobble/wrangler.toml +++ /dev/null @@ -1,12 +0,0 @@ -name = "scrobble-worker" -main = "./index.js" -compatibility_date = "2023-01-01" - -account_id = "" -workers_dev = true - -[env.production] -name = "scrobble-worker-production" -routes = [ - { pattern = "coryd.dev/api/scrobble*", zone_id = "" } -]