Compare commits

...

297 commits

Author SHA1 Message Date
a349858a7d
fix flickr link 2025-01-05 01:26:27 +00:00
73d3d0aa85
woops 2025-01-05 01:23:53 +00:00
42cb4f5561
I am a tit 2025-01-03 11:40:26 +00:00
296c823fc4 what am I even doing 2025-01-01 21:46:20 +00:00
ad60b38826 Username update 2024-12-30 22:56:39 +00:00
4b8c38216f bro thats a debug message in my website 2024-12-29 21:27:38 +00:00
a44d14c6bd Format sitemap.xml 2024-12-28 16:39:31 +00:00
51beb44c30 Update robots.txt 2024-12-28 16:37:43 +00:00
e19e504f1b Update sitemap 2024-12-28 16:34:20 +00:00
0a50c93d3a Server-side "is it christmas" 2024-12-27 20:28:16 +00:00
3e97458ee2 rudimentary "spam filter" 2024-12-27 18:47:40 +00:00
0a8db68e42 replace paws button 2024-12-25 23:41:49 +00:00
6c126bc20f Update last/current track display 2024-12-25 22:48:19 +00:00
80f4601670 Add wiki link 2024-12-22 03:29:01 +00:00
b65eca420a Show album cover for current track 2024-12-21 00:21:18 +00:00
02e9a6d85d set scrollbar colour 2024-12-19 20:27:19 +00:00
98cc18191a the silly button 2024-12-19 20:26:26 +00:00
11c3a2a85f Remove png 2024-12-14 20:12:44 +00:00
06db3b1551 Wrong image format 2024-12-14 20:11:28 +00:00
ec7e9ef0fb Add rosco image 2024-12-14 20:08:23 +00:00
bc9c002eb7 Update x86's website link 2024-12-14 19:13:45 +00:00
f3bc3da7f8 Update minimal css (error pages) 2024-12-12 00:45:32 +00:00
92f01ad9d0 Update logo 2024-12-12 00:45:32 +00:00
14c3a4e0ed Update dirlist.css to match site design 2024-12-10 20:50:08 +00:00
3a6758002f footer links (doy) 2024-12-09 20:54:10 +00:00
5596afa450 Handle no image being returned by tinyfox.dev 2024-12-09 20:48:27 +00:00
27116d79ce woops 2024-12-07 01:13:24 +00:00
f0f87f2a04 rosco :3 2024-12-07 01:11:00 +00:00
4a39504f6c Nuke unused pages 2024-12-07 01:10:40 +00:00
2d462347f5 Update page titles & embeds, swap snow script 2024-12-01 01:07:39 +00:00
083a4eb8af Now That's What I Call The Wrong Copyright Symbol 24 2024-11-30 22:58:30 +00:00
9c306bd74e Change storage perms 2024-11-30 22:47:40 +00:00
70234f23f8 AAAAA 2024-11-30 22:42:42 +00:00
588966a94f Sure is a new site design 2024-11-28 00:07:08 +00:00
b257c17f57 idk why this is here but I'm committing it 2024-11-04 23:13:32 +00:00
97cab32d50 woah is that a new design 2024-11-04 23:12:59 +00:00
858312f77a Update page layout
- Add more buttons
- Style <hr> elements
- Remove 'pixel nes' font from <h3> and <h4> elements
- Change footer grid column sizes to auto (previously 1fr)
- Add 5px top margin to sidebar buttons
2024-10-06 04:11:46 +01:00
f3694af95e Add privacy page 2024-10-06 04:11:08 +01:00
f00947d721 Update sitemap 2024-09-01 15:45:46 +01:00
4730f59dd0 There will be no bias in my house! 2024-08-31 00:47:19 +01:00
29f40ced3b Handle any errors if unable to get presence or weather data 2024-08-31 00:47:01 +01:00
ee5931cba8 Update .gitignore 2024-08-30 19:56:07 +01:00
93abf0cb1e Correct steam link 2024-08-30 19:51:26 +01:00
f674ef7838 YOLO 2024-08-22 22:24:01 +01:00
bf34ffcbc4 Add logo to readme 2024-08-16 09:47:44 +01:00
d61a2d0109 Accessibility stuff 2 2024-08-08 15:41:44 +01:00
80cbe94dc0 Merge branch 'redesign' 2024-08-08 15:35:48 +01:00
bb3f6afc81 Accessibility stuff 2024-08-08 15:34:32 +01:00
5472d7c7c7 Finish that shit 2024-08-08 15:21:30 +01:00
39d7895fad Add random quotes 2024-08-08 04:00:49 +01:00
33c49199c7 Initial redesign commit 2024-08-08 02:00:44 +01:00
031aa417b8 Stop using layout tables on bookmarks page 2024-07-12 23:51:50 +01:00
a480bdeac8 Improve computers page, change page width to 975px to compensate for scrollbars 2024-07-12 23:48:06 +01:00
84517b7c92 Minor improvements 2024-07-12 22:43:53 +01:00
217b24c1e8 Use the current hostname in schemeSwap.js instead of hard coding it 2024-07-12 22:43:15 +01:00
33fec5e189 Make CSS a little less messy 2024-07-12 21:49:58 +01:00
1bfc111503 Add apply button to scheme swap, make it easier to read 2024-07-12 16:58:31 +01:00
6f5740ecee Minor fixes, re-add calculators page 2024-07-12 16:50:33 +01:00
d52be035d0 Minor fixes 2024-07-12 16:24:22 +01:00
34055ccb41 Remove admin routes 2024-07-12 16:23:55 +01:00
d1ec296717 Move README.md to root folder 2024-07-12 03:00:24 +01:00
57abc7d5a7 Remove Auth0 2024-07-11 22:34:46 +01:00
acb18eb1ad Swap computers page to use main layout 2024-07-11 22:30:34 +01:00
0d7eb302e8 Change navbar images to use asset() 2024-07-11 22:29:57 +01:00
8d1469a5f4 Remove admin links 2024-07-11 22:25:32 +01:00
4b5c192301 Remove unused views 2024-07-11 22:24:41 +01:00
d7dab43cf4 Remove admin pages 2024-07-11 22:23:46 +01:00
0e0d76760e Remove unused route 2024-07-11 22:22:54 +01:00
c0eba1f9f7 Update composer lockfile 2024-07-11 01:15:42 +01:00
de10ced0d2 Add updatecache batch script 2024-07-09 00:47:36 +01:00
d9b84b39d2 Nuke redundant separate domain storage folders 2024-07-09 00:46:52 +01:00
829ecc816d Display whatever domain the site is being accessed from 2024-06-19 15:33:11 +01:00
387c296638 Multidomain. 2024-06-19 15:22:29 +01:00
2ea31ce775 Remove posthog pageview middleware 2024-06-19 15:15:35 +01:00
e1717e13d1 Move admin routes to prefix group 2024-06-18 02:52:19 +01:00
0f4da7e3df Add pageview logging via PostHog 2024-06-11 21:36:58 +01:00
3824f01f9b Actually use the $age variable on the homepage 2024-06-11 18:17:29 +01:00
dependabot[bot]
729be11b5a Bump follow-redirects from 1.15.4 to 1.15.6 (#17)
Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.15.4 to 1.15.6.
- [Release notes](https://github.com/follow-redirects/follow-redirects/releases)
- [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.15.4...v1.15.6)

---
updated-dependencies:
- dependency-name: follow-redirects
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-06-11 18:04:39 +01:00
dependabot[bot]
4114f350bf Bump vite from 4.5.2 to 4.5.3 (#20)
Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 4.5.2 to 4.5.3.
- [Release notes](https://github.com/vitejs/vite/releases)
- [Changelog](https://github.com/vitejs/vite/blob/v4.5.3/packages/vite/CHANGELOG.md)
- [Commits](https://github.com/vitejs/vite/commits/v4.5.3/packages/vite)

---
updated-dependencies:
- dependency-name: vite
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-06-11 18:04:10 +01:00
c9299b5410 Merge MVC rewrite into master (#21)
* Just commit it all

* Require auth

* crap

* Update homepage

* Block AI scrapers

* Update cache update script

* Add dummy file

* Remove unnecessary lastfm config var

* Use withQueryParameters for LastFM API

* Fix embeds

* Update example env

* Smard
2024-06-11 18:02:01 +01:00
2fbf6cdc39 Update music page design 2024-02-08 22:41:40 +00:00
e75b5ad8a9 Update music page design 2024-02-08 22:40:36 +00:00
35e1c10775 Update footer buttons 2024-02-04 00:52:15 +00:00
993198c16a Add underline to non-highlighted links 2024-02-04 00:44:01 +00:00
89b7a0b7ae Update homepage 2024-02-04 00:05:06 +00:00
210d83db45 Add database migrations 2024-01-31 21:17:56 +00:00
f7e4a21ff2 Remove sanctum 2024-01-31 21:17:46 +00:00
a1a8571873 Expand cookie to all domains *.diskfloppy.me 2024-01-26 12:29:00 +00:00
9f58d1e5b3 Improve schemeSwap.js 2024-01-26 12:26:48 +00:00
40cd7fc002 Add UA to guestbook 2024-01-26 12:26:37 +00:00
898176c5d4 Make info-tables full width 2024-01-22 13:43:25 +00:00
6f3be14459 turns out this code was important 2024-01-22 01:33:40 +00:00
2b9db42593 Add rosé pine themes 2024-01-22 01:30:54 +00:00
0cd22cf82b Remove unused HLJS code and unnecessary components 2024-01-22 01:19:24 +00:00
6f83c77109 Get scheme cookie server-side instead of client-side on page load 2024-01-22 01:19:23 +00:00
0237bc60f3 add pixellated images to dirlist.css 2024-01-22 00:11:39 +00:00
8baf29f486 woops 2024-01-22 00:11:01 +00:00
7c5461ddf3 CSS updates and a whole theme selector thing 2024-01-22 00:09:48 +00:00
663b96bad2 Update guestbook Update weather link 2024-01-22 00:09:20 +00:00
8da88fd38d Update guestbook notes 2024-01-22 00:09:05 +00:00
dependabot[bot]
faa43b2d74 Bump vite from 4.5.1 to 4.5.2 (#16)
Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 4.5.1 to 4.5.2.
- [Release notes](https://github.com/vitejs/vite/releases)
- [Changelog](https://github.com/vitejs/vite/blob/v4.5.2/packages/vite/CHANGELOG.md)
- [Commits](https://github.com/vitejs/vite/commits/v4.5.2/packages/vite)

---
updated-dependencies:
- dependency-name: vite
  dependency-type: direct:development
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-01-20 14:44:03 +00:00
26ab7d24d4 Fix footer image link 2024-01-12 19:02:10 +00:00
03bc2cd211 Remove debugging code 2024-01-12 18:59:26 +00:00
69ae67d510 Fix footer buttons 2024-01-12 18:58:23 +00:00
f68e4cb3e6 Add custom error pages, pixel images, etc (also improve computers) 2024-01-12 18:57:33 +00:00
361714b2f2 Swap Learn HTML button for Debian 2024-01-12 18:55:13 +00:00
dependabot[bot]
9c18e70754 Bump follow-redirects from 1.15.3 to 1.15.4 (#15)
Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.15.3 to 1.15.4.
- [Release notes](https://github.com/follow-redirects/follow-redirects/releases)
- [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.15.3...v1.15.4)

---
updated-dependencies:
- dependency-name: follow-redirects
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-01-12 18:47:02 +00:00
d39ae4b8b5 Move content/footer out of pagebody and remove it 2024-01-08 23:35:25 +00:00
ecfd933db1 Un-break music page 2024-01-05 22:18:52 +00:00
968c1c996f Update homepage (correct dumb typo) 2024-01-03 13:07:59 +00:00
a1eff2c46e Change snow to only show in December 2024-01-03 12:44:02 +00:00
652afe8093 Update dev server run config 2023-12-31 02:21:54 +00:00
506dbc2b90 Add hr to header and style hrs 2023-12-31 02:21:44 +00:00
0b050ec128 Move README.md to .github and add CODEOWNERS 2023-12-31 02:20:59 +00:00
6bae748385 Increment version 2023-12-31 02:14:41 +00:00
398fb1a1b3 Add sentry, update dirlist.css 2023-12-31 02:06:18 +00:00
5bbe4ed4b5 Disable admin routes 2023-12-31 02:04:42 +00:00
0b6f833b51 Add 'served by' to footer 2023-12-05 00:28:44 +00:00
80ca3f4345 Update dirlist css 2023-12-05 00:24:30 +00:00
ed7a271816 Import View facade in web routes 2023-12-05 00:19:48 +00:00
9b4410becf Import DB facade in web routes 2023-12-05 00:12:47 +00:00
e4e7ad6267 Update run configurations 2023-12-05 00:12:47 +00:00
adce1b1cf8 Add robots.txt 2023-11-29 18:40:14 +00:00
359b480e0d fix: snowflakes falling below window viewport 2023-11-27 21:36:55 +00:00
90c52206ef guestbook: remove name placeholder & reformat date 2023-11-27 20:30:32 +00:00
60c11f8376 Add snow 2023-11-26 15:40:38 +00:00
c644b720ea Update deps 2023-11-18 23:06:30 +00:00
a85e8da2e8 Revert "Add DMCA email to footer"
This reverts commit b6564409c8.
2023-11-04 21:41:39 +00:00
59e5dc3470 Remove unnecessary CSS 2023-10-25 23:32:55 +01:00
41c22dd7f4 Add DMCA email to footer 2023-10-25 23:30:28 +01:00
62b503194f Fix wrapping on "Never said" box 2023-10-25 23:30:19 +01:00
a4edf22794 Update homepage info 2023-10-25 23:30:02 +01:00
d70bf3bc74 Remove obsolete script attr 2023-10-25 22:57:12 +01:00
c21e37a260 Update minimal.css to use new color scheme 2023-10-25 22:55:54 +01:00
b249fb8215 Move "Things they never said", add CSS & Python to interests 2023-10-19 00:32:31 +01:00
4610066729 Add w/h to dimden button 2023-10-19 00:31:59 +01:00
8796ca9abe Bump ver 2023-10-16 23:42:47 +01:00
98f2ccefea Added "Things they never said" to the homepage 2023-10-16 23:41:49 +01:00
Frankie B
35924db567 Remove niko from homepage 2023-10-15 21:07:44 +01:00
Frankie B
fff8973a85 Merge branch 'master' of github.com:floppydisk05/diskfloppy.me 2023-10-15 20:54:49 +01:00
4b585fe2ca Update pages to be ADA-compliant 2023-10-15 20:52:32 +01:00
Frankie B
d8390f7a54 Bump version 2023-10-15 19:44:41 +01:00
Frankie B
fcb30657cb Add PhpStorm run config 2023-10-15 19:40:47 +01:00
4066dbb6d3 woops 2023-10-15 12:48:36 +01:00
587788cb7a Merge remote-tracking branch 'origin/master' 2023-10-15 12:44:24 +01:00
fe26401edc Remove unnecessary px units 2023-10-15 12:43:30 +01:00
ef3fd13b55 Change section titles on homepage to h2 2023-10-15 12:42:42 +01:00
98b36dd089 Update header style, add theme to head 2023-10-15 12:41:15 +01:00
5b3a2efd82 Update to move theme colors to seperate file, add theme selector styles in advance 2023-10-15 12:40:11 +01:00
a9e1cba778 Update sitemap.xml 2023-10-10 22:36:15 +01:00
f0ebb75759 Increment version 2023-09-08 23:21:47 +01:00
9a0d3a4ccc feat: add error handling (#14)
* Remove commented out crap
* Update theme to use some colors from catppuccin, add error handling for API/DB
2023-09-08 23:19:40 +01:00
3fc99d1c9d Add computers to nav 2023-08-26 01:22:33 +01:00
d4fef8b313 Update computers page design 2023-08-26 01:20:28 +01:00
0262ba30ab Add pubfiles link to nav 2023-08-25 20:05:54 +01:00
e6d14246c9 Add pub symlink 2023-08-25 19:57:35 +01:00
0655a95967 Fix root namespace in master.css, add dirlist.css 2023-08-25 19:45:04 +01:00
9dfbac4b56 Update site version number format 2023-08-24 21:39:47 +01:00
imgbot[bot]
f1f1169606 chore: optimize images (#13)
*Total -- 3,026.77kb -> 1,661.09kb (45.12%)

/public/images/buttons/vim.gif -- 3.79kb -> 0.88kb (76.82%)
/public/images/logo.png -- 2.26kb -> 0.86kb (61.99%)
/public/images/icons/nav/guestbook.png -- 1.07kb -> 0.48kb (55.41%)
/public/images/icons/nav/login.png -- 1.03kb -> 0.46kb (55.21%)
/public/images/icons/nav/bookmarks.png -- 1.06kb -> 0.48kb (55.12%)
/public/images/icons/nav/music.png -- 1.05kb -> 0.47kb (54.94%)
/public/images/icons/nav/mail.png -- 1.14kb -> 0.56kb (51.11%)
/public/images/login-background.png -- 2,992.52kb -> 1,637.08kb (45.29%)
/public/images/buttons/linuxnow.gif -- 3.88kb -> 2.25kb (42.01%)
/public/favicon-128x128.png -- 1.28kb -> 0.76kb (40.91%)
/public/images/buttons/vcss-blue.gif -- 1.72kb -> 1.31kb (23.76%)
/public/favicon-32x32.png -- 0.67kb -> 0.58kb (14.1%)
/public/images/icons/nav/home.png -- 0.55kb -> 0.48kb (12.83%)
/public/images/icons/fav/png/calc.png -- 12.24kb -> 11.97kb (2.23%)
/public/images/buttons/browser.gif -- 2.50kb -> 2.49kb (0.66%)

Signed-off-by: ImgBotApp <ImgBotHelp@gmail.com>
Co-authored-by: ImgBotApp <ImgBotHelp@gmail.com>
2023-08-22 20:05:22 +01:00
5d6f390968 niko 2023-08-22 20:03:02 +01:00
37b8be496e Remove invalid css property 2023-08-22 20:03:02 +01:00
1af7891b11 Swap out some buttons 2023-08-22 20:03:02 +01:00
f7d589aad4 Tidy up css 2023-08-22 20:03:02 +01:00
59dd3cbdfa Add "placeholder" bot page 2023-08-22 12:03:05 +01:00
5acec31981 aaaaaa 2023-08-15 18:33:18 +01:00
de8181ce93 die 2023-08-15 00:17:00 +01:00
09cffe2562 Improve table accessibility 2023-08-15 00:13:53 +01:00
bc781baf14 Underline links on hover 2023-08-15 00:08:38 +01:00
4f10d73cf2 Add width/height to homepage image 2023-08-15 00:04:52 +01:00
9d22db13a5 Add width/height to nav images 2023-08-15 00:04:27 +01:00
d78ba74d44 Add meta description 2023-08-15 00:02:26 +01:00
28a94afa50 Fix homepage image 2023-08-14 23:47:29 +01:00
fd12540d0a we ball 2023-08-14 23:45:31 +01:00
cc7fbbcdca Actually v6 2023-08-14 22:51:16 +01:00
88516c780c Update head again 2023-07-29 23:34:34 +01:00
5ba30c2401 Update page titles, fix favicon 2023-07-29 23:32:21 +01:00
f56107be8d Fix class names 2023-07-29 18:17:57 +01:00
c16b9d351f Remove duplicate lines 2023-07-29 18:16:08 +01:00
e558997a6a Remove unused highlighting styles, change "highlight.js" to just "highlight" 2023-07-29 18:14:26 +01:00
5f3348ee79 Fix messed up css 2023-07-29 18:13:12 +01:00
abece1760b Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
d6cd2d3154 Update routes/web.php
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
ba85934ebc Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
05c5c68460 Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
8e36d3dcba Merge fixes into v5.5 branch (#12)
---------
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
4f50fa52c3 Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
10714d05bd Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
772460fc6e Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
29338c7175 Update public/css/highlight.js/stackoverflow-dark.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
541106420e Update public/css/master.css
Co-authored-by: codacy-production[bot] <61871480+codacy-production[bot]@users.noreply.github.com>
2023-07-29 18:10:50 +01:00
afd430e052 Update version 2023-07-29 18:10:50 +01:00
b1bdad158b Disable contact link (for now), remove login link temporarily 2023-07-29 18:10:50 +01:00
754e074dd9 Add .DS_Store to gitignore 2023-07-29 18:10:50 +01:00
1013cd0456 Add hlphp & codeblock component 2023-07-29 18:10:50 +01:00
9a5ebd6465 Update header to new design 2023-07-29 18:10:50 +01:00
b29d84eef1 Update stylesheet 2023-07-29 18:10:50 +01:00
811a96cbe3 Update routes 2023-07-29 18:10:50 +01:00
aa61d91b79 Update email, remove weather & music from homepage 2023-07-29 18:10:50 +01:00
48de704b66 Add weather page 2023-07-29 18:10:50 +01:00
e171a0f8eb Add music page 2023-07-29 18:10:50 +01:00
91896f9dff Fix favicon path 2023-07-29 18:10:50 +01:00
3f42bac3f4 Format footer, add dimden.dev button 2023-07-29 18:10:50 +01:00
03769ee93e Update default API root 2023-07-29 18:10:50 +01:00
e5c778e7ad Update 2023-07-29 18:10:50 +01:00
aeb9501237 Remove submodule 2023-07-20 23:52:23 +01:00
Frankie B
1556e6019e Add login background to images folder 2023-07-20 23:38:53 +01:00
8b35647f85 Add publicfiles submodule 2023-07-20 23:36:54 +01:00
7c572a1ca6 Add IP to guestbook admin page 2023-07-20 03:33:04 +01:00
1c8fc95e31 ACTUALLY make the cooldown 60 minutes 2023-07-20 03:25:27 +01:00
0e5f6cd90a Correct SQL syntax error 2023-07-19 01:59:22 +01:00
ac1c84ea55 Update table names to new format 2023-07-19 01:58:32 +01:00
fe06cd915c feat: move bookmarks to database (#9)
* Move bookmarks to SQL DB
* Increment version
2023-07-19 01:50:07 +01:00
c04f07cb5c Remove htmlspecialchars from guestbook display
It was already run when the entry was recorded
2023-07-16 22:02:54 +01:00
2a11cff663 feat: site admin (#8) 2023-07-16 21:02:51 +01:00
c5d62dc343 Add logo to public folder 2023-07-16 18:24:41 +01:00
b942762409 Add cache update script 2023-07-16 15:35:07 +01:00
a40febdef9 Update error message files, increment version 2023-07-16 15:32:06 +01:00
22b74d1764 Add ability to ban users from guestbook (by IP) 2023-07-16 15:27:48 +01:00
805e9f9dca Update guestbook notices to list 2023-07-16 14:59:31 +01:00
fc7c365672 Move ratelimit error to new minimal layout template 2023-07-16 02:59:30 +01:00
70afd73d2d increment version number 2023-07-16 01:51:00 +01:00
94133ec0f7 feat: add guestbook with rate limiting (#6)
* Re-add guestbook w/ rate limiting
* Add guestbook to navbar
2023-07-16 01:49:09 +01:00
8adae46775 Update minimum site width to 780px 2023-07-14 02:57:20 +01:00
06e760f975 fix: use bull instead of bullet for site updates (fixes for older browsers) 2023-07-14 01:42:04 +01:00
Frankie B
74c48d7bb6 Add wiki link to navbar 2023-07-14 01:13:50 +01:00
c96e27b8d2 Merge CSS into one file 2023-07-12 15:10:18 +01:00
c77a184c37 Update site version 2023-07-12 01:32:10 +01:00
8584d25961 Add recent site updates (from git) 2023-07-12 01:16:52 +01:00
b60a70394f Update footer 2023-07-12 00:37:33 +01:00
f7fa536753 Update composer.json 2023-07-12 00:27:38 +01:00
b8de913210 Remove duplicated lines from env 2023-07-12 00:27:33 +01:00
d4021128fe Add misc section to bookmarks 2023-07-11 20:48:49 +01:00
5d0fc96ba5 Add bookmark section names as comments 2023-07-11 20:45:40 +01:00
Frankie B
4ff6785da1 Update 'git' to 'cgit' in nav 2023-07-11 19:24:47 +01:00
01b9e61b6a Update ALL indentation to spaces, not tabs 2023-07-11 19:24:00 +01:00
b453b17797 Update about on homepage 2023-07-06 00:09:50 +01:00
50b0a2b5b3 Update doctype to HTML 4.01 2023-07-06 00:09:38 +01:00
Frankie B
09e5615505 Re-add '@' 2023-07-04 22:54:45 +01:00
Frankie B
cbdbd2d0c7 Remove unnecessary line break 2023-07-04 18:46:25 +01:00
Frankie B
8a152b2138 Add sitemap 2023-07-04 18:39:38 +01:00
Frankie B
8b4a838785 Add Stack Overflow flair to homepage 2023-07-04 18:39:06 +01:00
e816b3e3dc Update lastfm list formatting 2023-07-04 01:14:17 +01:00
5e662802bc remove page 2023-07-04 01:11:02 +01:00
343207e8e4 remove 'repos' link from navbar 2023-07-04 01:07:57 +01:00
8921eb16f7 style: fix html alignment, etc. 2023-07-03 19:07:31 +01:00
c3509c0d41 Update favicon 2023-07-03 18:39:11 +01:00
94fa32d53e Remove random comment from default layout 2023-07-03 18:34:32 +01:00
0f265f43f2 Update to work with API again 2023-07-03 15:29:54 +01:00
3c711a3be5 Update mastodon link 2023-07-02 22:56:15 +01:00
63ab693d87 feat: update lastfm & weather to use internal API 2023-07-02 02:01:54 +01:00
Frankie B
7884f44391 fix: actually align it this time 2023-06-21 01:54:14 +01:00
a7ed69542b feat: align weather data 2023-06-21 01:51:10 +01:00
e7e2cfaf4b feat: align homepage links 2023-06-21 01:50:39 +01:00
6feda31d56 feat: change all fonts to monospace 2023-06-21 01:49:03 +01:00
6a2851447c Add Matrix to homepage 2023-06-21 01:47:01 +01:00
294a9573e4 fix: correct degreesToCompassDirection function 2023-06-17 13:58:08 +01:00
476a58fafc Update README.md 2023-06-16 22:04:03 +01:00
f0ed9a670f why is there even a link here 2023-06-15 00:06:41 +01:00
cb6e3d378d add w/h to footer images 2023-06-15 00:03:06 +01:00
025f4e1773 feat: fix page titles 2023-06-14 23:50:57 +01:00
b87c1467c6 fix: make configs serializable 2023-06-14 23:35:47 +01:00
606c641558 fix: class errors 2023-06-14 23:24:47 +01:00
ad7f3fca65 Move classes to models folder 2023-06-14 22:52:00 +01:00
cf2c13fa26 Added homepage link to nav 2023-06-14 22:15:44 +01:00
160c8a5d50 feat: computers page 2023-06-14 22:15:44 +01:00
761cbb11a4 feat: calculators page 2023-06-14 22:15:44 +01:00
4ffec4148a feat: projects page 2023-06-14 22:15:44 +01:00
bf5b014435 Remove guestbook from nav 2023-06-14 22:15:44 +01:00
d9e3c5b179 Vastly improve lastfm thing 2023-06-14 22:15:44 +01:00
1ffe9ea2b2 Made weatherdata less painful to look at 2023-06-14 22:15:44 +01:00
16ecc6abe3 Add bookmarks page 2023-06-14 22:15:44 +01:00
1763281e39 Fix homepage title 2023-06-14 22:15:44 +01:00
b760a00f3f Remove unnecessary stuff
Watch everything break when I do this
2023-06-14 22:15:44 +01:00
168400fab0 Add global layout and homepage 2023-06-14 22:15:44 +01:00
8af402a9e2 Initialize laravel app 2023-06-14 22:15:44 +01:00
3d69dd05c2 Update README.md 2023-06-12 22:22:03 +01:00
Frankie B
fc2111ad4e Change Vbc to campos on bookmarks page 2023-06-11 00:44:06 +01:00
Frankie B
6fd3f5b1d0 Add git to navbar 2023-05-25 20:14:34 +01:00
Frankie B
2832b08777 Disable guestbook submission 2023-05-25 20:14:34 +01:00
Frankie B
a160a5b4d1 Update computers page 2023-05-25 20:14:34 +01:00
092a771283 Add IDE configs 2023-04-10 01:53:34 +01:00
b9cf312ee6 Update .gitignore 2023-04-02 11:51:58 +01:00
Frankie B
cc2d653da6 Fix weatherdata date 2023-04-01 18:04:09 +00:00
Frankie B
5812807f7d Update banned keywords 2023-04-01 18:03:40 +00:00
Frankie B
05525e7a97 Add icons to bookmarks, computers and guestbook 2023-01-26 22:36:32 +00:00
Frankie B
7637493fbb Add very basic spam filter to guestbook 2023-01-26 22:12:08 +00:00
Frankie B
6a3d6af654 Reformat footer buttons 2023-01-26 22:11:46 +00:00
Frankie B
60d5008596 Correct weatherdata URL 2023-01-26 22:11:31 +00:00
Frankie B
b55abe4d15 Re-organize bookmarks page, remove test comment 2023-01-26 22:11:20 +00:00
Frankie B
47b751c020 Merge branch 'master' of https://github.com/floppydisk05/website 2022-12-20 20:55:40 +00:00
Frankie B
dcc3c8dd54 Move title path thing to page title 2022-12-20 20:55:38 +00:00
Frankie B
ea63711fb9 Add user to example config 2022-12-18 15:00:40 +00:00
Frankie B
5fab5ac440 Update NetRunner description 2022-12-11 13:26:48 +00:00
Frankie B
67dbc1f6e8 Add weather data to homepage 2022-12-11 13:25:48 +00:00
Frankie B
039a2fb895 Brackets 2022-12-11 13:25:36 +00:00
Frankie B
27cac08f46 Merge pull request #2 from floppydisk05/imgbot
[ImgBot] Optimize images
2022-12-05 18:36:29 +00:00
ImgBotApp
896b5c1550 [ImgBot] Optimize images
*Total -- 3,332.12kb -> 3,056.82kb (8.26%)

/res/img/calculators/casio-fx-82/4s.jpeg -- 177.47kb -> 160.32kb (9.66%)
/res/img/calculators/casio-fx-cg50/4s.jpeg -- 173.14kb -> 156.47kb (9.63%)
/res/img/calculators/ti-30/4s.jpeg -- 186.95kb -> 169.00kb (9.6%)
/res/img/calculators/casio-fx-cg50/3s.jpeg -- 175.37kb -> 159.55kb (9.02%)
/res/img/calculators/ti-30/1s.jpeg -- 173.27kb -> 158.30kb (8.64%)
/res/img/calculators/casio-fx-cg50/1s.jpeg -- 165.56kb -> 151.31kb (8.61%)
/res/img/calculators/casio-fx-82/1s.jpeg -- 158.89kb -> 145.25kb (8.58%)
/res/img/calculators/casio-fx-120/3s.jpeg -- 155.33kb -> 142.01kb (8.58%)
/res/img/calculators/texet-880/4s.jpeg -- 173.08kb -> 158.79kb (8.26%)
/res/img/calculators/ti-30/3s.jpeg -- 169.90kb -> 155.93kb (8.22%)
/res/img/calculators/casio-fx-120/1s.jpeg -- 144.70kb -> 132.92kb (8.14%)
/res/img/calculators/casio-fx-82/3s.jpeg -- 167.95kb -> 154.47kb (8.03%)
/res/img/calculators/texet-880/1s.jpeg -- 152.85kb -> 140.77kb (7.9%)
/res/img/calculators/texet-880/2s.jpeg -- 153.63kb -> 141.58kb (7.84%)
/res/img/calculators/casio-fx-120/2s.jpeg -- 143.30kb -> 132.12kb (7.8%)
/res/img/calculators/casio-fx-82/2s.jpeg -- 145.27kb -> 134.17kb (7.64%)
/res/img/calculators/ti-30/2s.jpeg -- 144.47kb -> 133.52kb (7.58%)
/res/img/calculators/texet-880/3s.jpeg -- 165.18kb -> 152.85kb (7.46%)
/res/img/calculators/casio-fx-cg50/2s.jpeg -- 136.60kb -> 126.51kb (7.39%)
/res/img/calculators/casio-fx-120/4s.jpeg -- 124.82kb -> 115.78kb (7.24%)
/norton.png -- 132.15kb -> 123.22kb (6.75%)
/res/img/icons/png/calc.png -- 12.24kb -> 11.97kb (2.23%)

Signed-off-by: ImgBotApp <ImgBotHelp@gmail.com>
2022-09-20 01:12:52 +00:00
340 changed files with 17138 additions and 1353 deletions

18
.editorconfig Normal file
View file

@ -0,0 +1,18 @@
root = true
[*]
charset = utf-8
end_of_line = lf
indent_size = 4
indent_style = space
insert_final_newline = true
trim_trailing_whitespace = true
[*.md]
trim_trailing_whitespace = false
[*.{yml,yaml}]
indent_size = 2
[docker-compose.yml]
indent_size = 4

28
.env.example Normal file
View file

@ -0,0 +1,28 @@
APP_NAME=Laravel
APP_ENV=local
APP_KEY=
APP_DEBUG=true
APP_URL=http://localhost
LOG_CHANNEL=stack
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=
BROADCAST_DRIVER=log
CACHE_DRIVER=file
FILESYSTEM_DISK=local
QUEUE_CONNECTION=sync
SESSION_DRIVER=file
SESSION_LIFETIME=120
MEMCACHED_HOST=127.0.0.1
LASTFM_KEY=
LASTFM_USER=

11
.gitattributes vendored Normal file
View file

@ -0,0 +1,11 @@
* text=auto eol=lf
*.blade.php diff=html
*.css diff=css
*.html diff=html
*.md diff=markdown
*.php diff=php
/.github export-ignore
CHANGELOG.md export-ignore
.styleci.yml export-ignore

1
.github/CODEOWNERS vendored Normal file
View file

@ -0,0 +1 @@
* @RoscoeDaWah

30
.gitignore vendored
View file

@ -1,6 +1,24 @@
ignore/
discord/
oreilly/
publicfiles/
inc/config.inc.php
files/
/.phpunit.cache
/node_modules
/public/build
/public/hot
/public/storage
/storage/*.key
/vendor
.env
.env.backup
.env.production
.phpunit.result.cache
Homestead.json
Homestead.yaml
auth.json
npm-debug.log
yarn-error.log
/.fleet
/.idea
/.vscode
**/.DS_Store
/log
/storage
/tmp
/public/pub

View file

@ -1,3 +0,0 @@
Options +Indexes
RedirectMatch 403 ^/archive/?$

View file

@ -0,0 +1,5 @@
<component name="ProjectRunConfigurationManager">
<configuration default="false" name="Development Server (External)" type="PhpLocalRunConfigurationType" factoryName="PHP Console" path="$PROJECT_DIR$/artisan" scriptParameters="serve --host 0.0.0.0 --port 8000">
<method v="2" />
</configuration>
</component>

View file

@ -0,0 +1,5 @@
<component name="ProjectRunConfigurationManager">
<configuration default="false" name="Development Server" type="PhpLocalRunConfigurationType" factoryName="PHP Console" path="$PROJECT_DIR$/artisan" scriptParameters="serve">
<method v="2" />
</configuration>
</component>

View file

@ -1 +1,3 @@
# Website
<img src="https://git.frzn.dev/RoscoeDaWah/wah.moe/raw/branch/master/assets/logo.svg" alt="" height="100" align="center"/>
<hr>
My personal website, developed using the Laravel framework

27
app/Console/Kernel.php Normal file
View file

@ -0,0 +1,27 @@
<?php
namespace App\Console;
use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
class Kernel extends ConsoleKernel
{
/**
* Define the application's command schedule.
*/
protected function schedule(Schedule $schedule): void
{
// $schedule->command('inspire')->hourly();
}
/**
* Register the commands for the application.
*/
protected function commands(): void
{
$this->load(__DIR__.'/Commands');
require base_path('routes/console.php');
}
}

View file

@ -0,0 +1,32 @@
<?php
namespace App\Exceptions;
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
use Throwable;
class Handler extends ExceptionHandler
{
/**
* The list of the inputs that are never flashed to the session on validation exceptions.
*
* @var array<int, string>
*/
protected $dontFlash = [
'current_password',
'password',
'password_confirmation',
];
/**
* Register the exception handling callbacks for the application.
*/
public function register(): void
{
$this->reportable(function (Throwable $e) {
if (app()->bound('sentry')) {
app('sentry')->captureException($e);
}
});
}
}

View file

@ -0,0 +1,15 @@
<?php
namespace App\Http\Controllers;
use App\Models\BookmarkSite;
use App\Models\BookmarkCategory;
use Illuminate\View\View;
class BookmarksController extends Controller
{
public function show() : View {
$categories = BookmarkCategory::with('sites')->get();
return view('bookmarks', compact('categories'));
}
}

View file

@ -0,0 +1,13 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\View\View;
class CalculatorsController extends Controller
{
public function show() : View {
return view('calculators');
}
}

View file

@ -0,0 +1,13 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\View\View;
class ComputersController extends Controller
{
public function show() : View {
return view('computers');
}
}

View file

@ -0,0 +1,12 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Validation\ValidatesRequests;
use Illuminate\Routing\Controller as BaseController;
class Controller extends BaseController
{
use AuthorizesRequests, ValidatesRequests;
}

View file

@ -0,0 +1,33 @@
<?php
namespace App\Http\Controllers;
use App\Models\GuestbookEntry;
use Illuminate\Http\Request;
use Illuminate\Http\RedirectResponse;
use Illuminate\Contracts\View\View;
use Illuminate\Validation\ValidationException;
use UAParser\Parser;
class GuestbookController extends Controller {
public function show(): View {
$entries = GuestbookEntry::selectEntries();
$parser = Parser::create();
return view('guestbook')
->with('entries', $entries)
->with('parser', $parser);
}
/**
* Creates a new guestbook entry
*
* @param Request $request
* @return RedirectResponse
* @throws ValidationException
*/
public function addEntry(Request $request): RedirectResponse {
GuestbookEntry::insertGuestbookEntry($request);
return back()->with('success', 'Entry submitted successfully!');
}
}

View file

@ -0,0 +1,33 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\View\View;
use DateTime;
class HomeController extends Controller {
/**
* Returns age based on birthday date and current date (GMT)
* @return int
*/
function returnAge(): int {
date_default_timezone_set('Europe/London');
$birthday = new DateTime("2005-06-07");
$currentDate = DateTime::createFromFormat("Y-m-d", date("Y-m-d"));
$age = $birthday->diff($currentDate);
return $age->y;
}
/**
* Shows home page
* @return View
*/
public function show(): View {
return view('home', [
'age' => $this->returnAge(),
]);
}
}

View file

@ -0,0 +1,77 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\View\View;
class MusicController extends Controller
{
public function getCurrentTrack() {
// If it's already cached just return that
if (Cache::has('current_track')) {
return Cache::get('current_track');
}
$response = Http::withQueryParameters([
'method' => 'user.getrecenttracks',
'user' => Config::get('services.lastfm.user'),
'format' => 'json',
'nowplaying' => 'true',
'api_key' => Config::get('services.lastfm.key')
])->get('https://ws.audioscrobbler.com/2.0/');
$data = $response->json();
error_log($response->body());
$track_data = $data["recenttracks"]["track"][0];
// $image = array_column($track_data["image"], null, 'size')['large'] ?? false;
$image = $track_data["image"][(array_key_last($track_data["image"]))] ?? false;
$now_playing = false;
if (array_key_exists("@attr", $track_data)) {
$now_playing = $track_data["@attr"]["nowplaying"] == "true" ?? ["url"=>null];
}
$current_track = [
'title' => $track_data["name"],
'artist' => $track_data["artist"]["#text"],
'url' => $track_data["url"],
'image' => $image["#text"],
'header' => $now_playing ? "Now Playing" : "Last Track",
];
Cache::put('current_track', $current_track, now()->addSeconds(15));
return $current_track;
}
public function getTopTracks() {
// If it's already cached just return that
if (Cache::has('top_tracks')) {
return Cache::get('top_tracks');
}
$response = Http::withQueryParameters([
'method' => 'user.gettoptracks',
'user' => Config::get('services.lastfm.user'),
'format' => 'json',
'period' => '1month',
'limit' => 10,
'api_key' => Config::get('services.lastfm.key')
])->get('https://ws.audioscrobbler.com/2.0/');
$data = $response->json();
$topTracks = [];
foreach ($data["toptracks"]["track"] as $track) {
$topTracks[] = [
'title' => $track["name"],
'artist' => $track["artist"]["name"],
'url' => $track["url"],
'plays' => $track["playcount"],
];
}
Cache::put('top_tracks', $topTracks, now()->addSeconds(15));
return $topTracks;
}
public function show() : View {
return view('music')
->with('current_track', $this->getCurrentTrack())
->with('top_tracks', $this->getTopTracks());
}
}

View file

@ -0,0 +1,16 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\View\View;
class PrivacyController extends Controller{
/**
* Shows the page
* @return View
*/
public function show(): View {
return view('privacy');
}
}

View file

@ -0,0 +1,48 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\File;
use Illuminate\View\View;
class RoscoController extends Controller {
public function getImages(): array {
$images = [];
foreach (File::glob(public_path('images/rosco').'/*') as $path) {
$image_data = [];
try {
$exif = exif_read_data($path);
} catch (Exception $ex) {
}
$image_data["path"] = str_replace(public_path(), '', $path);
if (isset($exif)) {
if (isset($exif["ImageDescription"])) {
$image_data["description"] = $exif["ImageDescription"];
}
if (isset($exif["DateTime"])) {
$image_data["date"] = strtotime($exif["DateTime"]);
}
}
array_push($images, $image_data);
}
usort($images, function ($a, $b) {
$dateA = $a['date'] ?? PHP_INT_MIN;
$dateB = $b['date'] ?? PHP_INT_MIN;
return $dateB <=> $dateA;
});
return $images;
}
/**
* Shows the page
* @return View
*/
public function show(): View {
return view('rosco', [
'images' => $this->getImages(),
]);
}
}

73
app/Http/Kernel.php Normal file
View file

@ -0,0 +1,73 @@
<?php
namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel
{
/**
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*
* @var array<int, class-string|string>
*/
protected $middleware = [
// \App\Http\Middleware\TrustHosts::class,
\App\Http\Middleware\TrustProxies::class,
\Illuminate\Http\Middleware\HandleCors::class,
\App\Http\Middleware\PreventRequestsDuringMaintenance::class,
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
\App\Http\Middleware\TrimStrings::class,
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
];
/**
* The application's route middleware groups.
*
* @var array<string, array<int, class-string|string>>
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
'api' => [
// \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
\Illuminate\Routing\Middleware\ThrottleRequests::class.':api',
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
];
protected $routeMiddleware = [
'rate_limit' => \App\Http\Middleware\RateLimiter::class,
'validator' => \App\Http\Middleware\GuestbookValidate::class,
];
/**
* The application's middleware aliases.
*
* Aliases may be used instead of class names to conveniently assign middleware to routes and groups.
*
* @var array<string, class-string|string>
*/
protected $middlewareAliases = [
'auth' => \App\Http\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'auth.session' => \Illuminate\Session\Middleware\AuthenticateSession::class,
'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'password.confirm' => \Illuminate\Auth\Middleware\RequirePassword::class,
'signed' => \App\Http\Middleware\ValidateSignature::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
];
}

View file

@ -0,0 +1,17 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Auth\Middleware\Authenticate as Middleware;
use Illuminate\Http\Request;
class Authenticate extends Middleware
{
/**
* Get the path the user should be redirected to when they are not authenticated.
*/
protected function redirectTo(Request $request): ?string
{
return $request->expectsJson() ? null : route('login');
}
}

View file

@ -0,0 +1,17 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Cookie\Middleware\EncryptCookies as Middleware;
class EncryptCookies extends Middleware
{
/**
* The names of the cookies that should not be encrypted.
*
* @var array<int, string>
*/
protected $except = [
"colorscheme"
];
}

View file

@ -0,0 +1,37 @@
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class GuestbookValidate
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
if (
!$request->validate([
'name' => 'required',
'message' => 'required'
]) ||
$this->containsUrl($request->get('message')) ||
$this->containsUrl($request->get('name'))
) {
return response()->view('errors.guestbook-invalid', [], 400);
}
return $next($request);
}
public function containsUrl($str) {
$matches = [];
$pattern = '/\b(?:https?|ftp|www)(:\/\/)*[-A-Z0-9+&@#\/%?=~_|$!:,.;]*[A-Z0-9+&@#\/%=~_|$]/i';
preg_match_all($pattern, $str, $matches);
return count($matches[0]);
}
}

View file

@ -0,0 +1,15 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\PreventRequestsDuringMaintenance as Middleware;
class PreventRequestsDuringMaintenance extends Middleware
{
/**
* The URIs that should be reachable while maintenance mode is enabled.
*
* @var array<int, string>
*/
protected $except = [];
}

View file

@ -0,0 +1,35 @@
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Cache;
use Symfony\Component\HttpFoundation\Response;
class RateLimiter
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
if (auth()->check()) {
return $next($request);
}
$ipAddress = $request->ip();
$cacheKey = 'rate_limit_'.$ipAddress;
if (Cache::has($cacheKey)) {
// If the cache key exists, the IP has submitted an entry within the last hour.
return response()->view('errors.guestbook-ratelimit', [], 429);
}
// Add the IP address to the cache and set the expiration time to one hour.
Cache::put($cacheKey, true, 3600);
return $next($request);
}
}

View file

@ -0,0 +1,30 @@
<?php
namespace App\Http\Middleware;
use App\Providers\RouteServiceProvider;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Symfony\Component\HttpFoundation\Response;
class RedirectIfAuthenticated
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next, string ...$guards): Response
{
$guards = empty($guards) ? [null] : $guards;
foreach ($guards as $guard) {
if (Auth::guard($guard)->check()) {
return redirect(RouteServiceProvider::HOME);
}
}
return $next($request);
} // End handle().
}

View file

@ -0,0 +1,19 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\TrimStrings as Middleware;
class TrimStrings extends Middleware
{
/**
* The names of the attributes that should not be trimmed.
*
* @var array<int, string>
*/
protected $except = [
'current_password',
'password',
'password_confirmation',
];
}

View file

@ -0,0 +1,20 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Http\Middleware\TrustHosts as Middleware;
class TrustHosts extends Middleware
{
/**
* Get the host patterns that should be trusted.
*
* @return array<int, string|null>
*/
public function hosts(): array
{
return [
$this->allSubdomainsOfApplicationUrl(),
];
}
}

View file

@ -0,0 +1,29 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Http\Middleware\TrustProxies as Middleware;
use Illuminate\Http\Request;
class TrustProxies extends Middleware
{
/**
* The trusted proxies for this application.
*
* @var array<int, string>|string|null
*/
protected $proxies;
/**
* The headers that should be used to detect proxies.
*
* @var int
*/
protected $headers =(
Request::HEADER_X_FORWARDED_FOR |
Request::HEADER_X_FORWARDED_HOST |
Request::HEADER_X_FORWARDED_PORT |
Request::HEADER_X_FORWARDED_PROTO |
Request::HEADER_X_FORWARDED_AWS_ELB
);
}

View file

@ -0,0 +1,22 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Routing\Middleware\ValidateSignature as Middleware;
class ValidateSignature extends Middleware
{
/**
* The names of the query string parameters that should be ignored.
*
* @var array<int, string>
*/
protected $except = [
// 'fbclid',
// 'utm_campaign',
// 'utm_content',
// 'utm_medium',
// 'utm_source',
// 'utm_term',
];
}

View file

@ -0,0 +1,15 @@
<?php
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as Middleware;
class VerifyCsrfToken extends Middleware
{
/**
* The URIs that should be excluded from CSRF verification.
*
* @var array<int, string>
*/
protected $except = [];
}

View file

@ -0,0 +1,36 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BookmarkCategory extends Model
{
use HasFactory;
protected $table = "bookmark__categories";
protected $fillable = ['name'];
public function sites() {
return $this->hasMany(BookmarkSite::class, 'category');
}
public static function insertBookmarkCategory(string $name) {
$newBookmarkCategory = new BookmarkCategory;
$newBookmarkCategory->name = $name;
$newBookmarkCategory->save();
}
public static function selectBookmarks(int $id) {
$bookmarks = BookmarkSite::where('category', '=', $id)->firstOrFail();
return $bookmarks;
}
public static function importBookmarkCategory(array $data) {
foreach ($data as $category) {
$newBookmarkCategory = new BookmarkCategory;
$newBookmarkCategory->name = $category['name'];
$newBookmarkCategory->priority = intval($category['priority']);
$newBookmarkCategory->save();
}
}
}

View file

@ -0,0 +1,35 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BookmarkSite extends Model {
use HasFactory;
protected $table = "bookmark__sites";
protected $fillable = ['name', 'description', 'url', 'category'];
public function category() {
return $this->belongsTo(BookmarkCategory::class, 'category');
}
public static function insertBookmark(string $name, string $url, int $category) {
$category = BookmarkCategory::where('id', $category)->firstOrFail();
$newBookmark = new BookmarkSite;
$newBookmark->name = $name;
$newBookmark->url = $url;
$newBookmark->category = $category->id;
$newBookmark->save();
}
public static function importBookmark(array $data) {
foreach ($data as $site) {
$newBookmark = new BookmarkSite;
$newBookmark->name = $site['name'];
$newBookmark->description = $site['description'];
$newBookmark->url = $site['url'];
$newBookmark->category = $site['category_id'];
$newBookmark->save();
}
}
}

View file

@ -0,0 +1,50 @@
<?php
namespace App\Models;
use Illuminate\Http\Request;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class GuestbookEntry extends Model
{
use HasFactory;
protected $table = "guestbook__entries";
protected $fillable = ['name', 'message'];
/**
* Creates a new guestbook entry.
*
* @param Request $request The HTTP POST request
* @return void
*/
public static function insertGuestbookEntry(Request $request) {
$newEntry = new GuestbookEntry;
$newEntry->name = $request->get('name');
$newEntry->message = $request->get('message');
$newEntry->ip = $request->ip();
$newEntry->agent = $request->userAgent();
$newEntry->admin = auth()->check();
$newEntry->save();
}
public static function selectEntries() {
$entries = GuestbookEntry::orderBy('created_at', 'desc')->get();
return $entries;
}
public static function importGuestbookEntry(array $data) {
foreach ($data as $entry) {
$dt = new \DateTime('@' . $entry['timestamp']);
$newEntry = new GuestbookEntry;
$newEntry->name = $entry['name'];
$newEntry->ip = $entry['ip_address'];
$newEntry->agent = $entry['agent'];
$newEntry->admin = $entry['site_owner'];
$newEntry->message = $entry['message'];
$newEntry->created_at = $dt;
$newEntry->updated_at = $dt;
$newEntry->save();
}
}
}

View file

@ -0,0 +1,21 @@
<?php
namespace App\Providers;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\ServiceProvider;
use PostHog\PostHog;
class AppServiceProvider extends ServiceProvider {
/**
* Register any application services.
*/
public function register(): void {
//
}
/**
* Bootstrap any application services.
*/
public function boot(): void {}
}

View file

@ -0,0 +1,25 @@
<?php
namespace App\Providers;
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
class AuthServiceProvider extends ServiceProvider
{
/**
* The model to policy mappings for the application.
*
* @var array<class-string, class-string>
*/
protected $policies = [
//
];
/**
* Register any authentication / authorization services.
*/
public function boot(): void
{
//
}
}

View file

@ -0,0 +1,19 @@
<?php
namespace App\Providers;
use Illuminate\Support\Facades\Broadcast;
use Illuminate\Support\ServiceProvider;
class BroadcastServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*/
public function boot(): void
{
Broadcast::routes();
require base_path('routes/channels.php');
}
}

View file

@ -0,0 +1,38 @@
<?php
namespace App\Providers;
use Illuminate\Auth\Events\Registered;
use Illuminate\Auth\Listeners\SendEmailVerificationNotification;
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Event;
class EventServiceProvider extends ServiceProvider
{
/**
* The event to listener mappings for the application.
*
* @var array<class-string, array<int, class-string>>
*/
protected $listen = [
Registered::class => [
SendEmailVerificationNotification::class,
],
];
/**
* Register any events for your application.
*/
public function boot(): void
{
//
}
/**
* Determine if events and listeners should be automatically discovered.
*/
public function shouldDiscoverEvents(): bool
{
return false;
}
}

View file

@ -0,0 +1,40 @@
<?php
namespace App\Providers;
use Illuminate\Cache\RateLimiting\Limit;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\RateLimiter;
use Illuminate\Support\Facades\Route;
class RouteServiceProvider extends ServiceProvider
{
/**
* The path to your application's "home" route.
*
* Typically, users are redirected here after authentication.
*
* @var string
*/
public const HOME = '/home';
/**
* Define your route model bindings, pattern filters, and other route configuration.
*/
public function boot(): void
{
RateLimiter::for('api', function (Request $request) {
return Limit::perMinute(60)->by($request->user()?->id ?: $request->ip());
});
$this->routes(function () {
Route::middleware('api')
->prefix('api')
->group(base_path('routes/api.php'));
Route::middleware('web')
->group(base_path('routes/web.php'));
});
}
}

View file

@ -0,0 +1,27 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class CurrentTrack extends Component
{
public $track;
/**
* Create a new component instance.
*/
public function __construct($track)
{
$this->track = $track;
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.current-track');
}
}

View file

@ -0,0 +1,68 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\View\Component;
class DiscordStatus extends Component
{
/**
* Create a new component instance.
*/
public function __construct()
{
//
}
/**
* Returns current Discord presence from Lanyard API
* @return array|mixed
*/
public function getDiscordPresence(): mixed {
// If it's already cached just return that
if (Cache::has('discord_presence')) {
return Cache::get('discord_presence');
}
$response = Http::get('https://api.lanyard.rest/v1/users/' . Config::get('services.lanyard.user_id'));
$data = $response->json();
if (!isset($data["data"])) return null;
$presence = $data["data"];
Cache::put('discord_presence', $presence, now()->addSeconds(60));
return $presence;
}
public function getOnlineStatus(): ?array {
$presence = $this->getDiscordPresence();
if ($presence == null) return null;
return match ($presence["discord_status"]) {
"online", "dnd" => [
"text" => "online",
"color" => "#02c83a"
],
"idle" => [
"text" => "away",
"color" => "#d77c20"
],
default => [
"text" => "offline",
"color" => "#ca3329"
],
};
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.discord-status', [
'status' => $this->getOnlineStatus(),
]);
}
}

View file

@ -0,0 +1,34 @@
<?php
namespace App\View\Components;
use Closure;
use DateTime;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class Layout extends Component {
/**
* Create a new component instance.
*/
public function __construct() {}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string {
return view('components.layout', [
'isChristmas' => $this->isItChristmas()
]);
}
public function isItChristmas() : bool {
$currentDate = new DateTime();
$currentYear = intval($currentDate->format('Y'));
$startDate = new DateTime("$currentYear-11-10");
$endDate = new DateTime(($currentYear + 1) . "-01-01");
return $currentDate >= $startDate && $currentDate < $endDate;
}
}

View file

@ -0,0 +1,27 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class Navbar extends Component
{
public $title;
/**
* Create a new component instance.
*/
public function __construct($title)
{
$this->title = $title;
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.navigation');
}
}

View file

@ -0,0 +1,34 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class NeverSaid extends Component
{
/**
* Create a new component instance.
*/
public function __construct()
{
//
}
function returnQuote(): array {
$quotes = config('quotes.neversaid');
$index = rand(0, count($quotes) - 1);
return $quotes[$index];
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.never-said', [
"quote" => $this->returnQuote()
]);
}
}

View file

@ -0,0 +1,35 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class TohQuote extends Component
{
/**
* Create a new component instance.
*/
public function __construct()
{
//
}
function returnQuote(): array {
$quotes = config('quotes.toh');
$index = rand(0, count($quotes) - 1);
return $quotes[$index];
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.toh-quote',[
'quote' => $this->returnQuote()
]);
}
}

View file

@ -0,0 +1,27 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class TopTracks extends Component
{
public $tracks;
/**
* Create a new component instance.
*/
public function __construct($tracks)
{
$this->tracks = $tracks;
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.top-tracks');
}
}

View file

@ -0,0 +1,29 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\View\Component;
class Track extends Component
{
public $track;
public $count;
/**
* Create a new component instance.
*/
public function __construct($track, $count)
{
$this->track = $track;
$this->count = $count;
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.track');
}
}

View file

@ -0,0 +1,41 @@
<?php
namespace App\View\Components;
use Closure;
use Illuminate\Contracts\View\View;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\View\Component;
class Wah extends Component
{
/**
* Create a new component instance.
*/
public function __construct() {}
public function getWah(): string {
try {
$response = Http::get('https://api.tinyfox.dev/img.json?animal=wah');
$data = $response->json();
if ($data == null) return "";
return "https://api.tinyfox.dev" . $data["loc"];
} catch (Exception $ex) {
return "";
}
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string {
return view('components.wah', [
'wah' => $this->getWah(),
]);
}
}

View file

@ -0,0 +1,50 @@
<?php
namespace App\View\Components;
use Closure;
use Exception;
use Illuminate\Contracts\View\View;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Http;
use Illuminate\View\Component;
class Weather extends Component
{
/**
* Create a new component instance.
*/
public function __construct()
{
//
}
public function getWeatherData(): mixed {
// If it's already cached just return that
if (Cache::has('weather_data')) {
return Cache::get('weather_data');
}
try {
$response = Http::get('http://' . Config::get('services.weatherlink') . '/v1/current_conditions');
$data = $response->json();
$conditions = $data["data"]["conditions"];
Cache::put('weather_data', $conditions, now()->addSeconds(60));
return $conditions;
} catch (Exception $ex) {
return null;
}
}
/**
* Get the view / contents that represent the component.
*/
public function render(): View|Closure|string
{
return view('components.weather', [
'conditions' => $this->getWeatherData(),
]);
}
}

53
artisan Executable file
View file

@ -0,0 +1,53 @@
#!/usr/bin/env php
<?php
define('LARAVEL_START', microtime(true));
/*
|--------------------------------------------------------------------------
| Register The Auto Loader
|--------------------------------------------------------------------------
|
| Composer provides a convenient, automatically generated class loader
| for our application. We just need to utilize it! We'll require it
| into the script here so that we do not have to worry about the
| loading of any of our classes manually. It's great to relax.
|
*/
require __DIR__.'/vendor/autoload.php';
$app = require_once __DIR__.'/bootstrap/app.php';
/*
|--------------------------------------------------------------------------
| Run The Artisan Application
|--------------------------------------------------------------------------
|
| When we run the console application, the current CLI command will be
| executed in this console and the response sent back to a terminal
| or another output device for the developers. Here goes nothing!
|
*/
$kernel = $app->make(Illuminate\Contracts\Console\Kernel::class);
$status = $kernel->handle(
$input = new Symfony\Component\Console\Input\ArgvInput,
new Symfony\Component\Console\Output\ConsoleOutput
);
/*
|--------------------------------------------------------------------------
| Shutdown The Application
|--------------------------------------------------------------------------
|
| Once Artisan has finished running, we will fire off the shutdown events
| so that any final work may be done by the application before we shut
| down the process. This is the last thing to happen to the request.
|
*/
$kernel->terminate($input, $status);
exit($status);

45
assets/logo.svg Normal file
View file

@ -0,0 +1,45 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="100%" height="100%" viewBox="0 0 1893 339" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;">
<g transform="matrix(1,0,0,1,0,-420.871)">
<g id="Artboard2" transform="matrix(0.73917,0,0,0.235401,0,420.871)">
<rect x="0" y="0" width="2560" height="1440" style="fill:none;"/>
<g transform="matrix(1.62833,0,0,5.11304,-84.1879,-2332.06)">
<g transform="matrix(0.9823,0.187314,-0.187314,0.9823,115.768,-33.3744)">
<path d="M326.769,715.888C330.602,715.888 334.435,713.529 335.909,711.76C377.188,663.11 403.135,488.853 403.135,488.263C403.135,483.545 401.071,479.418 395.764,478.238L343.281,467.918C342.101,467.624 340.922,467.624 339.742,467.624C336.204,467.624 334.14,469.098 332.961,472.931C329.717,484.135 308.783,589.987 302.001,607.383C300.822,610.921 299.643,612.395 298.463,612.395C297.284,612.395 296.104,610.921 295.515,607.972L273.991,526.594C272.516,522.466 268.388,519.222 262.491,519.222L261.607,519.222L223.276,521.581C214.136,522.171 210.303,526.299 210.008,530.427C204.111,614.754 202.047,615.344 198.509,615.344C197.329,615.344 196.15,614.164 195.265,612.1L138.949,482.661C138.064,480.597 135.116,477.648 130.398,477.648C129.219,477.648 128.039,477.943 126.86,478.238L70.249,497.993C67.3,498.878 65.826,502.416 65.826,505.954C65.826,507.134 66.121,508.608 66.711,509.787L159.883,718.836C161.063,721.49 165.191,724.144 170.203,724.144L171.088,724.144L214.431,721.785C222.687,721.785 229.173,718.836 249.518,644.239L273.106,712.939C273.991,715.593 278.413,718.247 283.426,718.247L284.31,718.247L326.769,715.888Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:7.06px;"/>
</g>
<g transform="matrix(0.996964,-0.077866,0.077866,0.996964,-83.3213,42.4174)">
<path d="M650.81,701.735C653.758,700.556 655.233,697.312 655.233,694.364C655.233,692.889 654.643,691.12 654.053,689.941L551.74,481.776C550.561,479.123 545.548,476.174 539.356,476.174L496.603,476.174C492.18,476.174 487.757,478.238 485.988,479.712C437.928,524.53 387.508,690.236 387.508,699.376C387.508,703.799 389.867,707.337 395.469,709.106L440.581,722.08C442.35,722.669 443.825,722.964 445.299,722.964C448.837,722.964 451.196,720.9 452.67,717.362C453.555,714.708 457.683,703.799 463.285,689.646L517.832,692.3L518.422,692.3C522.255,692.3 525.203,689.056 525.498,685.518L529.036,632.74L529.036,632.15C529.036,628.317 526.088,625.074 522.255,625.074L488.642,623.305C507.218,576.423 510.461,568.168 512.82,568.168C513.704,568.168 514.589,569.052 515.473,571.116L580.93,717.952C581.815,720.016 585.353,722.669 590.071,722.669C591.545,722.669 593.314,722.375 594.788,721.785L650.81,701.735Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:7.06px;"/>
</g>
<g transform="matrix(0.997179,0.0750623,-0.0750623,0.997179,-50.4766,-58.4735)">
<path d="M899.664,721.785C903.497,721.785 906.74,718.836 907.035,715.003L919.124,485.02C919.124,481.187 916.175,477.648 912.342,477.648L853.077,474.405L852.488,474.405C848.655,474.405 845.706,477.648 845.411,481.187L841.283,560.502L778.48,557.258L777.89,557.258C774.352,557.258 771.109,560.502 770.814,564.04L768.455,615.639L768.455,616.228C768.455,619.767 771.404,623.01 775.237,623.305L838.04,626.253L833.322,711.17C833.322,715.003 836.271,718.247 840.104,718.541L899.664,721.785ZM750.764,720.311C754.597,720.311 757.841,717.067 757.841,713.234L757.841,482.956C757.841,479.123 754.597,475.879 750.764,475.879L690.909,475.879C687.076,475.879 683.833,479.123 683.833,482.956L683.833,713.234C683.833,717.067 687.076,720.311 690.909,720.311L750.764,720.311Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:7.06px;"/>
</g>
<g transform="matrix(0.991478,-0.130275,0.130275,0.991478,-201.194,134.945)">
<path d="M1022.32,629.497C1025.86,629.497 1028.22,626.843 1028.81,623.305C1033.53,596.178 1038.24,558.732 1038.24,523.94C1038.24,477.059 1033.82,476.174 1028.51,476.174L965.415,476.174C961.877,476.174 959.518,479.123 959.518,482.366C959.813,523.055 964.236,597.063 966.005,623.305C966.3,626.843 968.954,629.497 972.492,629.497L1022.32,629.497ZM996.67,726.208C1019.67,726.208 1038.54,707.337 1038.54,684.044C1038.54,660.751 1019.67,641.88 996.67,641.88C973.376,641.88 954.506,660.751 954.506,684.044C954.506,707.337 973.376,726.208 996.67,726.208Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:7.06px;"/>
</g>
</g>
<g transform="matrix(1.08899,0,0,3.41949,182.218,-900.313)">
<path d="M1220.95,663.011C1221.88,662.394 1222.96,661.778 1222.96,660.544C1222.96,659.928 1222.65,659.157 1221.88,658.232C1212.94,647.902 1197.06,623.541 1197.06,593.784C1197.06,565.415 1212.01,541.055 1221.26,530.108C1222.34,528.874 1222.65,527.949 1222.65,527.024C1222.65,525.945 1221.88,525.174 1220.8,524.403L1216.64,522.09C1216.02,521.782 1215.4,521.474 1214.94,521.474C1213.4,521.474 1212.16,522.553 1211.24,523.632C1202.45,533.5 1183.8,557.089 1183.8,593.784C1183.8,631.096 1203.22,654.84 1211.7,664.399C1212.78,665.632 1213.71,666.095 1214.63,666.095C1215.25,666.095 1215.71,665.941 1216.33,665.632L1220.95,663.011Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
<g transform="matrix(0.990492,-0.137573,0.137573,0.990492,-69.4464,184.165)">
<path d="M1242.85,649.597C1243.15,655.456 1246.09,657.923 1251.17,659.157C1252.25,659.311 1253.49,659.465 1254.72,659.773C1261.96,661.007 1269.21,661.624 1276.3,661.624C1320.09,661.624 1358.33,637.726 1358.33,594.093C1358.33,585.459 1356.79,575.899 1353.39,565.569C1344.61,538.588 1317.32,527.333 1291.26,527.333C1282.16,527.333 1273.07,528.72 1265.05,531.341L1240.38,532.729C1238.38,532.729 1236.83,534.579 1236.83,536.583L1242.85,649.597ZM1276.92,561.561C1280.47,560.635 1284.32,560.019 1288.02,560.019C1316.55,560.019 1316.7,590.546 1316.7,593.168C1316.7,612.748 1301.9,625.545 1284.01,625.545C1282.78,625.545 1281.55,625.545 1280.31,625.391L1276.92,561.561Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<g transform="matrix(0.999241,0.0389517,-0.0389517,0.999241,24.2226,-55.6835)">
<path d="M1510.66,593.63C1510.66,567.882 1492.16,527.178 1442.82,527.178C1415.68,527.178 1386.39,540.13 1376.37,568.961C1373.13,578.52 1371.59,587.617 1371.59,596.097C1371.59,634.488 1402.42,660.39 1437.58,660.39C1468.88,660.39 1510.66,636.03 1510.66,593.63ZM1442.82,626.316C1426.94,626.316 1412.14,613.057 1412.14,593.476C1412.14,579.445 1419.85,560.327 1442.2,560.327C1463.63,560.327 1471.81,578.212 1471.81,593.476C1471.81,610.898 1461.17,626.316 1442.82,626.316Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<g transform="matrix(0.998795,-0.0490748,0.0490748,0.998795,-27.2616,77.677)">
<path d="M1590.68,657.769C1592.53,657.615 1594.22,656.073 1594.22,654.069L1594.22,653.915L1589.6,565.723L1613.96,564.49C1616.12,564.336 1617.66,562.486 1617.66,560.481L1616.27,532.266C1616.27,530.108 1614.27,528.566 1612.26,528.566L1551.21,531.804L1522.38,533.346C1520.37,533.5 1518.83,535.042 1518.83,536.892L1518.83,537.2L1520.22,565.723C1520.22,567.728 1522.07,569.27 1524.23,569.27L1549.51,567.882L1554.14,655.919C1554.14,657.769 1555.68,659.465 1557.68,659.465L1557.99,659.465L1590.68,657.769Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<g transform="matrix(0.993146,-0.116878,0.116878,0.993146,-57.3371,210.711)">
<path d="M1834.28,659.157C1836.6,659.157 1838.29,656.844 1838.44,654.685L1843.69,535.196L1843.69,534.887C1843.69,533.191 1842.76,531.033 1839.83,530.879L1809.15,529.337L1808.84,529.337C1806.68,529.337 1804.22,530.57 1803.6,531.341C1796.05,540.284 1781.55,562.948 1768.91,584.688C1768.6,585.15 1768.45,585.459 1768.14,585.459C1767.83,585.459 1767.68,585.304 1767.37,584.842C1754.73,563.102 1740.23,540.284 1732.68,531.341C1732.06,530.57 1728.98,529.337 1726.82,529.337L1726.51,529.337L1696.14,531.033C1693.21,531.341 1692.28,533.654 1692.28,535.35L1698.3,654.685C1698.3,656.844 1699.99,659.157 1702.46,659.157L1702.61,659.157L1732.22,656.69C1735.61,656.381 1737.77,653.144 1737.77,651.448L1737.77,651.293L1730.83,585.767L1730.83,584.688C1730.83,583.763 1730.98,583.146 1731.29,583.146C1731.75,583.146 1732.22,583.608 1732.83,584.379C1735.76,588.388 1747.02,611.515 1754.73,625.7C1755.65,627.55 1757.19,629.862 1759.97,629.862L1775.85,629.246C1779.24,629.092 1780.94,626.933 1781.55,625.7C1789.11,611.515 1800.36,587.463 1803.14,583.608C1803.76,582.837 1804.22,582.375 1804.53,582.375C1804.99,582.375 1805.14,582.992 1805.14,584.071L1805.14,584.842L1797.9,651.448L1797.9,651.602C1797.9,653.298 1799.44,656.69 1802.83,656.844L1834.13,659.157L1834.28,659.157Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<g transform="matrix(0.994193,0.107609,-0.107609,0.994193,75.0929,-204.041)">
<path d="M1997.71,593.63C1997.71,567.882 1979.21,527.178 1929.87,527.178C1902.74,527.178 1873.44,540.13 1863.42,568.961C1860.18,578.52 1858.64,587.617 1858.64,596.097C1858.64,634.488 1889.48,660.39 1924.63,660.39C1955.93,660.39 1997.71,636.03 1997.71,593.63ZM1929.87,626.316C1913.99,626.316 1899.19,613.057 1899.19,593.476C1899.19,579.445 1906.9,560.327 1929.26,560.327C1950.69,560.327 1958.86,578.212 1958.86,593.476C1958.86,610.898 1948.22,626.316 1929.87,626.316Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<g transform="matrix(0.99192,-0.126865,0.126865,0.99192,-58.7652,265.507)">
<path d="M2093.61,655.919C2095.77,655.765 2097.31,653.915 2097.31,651.91L2096.24,625.083C2096.24,623.233 2094.54,621.537 2092.53,621.537L2092.23,621.537L2054.76,623.541L2053.99,609.202L2079.58,609.202C2081.74,609.202 2083.28,607.506 2083.44,605.348L2083.75,581.758L2083.75,581.45C2083.75,579.445 2081.9,577.904 2080.05,577.904L2052.45,577.904L2051.68,564.644L2087.6,562.794C2089.45,562.64 2091.15,560.944 2091.15,559.094L2091.15,558.785L2089.91,531.958C2089.76,530.108 2088.06,528.412 2086.21,528.412L2085.91,528.412L2044.89,530.57L2044.28,530.57L2016.22,532.112C2014.37,532.112 2012.67,533.808 2012.67,535.658L2012.67,535.967L2018.99,656.227C2019.14,658.077 2020.69,659.773 2022.54,659.773L2022.85,659.773L2052.91,658.232C2053.06,658.232 2053.37,658.077 2053.53,658.077L2093.61,655.919Z" style="fill:rgb(223,80,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
<path d="M2115.35,665.632C2115.97,665.941 2116.43,666.095 2117.05,666.095C2117.97,666.095 2118.9,665.632 2119.98,664.399C2128.46,654.84 2147.89,631.096 2147.89,593.784C2147.89,557.089 2129.23,533.5 2120.44,523.632C2119.52,522.553 2118.28,521.474 2116.74,521.474C2116.28,521.474 2115.66,521.782 2115.05,522.09L2110.88,524.403C2109.8,525.174 2109.03,525.945 2109.03,527.024C2109.03,527.949 2109.34,528.874 2110.42,530.108C2119.67,541.055 2134.63,565.415 2134.63,593.784C2134.63,623.541 2118.74,647.902 2109.8,658.232C2109.03,659.157 2108.72,659.928 2108.72,660.544C2108.72,661.778 2109.8,662.394 2110.73,663.011L2115.35,665.632Z" style="fill:rgb(255,152,0);fill-rule:nonzero;stroke:rgb(249,247,204);stroke-width:5.59px;"/>
</g>
</g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 12 KiB

BIN
oreilly.zip → auth0 Normal file → Executable file

Binary file not shown.

View file

@ -1,30 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Bookmarks</title>
<!--<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">-->
<meta property="og:title" content="title">
<meta property="og:description" content="description">
<!--<meta property="og:image" content="/res/img/icons/png/computer.png">-->
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

View file

@ -1,56 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Bookmarks</title>
<!--<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">-->
<meta property="og:title" content="Bookmarks">
<meta property="og:description" content="friends' websites or sites I just find cool">
<!--<meta property="og:image" content="/res/img/icons/png/computer.png">-->
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
<h1>Friends' Websites</h1>
<ul>
<li><a href="http://www.nick99nack.com/">nick99nack</a> - Currently in the process of taking over the internet. I <i>Totally</i> didn't steal any of his stuff.</li>
<li><a href="http://dkay.xyz/">dkay</a> - The land of norton.</li>
<li><a href="https://campos02.me/">Vbc</a> - Cool brazilian dude, does programming and stuff</li>
<li><a href="https://kickfacehq.com/">KickfaceHQ</a> - The interwebz home of Daniel Kickface and Team Kickface! Uses a totally rad FrontPage 2003 theme.</li>
<li><a href="https://joshuaalto.com/">Sashi</a> - Site redesign #8! I'll find a website style I enjoy eventually, I swear!</li>
<li><a href="http://strangenessnetworks.com/">noone</a> - Strangeness Network, noone's website.</li>
<li><a href="https://notashelf.dev/">raf</a> - is a shelf</li>
<li><a href="https://starman0620.neocities.org/">CamK06</a> - Now with more outdated HTML!</li>
<li><a href="https://hiden.pw/">HIDEN</a> - Moar buttons!</li>
<li><a href="http://cocomark.neocities.org/">Coco</a> - needs to go to the brain store</li>
<li><a href="http://toxi.pw/">Toxidations</a> - h (idk if this is his actual domain he has like 5)</li>
<li><a href="http://xproot.pw/">xproot</a> - a random internet person on this very random planet</li>
</ul>
<h1>Computing / Technology</h1>
<ul>
<li><a href="http://www.winworldpc.com/">WinWorld</a> - WinWorld is an online museum dedicated to the preservation and sharing of vintage, abandoned, and pre-release software.</li>
<li><a href="http://nina.chat/">NINA</a> - Upcoming revival of the America Online service.</li>
<li><a href="http://escargot.chat/">Escargot</a> - MSN & Yahoo Messenger Revival</li>
</ul>
<h1>Other Cool Stuff</h1>
<ul>
<li><a href="http://toastytech.com/">ToastyTech</a> - Nathan's Toasty Technology Page</li>
<li><a href="http://www.hoary.org/browse/">Optimized for no one</a> - Optimized for no one, but pretty much OK with . . .</li>
<li><a href="http://www.cameronsworld.net/">Cameron's World</a> - A love letter to the Internet of old.</li>
</ul>
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

55
bootstrap/app.php Normal file
View file

@ -0,0 +1,55 @@
<?php
/*
|--------------------------------------------------------------------------
| Create The Application
|--------------------------------------------------------------------------
|
| The first thing we will do is create a new Laravel application instance
| which serves as the "glue" for all the components of Laravel, and is
| the IoC container for the system binding all of the various parts.
|
*/
$app = new Gecche\Multidomain\Foundation\Application(
$_ENV['APP_BASE_PATH'] ?? dirname(__DIR__)
);
/*
|--------------------------------------------------------------------------
| Bind Important Interfaces
|--------------------------------------------------------------------------
|
| Next, we need to bind some important interfaces into the container so
| we will be able to resolve them when needed. The kernels serve the
| incoming requests to this application from both the web and CLI.
|
*/
$app->singleton(
Illuminate\Contracts\Http\Kernel::class,
App\Http\Kernel::class
);
$app->singleton(
Illuminate\Contracts\Console\Kernel::class,
App\Console\Kernel::class
);
$app->singleton(
Illuminate\Contracts\Debug\ExceptionHandler::class,
App\Exceptions\Handler::class
);
/*
|--------------------------------------------------------------------------
| Return The Application
|--------------------------------------------------------------------------
|
| This script returns the application instance. The instance is given to
| the calling script so we can separate the building of the instances
| from the actual running of the application and sending responses.
|
*/
return $app;

2
bootstrap/cache/.gitignore vendored Normal file
View file

@ -0,0 +1,2 @@
*
!.gitignore

View file

@ -1,142 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Calculators</title>
<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">
<meta property="og:title" content="Calculators">
<meta property="og:description" content="C a l c u l a t o r s">
<meta property="og:image" content="/res/img/icons/png/calc.png">
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
<h1>CASIO fx-CG50</h1>
<p>TBD</p>
<h2>Pictures</h2>
<p>Click images to view full size</p>
<a href="/res/img/calculators/casio-fx-cg50/1s.jpeg"><img src="/res/img/calculators/casio-fx-cg50/1s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-cg50/2s.jpeg"><img src="/res/img/calculators/casio-fx-cg50/2s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-cg50/3s.jpeg"><img src="/res/img/calculators/casio-fx-cg50/3s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-cg50/4s.jpeg"><img src="/res/img/calculators/casio-fx-cg50/4s.jpeg" width="15%"></a>
<h1>CASIO fx-120 (1977-78)</h1>
<p>TBD</p>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>Size</b></td>
<td>8.4cm x 16.2cm x 2.4cm</td>
</tr>
<tr>
<td><b>Weight (w/ battery)</b></td>
<td>209g</td>
</tr>
<tr>
<td><b>Type</b></td>
<td>Scientific</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Hitachi HD38111A</td>
</tr>
<tr>
<td><b>Registers</b></td>
<td>2 standard<br>1 constant<br>4 bracket<br>1 memory</td>
</tr>
<tr>
<td><b>Features</b></td>
<td>%, +/-, RV, F, Sci, a<sup>b</sup>&frasl;<sub>c</sub>, Sqr, x<sup>2</sup>, pi, <sup>1</sup>&frasl;<sub>x</sub>, trig,<br>hyp, DMS-DD, log, y<sup>x</sup>, SD, nCr, P-R, n!</sup></td>
</tr>
<tr>
<td><b>Display</b></td>
<td>12-digit VFD (NEC LD8197A)</td>
</tr>
</table>
<h2>Pictures</h2>
<p>Click images to view full size</p>
<a href="/res/img/calculators/casio-fx-120/1s.jpeg"><img src="/res/img/calculators/casio-fx-120/1s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-120/2s.jpeg"><img src="/res/img/calculators/casio-fx-120/2s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-120/3s.jpeg"><img src="/res/img/calculators/casio-fx-120/3s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-120/4s.jpeg"><img src="/res/img/calculators/casio-fx-120/4s.jpeg" width="15%"></a>
<h1>CASIO fx-82 (1982-85)</h1>
<p>TBD</p>
<h2>Pictures</h2>
<p>Click images to view full size</p>
<a href="/res/img/calculators/casio-fx-82/1s.jpeg"><img src="/res/img/calculators/casio-fx-82/1s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-82/2s.jpeg"><img src="/res/img/calculators/casio-fx-82/2s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-82/3s.jpeg"><img src="/res/img/calculators/casio-fx-82/3s.jpeg" width="15%"></a>
<a href="/res/img/calculators/casio-fx-82/4s.jpeg"><img src="/res/img/calculators/casio-fx-82/4s.jpeg" width="15%"></a>
<h1>Texas Instruments TI-30 (1976-90)</h1>
<p>TBD</p>
<h2>Pictures</h2>
<p>Click images to view full size</p>
<a href="/res/img/calculators/ti-30/1s.jpeg"><img src="/res/img/calculators/ti-30/1s.jpeg" width="15%"></a>
<a href="/res/img/calculators/ti-30/2s.jpeg"><img src="/res/img/calculators/ti-30/2s.jpeg" width="15%"></a>
<a href="/res/img/calculators/ti-30/3s.jpeg"><img src="/res/img/calculators/ti-30/3s.jpeg" width="15%"></a>
<a href="/res/img/calculators/ti-30/4s.jpeg"><img src="/res/img/calculators/ti-30/4s.jpeg" width="15%"></a>
<h1>Texet 880 Executive (1977-78)</h1>
<p>The calculator measures 74.2mm x 135mm x 22.2mm. It weighs 86g without the battery installed, which is a 9v PP3-type battery. Rather than the usual press-stud type holder, the housing has two metal slide clips. There is also what I assume to be a sponge at one end which is supposed to aid in holding the battery in, however it appears to have gone completely hard and I will most likely replace it in the future. There's small adaptor hole at the top, of which the input isn't specified (though it's generally agreed that it's 4.5v centre-positive).</p>
<p>The case is black &amp; silvery colored with a thin brushed metallic front panel. The eight-digit bubble display has an absolutely <i>terrible</i> viewing angle, which means you either have to be holding it under your coat or against your face to read it!</p>
The keypad is particularly strange in the way that it has 3 cancel buttons, <pre>[CE]</pre>, <pre>[C]</pre> and <pre>[CA]</pre>, while the <pre>[CS]</pre> button is a Clear Sign button, <i>not</i> another cancel! The keys themselves are particularly stiff and you really have to push them to get them to register. Many 880s suffered something referred to as the "pseudo fixed decimal bug" where, if you typed in <pre>1 + 1.00 = </pre>, it would display <pre>2.00</pre> instead of the expected <pre>2</pre>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>Size</b></td>
<td>7.4cm x 13.5cm x 2.2cm</td>
</tr>
<tr>
<td><b>Weight (w/o battery)</b></td>
<td>86</td>
</tr>
<tr>
<td><b>Type</b></td>
<td>Arithmetic</td>
</tr>
<tr>
<td><b>Logic</b></td>
<td>Algebraic</td>
</tr>
<tr>
<td><b>Power Source</b></td>
<td>PP3 9v</td>
</tr>
<tr>
<td><b>Display</b></td>
<td>8-digit LED</td>
</tr>
</table>
<h2>Pictures</h2>
<p>Click images to view full size</p>
<a href="/res/img/calculators/texet-880/1s.jpeg"><img src="/res/img/calculators/texet-880/1s.jpeg" width="15%"></a>
<a href="/res/img/calculators/texet-880/2s.jpeg"><img src="/res/img/calculators/texet-880/2s.jpeg" width="15%"></a>
<a href="/res/img/calculators/texet-880/3s.jpeg"><img src="/res/img/calculators/texet-880/3s.jpeg" width="15%"></a>
<a href="/res/img/calculators/texet-880/4s.jpeg"><img src="/res/img/calculators/texet-880/4s.jpeg" width="15%"></a>
<!--<h2>TL;DR</h2>
<ul>
<li>Sponge in battery compartment has gone hard and should probably be replaced</li>
<li>Power input is unlabelled but is widely agreed to be 4.5v centre-positive</li>
<lI>Uses an 8-digit bubble display with a terrible viewing angle</li>
<li>Has 3 cancel buttons (<pre>[CE]</pre>, <pre>[C]</pre> and <pre>[CA]</pre>)</li>
<li>Has particularly stiff keys</li>
<li>Many suffered from the "pseudo fixed decimal bug", however mine does not</li>
</ul>-->
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

73
composer.json Normal file
View file

@ -0,0 +1,73 @@
{
"name": "RoscoeDaWah/wah.moe",
"type": "project",
"description": "My personal website, developed using the Laravel framework.",
"keywords": ["laravel", "framework"],
"license": "MIT",
"require": {
"php": "^8.1",
"gecche/laravel-multidomain": "^10.2",
"guzzlehttp/guzzle": "^7.2",
"intervention/image": "^3.9",
"laravel/framework": "^10.10",
"laravel/tinker": "^2.8",
"scrivo/highlight.php": "v9.18.1.10",
"sentry/sentry-laravel": "^4.1",
"spatie/laravel-honeypot": "^4.3",
"spatie/laravel-html": "^3.4",
"ua-parser/uap-php": "^3.9.14",
"ext-exif": "*"
},
"require-dev": {
"fakerphp/faker": "^1.9.1",
"laravel/pint": "^1.0",
"laravel/sail": "^1.18",
"mockery/mockery": "^1.4.4",
"nunomaduro/collision": "^7.0",
"phpunit/phpunit": "^10.1",
"spatie/laravel-ignition": "^2.0"
},
"autoload": {
"psr-4": {
"App\\": "app/",
"Database\\Factories\\": "database/factories/",
"Database\\Seeders\\": "database/seeders/"
}
},
"autoload-dev": {
"psr-4": {
"Tests\\": "tests/"
}
},
"scripts": {
"post-autoload-dump": [
"Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
"@php artisan package:discover --ansi"
],
"post-update-cmd": [
"@php artisan vendor:publish --tag=laravel-assets --ansi --force"
],
"post-root-package-install": [
"@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
],
"post-create-project-cmd": [
"@php artisan key:generate --ansi"
]
},
"extra": {
"laravel": {
"dont-discover": []
}
},
"config": {
"optimize-autoloader": true,
"preferred-install": "dist",
"sort-packages": true,
"allow-plugins": {
"pestphp/pest-plugin": true,
"php-http/discovery": true
}
},
"minimum-stability": "stable",
"prefer-stable": true
}

9242
composer.lock generated Normal file

File diff suppressed because it is too large Load diff

View file

@ -1,304 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Computers</title>
<!--<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">-->
<meta property="og:title" content="Computers">
<meta property="og:description" content="Computers I own or have owned.">
<!--<meta property="og:image" content="/res/img/icons/png/computer.png">-->
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content"><table class="computers" border="0">
<tr>
<!-- Lenovo ThinkPad T430 -->
<td class="computer">
<h1>Lenovo ThinkPad T430 (2012)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Arch Linux x86_64 / Windows 7 Pro</td>
</tr>
<tr>
<td><b>LCD Resolution</b></td>
<td>1600x900</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel i7-3520M (4 cores) @ 3.6GHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>Intel 3rd Gen Core processor Graphics Controller</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>16GB</td>
</tr>
<tr>
<td><b>HDD0</b></td>
<td>Crucial CT500MX500SSD1 (500GB, Linux)</td>
</tr>
<tr>
<td><b>HDD1</b></td>
<td>Crucial CT250MX500SSD1 (250GB, Windows)</td>
</tr>
</table>
</td>
<!-- Macbook Pro (2018) -->
<td class="computer">
<h1>Macbook Pro (2018)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>macOS 12.5.1</td>
</tr>
<tr>
<td><b>LCD Resolution</b></td>
<td>2560x1600 (Retina)</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel i5-8259U (8 cores) @ 2.3GHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>Intel Iris Plus Graphics 655</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>8GB</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Apple SSD AP0256M (250GB)</td>
</tr>
</table>
</td>
</tr>
<tr>
<!-- IBM ThinkPad T40 (2003) -->
<td class="computer">
<h1>IBM ThinkPad T40 (2003)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Windows XP Pro / Windows 2000 Pro (Extended)</td>
</tr>
<tr>
<td><b>LCD Resolution</b></td>
<td>1024x768</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel Pentium M (single core) @ 1.3GHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>ATI Mobility Radeon 7500 (32MB)</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>1GB (DDR SDRAM)</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Fujitsu MHS2030AT (30GB)</td>
</tr>
</table>
</td>
<!-- IBM ThinkPad X41 (2005) -->
<td class="computer">
<h1>IBM ThinkPad X41 (2005)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Windows XP Tablet PC Edition (2005, SP3)</td>
</tr>
<tr>
<td><b>LCD Resolution</b></td>
<td>1024x768 (TFT)</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel Pentium M (single core) @ 1.6GHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>Mobile Intel 915GM/GMS 910GML Express Chipset Family (128MB)</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>1.5GB (DDR SDRAM)</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Hitachi HTC426040G9AT00 (40GB)</td>
</tr>
</table>
</td>
</tr>
<tr>
<!-- Dell OptiPlex GX1 (400L+, 1999) -->
<td class="computer">
<h1>Dell OptiPlex GX1 (400L+, 1999)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Windows NT 4.0 (SP6)</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel Pentium II (Deschutes) @ 400 MHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>ATI 3D Rage Pro (4MB)</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>639MB (SDR SDRAM)</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Maxtor 2F020J0 (20GB)</td>
</tr>
</table>
</td>
<!-- Dell Inspiron 1525 (2008) -->
<td class="computer">
<h1>Dell Inspiron 1525 (2008)</h1>
<h2>Specifications</h2>
<p>TBD</p>
</td>
</tr>
<tr>
<!-- Dell OptiPlex 745 (USFF, 2007, x3) -->
<td class="computer">
<h1>Dell OptiPlex 745 (USFF, 2007, x3)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Various</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel Pentium Dual Core</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>4GB</td>
</tr>
</table>
</td>
<!-- Compaq Armada M300 (2000) -->
<td class="computer">
<h1>Compaq Armada M300 (2000)</h1>
<h2>Specifications</h2>
<p>TBD</p>
</td>
</tr>
<tr>
<!-- Random Whitebox (???) -->
<td class="computer">
<h1>Random Whitebox (???)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Windows XP Pro (SP3)</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>AMD Athon-PECM (Thunderbird, 4 cores, 1.2GHz)</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>Hercules 3D Propher 9000 PCI (ATI Radeon 9000, 64MB)</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>500MB</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Seagate ST3160215ACE (150GB)</td>
</tr>
</table>
</td>
<!-- Mac mini (2014) -->
<td class="computer">
<h1>Mac mini (2014)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>VMware ESXi 6.7.0u3</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel i5-4278U (4 cores) @ 2.6GHz</td>
</tr>
<tr>
<td><b>GPU</b></td>
<td>Intel Iris Graphics</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>8GB</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>Apple HDD HTS541 (1TB)</td>
</tr>
</table>
</td>
</tr>
<tr>
<!-- Fujitsu Milan (1996) -->
<td class="computer">
<h1>Fujitsu Milan (1996)</h1>
<h2>Specifications</h2>
<table class="skami">
<tr>
<td><b>OS</b></td>
<td>Windows 98 SE</td>
</tr>
<tr>
<td><b>CPU</b></td>
<td>Intel Pentium</td>
</tr>
<tr>
<td><b>Memory</b></td>
<td>32MB</td>
</tr>
<tr>
<td><b>HDD</b></td>
<td>IBM DPRA-21215 (1215MB)</td>
</tr>
</table>
</td>
</tr>
</tr></table></div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

34
config/app.php Normal file
View file

@ -0,0 +1,34 @@
<?php
use Illuminate\Support\Facades\Facade;
use Illuminate\Support\ServiceProvider;
return [
'name' => env('APP_NAME', 'diskfloppy.me'),
'version' => '2025.01.01',
'env' => env('APP_ENV', 'production'),
'debug' => (bool) env('APP_DEBUG', false),
'url' => env('APP_URL', 'http://localhost'),
'api_root' => env('API_ROOT', 'http://localhost:3000'),
'asset_url' => env('ASSET_URL'),
'timezone' => 'UTC',
'locale' => 'en',
'fallback_locale' => 'en',
'faker_locale' => 'en_US',
'key' => env('APP_KEY'),
'cipher' => 'AES-256-CBC',
'maintenance' => [
'driver' => 'file',
],
'providers' => ServiceProvider::defaultProviders()->merge([
App\Providers\AppServiceProvider::class,
App\Providers\AuthServiceProvider::class,
App\Providers\EventServiceProvider::class,
App\Providers\RouteServiceProvider::class,
])->replace([
\Illuminate\Queue\QueueServiceProvider::class => \Gecche\Multidomain\Queue\QueueServiceProvider::class,
])->toArray(),
'aliases' => Facade::defaultAliases()->merge([
])->toArray(),
];

115
config/auth.php Normal file
View file

@ -0,0 +1,115 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Authentication Defaults
|--------------------------------------------------------------------------
|
| This option controls the default authentication "guard" and password
| reset options for your application. You may change these defaults
| as required, but they're a perfect start for most applications.
|
*/
'defaults' => [
'guard' => 'web',
'passwords' => 'users',
],
/*
|--------------------------------------------------------------------------
| Authentication Guards
|--------------------------------------------------------------------------
|
| Next, you may define every authentication guard for your application.
| Of course, a great default configuration has been defined for you
| here which uses session storage and the Eloquent user provider.
|
| All authentication drivers have a user provider. This defines how the
| users are actually retrieved out of your database or other storage
| mechanisms used by this application to persist your user's data.
|
| Supported: "session"
|
*/
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
],
/*
|--------------------------------------------------------------------------
| User Providers
|--------------------------------------------------------------------------
|
| All authentication drivers have a user provider. This defines how the
| users are actually retrieved out of your database or other storage
| mechanisms used by this application to persist your user's data.
|
| If you have multiple user tables or models you may configure multiple
| sources which represent each model / table. These sources may then
| be assigned to any extra authentication guards you have defined.
|
| Supported: "database", "eloquent"
|
*/
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\Models\User::class,
],
// 'users' => [
// 'driver' => 'database',
// 'table' => 'users',
// ],
],
/*
|--------------------------------------------------------------------------
| Resetting Passwords
|--------------------------------------------------------------------------
|
| You may specify multiple password reset configurations if you have more
| than one user table or model in the application and you want to have
| separate password reset settings based on the specific user types.
|
| The expiry time is the number of minutes that each reset token will be
| considered valid. This security feature keeps tokens short-lived so
| they have less time to be guessed. You may change this as needed.
|
| The throttle setting is the number of seconds a user must wait before
| generating more password reset tokens. This prevents the user from
| quickly generating a very large amount of password reset tokens.
|
*/
'passwords' => [
'users' => [
'provider' => 'users',
'table' => 'password_reset_tokens',
'expire' => 60,
'throttle' => 60,
],
],
/*
|--------------------------------------------------------------------------
| Password Confirmation Timeout
|--------------------------------------------------------------------------
|
| Here you may define the amount of seconds before a password confirmation
| times out and the user is prompted to re-enter their password via the
| confirmation screen. By default, the timeout lasts for three hours.
|
*/
'password_timeout' => 10800,
];

117
config/bookmarks.php Normal file
View file

@ -0,0 +1,117 @@
<?php
return [
// Friends' Websites
[
'name' => "Friends' Websites",
'bookmarks' => [
[
'name' => "nick99nack",
'url' => "http://www.nick99nack.com/",
'description' => "Currently in the process of taking over the internet. I Totally didn't steal any of his stuff."
],
[
'name' => "campos",
'url' => "https://campos02.me/",
'description' => "Cool brazilian dude, does programming and stuff"
],
[
'name' => "Sashi",
'url' => "https://joshuaalto.com/",
'description' => "Site redesign #8! I'll find a website style I enjoy eventually, I swear!"
],
[
'name' => "noone",
'url' => "http://strangenessnetworks.com/",
'description' => "Strangeness Networks, noone's website."
],
[
'name' => "raf",
'url' => "https://notashelf.dev/",
'description' => "is a shelf"
],
[
'name' => "CamK06",
'url' => "https://starman0620.neocities.org/",
'description' => "Now with more outdated HTML!"
],
[
'name' => "HIDEN",
'url' => "https://hiden.pw/",
'description' => "Moar buttons!"
],
[
'name' => "coco",
'url' => "http://cocomark.neocities.org/",
'description' => "needs to go to the brain store"
],
[
'name' => "Toxidation",
'url' => "http://toxi.pw/",
'description' => "h (idk if this is his actual domain he has like 5)"
],
[
'name' => "xproot",
'url' => "http://xproot.pw/",
'description' => "a random internet person on this very random planet"
]
]
],
// Cool Projects
[
'name' => "Cool Projects",
'bookmarks' => [
[
'name' => "ToS;DR",
'url' => "https://tosdr.org/",
'description' => "\"I have read and agree to the Terms\" is the biggest lie on the web. They aim to fix that."
],
[
'name' => "NINA",
'url' => "https://nina.chat/",
'description' => "Yahoo! Messenger (and soon AOL) revival"
],
[
'name' => "Escargot",
'url' => "https://escargot.chat/",
'description' => "MSN/WLM revival"
],
]
],
// Other Cool Stuff
[
'name' => "Other Cool Stuff",
'bookmarks' => [
[
'name' => "WinWorld",
'url' => "http://www.winworldpc.com/",
'description' => "WinWorld is an online museum dedicated to the preservation and sharing of vintage, abandoned, and pre-release software."
],
[
'name' => "ToastyTech",
'url' => "http://toastytech.com/",
'description' => "Nathan's Toasty Technology Page"
],
[
'name' => "Optimized for no one",
'url' => "http://www.hoary.org/browse/",
'description' => "Optimized for no one, but pretty much OK with . . ."
],
[
'name' => "Cameron's World",
'url' => "http://www.cameronsworld.net/",
'description' => "A love letter to the Internet of old."
]
]
],
// Miscellaneous Resources
[
'name' => "Miscellaneous Resources",
'bookmarks' => [
[
'name' => "Home Manager (Appendix A)",
'url' => "https://rycee.gitlab.io/home-manager/options.html",
'description' => "Useful list of configuration options for Home Manager."
]
]
]
];

44
config/broadcasting.php Normal file
View file

@ -0,0 +1,44 @@
<?php
return [
'default' => env('BROADCAST_DRIVER', 'null'),
'connections' => [
'pusher' => [
'driver' => 'pusher',
'key' => env('PUSHER_APP_KEY'),
'secret' => env('PUSHER_APP_SECRET'),
'app_id' => env('PUSHER_APP_ID'),
'options' => [
'cluster' => env('PUSHER_APP_CLUSTER'),
'host' => env('PUSHER_HOST') ?: 'api-'.env('PUSHER_APP_CLUSTER', 'mt1').'.pusher.com',
'port' => env('PUSHER_PORT', 443),
'scheme' => env('PUSHER_SCHEME', 'https'),
'encrypted' => true,
'useTLS' => env('PUSHER_SCHEME', 'https') === 'https',
],
'client_options' => [
// Guzzle client options: https://docs.guzzlephp.org/en/stable/request-options.html
],
],
'ably' => [
'driver' => 'ably',
'key' => env('ABLY_KEY'),
],
'redis' => [
'driver' => 'redis',
'connection' => 'default',
],
'log' => [
'driver' => 'log',
],
'null' => [
'driver' => 'null',
],
],
];

111
config/cache.php Normal file
View file

@ -0,0 +1,111 @@
<?php
use Illuminate\Support\Str;
return [
/*
|--------------------------------------------------------------------------
| Default Cache Store
|--------------------------------------------------------------------------
|
| This option controls the default cache connection that gets used while
| using this caching library. This connection is used when another is
| not explicitly specified when executing a given caching function.
|
*/
'default' => env('CACHE_DRIVER', 'file'),
/*
|--------------------------------------------------------------------------
| Cache Stores
|--------------------------------------------------------------------------
|
| Here you may define all of the cache "stores" for your application as
| well as their drivers. You may even define multiple stores for the
| same cache driver to group types of items stored in your caches.
|
| Supported drivers: "apc", "array", "database", "file",
| "memcached", "redis", "dynamodb", "octane", "null"
|
*/
'stores' => [
'apc' => [
'driver' => 'apc',
],
'array' => [
'driver' => 'array',
'serialize' => false,
],
'database' => [
'driver' => 'database',
'table' => 'cache',
'connection' => null,
'lock_connection' => null,
],
'file' => [
'driver' => 'file',
'path' => storage_path('framework/cache/data'),
'lock_path' => storage_path('framework/cache/data'),
],
'memcached' => [
'driver' => 'memcached',
'persistent_id' => env('MEMCACHED_PERSISTENT_ID'),
'sasl' => [
env('MEMCACHED_USERNAME'),
env('MEMCACHED_PASSWORD'),
],
'options' => [
// Memcached::OPT_CONNECT_TIMEOUT => 2000,
],
'servers' => [
[
'host' => env('MEMCACHED_HOST', '127.0.0.1'),
'port' => env('MEMCACHED_PORT', 11211),
'weight' => 100,
],
],
],
'redis' => [
'driver' => 'redis',
'connection' => 'cache',
'lock_connection' => 'default',
],
'dynamodb' => [
'driver' => 'dynamodb',
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
'region' => env('AWS_DEFAULT_REGION', 'us-east-1'),
'table' => env('DYNAMODB_CACHE_TABLE', 'cache'),
'endpoint' => env('DYNAMODB_ENDPOINT'),
],
'octane' => [
'driver' => 'octane',
],
],
/*
|--------------------------------------------------------------------------
| Cache Key Prefix
|--------------------------------------------------------------------------
|
| When utilizing the APC, database, memcached, Redis, or DynamoDB cache
| stores there might be other applications using the same cache. For
| that reason, you may prefix every cache key to avoid collisions.
|
*/
'prefix' => env('CACHE_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_cache_'),
];

34
config/cors.php Normal file
View file

@ -0,0 +1,34 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Cross-Origin Resource Sharing (CORS) Configuration
|--------------------------------------------------------------------------
|
| Here you may configure your settings for cross-origin resource sharing
| or "CORS". This determines what cross-origin operations may execute
| in web browsers. You are free to adjust these settings as needed.
|
| To learn more: https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS
|
*/
'paths' => ['api/*', 'sanctum/csrf-cookie'],
'allowed_methods' => ['*'],
'allowed_origins' => ['*'],
'allowed_origins_patterns' => [],
'allowed_headers' => ['*'],
'exposed_headers' => [],
'max_age' => 0,
'supports_credentials' => false,
];

31
config/database.php Normal file
View file

@ -0,0 +1,31 @@
<?php
use Illuminate\Support\Str;
return [
'default' => env('DB_CONNECTION', 'mysql'),
'connections' => [
'mysql' => [
'driver' => 'mysql',
'url' => env('DATABASE_URL'),
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'unix_socket' => env('DB_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'prefix_indexes' => true,
'strict' => true,
'engine' => null,
'options' => extension_loaded('pdo_mysql') ? array_filter([
PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
]) : [],
],
],
'migrations' => 'migrations',
];

27
config/domain.php Normal file
View file

@ -0,0 +1,27 @@
<?php
return [
'env_stub' => '.env',
'storage_dirs' => [
'app' => [
'public' => [
],
],
'framework' => [
'cache' => [
],
'testing' => [
],
'sessions' => [
],
'views' => [
],
],
'logs' => [
],
],
'domains' => [
'diskfloppy.me' => 'diskfloppy.me',
'dwiskfwoppy.me' => 'diskfloppy.me',
],
];

76
config/filesystems.php Normal file
View file

@ -0,0 +1,76 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Default Filesystem Disk
|--------------------------------------------------------------------------
|
| Here you may specify the default filesystem disk that should be used
| by the framework. The "local" disk, as well as a variety of cloud
| based disks are available to your application. Just store away!
|
*/
'default' => env('FILESYSTEM_DISK', 'local'),
/*
|--------------------------------------------------------------------------
| Filesystem Disks
|--------------------------------------------------------------------------
|
| Here you may configure as many filesystem "disks" as you wish, and you
| may even configure multiple disks of the same driver. Defaults have
| been set up for each driver as an example of the required values.
|
| Supported Drivers: "local", "ftp", "sftp", "s3"
|
*/
'disks' => [
'local' => [
'driver' => 'local',
'root' => storage_path('app'),
'throw' => false,
],
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
'throw' => false,
],
's3' => [
'driver' => 's3',
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
'region' => env('AWS_DEFAULT_REGION'),
'bucket' => env('AWS_BUCKET'),
'url' => env('AWS_URL'),
'endpoint' => env('AWS_ENDPOINT'),
'use_path_style_endpoint' => env('AWS_USE_PATH_STYLE_ENDPOINT', false),
'throw' => false,
],
],
/*
|--------------------------------------------------------------------------
| Symbolic Links
|--------------------------------------------------------------------------
|
| Here you may configure the symbolic links that will be created when the
| `storage:link` Artisan command is executed. The array keys should be
| the locations of the links and the values should be their targets.
|
*/
'links' => [
public_path('storage') => storage_path('app/public'),
],
];

17
config/hashing.php Normal file
View file

@ -0,0 +1,17 @@
<?php
return [
// One of "bcrypt", "argon", "argon2id"
'driver' => 'bcrypt',
'bcrypt' => [
'rounds' => env('BCRYPT_ROUNDS', 10),
],
'argon' => [
'memory' => 65536,
'threads' => 1,
'time' => 4,
],
];

93
config/logging.php Normal file
View file

@ -0,0 +1,93 @@
<?php
use Monolog\Handler\NullHandler;
use Monolog\Handler\StreamHandler;
use Monolog\Handler\SyslogUdpHandler;
use Monolog\Processor\PsrLogMessageProcessor;
return [
'default' => env('LOG_CHANNEL', 'stack'),
'deprecations' => [
'channel' => env('LOG_DEPRECATIONS_CHANNEL', 'null'),
'trace' => false,
],
'channels' => [
'stack' => [
'driver' => 'stack',
'channels' => ['single'],
'ignore_exceptions' => false,
],
'single' => [
'driver' => 'single',
'path' => storage_path('logs/laravel.log'),
'level' => env('LOG_LEVEL', 'debug'),
'replace_placeholders' => true,
],
'daily' => [
'driver' => 'daily',
'path' => storage_path('logs/laravel.log'),
'level' => env('LOG_LEVEL', 'debug'),
'days' => 14,
'replace_placeholders' => true,
],
'slack' => [
'driver' => 'slack',
'url' => env('LOG_SLACK_WEBHOOK_URL'),
'username' => 'Laravel Log',
'emoji' => ':boom:',
'level' => env('LOG_LEVEL', 'critical'),
'replace_placeholders' => true,
],
'papertrail' => [
'driver' => 'monolog',
'level' => env('LOG_LEVEL', 'debug'),
'handler' => env('LOG_PAPERTRAIL_HANDLER', SyslogUdpHandler::class),
'handler_with' => [
'host' => env('PAPERTRAIL_URL'),
'port' => env('PAPERTRAIL_PORT'),
'connectionString' => 'tls://'.env('PAPERTRAIL_URL').':'.env('PAPERTRAIL_PORT'),
],
'processors' => [PsrLogMessageProcessor::class],
],
'stderr' => [
'driver' => 'monolog',
'level' => env('LOG_LEVEL', 'debug'),
'handler' => StreamHandler::class,
'formatter' => env('LOG_STDERR_FORMATTER'),
'with' => [
'stream' => 'php://stderr',
],
'processors' => [PsrLogMessageProcessor::class],
],
'syslog' => [
'driver' => 'syslog',
'level' => env('LOG_LEVEL', 'debug'),
'facility' => LOG_USER,
'replace_placeholders' => true,
],
'errorlog' => [
'driver' => 'errorlog',
'level' => env('LOG_LEVEL', 'debug'),
'replace_placeholders' => true,
],
'null' => [
'driver' => 'monolog',
'handler' => NullHandler::class,
],
'emergency' => [
'path' => storage_path('logs/laravel.log'),
],
],
];

125
config/mail.php Normal file
View file

@ -0,0 +1,125 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Default Mailer
|--------------------------------------------------------------------------
|
| This option controls the default mailer that is used to send any email
| messages sent by your application. Alternative mailers may be setup
| and used as needed; however, this mailer will be used by default.
|
*/
'default' => env('MAIL_MAILER', 'smtp'),
/*
|--------------------------------------------------------------------------
| Mailer Configurations
|--------------------------------------------------------------------------
|
| Here you may configure all of the mailers used by your application plus
| their respective settings. Several examples have been configured for
| you and you are free to add your own as your application requires.
|
| Laravel supports a variety of mail "transport" drivers to be used while
| sending an e-mail. You will specify which one you are using for your
| mailers below. You are free to add additional mailers as required.
|
| Supported: "smtp", "sendmail", "mailgun", "ses", "ses-v2",
| "postmark", "log", "array", "failover"
|
*/
'mailers' => [
'smtp' => [
'transport' => 'smtp',
'url' => env('MAIL_URL'),
'host' => env('MAIL_HOST', 'smtp.mailgun.org'),
'port' => env('MAIL_PORT', 587),
'encryption' => env('MAIL_ENCRYPTION', 'tls'),
'username' => env('MAIL_USERNAME'),
'password' => env('MAIL_PASSWORD'),
'timeout' => null,
'local_domain' => env('MAIL_EHLO_DOMAIN'),
],
'ses' => [
'transport' => 'ses',
],
'mailgun' => [
'transport' => 'mailgun',
// 'client' => [
// 'timeout' => 5,
// ],
],
'postmark' => [
'transport' => 'postmark',
// 'client' => [
// 'timeout' => 5,
// ],
],
'sendmail' => [
'transport' => 'sendmail',
'path' => env('MAIL_SENDMAIL_PATH', '/usr/sbin/sendmail -bs -i'),
],
'log' => [
'transport' => 'log',
'channel' => env('MAIL_LOG_CHANNEL'),
],
'array' => [
'transport' => 'array',
],
'failover' => [
'transport' => 'failover',
'mailers' => [
'smtp',
'log',
],
],
],
/*
|--------------------------------------------------------------------------
| Global "From" Address
|--------------------------------------------------------------------------
|
| You may wish for all e-mails sent by your application to be sent from
| the same address. Here, you may specify a name and address that is
| used globally for all e-mails that are sent by your application.
|
*/
'from' => [
'address' => env('MAIL_FROM_ADDRESS', 'hello@example.com'),
'name' => env('MAIL_FROM_NAME', 'Example'),
],
/*
|--------------------------------------------------------------------------
| Markdown Mail Settings
|--------------------------------------------------------------------------
|
| If you are using Markdown based email rendering, you may configure your
| theme and component paths here, allowing you to customize the design
| of the emails. Or, you may simply stick with the Laravel defaults!
|
*/
'markdown' => [
'theme' => 'default',
'paths' => [
resource_path('views/vendor/mail'),
],
],
];

71
config/projects.php Normal file
View file

@ -0,0 +1,71 @@
<?php
return [
[
'name' => "Websites",
'projects' => [
[
'name' => "diskfloppy.me",
'description' => "The website you're looking at right now!",
'url' => "https://github.com/floppydisk05/diskfloppy.me",
'languages' => ["PHP", "CSS"]
],
[
'name' => "NetDrivers",
'description' => "Driver downloads website.",
'url' => "https://github.com/floppydisk05/NetDrivers",
'languages' => ["Ruby", "CSS"]
]
]
],
[
'name' => "APIs",
'projects' => [
[
'name' => "trivia-api",
'description' => "API to serve random trivia questions.",
'url' => "https://github.com/floppydisk05/trivia-api",
'languages' => ["JavaScript"]
]
]
],
[
'name' => "Discord Bots",
'projects' => [
[
'name' => "PlexBot",
'description' => "A basic bot to play music from the configured Plex server in a Discord voice channel.",
'url' => "https://github.com/floppydisk05/PlexBot",
'languages' => ["Python"]
]
]
],
[
'name' => "Abandoned Projects",
'projects' => [
[
'name' => "website-cf",
'description' => "Rewrite of my personal website in Adobe ColdFusion.",
'url' => "https://github.com/floppydisk05/website-cf",
'languages' => ["Adobe ColdFusion"]
],
[
'name' => "WinBotJDA",
'description' => "Rewrite of CamK06's WinBot using Java and DiscordJDA.",
'url' => "https://github.com/floppydisk05/WinBotJDA",
'languages' => ["Java"]
],
[
'name' => "delayed-eject",
'description' => "Scripts which eject the cd drive a lot to annoy nick.",
'url' => "https://github.com/floppydisk05/delayed-eject",
'languages' => ["Shell", "C"]
],
[
'name' => "php-sound",
'description' => "Plays a specified sound file or files on the web server when a php page is loaded.",
'url' => "https://github.com/floppydisk05/php-sound",
'languages' => ["PHP", "Shell"]
]
]
]
];

109
config/queue.php Normal file
View file

@ -0,0 +1,109 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Default Queue Connection Name
|--------------------------------------------------------------------------
|
| Laravel's queue API supports an assortment of back-ends via a single
| API, giving you convenient access to each back-end using the same
| syntax for every one. Here you may define a default connection.
|
*/
'default' => env('QUEUE_CONNECTION', 'sync'),
/*
|--------------------------------------------------------------------------
| Queue Connections
|--------------------------------------------------------------------------
|
| Here you may configure the connection information for each server that
| is used by your application. A default configuration has been added
| for each back-end shipped with Laravel. You are free to add more.
|
| Drivers: "sync", "database", "beanstalkd", "sqs", "redis", "null"
|
*/
'connections' => [
'sync' => [
'driver' => 'sync',
],
'database' => [
'driver' => 'database',
'table' => 'jobs',
'queue' => 'default',
'retry_after' => 90,
'after_commit' => false,
],
'beanstalkd' => [
'driver' => 'beanstalkd',
'host' => 'localhost',
'queue' => 'default',
'retry_after' => 90,
'block_for' => 0,
'after_commit' => false,
],
'sqs' => [
'driver' => 'sqs',
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'),
'queue' => env('SQS_QUEUE', 'default'),
'suffix' => env('SQS_SUFFIX'),
'region' => env('AWS_DEFAULT_REGION', 'us-east-1'),
'after_commit' => false,
],
'redis' => [
'driver' => 'redis',
'connection' => 'default',
'queue' => env('REDIS_QUEUE', 'default'),
'retry_after' => 90,
'block_for' => null,
'after_commit' => false,
],
],
/*
|--------------------------------------------------------------------------
| Job Batching
|--------------------------------------------------------------------------
|
| The following options configure the database and table that store job
| batching information. These options can be updated to any database
| connection and table which has been defined by your application.
|
*/
'batching' => [
'database' => env('DB_CONNECTION', 'mysql'),
'table' => 'job_batches',
],
/*
|--------------------------------------------------------------------------
| Failed Queue Jobs
|--------------------------------------------------------------------------
|
| These options configure the behavior of failed queue job logging so you
| can control which database and table are used to store the jobs that
| have failed. You may change them to any database / table you wish.
|
*/
'failed' => [
'driver' => env('QUEUE_FAILED_DRIVER', 'database-uuids'),
'database' => env('DB_CONNECTION', 'mysql'),
'table' => 'failed_jobs',
],
];

957
config/quotes.php Normal file
View file

@ -0,0 +1,957 @@
<?php
return [
"toh" => [
[
"lines" => [
[
"character" => "EDA",
"line" => "Ahh sure. Spare us."
],
[
"character" => "LILITH",
"line" => "Woe to us whose fates are sealed."
]
],
"attribution" => "The Owl House, S1E11"
],
[
"lines" => [
[
"character" => "EDA",
"line" => "Hey freeloaders! Guess what today is!"
]
],
"attribution" => "The Owl House, S1E12"
],
[
"lines" => [
[
"character" => "EDA",
"line" => "Quitting! It's like trying, but easier!"
]
],
"attribution" => "The Owl House, S1E13"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Can it, Fangs! You don't know diddly-dang about squiddly-squat!"
]
],
"attribution" => "The Owl House, S1E13"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Holy bones, you poofed it! Call the cops, this guy's crazy!"
]
],
"attribution" => "The Owl House, S1E14"
],
[
"lines" => [
[
"character" => "EDA",
"line" => "There is one way, but it's terribly dangerous and partially illegal."
]
],
"attribution" => "The Owl House, S1E15"
],
[
"lines" => [
[
"character" => "GUS CLONE",
"line" => "I'd rather die than expose my secrets!"
],
[
"character" => "GUS",
"line" => "Then die, you shall!"
]
],
"attribution" => "The Owl House, S1E15"
],
[
"lines" => [
[
"character" => "LUZ",
"line" => "Vee, you're giving up too quick!"
],
[
"character" => "VEE",
"line" => "I'm being realistic."
]
],
"attribution" => "The Owl House, S2E10"
],
[
"lines" => [
[
"character" => "LUZ",
"line" => "I have questions about that name..."
],
[
"character" => "LILITH",
"line" => "And I have questions about my life!"
]
],
"attribution" => "The Owl House, S2E12"
],
[
"lines" => [
[
"character" => "EMIRA",
"line" => "We can shout as loud as we want, but money always shouts louder."
]
],
"attribution" => "The Owl House, S2E20"
],
[
"lines" => [
[
"character" => "VEE",
"line" => "Uhh, no, I'm new in town, I just have one of those faces! But, ju-just one, the normal amount of face."
]
],
"attribution" => "The Owl House, S3E01"
],
[
"lines" => [
[
"character" => "RAINE",
"line" => "You Know I Hate These Things. Talking To People. Waving To People. People."
]
],
"attribution" => "The Owl House, S2E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Who dares intrude upon I, the King of Demons?!"
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Soon, Mr. Ducky, we shall drink the fear of those who mocked us."
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Try to catch me when Im covered in grease! I'm a squirmy little fella."
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "My crown! Yes, yes! I can feel my powers returning! You, there. Nightmare critter. I shall call you Francois, and you shall be a minion in my army of darkness. Haha!"
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Weh?"
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "That was actually one of her better breakups!"
]
],
"attribution" => "The Owl House, S1E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I AM NOT YOUR CUTIE-PIE!!!"
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Ha! Good luck. The Boiling Isles is nothing but a cesspool of despair."
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "You should run a small business of more scones into my mouth."
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Finally, all that mean-spirited laughter made me sleepy."
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Less talky, more nappy."
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Can't mistake her smell. Like lemons and young, naïve confidence."
]
],
"attribution" => "The Owl House, S1E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I have no son! Eat salt!"
]
],
"attribution" => "The Owl House, S1E3"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Even demons have inner demons."
]
],
"attribution" => "The Owl House, S1E4"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Look, now we're boo-boo buddies!"
]
],
"attribution" => "The Owl House, S1E4"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Bap!"
]
],
"attribution" => "The Owl House, S1E4"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Remember when her head got cut off last week? That woman can survive anything. She's probably just tired from staying up all night chasing shrews and voles."
]
],
"attribution" => "The Owl House, S1E4"
],
[
"lines" => [
[
"character" => "KING",
"line" => "That voice. That horrific voice!!!"
]
],
"attribution" => "The Owl House, S1E4"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Show me the picture! Hah! I can draw better than that. You know, they once called me the King of Artists."
]
],
"attribution" => "The Owl House, S1E5"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Are you bestowing gifts upon me? Yes! I accept your offering! The King of Demons is back!"
]
],
"attribution" => "The Owl House, S1E5"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Cupcakes in my tummy-tum makes the King say yummy-yum!"
]
],
"attribution" => "The Owl House, S1E5"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Mmm? Oh, yeah. No."
]
],
"attribution" => "The Owl House, S1E5"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I'm stealing everything that's not nailed down!"
]
],
"attribution" => "The Owl House, S1E6"
],
[
"lines" => [
[
"character" => "KING",
"line" => "King? Who's King? I go by Little Bone Boy now."
]
],
"attribution" => "The Owl House, S1E6"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Rivals are meant to be annihilated not befriended. Now keep reading. I've been sucked into your awful fandom."
]
],
"attribution" => "The Owl House, S1E7"
],
[
"lines" => [
[
"character" => "KING",
"line" => "What does Luz know about problems anyway? All she has is dumb teen drama! She doesn't understand how hard some of us have it."
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Well, I don't know if you realized, but I'm not a baby!"
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "My life is a living nightmare!"
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Fight to the death!"
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I've got some... very confusing emotions right now."
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "All right, you acneencrusted hormone buckets. Let's go let out some teen angst!"
]
],
"attribution" => "The Owl House, S1E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Ooh! Fight, fight, fight!"
]
],
"attribution" => "The Owl House, S1E9"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Yes! Yes! This is a throne worthy of a tyrant. Bow to me you snotty underlings. Bow!"
]
],
"attribution" => "The Owl House, S1E10"
],
[
"lines" => [
[
"character" => "KING",
"line" => "*Rage squeals*"
]
],
"attribution" => "The Owl House, S1E10"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Hey you scum! Which one of you wants to read my literary masterpiece? Anyone brave enough?"
]
],
"attribution" => "The Owl House, S1E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I've always wanted a people chair! I'm in! This will be my first step in my reclamation of power!"
]
],
"attribution" => "The Owl House, S1E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I'm sorry, my lawyer advised me not to look at unsolicited work."
]
],
"attribution" => "The Owl House, S1E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "What's a book? Good night!"
]
],
"attribution" => "The Owl House, S1E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Hey! Less ready, more scratchy!"
]
],
"attribution" => "The Owl House, S1E12"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Military discipline, cooking! Ha, I truly am a demon for all seasons! Just a dash of Eda's secret sauce and I'm the creator of life!"
]
],
"attribution" => "The Owl House, S1E12"
],
[
"lines" => [
[
"character" => "KING",
"line" => "This day shall live in infamy."
]
],
"attribution" => "The Owl House, S1E12"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Obedience? Well, what is a teacher if not an authority figure? A king of children, if you will. Yes! I am your teacher! You may call me Mr. King!"
]
],
"attribution" => "The Owl House, S1E13"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Assume a coefficient of ten, carry the two, solve for Y, and that is the way to steal a pie from a windowsill! Also you can eat trash."
]
],
"attribution" => "The Owl House, S1E13"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Alright. Read chapters three to five on the right way to scratch yourself in public. Spoiler alert: There's no wrong way! Ah, days like these make being a teacher all worth it."
]
],
"attribution" => "The Owl House, S1E13"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Oh dear, I've gotten a tube stuck on my nose! Will I ever eat again? Looks like I'm toast!"
]
],
"attribution" => "The Owl House, S1E14"
],
[
"lines" => [
[
"character" => "KING",
"line" => "The King of Demons misses nobody! I wouldn't care if she came through this door right now!"
]
],
"attribution" => "The Owl House, S1E14"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Beat up the man and steal his things for me!"
]
],
"attribution" => "The Owl House, S1E14"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I'm gonna bake that kid into a pie!"
]
],
"attribution" => "The Owl House, S1E15"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Senseless violence. Yes, attack! DEATH IS YOUR GOD!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I FORGE MY OWN PATH!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Why am I doing this? I don't even wear clothes!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Ha! What possible regrets could come from the internet? Oh, did you know the earth is actually flat!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "We're going to turn this blood-bath into a fun-bath!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Girl, you can pull off anything! Up top! We're style geniuses!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Now I am king and queen! Best of both things!"
]
],
"attribution" => "The Owl House, S1E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Yes! Now Ill strike fear into my enemies with this armor of intimidation."
]
],
"attribution" => "The Owl House, S1E17"
],
[
"lines" => [
[
"character" => "KING",
"line" => "You know what, when she first got here, I thought we were gonna eat her. But now I only think of that, like, sometimes."
]
],
"attribution" => "The Owl House, S1E18"
],
[
"lines" => [
[
"character" => "KING",
"line" => "The cake is me!"
]
],
"attribution" => "The Owl House, S1E18"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Me and Eda don't always see eye to eye, but I do consider her family. I want her back as much as you do."
]
],
"attribution" => "The Owl House, S1E19"
],
[
"lines" => [
[
"character" => "KING",
"line" => "We'll have to do something so diabolical, so criminally insane, that they'll have to send us to the Conformatorium."
]
],
"attribution" => "The Owl House, S1E19"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I'm never letting you go! You're never returning to the human realm!"
]
],
"attribution" => "The Owl House, S2E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "King want a cracker!"
]
],
"attribution" => "The Owl House, S2E1"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Weh? Yeah yeah, I'll deal with it. No one ever said power came with responsibility..."
]
],
"attribution" => "The Owl
House, S2E2"
],
[
"lines" => [
[
"character" => "KING",
"line" => "The King of Demons yields to no one!"
]
],
"attribution" => "The Owl House, S2E3"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Ah, the chamber where I would devour the hearts of my foes. The taste was cold and bitter, but I bet yours would be sweet, Luz."
]
],
"attribution" => "The Owl House, S2E3"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Is that a six-footed pig or a floating appendage? Why, no! It's Gus the Illusion Master. Please leave a message."
]
],
"attribution" => "The Owl House, S2E5"
],
[
"lines" => [
[
"character" => "KING",
"line" => "And weh, and weh, and weh, and weh, and weh, and weh, and weh, and weh!"
]
],
"attribution" => "The Owl House, S2E7"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Haha! Saint Epiderm? More like Stank Epiderm!"
]
],
"attribution" => "The Owl House, S2E7"
],
[
"lines" => [
[
"character" => "KING",
"line" => "DID YOU OWL PELLET ME?!"
]
],
"attribution" => "The Owl House, S2E8"
],
[
"lines" => [
[
"character" => "KING",
"line" => "You look like one of my hairballs. Let's just do the trench coat thing!"
]
],
"attribution" => "The Owl House, S2E9"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Guess minecart chases are a lot more dangerous than video games make'em seem."
]
],
"attribution" => "The Owl House, S2E9"
],
[
"lines" => [
[
"character" => "KING",
"line" => "I can't wait to eat HUMAN snacks!"
]
],
"attribution" => "The Owl House, S2E10"
],
[
"lines" => [
[
"character" => "KING",
"line" => "It was the... yeast I could do."
]
],
"attribution" => "The Owl House, S2E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "With my love of mayhem and Hootys desperate need for attention, thisll be a cake walk!"
]
],
"attribution" => "The Owl House, S2E11"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Hey, Eda, look! \"Dear sister, join the Emperor's Coven and together, we can become gods!\""
]
],
"attribution" => "The Owl House, S2E12"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Ooh! That'll work great when birds try to fly away with me."
]
],
"attribution" => "The Owl House, S2E14"
],
[
"lines" => [
[
"character" => "KING",
"line" => "What you need is a healthy distractions from your problems. Like breakfast!"
]
],
"attribution" => "The Owl House, S2E14"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Is this thing on? Demon King to Luzura, you copy?"
]
],
"attribution" => "The Owl House, S2E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "Uh, oh. Uh... Hable más lento, por favor."
]
],
"attribution" => "The Owl House, S2E16"
],
[
"lines" => [
[
"character" => "KING",
"line" => "The Collector is just a little kid. A scary, powerful one, but… also… sad, and alone. I dont know, this whole time, I was scared of making him mad, but… I think I can relate to him."
]
],
"attribution" => "The Owl House, S3E1"
]
],
"neversaid" => [
[
"name" => "ASM",
"quote" => "The Director liked all the props we got today."
],
[
"name" => "PM",
"quote" => "Ah ha, a revolve. Terrific."
],
[
"name" => "Chippie",
"quote" => "I don't know, let's look at the ground plan."
],
[
"name" => "Set Designer",
"quote" => "Well, let's just have whatever is cheaper."
],
[
"name" => "Sound",
"quote" => "Better turn that down a bit. We don't want to deafen them."
],
[
"name" => "Director",
"quote" => "Sorry, my mistake."
],
[
"name" => "Electrics",
"quote" => "This equipment is more complicated than we need."
],
[
"name" => "Performer",
"quote" => "I really think my big scene should be cut."
],
[
"name" => "SM",
"quote" => "Can we do that scene change again please?"
],
[
"name" => "LX designer",
"quote" => "Bit more light from those big chaps at the side. Yes that's right, the ones on stalks whatever they are called."
],
[
"name" => "Electrics",
"quote" => "All the equipment works perfectly."
],
[
"name" => "Musicians",
"quote" => "So what if that's the end of a call. Let's just finish this bit off."
],
[
"name" => "Wardrobe",
"quote" => "Now, when exactly is the first dress rehearsal?"
],
[
"name" => "Workshop",
"quote" => "I don't want anyone to know, but if you insist then yes, I admit it, I have just done an all-nighter."
],
[
"name" => "Performer",
"quote" => "This costume is so comfortable."
],
[
"name" => "Admin",
"quote" => "The level of overtime payments here are simply unacceptable. Our backstage staff deserve better."
],
[
"name" => "Box Office",
"quote" => "Comps? No problem."
],
[
"name" => "Set Designer",
"quote" => "You're right, it looks dreadful."
],
[
"name" => "Flyman",
"quote" => "No, my lips are sealed. What I may or may not have seen remains a secret."
],
[
"name" => "Electrics",
"quote" => "That had nothing to do with the computer, it was my fault."
],
[
"name" => "Crew",
"quote" => "No, no, I'm sure that's our job."
],
[
"name" => "SMgt",
"quote" => "Thanks, but I don't drink."
],
[
"name" => "Performer",
"quote" => "Let me stand down here with my back to the audience."
],
[
"name" => "Chippie",
"quote" => "I can't really manage those big fast power tools myself."
],
[
"name" => "Chippie",
"quote" => "I prefer to use these little hand drills."
],
[
"name" => "All",
"quote" => "Let's go and ask the Production Manager. He'll know."
]
]
];

108
config/sentry.php Normal file
View file

@ -0,0 +1,108 @@
<?php
/**
* Sentry Laravel SDK configuration file.
*
* @see https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/
*/
return [
// @see https://docs.sentry.io/product/sentry-basics/dsn-explainer/
'dsn' => env('SENTRY_LARAVEL_DSN', env('SENTRY_DSN')),
// The release version of your application
// Example with dynamic git hash: trim(exec('git --git-dir ' . base_path('.git') . ' log --pretty="%h" -n1 HEAD'))
'release' => env('SENTRY_RELEASE'),
// When left empty or `null` the Laravel environment will be used (usually discovered from `APP_ENV` in your `.env`)
'environment' => env('SENTRY_ENVIRONMENT'),
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#sample-rate
'sample_rate' => env('SENTRY_SAMPLE_RATE') === null ? 1.0 : (float)env('SENTRY_SAMPLE_RATE'),
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#traces-sample-rate
'traces_sample_rate' => env('SENTRY_TRACES_SAMPLE_RATE') === null ? null : (float)env('SENTRY_TRACES_SAMPLE_RATE'),
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#profiles-sample-rate
'profiles_sample_rate' => env('SENTRY_PROFILES_SAMPLE_RATE') === null ? null : (float)env('SENTRY_PROFILES_SAMPLE_RATE'),
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#send-default-pii
'send_default_pii' => env('SENTRY_SEND_DEFAULT_PII', false),
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#ignore-exceptions
// 'ignore_exceptions' => [],
// @see: https://docs.sentry.io/platforms/php/guides/laravel/configuration/options/#ignore-transactions
// 'ignore_transactions' => [],
// Breadcrumb specific configuration
'breadcrumbs' => [
// Capture Laravel logs as breadcrumbs
'logs' => env('SENTRY_BREADCRUMBS_LOGS_ENABLED', true),
// Capture Laravel cache events (hits, writes etc.) as breadcrumbs
'cache' => env('SENTRY_BREADCRUMBS_CACHE_ENABLED', true),
// Capture Livewire components like routes as breadcrumbs
'livewire' => env('SENTRY_BREADCRUMBS_LIVEWIRE_ENABLED', true),
// Capture SQL queries as breadcrumbs
'sql_queries' => env('SENTRY_BREADCRUMBS_SQL_QUERIES_ENABLED', true),
// Capture SQL query bindings (parameters) in SQL query breadcrumbs
'sql_bindings' => env('SENTRY_BREADCRUMBS_SQL_BINDINGS_ENABLED', false),
// Capture queue job information as breadcrumbs
'queue_info' => env('SENTRY_BREADCRUMBS_QUEUE_INFO_ENABLED', true),
// Capture command information as breadcrumbs
'command_info' => env('SENTRY_BREADCRUMBS_COMMAND_JOBS_ENABLED', true),
// Capture HTTP client request information as breadcrumbs
'http_client_requests' => env('SENTRY_BREADCRUMBS_HTTP_CLIENT_REQUESTS_ENABLED', true),
],
// Performance monitoring specific configuration
'tracing' => [
// Trace queue jobs as their own transactions (this enables tracing for queue jobs)
'queue_job_transactions' => env('SENTRY_TRACE_QUEUE_ENABLED', false),
// Capture queue jobs as spans when executed on the sync driver
'queue_jobs' => env('SENTRY_TRACE_QUEUE_JOBS_ENABLED', true),
// Capture SQL queries as spans
'sql_queries' => env('SENTRY_TRACE_SQL_QUERIES_ENABLED', true),
// Capture SQL query bindings (parameters) in SQL query spans
'sql_bindings' => env('SENTRY_TRACE_SQL_BINDINGS_ENABLED', false),
// Capture where the SQL query originated from on the SQL query spans
'sql_origin' => env('SENTRY_TRACE_SQL_ORIGIN_ENABLED', true),
// Capture views rendered as spans
'views' => env('SENTRY_TRACE_VIEWS_ENABLED', true),
// Capture Livewire components as spans
'livewire' => env('SENTRY_TRACE_LIVEWIRE_ENABLED', true),
// Capture HTTP client requests as spans
'http_client_requests' => env('SENTRY_TRACE_HTTP_CLIENT_REQUESTS_ENABLED', true),
// Capture Redis operations as spans (this enables Redis events in Laravel)
'redis_commands' => env('SENTRY_TRACE_REDIS_COMMANDS', false),
// Capture where the Redis command originated from on the Redis command spans
'redis_origin' => env('SENTRY_TRACE_REDIS_ORIGIN_ENABLED', true),
// Enable tracing for requests without a matching route (404's)
'missing_routes' => env('SENTRY_TRACE_MISSING_ROUTES_ENABLED', false),
// Configures if the performance trace should continue after the response has been sent to the user until the application terminates
// This is required to capture any spans that are created after the response has been sent like queue jobs dispatched using `dispatch(...)->afterResponse()` for example
'continue_after_response' => env('SENTRY_TRACE_CONTINUE_AFTER_RESPONSE', true),
// Enable the tracing integrations supplied by Sentry (recommended)
'default_integrations' => env('SENTRY_TRACE_DEFAULT_INTEGRATIONS_ENABLED', true),
],
];

25
config/services.php Normal file
View file

@ -0,0 +1,25 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| Third Party Services
|--------------------------------------------------------------------------
|
| This file is for storing the credentials for third party services such
| as Mailgun, Postmark, AWS and more. This file provides the de facto
| location for this type of information, allowing packages to have
| a conventional file to locate the various service credentials.
|
*/
'lastfm' => [
'key' => env('LASTFM_KEY'),
'user' => env('LASTFM_USER'),
],
'lanyard' => [
'user_id' => env('DISCORD_USER_ID'),
],
'weatherlink' => env('WEATHERLINK_IP')
];

201
config/session.php Normal file
View file

@ -0,0 +1,201 @@
<?php
use Illuminate\Support\Str;
return [
/*
|--------------------------------------------------------------------------
| Default Session Driver
|--------------------------------------------------------------------------
|
| This option controls the default session "driver" that will be used on
| requests. By default, we will use the lightweight native driver but
| you may specify any of the other wonderful drivers provided here.
|
| Supported: "file", "cookie", "database", "apc",
| "memcached", "redis", "dynamodb", "array"
|
*/
'driver' => env('SESSION_DRIVER', 'file'),
/*
|--------------------------------------------------------------------------
| Session Lifetime
|--------------------------------------------------------------------------
|
| Here you may specify the number of minutes that you wish the session
| to be allowed to remain idle before it expires. If you want them
| to immediately expire on the browser closing, set that option.
|
*/
'lifetime' => env('SESSION_LIFETIME', 120),
'expire_on_close' => false,
/*
|--------------------------------------------------------------------------
| Session Encryption
|--------------------------------------------------------------------------
|
| This option allows you to easily specify that all of your session data
| should be encrypted before it is stored. All encryption will be run
| automatically by Laravel and you can use the Session like normal.
|
*/
'encrypt' => false,
/*
|--------------------------------------------------------------------------
| Session File Location
|--------------------------------------------------------------------------
|
| When using the native session driver, we need a location where session
| files may be stored. A default has been set for you but a different
| location may be specified. This is only needed for file sessions.
|
*/
'files' => storage_path('framework/sessions'),
/*
|--------------------------------------------------------------------------
| Session Database Connection
|--------------------------------------------------------------------------
|
| When using the "database" or "redis" session drivers, you may specify a
| connection that should be used to manage these sessions. This should
| correspond to a connection in your database configuration options.
|
*/
'connection' => env('SESSION_CONNECTION'),
/*
|--------------------------------------------------------------------------
| Session Database Table
|--------------------------------------------------------------------------
|
| When using the "database" session driver, you may specify the table we
| should use to manage the sessions. Of course, a sensible default is
| provided for you; however, you are free to change this as needed.
|
*/
'table' => 'sessions',
/*
|--------------------------------------------------------------------------
| Session Cache Store
|--------------------------------------------------------------------------
|
| While using one of the framework's cache driven session backends you may
| list a cache store that should be used for these sessions. This value
| must match with one of the application's configured cache "stores".
|
| Affects: "apc", "dynamodb", "memcached", "redis"
|
*/
'store' => env('SESSION_STORE'),
/*
|--------------------------------------------------------------------------
| Session Sweeping Lottery
|--------------------------------------------------------------------------
|
| Some session drivers must manually sweep their storage location to get
| rid of old sessions from storage. Here are the chances that it will
| happen on a given request. By default, the odds are 2 out of 100.
|
*/
'lottery' => [2, 100],
/*
|--------------------------------------------------------------------------
| Session Cookie Name
|--------------------------------------------------------------------------
|
| Here you may change the name of the cookie used to identify a session
| instance by ID. The name specified here will get used every time a
| new session cookie is created by the framework for every driver.
|
*/
'cookie' => env(
'SESSION_COOKIE',
Str::slug(env('APP_NAME', 'laravel'), '_').'_session'
),
/*
|--------------------------------------------------------------------------
| Session Cookie Path
|--------------------------------------------------------------------------
|
| The session cookie path determines the path for which the cookie will
| be regarded as available. Typically, this will be the root path of
| your application but you are free to change this when necessary.
|
*/
'path' => '/',
/*
|--------------------------------------------------------------------------
| Session Cookie Domain
|--------------------------------------------------------------------------
|
| Here you may change the domain of the cookie used to identify a session
| in your application. This will determine which domains the cookie is
| available to in your application. A sensible default has been set.
|
*/
'domain' => env('SESSION_DOMAIN'),
/*
|--------------------------------------------------------------------------
| HTTPS Only Cookies
|--------------------------------------------------------------------------
|
| By setting this option to true, session cookies will only be sent back
| to the server if the browser has a HTTPS connection. This will keep
| the cookie from being sent to you when it can't be done securely.
|
*/
'secure' => env('SESSION_SECURE_COOKIE'),
/*
|--------------------------------------------------------------------------
| HTTP Access Only
|--------------------------------------------------------------------------
|
| Setting this value to true will prevent JavaScript from accessing the
| value of the cookie and the cookie will only be accessible through
| the HTTP protocol. You are free to modify this option if needed.
|
*/
'http_only' => true,
/*
|--------------------------------------------------------------------------
| Same-Site Cookies
|--------------------------------------------------------------------------
|
| This option determines how your cookies behave when cross-site requests
| take place, and can be used to mitigate CSRF attacks. By default, we
| will set this value to "lax" since this is a secure default value.
|
| Supported: "lax", "strict", "none", null
|
*/
'same_site' => 'lax',
];

36
config/view.php Normal file
View file

@ -0,0 +1,36 @@
<?php
return [
/*
|--------------------------------------------------------------------------
| View Storage Paths
|--------------------------------------------------------------------------
|
| Most templating systems load templates from disk. Here you may specify
| an array of paths that should be checked for your views. Of course
| the usual Laravel view path has already been registered for you.
|
*/
'paths' => [
resource_path('views'),
],
/*
|--------------------------------------------------------------------------
| Compiled View Path
|--------------------------------------------------------------------------
|
| This option determines where all the compiled Blade templates will be
| stored for your application. Typically, this is within the storage
| directory. However, as usual, you are free to change this value.
|
*/
'compiled' => env(
'VIEW_COMPILED_PATH',
realpath(storage_path('framework/views'))
),
];

1
database/.gitignore vendored Normal file
View file

@ -0,0 +1 @@
*.sqlite*

View file

@ -0,0 +1,23 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\BookmarkCategory>
*/
class BookmarkCategoryFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'name' => $this->faker->word,
];
}
}

View file

@ -0,0 +1,27 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
use App\Models\BookmarkCategory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\BookmarkSite>
*/
class BookmarkSiteFactory extends Factory
{
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'name' => $this->faker->name,
'description' => $this->faker->sentence,
'url' => $this->faker->url,
'category' => BookmarkCategory::factory(),
];
}
}

View file

@ -0,0 +1,29 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('bookmark__categories', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->unsignedBigInteger('priority')->nullable();
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('bookmark__categories');
}
};

View file

@ -0,0 +1,35 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('bookmark__sites', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->text('description')->nullable();
$table->string('url');
$table->unsignedBigInteger('category');
$table->foreign('category')
->references('id')
->on('bookmark__categories')
->onDelete('cascade');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('bookmarks');
}
};

View file

@ -0,0 +1,32 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('guestbook__entries', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->string('ip');
$table->string('agent');
$table->longText('message');
$table->boolean('admin');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('guestbook__entries');
}
};

View file

@ -0,0 +1,30 @@
<?php
namespace Database\Seeders;
use App\Models\BookmarkCategory;
use App\Models\BookmarkSite;
use Illuminate\Database\Seeder;
class BookmarkCategoriesTableSeeder extends Seeder
{
/**
* Run the database seeds.
*/
public function run(): void {
// BookmarkCategory::factory()->count(5)->create()->each(function ($category) {
// $category->sites()->saveMany(BookmarkSite::factory()->count(3)->make());
// });
$category = new BookmarkCategory([
'name' => 'cool people',
]);
$category->save();
$site = new BookmarkSite([
'name' => 'campos',
'description' => 'Cool brazilian dude, does programming and stuff',
'url' => 'https://campos02.me/',
'category' => 1,
]);
$site->save();
}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 720 B

View file

@ -1,91 +0,0 @@
<?php $db = new PDO("sqlite:/mnt/data1/webdata/floppydisk/guestbook.db"); ?>
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Guestbook</title>
<!--<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">-->
<meta property="og:title" content="Guestbook">
<meta property="og:description" content="h">
<!--<meta property="og:image" content="/res/img/icons/png/computer.png">-->
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
<br>
<form action="submit.php" method="post">
<fieldset>
<legend>Add Entry</legend>
<table class="form">
<tr>
<td class="form"><label for="name">Name: </label></td>
<td class="form"><input type="text" name="name"></td>
</tr>
<tr>
<td class="form"><label for="message">Message: </label></td>
<td class="form"><textarea name="message"></textarea></td>
</tr>
<tr>
<td class="form"><label for="showip">Show IP: </label></td>
<td class="form"><input type="checkbox" name="showip" value="yes"></td>
</tr>
<tr>
<td class="form"><label for="showinfo">Show info: </label></td>
<td class="form"><input type="checkbox" name="showinfo" value="yes" checked></td>
</tr>
<tr>
<td class="form" colspan="2"><input type="submit"></td>
</tr>
</table>
</fieldset>
</form>
<?php
// Pain
$count_query = $db->prepare('SELECT COUNT(*) FROM Entries');
$count_query->execute();
$count = $count_query->fetch()[0];
echo '<h1>Entries <small>(' . $count . ' total)</small></h1>';
// Prepare SELECT statement.
$select = "SELECT name, message, show_info, show_ip, ip, submitted, browser_info FROM Entries ORDER BY id DESC";
$stmt = $db->prepare($select);
// Execute statement.
$stmt->execute(); // ID between 1 and 3.
// Get the results.
$results = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach($results as $row) {
echo '<table border="1" width="500"><tr><td><pre>';
$submittedRaw = $row['submitted'];
$submittedDT = new DateTime("@$submittedRaw");
$submitted = $submittedDT->format('H:i:s - Y-m-d');
$browser = get_browser(null, true);
$sys = $browser['parent'] . ' (' . $browser['platform_description'] . ' ' . $browser['platform_version'] . ')';
echo 'Name: ' . $row['name'] . PHP_EOL;
if ($row['show_ip']) echo 'IP: ' . $row['ip'] . PHP_EOL;
if ($row['show_info']) echo 'Sys: ' . $row['browser_info'] . PHP_EOL;
echo 'Date: ' . $submitted . PHP_EOL . PHP_EOL;
echo $row['message'];
echo '</pre></td></tr></table><br>';
}
?>
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

View file

@ -1,57 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Guestbook</title>
<!--<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">-->
<!--<meta property="og:image" content="/res/img/icons/png/computer.png">-->
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
<?php
$name = strip_tags($_POST["name"]);
$msg = strip_tags($_POST["message"]);
if ($msg === "" || $name === "" || strip_tags(htmlspecialchars_decode($msg)) === "") {
echo '<b>You must provide both a name and message!</b>';
} else {
$db = new PDO("sqlite:/mnt/data1/webdata/floppydisk/guestbook.db");
$showinfo = isset($_POST["showinfo"]) ? true : false;
$showip = isset($_POST["showip"]) ? true : false;
$ip = $_SERVER['REMOTE_ADDR'];
$browser = get_browser(null, true);
$sys = $browser['parent'] . ' (' . $browser['platform_description'] . ' ' . $browser['platform_version'] . ')';
$data = array('name' => $name, 'message' => $msg, 'show_info' => $showinfo, 'show_ip' => $showip, 'ip' => $ip, 'submitted' => time(), 'sys' => $sys);
$insert = "INSERT INTO Entries (name, message, show_info, show_ip, ip, submitted, browser_info) VALUES (:name, :message, :show_info, :show_ip, :ip, :submitted, :browser)";
$stmt = $db->prepare($insert);
$stmt->bindParam(':name', $data['name'], PDO::PARAM_STR);
$stmt->bindParam(':message', $data['message'], PDO::PARAM_STR);
$stmt->bindParam(':show_info', $data['show_info'], PDO::PARAM_STR);
$stmt->bindParam(':show_ip', $data['show_ip'], PDO::PARAM_STR);
$stmt->bindParam(':ip', $data['ip'], PDO::PARAM_STR);
$stmt->bindParam(':submitted', $data['submitted'], PDO::PARAM_STR);
$stmt->bindParam(':browser', $data['sys'], PDO::PARAM_STR);
$stmt->execute();
echo '<b>Success!</b>';
}
?><br><br>
<a href="./">Back</a>
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('../inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

View file

@ -1,2 +0,0 @@
#!/bin/sh
GIT_WORK_TREE=/var/www/main git checkout -f master

View file

@ -1,5 +0,0 @@
<?php
// Create a constant array with config variables
const CONF = array(
"lastfm_key" => "key"
);

View file

@ -1,5 +0,0 @@
<hr>
<div style="text-align: center;">
<img src="/res/img/buttons/browser.gif" alt="Any Damn Browser">&nbsp;<a href="https://www.linux.org/"><img src="/res/img/buttons/linuxnow.gif" alt="Linux NOW!"></a>&nbsp;<a href="https://www.vim.org/"><img src="/res/img/buttons/vim.gif" alt="vim"></a>&nbsp;<a href="http://jigsaw.w3.org/css-validator/check/referer"><img style="border:0;width:88px;height:31px" src="/res/img/buttons/vcss-blue.gif" alt="Valid CSS!"></a>&nbsp;<a href=""><img style="border:0;width:88px;height:31px" src="/res/img/buttons/valid-html401-blue.png" alt="Valid HTML 4.01!"></a><br>
Last Modified <span class="date"><?=date('Y-m-d H:i:s', filemtime($file) + 3600);?> GMT</span>
</div>

View file

@ -1,6 +0,0 @@
<meta charset="utf-8">
<meta property="og:type" content="website">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="theme-color" content="#333333">
<link rel="stylesheet" id="theme" href="/res/css/dark.css" type="text/css">
<script defer data-domain="diskfloppy.me" src="https://analytics.nickandfloppy.com/js/plausible.js"></script>

View file

@ -1,65 +0,0 @@
<h1>Last.fm <small><a href="https://www.last.fm/user/floppydisk_">Profile</a></small></h1>
<?php
require('inc/config.inc.php');
$curl_current = curl_init();
curl_setopt_array($curl_current, [
CURLOPT_URL => "https://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&user=".CONF['lastfm_user']."&nowplaying=true&format=json&api_key=".CONF['lastfm_key'],
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "GET",
]);
$current_response = curl_exec($curl_current);
$err = curl_error($curl_current);
curl_close($curl_current);
if ($err) {
die("cURL Error #:" . $err);
}
$current_response = json_decode($current_response, true);
$nowplaying = $current_response['recenttracks']['track'][0];
echo ' <b>Last/Current Track:</b> <a href="'.$nowplaying['url'].'">'.$nowplaying['name'].' • '.$nowplaying['artist']['#text'].'</a>'.PHP_EOL;
$tracks_to_show = 10;
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => "https://ws.audioscrobbler.com/2.0/?method=user.gettoptracks&user=".CONF['lastfm_user']."&format=json&period=7day&api_key=".CONF['lastfm_key'],
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "GET",
]);
$toptracks_response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
die("cURL Error #:" . $err);
}
echo ' <h2>Top '.$tracks_to_show.' Tracks (Last 7 days)</h2>'.PHP_EOL;
echo ' <ol>'.PHP_EOL;
$toptracks_response = json_decode($toptracks_response, true);
$tracks = $toptracks_response['toptracks']['track'];
$count = 0;
foreach ($tracks as $track) {
echo ' <li>'.PHP_EOL;
echo ' <a href="'.$track['url'].'">'.$track['name'].' • '.$track['artist']['name'].'</a>'.PHP_EOL;
echo ' <small>('.$track['playcount'].' plays)</small>'.PHP_EOL;
echo ' </li>'.PHP_EOL;
if ($count >= $tracks_to_show - 1) break;
$count++;
}
echo ' </ol>';

View file

@ -1,39 +0,0 @@
<div class="header">
<nav>
<div>
<a href="/projects/">projects</a> |
<a href="https://github.com/floppydisk05?tab=repositories">repos</a> |
<a href="/calculators/">calculators</a> |
<a href="/computers/">computers</a> |
<a href="/bookmarks/">bookmarks</a> |
<a href="/guestbook/">guestbook</a>
</div>
</nav>
<div class="pagetree">
<span class="title">
<?php
$uri = $_SERVER['REQUEST_URI'];
if ($uri === '/') { echo '~floppydisk'; }
else {
$uri = substr(substr($uri, 1), 0, -1);
if (!strpos($uri, '/')) {
$uriArr = explode('/', $uri);
$link = "/";
$links = '<a href="/">~floppydisk</a> / ';
$currentDir = basename(getcwd());
foreach($uriArr as $page) {
if ($page !== $currentDir) {
if ($link !== '/') $link = $link . '/' . $page;
else $link = $link . $page;
$links = $links . '<a href="' . $link . '">' . $page . '</a> / ';
}
}
$links = substr($links, 0, -3) . ' / ' . $currentDir;
echo $links;
}
}
?>
</span>
</div> <!-- pagetree -->
</div> <!-- header -->

View file

@ -1,48 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('./inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>~floppydisk</title>
<meta property="og:title" content="~floppydisk">
<meta property="og:description" content="This is the personal homepage of floppydisk.">
<meta property="og:image" content="/favicon.png">
<style>td{padding:0px;}</style>
</head>
<body>
<div class="page">
<?php require('./inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
<!--<br><table class="banner"><tr><td class="banner"><b>Service Message:</b> This is more related to <a class="bannerlink" href="//www.nickandfloppy.com/">nickandfloppy.com</a> but our Gitea service is currently in the process of being migrated to a new VPS. Due to the lengthly migration process, <a class="bannerlink" href="//git.nickandfloppy.com/">git.nickandfloppy.com</a> may periodically be unavailable, though this isn't expected until the final transition.<br><br>~ nick and floppy</td></tr></table>-->
<p>Hi!</p>
<p>This is the personal homepage of floppydisk.
</p>
<?php require('./inc/lastfm.inc.php') ?>
<h1>Contact</h1>
<p><strong>Mail</strong>: <a href="mailto:contact@diskfloppy.me">contact@diskfloppy.me</a><br>
<strong>IRC</strong>: <a href="https://r-type.ca/page.php?id=1034">floppydisk @ r-type</a><br>
</p>
<h1>Elsewhere</h1>
<p><strong>Mastodon:</strong> <a rel="me" href="https://mastodon.sdf.org/@floppydisk_">@floppydisk_@mastodon.sdf.org</a><br>
<strong>Twitter:</strong> <a href="https://twitter.com/floppydisk__">@floppydisk__</a><br>
<strong>GitHub:</strong> <a href="https://github.com/floppydisk05">floppydisk05</a><br>
<strong>SDF:</strong> <a href="http://floppydisk.sdf.org/">~floppydisk</a>
</p>
</div> <!-- content -->
<div id="footer" class="pagefooter">
<?php $file = __FILE__;require('./inc/footer.inc.php'); ?>
</div> <!-- footer -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

View file

@ -1,25 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Global -->
<?php require('../inc/header.inc.php'); ?>
<!-- Page-specific -->
<title>Calculators</title>
<link rel="shortcut icon" href="../res/img/icons/ico/calc.ico" type="image/x-icon">
<meta property="og:title" content="Calculators">
<meta property="og:description" content="C a l c u l a t o r s">
<meta property="og:image" content="/res/img/icons/png/calc.png">
</head>
<body>
<div class="page">
<?php require('../inc/nav.inc.php') ?>
<div id="pagebody">
<div id="content">
</div> <!-- content -->
</div> <!-- pagebody -->
</div> <!-- page -->
</body>
</html>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 132 KiB

776
package-lock.json generated Normal file
View file

@ -0,0 +1,776 @@
{
"name": "diskfloppy.me",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"dependencies": {
"@sentry/browser": "^7.40.0"
},
"devDependencies": {
"axios": "^1.1.2",
"laravel-vite-plugin": "^0.7.5",
"vite": "^4.5.3"
}
},
"node_modules/@esbuild/android-arm": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.20.tgz",
"integrity": "sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw==",
"cpu": [
"arm"
],
"dev": true,
"optional": true,
"os": [
"android"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/android-arm64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz",
"integrity": "sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ==",
"cpu": [
"arm64"
],
"dev": true,
"optional": true,
"os": [
"android"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/android-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.20.tgz",
"integrity": "sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"android"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/darwin-arm64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz",
"integrity": "sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA==",
"cpu": [
"arm64"
],
"dev": true,
"optional": true,
"os": [
"darwin"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/darwin-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz",
"integrity": "sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"darwin"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/freebsd-arm64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz",
"integrity": "sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw==",
"cpu": [
"arm64"
],
"dev": true,
"optional": true,
"os": [
"freebsd"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/freebsd-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz",
"integrity": "sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"freebsd"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-arm": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz",
"integrity": "sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg==",
"cpu": [
"arm"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-arm64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz",
"integrity": "sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA==",
"cpu": [
"arm64"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-ia32": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz",
"integrity": "sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA==",
"cpu": [
"ia32"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-loong64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz",
"integrity": "sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg==",
"cpu": [
"loong64"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-mips64el": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz",
"integrity": "sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ==",
"cpu": [
"mips64el"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-ppc64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz",
"integrity": "sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA==",
"cpu": [
"ppc64"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-riscv64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz",
"integrity": "sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A==",
"cpu": [
"riscv64"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-s390x": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz",
"integrity": "sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ==",
"cpu": [
"s390x"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/linux-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz",
"integrity": "sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"linux"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/netbsd-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz",
"integrity": "sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"netbsd"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/openbsd-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz",
"integrity": "sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"openbsd"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/sunos-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz",
"integrity": "sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"sunos"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/win32-arm64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz",
"integrity": "sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg==",
"cpu": [
"arm64"
],
"dev": true,
"optional": true,
"os": [
"win32"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/win32-ia32": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz",
"integrity": "sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g==",
"cpu": [
"ia32"
],
"dev": true,
"optional": true,
"os": [
"win32"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@esbuild/win32-x64": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz",
"integrity": "sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ==",
"cpu": [
"x64"
],
"dev": true,
"optional": true,
"os": [
"win32"
],
"engines": {
"node": ">=12"
}
},
"node_modules/@sentry-internal/feedback": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry-internal/feedback/-/feedback-7.91.0.tgz",
"integrity": "sha512-SJKTSaz68F5YIwF79EttBm915M2LnacgZMYRnRumyTmMKnebGhYQLwWbZdpaDvOa1U18dgRajDX8Qed/8A3tXw==",
"dependencies": {
"@sentry/core": "7.91.0",
"@sentry/types": "7.91.0",
"@sentry/utils": "7.91.0"
},
"engines": {
"node": ">=12"
}
},
"node_modules/@sentry-internal/tracing": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry-internal/tracing/-/tracing-7.91.0.tgz",
"integrity": "sha512-JH5y6gs6BS0its7WF2DhySu7nkhPDfZcdpAXldxzIlJpqFkuwQKLU5nkYJpiIyZz1NHYYtW5aum2bV2oCOdDRA==",
"dependencies": {
"@sentry/core": "7.91.0",
"@sentry/types": "7.91.0",
"@sentry/utils": "7.91.0"
},
"engines": {
"node": ">=8"
}
},
"node_modules/@sentry/browser": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry/browser/-/browser-7.91.0.tgz",
"integrity": "sha512-lJv3x/xekzC/biiyAsVCioq2XnKNOZhI6jY3ZzLJZClYV8eKRi7D3KCsHRvMiCdGak1d/6sVp8F4NYY+YiWy1Q==",
"dependencies": {
"@sentry-internal/feedback": "7.91.0",
"@sentry-internal/tracing": "7.91.0",
"@sentry/core": "7.91.0",
"@sentry/replay": "7.91.0",
"@sentry/types": "7.91.0",
"@sentry/utils": "7.91.0"
},
"engines": {
"node": ">=8"
}
},
"node_modules/@sentry/core": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry/core/-/core-7.91.0.tgz",
"integrity": "sha512-tu+gYq4JrTdrR+YSh5IVHF0fJi/Pi9y0HZ5H9HnYy+UMcXIotxf6hIEaC6ZKGeLWkGXffz2gKpQLe/g6vy/lPA==",
"dependencies": {
"@sentry/types": "7.91.0",
"@sentry/utils": "7.91.0"
},
"engines": {
"node": ">=8"
}
},
"node_modules/@sentry/replay": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry/replay/-/replay-7.91.0.tgz",
"integrity": "sha512-XwbesnLLNtaVXKtDoyBB96GxJuhGi9zy3a662Ba/McmumCnkXrMQYpQPh08U7MgkTyDRgjDwm7PXDhiKpcb03g==",
"dependencies": {
"@sentry-internal/tracing": "7.91.0",
"@sentry/core": "7.91.0",
"@sentry/types": "7.91.0",
"@sentry/utils": "7.91.0"
},
"engines": {
"node": ">=12"
}
},
"node_modules/@sentry/types": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry/types/-/types-7.91.0.tgz",
"integrity": "sha512-bcQnb7J3P3equbCUc+sPuHog2Y47yGD2sCkzmnZBjvBT0Z1B4f36fI/5WjyZhTjLSiOdg3F2otwvikbMjmBDew==",
"engines": {
"node": ">=8"
}
},
"node_modules/@sentry/utils": {
"version": "7.91.0",
"resolved": "https://registry.npmjs.org/@sentry/utils/-/utils-7.91.0.tgz",
"integrity": "sha512-fvxjrEbk6T6Otu++Ax9ntlQ0sGRiwSC179w68aC3u26Wr30FAIRKqHTCCdc2jyWk7Gd9uWRT/cq+g8NG/8BfSg==",
"dependencies": {
"@sentry/types": "7.91.0"
},
"engines": {
"node": ">=8"
}
},
"node_modules/asynckit": {
"version": "0.4.0",
"resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
"integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==",
"dev": true
},
"node_modules/axios": {
"version": "1.6.2",
"resolved": "https://registry.npmjs.org/axios/-/axios-1.6.2.tgz",
"integrity": "sha512-7i24Ri4pmDRfJTR7LDBhsOTtcm+9kjX5WiY1X3wIisx6G9So3pfMkEiU7emUBe46oceVImccTEM3k6C5dbVW8A==",
"dev": true,
"dependencies": {
"follow-redirects": "^1.15.0",
"form-data": "^4.0.0",
"proxy-from-env": "^1.1.0"
}
},
"node_modules/combined-stream": {
"version": "1.0.8",
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
"integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
"dev": true,
"dependencies": {
"delayed-stream": "~1.0.0"
},
"engines": {
"node": ">= 0.8"
}
},
"node_modules/delayed-stream": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
"integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
"dev": true,
"engines": {
"node": ">=0.4.0"
}
},
"node_modules/esbuild": {
"version": "0.18.20",
"resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.20.tgz",
"integrity": "sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA==",
"dev": true,
"hasInstallScript": true,
"bin": {
"esbuild": "bin/esbuild"
},
"engines": {
"node": ">=12"
},
"optionalDependencies": {
"@esbuild/android-arm": "0.18.20",
"@esbuild/android-arm64": "0.18.20",
"@esbuild/android-x64": "0.18.20",
"@esbuild/darwin-arm64": "0.18.20",
"@esbuild/darwin-x64": "0.18.20",
"@esbuild/freebsd-arm64": "0.18.20",
"@esbuild/freebsd-x64": "0.18.20",
"@esbuild/linux-arm": "0.18.20",
"@esbuild/linux-arm64": "0.18.20",
"@esbuild/linux-ia32": "0.18.20",
"@esbuild/linux-loong64": "0.18.20",
"@esbuild/linux-mips64el": "0.18.20",
"@esbuild/linux-ppc64": "0.18.20",
"@esbuild/linux-riscv64": "0.18.20",
"@esbuild/linux-s390x": "0.18.20",
"@esbuild/linux-x64": "0.18.20",
"@esbuild/netbsd-x64": "0.18.20",
"@esbuild/openbsd-x64": "0.18.20",
"@esbuild/sunos-x64": "0.18.20",
"@esbuild/win32-arm64": "0.18.20",
"@esbuild/win32-ia32": "0.18.20",
"@esbuild/win32-x64": "0.18.20"
}
},
"node_modules/follow-redirects": {
"version": "1.15.6",
"resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz",
"integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==",
"dev": true,
"funding": [
{
"type": "individual",
"url": "https://github.com/sponsors/RubenVerborgh"
}
],
"engines": {
"node": ">=4.0"
},
"peerDependenciesMeta": {
"debug": {
"optional": true
}
}
},
"node_modules/form-data": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz",
"integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==",
"dev": true,
"dependencies": {
"asynckit": "^0.4.0",
"combined-stream": "^1.0.8",
"mime-types": "^2.1.12"
},
"engines": {
"node": ">= 6"
}
},
"node_modules/fsevents": {
"version": "2.3.3",
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
"integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
"dev": true,
"hasInstallScript": true,
"optional": true,
"os": [
"darwin"
],
"engines": {
"node": "^8.16.0 || ^10.6.0 || >=11.0.0"
}
},
"node_modules/laravel-vite-plugin": {
"version": "0.7.8",
"resolved": "https://registry.npmjs.org/laravel-vite-plugin/-/laravel-vite-plugin-0.7.8.tgz",
"integrity": "sha512-HWYqpQYHR3kEQ1LsHX7gHJoNNf0bz5z5mDaHBLzS+PGLCTmYqlU5/SZyeEgObV7z7bC/cnStYcY9H1DI1D5Udg==",
"dev": true,
"dependencies": {
"picocolors": "^1.0.0",
"vite-plugin-full-reload": "^1.0.5"
},
"engines": {
"node": ">=14"
},
"peerDependencies": {
"vite": "^3.0.0 || ^4.0.0"
}
},
"node_modules/mime-db": {
"version": "1.52.0",
"resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
"integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
"dev": true,
"engines": {
"node": ">= 0.6"
}
},
"node_modules/mime-types": {
"version": "2.1.35",
"resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
"integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
"dev": true,
"dependencies": {
"mime-db": "1.52.0"
},
"engines": {
"node": ">= 0.6"
}
},
"node_modules/nanoid": {
"version": "3.3.7",
"resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz",
"integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==",
"dev": true,
"funding": [
{
"type": "github",
"url": "https://github.com/sponsors/ai"
}
],
"bin": {
"nanoid": "bin/nanoid.cjs"
},
"engines": {
"node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
}
},
"node_modules/picocolors": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
"integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
"dev": true
},
"node_modules/picomatch": {
"version": "2.3.1",
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
"integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
"dev": true,
"engines": {
"node": ">=8.6"
},
"funding": {
"url": "https://github.com/sponsors/jonschlinkert"
}
},
"node_modules/postcss": {
"version": "8.4.32",
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.32.tgz",
"integrity": "sha512-D/kj5JNu6oo2EIy+XL/26JEDTlIbB8hw85G8StOE6L74RQAVVP5rej6wxCNqyMbR4RkPfqvezVbPw81Ngd6Kcw==",
"dev": true,
"funding": [
{
"type": "opencollective",
"url": "https://opencollective.com/postcss/"
},
{
"type": "tidelift",
"url": "https://tidelift.com/funding/github/npm/postcss"
},
{
"type": "github",
"url": "https://github.com/sponsors/ai"
}
],
"dependencies": {
"nanoid": "^3.3.7",
"picocolors": "^1.0.0",
"source-map-js": "^1.0.2"
},
"engines": {
"node": "^10 || ^12 || >=14"
}
},
"node_modules/proxy-from-env": {
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
"integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==",
"dev": true
},
"node_modules/rollup": {
"version": "3.29.4",
"resolved": "https://registry.npmjs.org/rollup/-/rollup-3.29.4.tgz",
"integrity": "sha512-oWzmBZwvYrU0iJHtDmhsm662rC15FRXmcjCk1xD771dFDx5jJ02ufAQQTn0etB2emNk4J9EZg/yWKpsn9BWGRw==",
"dev": true,
"bin": {
"rollup": "dist/bin/rollup"
},
"engines": {
"node": ">=14.18.0",
"npm": ">=8.0.0"
},
"optionalDependencies": {
"fsevents": "~2.3.2"
}
},
"node_modules/source-map-js": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
"integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
"dev": true,
"engines": {
"node": ">=0.10.0"
}
},
"node_modules/vite": {
"version": "4.5.3",
"resolved": "https://registry.npmjs.org/vite/-/vite-4.5.3.tgz",
"integrity": "sha512-kQL23kMeX92v3ph7IauVkXkikdDRsYMGTVl5KY2E9OY4ONLvkHf04MDTbnfo6NKxZiDLWzVpP5oTa8hQD8U3dg==",
"dev": true,
"dependencies": {
"esbuild": "^0.18.10",
"postcss": "^8.4.27",
"rollup": "^3.27.1"
},
"bin": {
"vite": "bin/vite.js"
},
"engines": {
"node": "^14.18.0 || >=16.0.0"
},
"funding": {
"url": "https://github.com/vitejs/vite?sponsor=1"
},
"optionalDependencies": {
"fsevents": "~2.3.2"
},
"peerDependencies": {
"@types/node": ">= 14",
"less": "*",
"lightningcss": "^1.21.0",
"sass": "*",
"stylus": "*",
"sugarss": "*",
"terser": "^5.4.0"
},
"peerDependenciesMeta": {
"@types/node": {
"optional": true
},
"less": {
"optional": true
},
"lightningcss": {
"optional": true
},
"sass": {
"optional": true
},
"stylus": {
"optional": true
},
"sugarss": {
"optional": true
},
"terser": {
"optional": true
}
}
},
"node_modules/vite-plugin-full-reload": {
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/vite-plugin-full-reload/-/vite-plugin-full-reload-1.1.0.tgz",
"integrity": "sha512-3cObNDzX6DdfhD9E7kf6w2mNunFpD7drxyNgHLw+XwIYAgb+Xt16SEXo0Up4VH+TMf3n+DSVJZtW2POBGcBYAA==",
"dev": true,
"dependencies": {
"picocolors": "^1.0.0",
"picomatch": "^2.3.1"
}
}
}
}

Some files were not shown because too many files have changed in this diff Show more