diff --git a/.eleventy.js b/.eleventy.js
new file mode 100644
index 0000000..b191366
--- /dev/null
+++ b/.eleventy.js
@@ -0,0 +1,75 @@
+const fs = require("fs");
+const path = require("path");
+const i18n = require('./_data/i18n.js');
+
+module.exports = function(eleventyConfig) {
+ eleventyConfig.addCollection("post", function(collectionApi) {
+ return collectionApi.getFilteredByGlob("./posts/*").sort((a, b) => b.date - a.date);
+ });
+ eleventyConfig.addCollection("misc", (api) =>
+ api.getFilteredByTag("misc")
+ );
+ eleventyConfig.addFilter("getTranslation", (page, lang) => {
+ const dir = path.dirname(page.inputPath);
+ const file = path.join(dir, `${lang}.json`);
+
+ if (fs.existsSync(file)) {
+ return JSON.parse(fs.readFileSync(file, "utf-8"));
+ }
+
+ return {};
+ });
+ eleventyConfig.addCollection("88x31", () => {
+ return fs.readdirSync("static/images/88x31")
+ .map(file => ({
+ url: `/static/images/88x31/${file}`,
+ fileSlug: file
+ }));
+ });
+
+ eleventyConfig.addPassthroughCopy("static");
+
+ eleventyConfig.addNunjucksFilter("alternateLanguages", function(collection, postId, currentLanguageKey) {
+ return collection.filter(post =>
+ post.data.postId === postId && post.data.langKey !== currentLanguageKey
+ )
+ .map(post => ({
+ lang: post.data.langKey,
+ url: post.url,
+ title: post.data.title
+ }))
+ });
+
+ eleventyConfig.addFilter("absoluteUrl", function(url) {
+ const base = "https://adrianvic.github.io";
+ const prefix = "/tenkuma/web";
+ return base + prefix + url;
+ });
+
+ eleventyConfig.addFilter("postDate", (dateObj) => {
+ if (!dateObj) return "";
+ return dateObj.toLocaleString(undefined, {
+ year: "numeric",
+ month: "numeric",
+ day: "numeric",
+ timeZone: "America/Sao_Paulo"
+ });
+ });
+
+ eleventyConfig.addNunjucksFilter("smartTitle", function(str) {
+ if (!str) return "";
+ const smallWords = ["a","an","and","at","but","by","for","in","nor","of","on","or","so","the","to","up","yet",
+ "e","de","do","da","dos","das","a","o","um","uma","em","por","para","com","no","na","nos"];
+ return str.toLowerCase().split(" ").map((word, i) => {
+ if (i === 0) return word.charAt(0).toUpperCase() + word.slice(1);
+ return smallWords.includes(word) ? word : word.charAt(0).toUpperCase() + word.slice(1);
+ }).join(" ");
+ });
+
+ return {
+ pathPrefix: "/tenkuma/web",
+ dir: {
+ output: "docs"
+ }
+ };
+};
diff --git a/.forgejo/workflows/build-forgejo.yml b/.forgejo/workflows/build-forgejo.yml
new file mode 100644
index 0000000..e0b77da
--- /dev/null
+++ b/.forgejo/workflows/build-forgejo.yml
@@ -0,0 +1,49 @@
+name: Build Eleventy Forgero
+
+on:
+ push:
+ paths-ignore:
+ - '/maintenance/**'
+ - '/README.md'
+ branches:
+ - main
+ workflow_dispatch:
+ pull_request:
+ paths-ignore:
+ - '/maintenance/**'
+ - '/README.md'
+
+permissions:
+ contents: write
+
+jobs:
+ build:
+ runs-on: arch-linux
+
+ strategy:
+ matrix:
+ node-version: [24.x]
+
+ steps:
+ - uses: actions/checkout@v4
+
+ - name: Use Node.js ${{ matrix.node-version }}
+ uses: actions/setup-node@v4
+ with:
+ node-version: ${{ matrix.node-version }}
+
+ - name: Install dependencies & build
+ run: |
+ npm ci
+ npm run build -- --pathprefix="/pages/tenkuma/web"
+
+ - name: Deploy to forgejo-pages
+ run: |
+ git config user.email "adrianvictor+webmaster@disroot.org"
+ git config user.name "mareguma"
+ git checkout --orphan forgejo-pages
+ git rm -rf .
+ cp -r docs/* .
+ git add .
+ git commit -m "Deploy: $(date)"
+ git push -f origin forgejo-pages
\ No newline at end of file
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
new file mode 100644
index 0000000..8d068a5
--- /dev/null
+++ b/.github/workflows/build.yml
@@ -0,0 +1,44 @@
+name: Build Eleventy
+
+on:
+ push:
+ paths-ignore:
+ - '/maintenance/**'
+ - '/README.md'
+ branches:
+ - main
+ workflow_dispatch:
+ pull_request:
+ paths-ignore:
+ - '/maintenance/**'
+ - '/README.md'
+
+permissions:
+ contents: write
+
+jobs:
+ build:
+ runs-on: ubuntu-latest
+
+ strategy:
+ matrix:
+ node-version: [24.x]
+
+ steps:
+ - uses: actions/checkout@v4
+
+ - name: Use Node.js ${{ matrix.node-version }}
+ uses: actions/setup-node@v4
+ with:
+ node-version: ${{ matrix.node-version }}
+
+ - name: Install dependencies & build
+ run: |
+ npm ci
+ npm run build -- --pathprefix=""
+
+ - name: Deploy
+ uses: peaceiris/actions-gh-pages@v4
+ with:
+ publish_dir: ./docs
+ github_token: ${{ secrets.GITHUB_TOKEN }}
\ No newline at end of file
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..d1a9dc6
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,3 @@
+_site/
+node_modules/
+docs/
\ No newline at end of file
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..261eeb9
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,201 @@
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright [yyyy] [name of copyright owner]
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..65eb7c5
--- /dev/null
+++ b/README.md
@@ -0,0 +1,26 @@
+# Adrian Victor
+[](https://inspiran.beetal-castor.ts.net/git/tenkuma/web/actions?workflow=build-forgejo.yml)
+[](https://github.com/adrianvic/adrianvic.github.io/actions/workflows/build.yml)
+[](https://github.com/adrianvic/adrianvic.github.io/actions/workflows/pages/pages-build-deployment)
+
+My personal static website/blog built with Eleventy.
+
+
+
+## Mirrors
+ - Forgejo: https://inspiran.beetal-castor.ts.net/pages/tenkuma/web/
+ - GitHub Pages: https://adrianvic.github.io/
+ - NeoCities (some features are broken): https://tenkuma.neocities.org/
+
+## Interesting features
+ - Multiple pages
+ - Text support
+ - Interactive
+
+## Features that are not interesting at all
+ - Localization support with global/page string table
+ - Reusable elements with Eleventy's macros
+ - Responsive design for computers, medium sized devices and smartphones
+ - Functional without JavaScript
+ - Robust blog functionality with support for linking post translations with a common internal ID
+ - Some elements have hints while hovering, they update the text of a hint bar on the website header
diff --git a/README/index.html b/README/index.html
deleted file mode 100644
index 7176c98..0000000
--- a/README/index.html
+++ /dev/null
@@ -1,27 +0,0 @@
-
Adrian Victor
-
-
-
-
My personal static website/blog built with Eleventy.
NeoCities (some features are broken): https://tenkuma.neocities.org/
-
-
Interesting features
-
-
Multiple pages
-
Text support
-
Interactive
-
-
Features that are not interesting at all
-
-
Localization support with global/page string table
-
Reusable elements with Eleventy's macros
-
Responsive design for computers, medium sized devices and smartphones
-
Functional without JavaScript
-
Robust blog functionality with support for linking post translations with a common internal ID
-
Some elements have hints while hovering, they update the text of a hint bar on the website header
-
diff --git a/_data/i18n.js b/_data/i18n.js
new file mode 100644
index 0000000..ab17402
--- /dev/null
+++ b/_data/i18n.js
@@ -0,0 +1,137 @@
+const globalValues = {
+ mastodon: { url: "https://mstdn.social/@tenkuma", username: "@tenkuma@mstdn.social" },
+ github: { url: "https://github.com/adrianvic", username: "adrianvic" },
+ disrootGit: { url: "https://git.disroot.org/adrianvictor", username: "adrianvictor" },
+ discord: { url: "https://discord.com/users/681643259764015116", username: "@adrianvic" },
+ youtube: { url: "https://www.youtube.com/@adrianvictor8", username: "@adrianvictor8" },
+ bitview: { url: "https://www.bitview.net/user/tenkuma", username: "tenkuma" },
+ modrinth: { url: "https://modrinth.com/user/tenkumabear", username: "tenkumabear" },
+ xmpp: { url: "xmpp:adrianvictor@disroot.org", username: "adrianvictor@disroot.org" },
+ email: "adrianvictor@disroot.org",
+ margarinaRecordsWebsite: "https://margarina-records.rf.gd",
+ genius: { url: "https://genius.com/tenkuma", username: "tenkuma" },
+ homeVideoLink: "https://www.youtube.com/watch?v=6bnNAnSY9Uo",
+ homeVideoImage: "/thumbnails/fl_studio_linux.png",
+ homeVideoWebsite: "YouTube",
+ homeVideoDuration: "5:53",
+ homeSongTitle: "Velkommen",
+ homeSongLink: "https://margarina.bandcamp.com/album/velkommen",
+ homeSongImage: "/songs/velkommen.jpg",
+ homeSongWebsite: "Bandcamp",
+ homeSongDuration: "5:39",
+ homeSongAccent: "#482948"
+};
+
+module.exports = {
+ global: globalValues,
+ en: {
+ language: "english",
+ availableInOtherLanguages: "Also available in other languages",
+ pt: "portuguese",
+ en: "english",
+ home: "home",
+ welcome: "welcome",
+ homeWelcomeParagraph: "It seems that you have found my website! Hi, I am Adrian Victor (or tenkuma), a Brazilian guy who likes to mess around with computers, computer programs and enimatpyrtlyhtemids.",
+ socialsAndContact: "socials and contact",
+ aboutMe: "about me",
+ myMusic: "my music",
+ myVideos: "my videos",
+ mySoftware: "my software",
+ homeAboutMeParagraph: `
+ My name is Adrian Victor, but I go by tenkuma on-line. I'm in high school's last year, also studying computing. My hobbies are music and music production, programming, selfhosting, Linux, and a lot more.
+ `,
+ homeAboutMeParagraphTwo: `Tenkuma, or 天くま in japanese, means celestial bear and was given by a friend of mine that I lost contact a long time ago. Sakata is gone, but the name stayed and turned into an integral part of my digital self.`,
+ homeSocialsAndContactParagraph: `
+ I'm publicly available at Mastodon (${globalValues.mastodon.username}),
+ GitHub (${globalValues.github.username}),
+ Disroot Git (${globalValues.disrootGit.username}),
+ Discord (${globalValues.discord.username}),
+ YouTube (${globalValues.youtube.username}),
+ BitView (${globalValues.bitview.username}),
+ Modrinth (${globalValues.modrinth.username})
+ and XMPP (${globalValues.xmpp.username}).
+ `,
+ homeSocialsAndContactParagraphTwo: `You can message me on my E-mail (${globalValues.email}) or feel free to get in touch through any of the other places mentioned above. For project-specific subjects, check for the project's contact field or if there's no such field add +projectname to my E-mail address (example: adrianvictor+coolproject@disroot.org).
+
Please, avoid reaching me through ways not mentioned above :)`,
+ homeMyMusicParagraph: `I've always loved music, and lately I've been finding music production very interesting. I publish my songs as tenkuma, and have founded an amateur label called Margarina Records with my friends.`,
+ homeMyMusicParagraphTwo: `You can find my latest on songs Genius.`,
+ homeMyVideoParagraph: "I make videos for my YouTube channel. Videos do not come regularly, there's no schedule—just a guy wanting to show something.",
+ homeMyVideoRandomVideoParagraph: "Here's a random video I'm proud of:",
+ homeVideoTitle: "Installing FL Studio on linux.",
+ homeMySoftwareParagraph: `I am studying computing at IFC (SC, Brazil) but in my free time I have some projects like computer applications, Minecraft plugins, Minecraft servers, etc... Anything that is public should be in my GitHub profile.`,
+ pestoWikiLogoAlt: "A digital drawing of the top of a fork with a black outline, in the right a text in white says 'Pesto Wiki'",
+ homeMySoftwareNotableProjects: "These are my most notable projects:",
+ blogTitle: "Listing blog posts:",
+ eyeofnemesisProjectDesctiption: "Eye of Nemesis is a plugin that allows server admins to write policies that will deny or allow (black/whitelist) players to do specific things based on the value of nodes.",
+ jamfishProjectDesctiption: "Native music player for Android devices that connects to Jellyfin media servers. The code is based on Gelli's archived repository, which is based on an old version of Phonograph.",
+ pestoProjectDesctiption: "Multi-platform customizable client for wikis written in Python using PySide6 (QT).",
+ itemeconomyProjectDesctiption: "This PaperMC plugin integrates with VaultUnlocked to provide a unique, item-based economy system for your Minecraft server. Instead of relying solely on virtual balances, players use in-game items as physical currency, adding a layer of immersion and realism to your economy.",
+ by: "by",
+ back: "back",
+ hideBackground: "Hide background",
+ options: "Options",
+ alsoAvailableAsVideo: "Also available as video",
+ websiteDescription: "Personal website/blog of Adrian Victor.",
+ miscellaneous: "Miscellaneous",
+ i88x31hover: "Click to expand",
+ lastEditedIn: "last edited in",
+ permissionIssue: "Permission issue",
+ permissionIssueNotificationContent: "Unable to continue playing background music, please enable audio autoplay for this website.",
+ notificationDefaultHint: "Click to dismiss"
+
+ },
+ pt: {
+ language: "português",
+ availableInOtherLanguages: "Também disponível em outros idiomas",
+ pt: "português",
+ en: "inglês",
+ home: "início",
+ welcome: "bem-vindo",
+ homeWelcomeParagraph: "Parece que você encontrou meu website! Olá, sou Adrian Victor (ou tenkuma), um cara brasileiro que gosta de mexer com computadores, programas de computadores e enimatpirtlitemídios.",
+ socialsAndContact: "redes sociais e contato",
+ aboutMe: "sobre mim",
+ myMusic: "música",
+ myVideos: "vídeos",
+ mySoftware: "software",
+ homeAboutMeParagraph: `
+ Meu nome é Adrian Victor, mas on-line eu uso o nickname tenkuma. Estou no último ano do ensino médio e estudo informática. Meus hobbies são escutar e produzir música, programação, selfhosting, Linux, e muito mais.
+ `,
+ homeAboutMeParagraphTwo: `Tenkuma, ou 天くま em japonês, significa urso celestial e foi um nome dado a mim por um amigo que eu já perdi contato há muito tempo. Sakata se foi, mas o nome ficou e se tornou parte integral da personalidade do meu eu digital até hoje.`,
+ homeSocialsAndContactParagraph: `
+ Estou publicamente disponível no Mastodon (${globalValues.mastodon.username}),
+ GitHub (${globalValues.github.username}),
+ Disroot Git (${globalValues.disrootGit.username}),
+ Discord (${globalValues.discord.username}),
+ YouTube (${globalValues.youtube.username}),
+ BitView (${globalValues.bitview.username}),
+ Modrinth (${globalValues.modrinth.username})
+ e XMPP (${globalValues.xmpp.username}).
+ `,
+ homeSocialsAndContactParagraphTwo: `Você pode enviar um correio eletrônico para (${globalValues.email}) ou me contactar por qualquer outro meio citado acima. Para assuntos relativos a projetos específicos, verifique o campo de contato do projeto, caso não haja um adicione +nomedoprojeto ao meu endereço de E-mail (exemplo: adrianvictor+projetolegal@disroot.org).`,
+ homeMyMusicParagraph: `Sempre amei música, e tenho achado produção musical algo muito interessante ultimamente. Publico minhas músicas como tenkuma, junto com meus amigos formei a Margarina Records—uma label amadora.`,
+ homeMyMusicParagraphTwo: `Você pode conferir minhas músicas mais recentes no meu perfil do Genius.`,
+ homeMyVideoParagraph: "Eu faço vídeos para o meu canal do YouTube. Não posto regularmente; não tem calendário—apenas eu mostrando alguma coisa em vídeo.",
+ homeMyVideoRandomVideoParagraph: "Aqui está um vídeo aleatório que eu me orgulho de ter postado:",
+ homeVideoTitle: "Como instalar o FL Studio no Linux?",
+ homeMySoftwareParagraph: `Estou estudando informática no IFC (SC, Brazil) mas no meu tempo livre tenho projetos como programas de computador, plugins para Minecraft, servidores Minecraft, etc... Todos meus projetos públicos estão disponíveis no meu perfil do GitHub.`,
+ pestoWikiLogoAlt: "Um desenho digital do topo de um garfo com uma borda preta, à direita um texto branco diz 'Pesto Wiki'",
+ homeMySoftwareNotableProjects: "Esses são meus projetos mais notáveis:",
+ blogTitle: "Listando postagens do blog:",
+ eyeofnemesisProjectDesctiption: "Eye of Nemesis é um plugin que permite aos administradores de servidores escrever políticas que negarão ou permitirão (lista negra/branca) que os jogadores façam coisas específicas com base no valor dos nós.",
+ jamfishProjectDesctiption: "Reprodutor de música nativo para dispositivos Android que se conecta a servidores de mídia Jellyfin. O código é baseado no repositório arquivado do Gelli, que por sua vez se baseia em uma versão antiga do Phonograph.",
+ pestoProjectDesctiption: "Cliente personalizável multiplataforma para wikis escrito em Python usando PySide6 (QT).",
+ itemeconomyProjectDesctiption: "Este plugin PaperMC integra-se ao VaultUnlocked para fornecer um sistema de economia único baseado em itens para o seu servidor Minecraft. Em vez de depender apenas de saldos virtuais, os jogadores usam itens do jogo como moeda física, adicionando uma camada de imersão e realismo à sua economia.",
+ by: "por",
+ back: "voltar",
+ hideBackground: "Esconder imagem de fundo",
+ options: "Opções",
+ alsoAvailableAsVideo: "Também disponível em vídeo",
+ websiteDescription: "Website/blog pessoal de Adrian Victor.",
+ miscellaneous: "Miscelâneo",
+ i88x31hover: "Clique para expandir",
+ lastEditedIn: "editado por último em",
+ permissionIssue: "Problema de permissão",
+ permissionIssueNotificationContent: "Não foi possivel continuar tocando a música de fundo, por favor habilite reprodução automática de áudio para esse website.",
+ notificationDefaultHint: "Clique para ignorar"
+ }
+};
\ No newline at end of file
diff --git a/_data/languages.js b/_data/languages.js
new file mode 100644
index 0000000..322d425
--- /dev/null
+++ b/_data/languages.js
@@ -0,0 +1 @@
+module.exports = ["en", "pt"];
\ No newline at end of file
diff --git a/_includes/base.njk b/_includes/base.njk
new file mode 100644
index 0000000..28fb5d7
--- /dev/null
+++ b/_includes/base.njk
@@ -0,0 +1,61 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_includes/header.njk b/_includes/header.njk
new file mode 100644
index 0000000..29d6f22
--- /dev/null
+++ b/_includes/header.njk
@@ -0,0 +1,27 @@
+
+
It seems that you have found my website! Hi, I am Adrian Victor (or tenkuma), a Brazilian guy who likes to mess around with computers, computer programs and enimatpyrtlyhtemids.
- My name is Adrian Victor, but I go by tenkuma on-line. I'm in high school's last year, also studying computing. My hobbies are music and music production, programming, selfhosting, Linux, and a lot more.
-
-
Tenkuma, or 天くま in japanese, means celestial bear and was given by a friend of mine that I lost contact a long time ago. Sakata is gone, but the name stayed and turned into an integral part of my digital self.
You can message me on my E-mail (adrianvictor@disroot.org) or feel free to get in touch through any of the other places mentioned above. For project-specific subjects, check for the project's contact field or if there's no such field add +projectname to my E-mail address (example: adrianvictor+coolproject@disroot.org).
-
Please, avoid reaching me through ways not mentioned above :)
-
-
-
-
-
My Music
-
I've always loved music, and lately I've been finding music production very interesting. I publish my songs as tenkuma, and have founded an amateur label called Margarina Records with my friends.
I am studying computing at IFC (SC, Brazil) but in my free time I have some projects like computer applications, Minecraft plugins, Minecraft servers, etc... Anything that is public should be in my GitHub profile.
Native music player for Android devices that connects to Jellyfin media servers. The code is based on Gelli's archived repository, which is based on an old version of Phonograph.
This PaperMC plugin integrates with VaultUnlocked to provide a unique, item-based economy system for your Minecraft server. Instead of relying solely on virtual balances, players use in-game items as physical currency, adding a layer of immersion and realism to your economy.
Eye of Nemesis is a plugin that allows server admins to write policies that will deny or allow (black/whitelist) players to do specific things based on the value of nodes.
- This website is a collection with over 6500 GIF's and PNG's in 88x31 format. In the late 1990 and begin of the 2000's it was very common to use these pictures on your personal website.
-
- Andrew is a software engineer, a malware enthusiast and most importantly, a weird tall creature. I've grown up with his videos and he's a great inspiration for me.
-
- With Lucida, you can download music directly from Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, and Yandex Music in high quality for free. No catches, no mandatory ads, no BS. How does it work?
-
Android is that open-source operating system that works well for users and is loved by developers. Always known for breaking barriers and being open, expandable, versatile, and even friendly to power users–something not every system dares to be (iOS, Windows Phone). For a long time, Android was seen this way compared to its competitors: a breath of fresh air against the abusive practices of companies like Apple. But it seems the Android we've nurtured for two decades no longer fits in the pockets of Google executives; it is too free, creating ethical and technical barriers to the profitable exploitation path adopted by its developer.
-
-
What happened with Android?
-
-
At the end of this month (August 2025), Google announced that starting September 2026, all apps installed on certified devices (those with Google Android and locked bootloader) will need to undergo a developer verification process. This process involves collecting personal data from the individual distributing the app, so they can be identified and held accountable for potential malicious activities related to their software. The same applies to companies, which must also pay a $25 USD fee. This process is mandatory even if the app is distributed outside Google's official stores, raising obvious concerns about user privacy and freedom.
-
-
Implications, Justifications, and Motivations of the New Policy
-
-
It is important to examine Google's justification and try to understand its true motivation behind this distribution policy. Let's start by analyzing Google's statement:
-
-
"By making Android safer, we're protecting the open environment that allows developers and users to confidently create and connect. Android's new developer verification is an extra layer of security that deters bad actors and makes it harder for them to spread harm."
-
-
They argue that the new rules are intended to improve user security, preventing malicious software from being installed on certified Android devices. Again, we see "security" used to justify controversial practices that limit the end user's control over their device. This was also the justification given for the proven abusive sideloading restrictions that led Google to lose a lawsuit against Epic Games—a more sophisticated version of the same issue is happening here.
-
-
It is easy to sympathize with the company when the words are well-phrased, but as a user who loves alternative software outside the big tech ecosystem, I have seen enough examples of authority abuse to conclude that Google's recent actions are simply an attempt to regain part, if not all, of the control it had over Android devices before the previously mentioned case.
-
-
One example is the kio-gdrive software, widely used to integrate Google Drive with the KDE file manager on Linux systems. The software was blocked from asking users if they authorized access to their Google Drive account. Instead of the permission popup, Google displayed a warning implying that the legitimate software could be malicious. Developers reported:
-
-
"Google blocked us from using this back in June because we weren't able
-justify our API usage to their satisfaction. As such, the permission is now blocked [...] mamaking 25% of the KAccounts KCM non-functional. Remove the gdrive permissions [...] for now so at least other Google things can work (at least in theory)."
-
-
"It's beyond stupid (IMHO) if individual users can't indicate that they're fine with a particular piece of software accessing their supposedly sensitive data!"
-
-
Although I couldn't find the exact internal conversations between developers—and I'm giving Google the benefit of the doubt—it is at least suspicious that Google did not agree that software performing its primary functions within Google Drive should have a valid reason to access it. This was not an isolated case; Google operates behind the scenes to control what happens on Android. For example, apps compiled for older system versions would show alarming security warnings because recent changes introduced more permission barriers, even though old apps didn't support them. A reasonable warning would emphasize that permissions must be granted to support optional features, but the actual messages were vague, conveniently scaring users attempting sideloading and helping maintain the Play Store monopoly.
-
-
Speaking of alarming warnings, let's discuss Play Protect, software embedded in the Google Play Store that scans installed sideloaded apps and reports the results back to Google. At first glance, this is a good idea, assuming the user opts in. The problem arises when the difference between malware detection messages and warnings triggered by outdated software is unclear, causing two serious effects: it renders Google's protection service almost useless while maintaining the Play Store monopoly.
-
-
Imagine sideloading for the first time: you try to install an old version of a favored software. You receive exaggerated warnings about the supposed dangers, abandon the installation, and install the latest version from the Play Store. Google thus indirectly forces more users to use its store, ensuring the lucrative 30% transaction fee.
-
-
Now consider a second scenario: you're an advanced Android user who understands sideloading and loves installing open-source apps outside the Play Store. You click a suspicious link and download a malicious APK. Play Protect warns you during installation, but the warnings are so frequent and exaggerated (even when no malware is detected) that you ignore them out of habit. The result: malware on your device, and Play Protect was ineffective.
-
-
Sometimes, downloading software outside the Play Store is the only option, because developers may not want to publish apps there—either for privacy reasons (developers must disclose personal data when publishing) or because of publishing fees, which may discourage donation—supported developers. Users must have the freedom to choose what runs on their devices.
-
-
According to current information, developers don't have to make their data public if they avoid distributing apps via the Play Store. This is the least Google could do to make the new distribution policies fairer. Google also claims the verification isn't meant to inspect app content or purpose; it is supposedly only to block malware distribution. Whether this holds up remains to be seen, given it could also serve as a convenient tool for abuse of power.
-
-
Next Steps
-
-
We must watch how these policies are applied and how they affect the Android ecosystem. An inevitable consequence is that countless abandoned apps, perfectly functional without the new requirements, will disappear overnight. Not all old software connects to the internet, and not all represents a constant threat. Google is taking away the option for experienced users to take responsibility and say: "I know what I'm doing!", treating us as if they know what's best for everyone.
-
-
The commercial Android on phones is based on the AOSP, meaning Android's core remains open, and Google hasn't taken that from users yet. I plan to write another post explaining how to regain control of your device through system modifications, from the simplest, safest, most stable methods to advanced approaches, if you feel confident.
-
-
-
-
-
-
\ No newline at end of file
diff --git a/docs/posts/instalando-fl-studio-no-linux/index.html b/docs/posts/instalando-fl-studio-no-linux/index.html
deleted file mode 100644
index 72006e8..0000000
--- a/docs/posts/instalando-fl-studio-no-linux/index.html
+++ /dev/null
@@ -1,179 +0,0 @@
-
-
-
-
-
-
- Adrian Victor - Instalando FL Studio no Linux.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Desde que mudei permanentemente para o Linux em 2024, venho me impressionando com a capacidade inabalável da comunidade open-source de trazer a vida no Linux softwares complexos feitos originalmente para Windows. Entretanto, um dos programas amaldiçoados com os mais ímpetos e abstratos erros na velha guarda do Wine é o FL Studio, caracteristica essa que fez com que eu, por muito tempo, achasse que a DAW da Image-Line não iria rodar de jeito nenhum no sistema do penguim.
-
Acontece que o FL roda no Linux, e roda muito bem, considerando a sua complexidade. Descartando uns problemas visuais, algumas VSTs que simplesmente não rodam e uma gambiarra para rodar plugins 32-bits, a experiência de usar o FL Studio no Linux é bem sólida. Parece que a Valve, Wine e comunidade open-source não estão para brincadeira mesmo.
-
Antes de ir às formalidades, gostaria de definir o escopo desse tutorial. Faço ele com tudo o que cabe na minha memória recente trabalhando com o FL no Linux. Mas também não é uma postagem estática; se estiver faltando alguma coisa me mande um e-mail e eu atualizo.
-
-
Preparativos
-
O tutorial vai ser feito usando o Arch Linux em um computador com o conjunto de Intel i5-1235U + 16gb de RAM. Porém, vale ressaltar que, pela natureza do flatpak, o tutorial se aplica a qualquer máquina com o gerenciador de pacotes instalado.
-
O primeiro passo é instalar o software Bottles, que está disponível com o nome de com.usebottles.bottles no Flathub. O comando mais simples para instalar o app em um sistema com acesso ao Flathub (habilitado por padrão na maioria das distros, como na minha) é flatpak install bottles. Se você não é muito fã de rodar comandos, a maioria das lojas de apps no Linux baixam flatpaks e já vem com o Flathub habilitado—e saiba que essa é a última vez que vamos rodar comandos.
-
Se você não é fã do Flatpak, há um pacote do bottles no AUR. Pelo que eu entendi tem até uns desenvolvedores do Bottles envolvidos na manutenção desse pacote.
-
Depois disso, crie uma nova garrafa no Bottles. Eu recomendo criar uma no preset de jogos, já que o FL é meio visualmente complexo.
-
Por fim, antes da instalação, vamos instalar as dependências, que ficam acessíveis por um botão de mesmo nome nas opções da garrafa. O FL Studio possui apenas duas dependências opcionais:
-
-
allfonts
-
Fontes da Microsoft e Adobe, ajuda com alguns problemas relacionados a exibição de texto no FL. Eu geralmente não preciso instalar, mas já experienciei as teclas do piano roll sem legenda pela falta dessa dependência.
-
webview2
-
Necessário para o funcionamento do FL Cloud, Gopher (IA), Help Manual e talvez mais alguma outra função do FL que puxa um webview. Recomendo não instalar essa dependência se você não usa nenhuma dessas funções, porque sem ela reparei em um ganho de performance.
-
-
Estamos prontos para partir para a instalação da DAW.
-
-
Instalando o FL Studio
-
O Bottles já oferece um pacote de instalação do FL na página da garrafa, basta clicar em Instalar Programas e pesquisar por FL Studio. Porém, esse método de instalação não funcionou para mim, o instalador travou nas dependências. Creio que, se você tiver sucesso na sua instalação, o resultado vai ser o mesmo que fazendo o que eu vou descrever abaixo.
-
Primeiro, obtenha um instalador do FL Studio, caso já não tenha. A Image-Line oferece um instalador em seu website.
-
Com o instalador em mãos, basta usar o botão "Iniciar executável..." na página da garrafa e selecionar o seu instalador. Em alguns instantes você deve estar na instalação do FL Studio.
-
Se tudo ocorrer direito, a DAW recém instalada deve aparecer na lista de aplicativos com o nome "FL64". Você já pode iniciar ela.
-
-
Configuração Inicial
-
Ao abrir o FL Studio pela primeira vez, você provavelmente vai se deparar com uma tela de erro dizendo "The MIDI input device is already allocated. It may be in use by another application.", ignore os erros, e no menu de baixo escrito "Input", desabilite as entradas que tem a etiqueta FAIL.
-
Por mais que eu adoraria dizer que o FL Studio funciona perfeitamente no Linux, estamos trabalhando em um ambiente não suportado pela Image-Line e certamente mais instável do que seus sistemas nativos. Portanto, recomendo que habilite a opção de salvamento automático no modo mais agressivo.
-
-
Trabalhando com VSTs
-
Os plug-ins de produção musical são a maior fonte de incompatibilidades no nosso ambiente, mas isso não significa que a maioria não funciona fora da caixa.
-
Além dos que não funcionam, e, potencialmente, travam o seu FL Studio, há os plugins que não se comportam direito, como é o exemplo do Antares Auto-Tune Pro que funciona perfeitamente—dada a excessão de que a interface e animações ficam estranhas e travadas. Acho que isso se dá e repete em tantos plugins porque os frameworks usados para fazer suas interfaces funcionam de alguma forma bizarra que o Soda não é otimizado para rodar.
-
De qualquer forma, quanto a esses plugins teimosos, as únicas recomendações que eu tenho para mitigar o problema são evitar ao máximo deixá-los abertos enquanto faz outras coisas, e—se possível—usar alternativas que tem mais bom senso no quesito interface.
-
VSTs 32bits
-
Agora que o FL Studio está funcionando, você pode tentar abrir alguma VST de 32bits, e, fazendo isso, ver que ela provavelmente vai congelar a DAW.
-
Se você por acaso congelar sem o devido backup em um projeto importante, ao invés de fechar o FL Studio, você pode usar seu gerenciador de tarefas para matar o processo ILBridge.exe. Esse é o processo que trava a DAW quando você tenta carregar um plugin de 32bits, é a ponte que faz ele funcionar no FL Studio de 64bits—quando interrompido, a DAW exibe um erro sobre não conseguir carregar o plugin e volta ao normal.
-
Mas existe sim uma forma de rodar plugins 32bits. Adicione um Fruity Wrapper no lugar do plugin que você quer adicionar, mude para a aba de opções do mesmo e deixe ele assim. Agora clique com o botão direito no gerador/efeito que você acabou de adicionar e substitua-o pelo plugin desejado. A página de opções deve carregar. Clique no botão escrito "Processing" e marque "External window".
-
Pronto, o plugin deve aparecer em uma janela separada do FL Studio e estar funcionando como esperado.
-
-
Menções Honrosas
-
Abaixo estão alguns ressaltes que vale a pena saber:
-
Discos Virtuais
-
O Bottles usa uma versão própria do Wine chamada Soda, mas no fundo, no fundo mesmo, ainda é o Wine. Portanto, você pode se beneficiar das configurações de discos virtuais do Wine. Nas opções da garrafa, ao expandir o submenu "Ferramentas Legado do Wine", você encontra a opção "Configuração". Ao clicar nessa, um menu de aparência pré-histórica vai aparecer, no topo você pode ver uma aba nomeada "Unidades". Aí você pode mapear diferentes unidades do Windows para locais do seu sistema Linux, e eles vão aparecer no explorador de arquivos do Wine e estarão acessíveis para os aplicativos.
-
Aceleração de Hardware
-
Se o seu FL Studio estiver rodando terrivelmente mal, recomendo que dê uma olhada na opção "Use placa gráfica dedicada" da sua garrafa, com ela desativada a minha DAW trava incessantemente.
-
-
Conclusões
-
Não sou a pessoa mais apta para dizer até onde a usabilidade da DAW se extende no Linux; não sou nem de longe um usuário avançado do FL. Mas, a título de informação, consegui produzir a faixa Velkommen inteiramente no sistema do penguim e não tenho a intenção de voltar para o Windows.
-
É mesmo inconveniente quando um plugin ou outro não funciona, quando eu tenho que criar um Fruity Wrapper antes de usar um plugin 32bits, ou quando eu penso que talvez a DAW possa performar um pouco melhor nativamente no Windows. Porém, para mim, é um preço muito justo a se pagar para misturar nas minhas músicas um pouco desse suco de ideologia que é me desafiar a não usar o sistema da Microsoft.
-
Espero que você também encontre esse conforto—não na conveniência, mas em desafiar o molde com intenção. Excentricidade digna de um artista.
-
-
-
-
-
-
\ No newline at end of file
diff --git a/docs/posts/installing-fl-studio-on-linux/index.html b/docs/posts/installing-fl-studio-on-linux/index.html
deleted file mode 100644
index 8491c89..0000000
--- a/docs/posts/installing-fl-studio-on-linux/index.html
+++ /dev/null
@@ -1,162 +0,0 @@
-
-
-
-
-
-
- Adrian Victor - Installing FL Studio on linux.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Since I permanently moved to Linux in 2024, I have been impressed by the unwavering ability of the open-source community to bring to life in Linux complex software originally made for Windows. However, one of the programs cursed with the most stubborn and abstract errors in the old guard of Wine is FL Studio, a characteristic that made me, for a long time, think that Image-Line's DAW would not run at all on the penguin's system.
-
It turns out that FL runs on Linux, and runs very well, considering its complexity. Disregarding some visual problems, some VSTs that simply don't run, and a workaround to run 32-bit plugins, the experience of using FL Studio on Linux is quite solid. It seems that Valve, Wine, and the open-source community are not messing around.
-
Before getting into the formalities, I would like to define the scope of this tutorial. I'm making it with everything that fits in my recent memory working with FL on Linux. But it's also not a static post; if something is missing, send me an email and I'll update it.
-
-
Preparations
-
The tutorial will be done using Arch Linux on a computer with an Intel i5-1235U + 16GB of RAM setup. However, it's worth noting that, due to the nature of flatpak, the tutorial applies to any machine with the package manager installed.
-
The first step is to install the Bottles software, which is available under the name com.usebottles.bottles on Flathub. The simplest command to install the app on a system with access to Flathub (enabled by default on most distros, like mine) is flatpak install bottles. If you're not a fan of running commands, most app stores on Linux download flatpaks and come with Flathub already enabled—and know that this is the last time we'll run any command.
-
If you're not a fan of Flatpak, there's a Bottles package in the AUR. From what I understand, there are even some Bottles developers involved in maintaining that package.
-
After that, create a new bottle in Bottles. I recommend creating one in the games preset, since FL is somewhat visually complex.
-
Finally, before installation, let's install the dependencies, which are accessible through a button of the same name in the bottle's options. FL Studio has only two optional dependencies:
-
-
allfonts
-
Microsoft and Adobe fonts, helps with some text display issues in FL. I generally don't need to install it, but I have experienced unlabeled piano roll keys due to the lack of this dependency.
-
webview2
-
Necessary for FL Cloud, Gopher (AI), Help Manual, and possibly some other FL functions that pull a webview. I recommend not installing this dependency if you don't use any of these functions, because without it I noticed a performance gain.
-
-
We're ready to proceed with installing the DAW.
-
-
Installing FL Studio
-
Bottles already offers an FL installation package on the bottle's page, just click on Install Programs and search for FL Studio. However, this installation method didn't work for me; the installer froze on the dependencies. I believe that if you're successful with your installation, the result will be the same as what I'm about to describe below.
-
First, get an FL Studio installer, if you don't already have one. Image-Line offers an installer on its website.
-
With the installer in hand, just use the "Run executable..." button on the bottle's page and select your installer. In a few moments you should be in the FL Studio installation.
-
If everything goes right, the newly installed DAW should appear in the applications list with the name "FL64". You can already start it.
-
-
Initial Configuration
-
When you open FL Studio for the first time, you'll probably come across an error screen saying "The MIDI input device is already allocated. It may be in use by another application.", ignore the errors, and in the menu at the bottom labeled "Input", disable the inputs that have the FAIL label.
-
Much as I would love to say that FL Studio works perfectly on Linux, we're working in an environment not supported by Image-Line and certainly more unstable than its native systems. Therefore, I recommend that you enable the autosave option in the most aggressive mode.
-
-
Working with VSTs
-
Music production plugins are the biggest source of incompatibilities in our environment, but that doesn't mean that the majority don't work out of the box.
-
Beyond those that don't work, and potentially crash your FL Studio, there are plugins that don't behave right, like the example of Antares Auto-Tune Pro which works perfectly—given the exception that the interface and animations work strange and sluggish. I think this happens and repeats in so many plugins because the frameworks used to make their interfaces work somehow bizarrely that Soda is not optimized to run.
-
In any case, as for these stubborn plugins, the only recommendations I have to mitigate the problem are to avoid leaving them open as much as possible while doing other things, and—if possible—use alternatives that have more sense when it comes to interface.
-
-
32-bit VSTs
-
Now that FL Studio is working, you can try to open a 32-bit VST, and, doing so, see that it will probably freeze the DAW.
-
If you happen to freeze without proper backup on an important project, instead of closing FL Studio, you can use your task manager to kill the ILBridge.exe process. This is the process that freezes the DAW when you try to load a 32-bit plugin; it's the bridge that makes it work in 64-bit FL Studio—when interrupted, the DAW displays an error about not being able to load the plugin and returns to normal.
-
But there is indeed a way to run 32-bit plugins. Add a Fruity Wrapper in place of the plugin you want to add, switch to its options tab and leave it like that. Now right-click on the generator/effect you just added and replace it with the desired plugin. The options page should load. Click on the button labeled "Processing" and check "External window".
-
Done, the plugin should appear in a separate window from FL Studio and be working as expected.
-
-
Honorable Mentions
-
Below are some highlights worth knowing:
-
-
Virtual Drives
-
Bottles uses its own version of Wine called Soda, but deep down, it's still Wine. Therefore, you can benefit from Wine's virtual drive settings. In the bottle's options, when expanding the "Legacy Wine Tools" submenu, you'll find the "Configuration" option. When you click on it, a prehistoric-looking menu will appear; at the top you can see a tab named "Drives". There you can map different Windows drives to locations on your Linux system, and they will appear in the Wine file explorer and be accessible to applications.
-
-
Hardware Acceleration
-
If your FL Studio is running terribly, I recommend that you take a look at the "Use dedicated graphics card" option of your bottle, with it disabled my DAW freezes incessantly.
-
-
Conclusions
-
I'm not the most apt person to say how far the DAW's usability extends on Linux; I'm far from an advanced FL user. But, for your information, I was able to produce the track Velkommen entirely on the penguin's system and have no intention of going back to Windows.
-
It's really inconvenient when one plugin or another doesn't work, when I have to create a Fruity Wrapper before using a 32-bit plugin, or when I think that maybe the DAW could perform a little better natively on Windows. However, for me, it's a very fair price to pay to mix into my music a little bit of that ideology juice that is challenging myself not to use Microsoft's system.
-
I hope you also find that comfort—not in convenience, but in challenging the mold with intention. Eccentricity worthy of an artist.
-
-
-
-
-
-
\ No newline at end of file
diff --git a/docs/posts/verificacao-de-desenvolvedor-no-android/index.html b/docs/posts/verificacao-de-desenvolvedor-no-android/index.html
deleted file mode 100644
index 7ec775a..0000000
--- a/docs/posts/verificacao-de-desenvolvedor-no-android/index.html
+++ /dev/null
@@ -1,150 +0,0 @@
-
-
-
-
-
-
- Adrian Victor - Sobre as recentes mudanças nos requisitos de distribuição de apps no sistema Android feitas pela Google.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Android é aquele sistema operacional open-source que funciona bem para os usuários, e que os desenvolvedores amam. Sempre conhecido por quebrar barreiras e por ser aberto, expansível, versátil e até amigável com os mais nerds, coisa que nem todo sistema tem a cara e coragem de ser (iOS, Windows Phone). É assim que, por muito tempo, o Android foi visto em relação aos seus concorrentes: Um suspiro de ar puro em relação às práticas abusivas de empresas como a Apple. Mas parece que o Android que cultivamos por duas décadas não cabe mais no bolso dos executivos da Google, é livre demais, e isso criou barreiras éticas e técnicas no lucrativo caminho de exploração adotado pela sua desenvolvedora.
-
-
O que aconteceu com o Android?
-
-
A Google anunciou no final deste mês (Agosto de 2025) que a partir de Setembro de 2026 todos os apps instalados em dispositivos certificados (aqueles com o Android da Google e de bootloader bloqueado) precisarão passar pelo processo de verificação de desenvolvedor, processo cujo consiste da coleta de dados pessoais do indivíduo que vai distribuir a aplicação para que o mesmo possa ser identificado e atribuído a possíveis atividades maliciosas relacionadas ao seu software, o mesmo vale para empresas, que além disso precisam pagar uma taxa de 25 USD. O processo é forçado e necessário mesmo com a distribuição do app sendo feita fora das lojas oficiais da Google, o que trouxe óbvias preocupações sobre privacidade e liberdade dos usuários do sistema.
-
-
As implicações, justificativas e motivações da nova política
-
-
É importante analisar a justificativa e tentar entender a real motivação que a Google teve ao criar tal política de distribuição. Portanto começamos analisando a fala da Google:
-
-
"Para tornar o Android mais seguro, estamos protegendo o ambiente aberto que permite que desenvolvedores e usuários criem e se conectem com confiança. A nova verificação de desenvolvedor do Android é uma camada que detém atores maliciosos e faz com que seja mais difícil para que eles espalhem o mau."
-
-
Ela argumenta que as novas regras do sistema foram feitas com a intenção de aprimorar a segurança do usuário, evitando que software malicioso seja instalado em dispositivos Android certificados. Outra vez vemos segurança sendo usada como forma de justificar práticas controversas que limitam o poder do usuário final no seu próprio dispositivo. Essa também era a justificativa dada para a prática comprovadamente abusiva de bloqueio de sideloading de apps que levou a Google a perder seu caso no tribunal contra a empresa Epic Games, aqui vemos uma versão mais sofisticada da mesma.
-
-
É fácil simpatizar com a empresa quando as palavras são bem colocadas, mas como usuário ávido de softwares alternativos aos das big-techs, eu já vi exemplos de abuso de autoridade suficientes para concluir que as recentes ações da Google não passam de uma forma de recuperar parte, se não todo o controle que ela tinha sobre os dispositivos Android antes do caso mencionado anteriormente.
-
-
Um exemplo desses abusos é o caso do software kio-gdrive, que era amplamente utilizado para integrar o Google Drive ao explorador de arquivos do KDE, um ambiente para sistemas Linux. O software foi bloqueado de perguntar para os usuários se eles autorizavam o acesso a sua conta do Google Drive, no lugar do popup de permissão, a Google colocou um aviso informando os usuários que o software legítimo poderia ser malicioso, seguem os relatos dos desenvolvedores:
-
-
"Google bloqueou o nosso acesso a essa função em junho porque não conseguimos explicar o nosso uso da API de forma que eles julgam satisfatória. Por causa disso o sistema de permissões agora está bloqueado [...] tornando 25% das KAccounts KCM não funcionais. Remova as permissões [...] para que pelo menos o restante das integrações funcione (pelo menos em teoria)."
-
-
"É mais que estúpido (na minha humilde opinião) usuários individuais não poderem indicar que eles concordam com um software específico acessando seus dados supostamente sensíveis!"
-
-
Por mais que durante minhas pesquisas eu não tenha achado exatamente quais conversas foram trocadas pelo time de desenvolvedores—e com isso estou dando um grande benefício da dúvida para a Google—, é no mínimo suspeito que a Google não tenha concordado que um software que exerce suas funções primárias dentro do ambiente do Google Drive tem um motivo válido para usufruir do mesmo. Esse não foi um caso único, a Google age nas entrelinhas para controlar o que acontece ou não no Android, como quando apps compilados para versões mais antigas do sistema mostravam um aviso assustador sobre segurança pois mudanças recentes haviam colocado mais barreiras no sistema de permissões, porém os apps antigos não tinham suporte a elas. Um aviso sobre as permissões que seriam dadas ao aplicativo instalado, enfatizando que elas teriam que ser dadas ao aplicativo por ele não suportar as permissões opcionais é razoável, entretanto a mensagem exibida foi bem mais vaga do que deveria ser, o que convenientemente serviu para assustar os usuários que experimentavam sideloading e ajudou a manter o monopólio da Google Play Store.
-
-
Falando em avisos assustadores, chegou a hora de falar do Play Protect, um software embutido na Google Play Store que escaneia os apps instalados no seu dispositivo via sideloading e retorna o resultado para a base de dados da Google, uma ideia boa a primeira vista, levando em conta que a empresa respeita a escolha do usuário com o modelo opt-in, questionando o mesmo se ele gostaria de enviar seus apps instalados para a análise. O grande problema aparece quando a diferença entre as mensagens de detecção de malware e as que são acionadas pelo simples fato do software estar desatualizado é tão turva que causa dois efeitos graves, que juntos tornam o serviço de proteção da Google praticamente inútil para o usuário, enquanto mantém o monopólio da Google.
-
-
Suponhamos que você está experimentando sideloading pela primeira vez: você tenta instalar uma versão antiga de um software que você gosta. Você recebe a mensagem exacerbada sobre os supostos perigos de instalar o software desatualizado, desiste da instalação e instala a versão atual pela Google Play Store. Assim a Google força, mesmo que indiretamente, mais um usuário a usar sua loja, garantindo os lucrativos 30% de taxa nas transações dos apps.
-
-
Agora apresento um segundo cenário hipotético: você é um usuário mais avançado do sistema Android que tem total noção do que se trata o sideloading e adora instalar seus aplicativos de código aberto por fora da Play Store. Porém você clica em um link duvidoso e baixa um arquivo APK malicioso. Na hora de instalar você recebe o aviso do Play Protect, mas ele é tão frequente e exagerado (até mesmo quando nenhum malware foi detectado) que você acaba dispensando-o por já estar acostumado a ter que fazer isso (isso quando o usuário já não desativou ele nas configurações da Play Store). Agora o usuário tem um malware em seu dispositivo, o Play Protect foi inútil.
-
-
Em certas situações baixar um software por fora da loja da Google é a única opção, pois existem casos onde o desenvolvedor não quer publicar seu app na Play Store, tanto por questões de privacidade—já que os desenvolvedores são forçados a revelar certos dados pessoais para o público quando publicam seus apps—, quanto pela taxa imposta na publicação e vendas internas do aplicativo, que pode afastar desenvolvedores sustentados puramente por doações dos usuários. Pouco importa o motivo, os usuários devem ser livres para escolher o que roda em seus dispositivos.
-
-
De acordo com as informações disponibilizadas até agora, os desenvolvedores não precisarão tornar seus dados públicos caso optem por não distribuir sua aplicação na Play Store, e isso é o mínimo que a Google poderia fazer para tornar as novas políticas de distribuição mais justas para os desenvolvedores. A empresa também afirma que essa verificação não tem o objetivo de verificar o que há dentro da aplicação ou sua finalidade, portanto estaria sendo imposta puramente para barrar a distribuição contínua de malwares, resta ver se a afirmação se sustenta, tendo em vista que isso também pode ser uma ferramenta de abuso de poder conveniente para a Google, como outras serviram nos exemplos citados acima.
-
-
Próximos passos
-
-
Devemos ficar atentos a como essas novas políticas vão ser aplicadas, e como as mesmas afetarão o ecossistema do Android. Uma consequência inevitável das mudanças é que um número inestimável de aplicações abandonadas pelos desenvolvedores, que, se não fosse pelos novos requisitos, seriam perfeitamente funcionais serão perdidas de um dia para o outro. Nem todo software antigo se conecta à internet, nem todo software antigo representa um perigo constante ao usuário. A Google está tirando do usuário experiente a opção de assumir a responsabilidade e dizer: "Eu sei o que estou fazendo!", nos segurando como crianças, como se soubessem o que é melhor para todos.
-
-
O Android comercializado nos celulares é baseado no AOSP, o que significa que a força vital do Android é aberta, e isso a Google ainda não tirou dos usuários. Portanto pretendo fazer um outro post explicando como você pode recuperar o controle do seu dispositivo por meio de modificações no sistema, da forma mais simples, segura e estável possível, até as formas mais avançadas, caso você se sinta confiante.
-
-
-
-
-
-
\ No newline at end of file
diff --git a/docs/pt/blog/index.html b/docs/pt/blog/index.html
deleted file mode 100644
index 3be56fa..0000000
--- a/docs/pt/blog/index.html
+++ /dev/null
@@ -1,115 +0,0 @@
-
-
-
-
-
-
- Adrian Victor
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Parece que você encontrou meu website! Olá, sou Adrian Victor (ou tenkuma), um cara brasileiro que gosta de mexer com computadores, programas de computadores e enimatpirtlitemídios.
- Meu nome é Adrian Victor, mas on-line eu uso o nickname tenkuma. Estou no último ano do ensino médio e estudo informática. Meus hobbies são escutar e produzir música, programação, selfhosting, Linux, e muito mais.
-
-
Tenkuma, ou 天くま em japonês, significa urso celestial e foi um nome dado a mim por um amigo que eu já perdi contato há muito tempo. Sakata se foi, mas o nome ficou e se tornou parte integral da personalidade do meu eu digital até hoje.
Você pode enviar um correio eletrônico para (adrianvictor@disroot.org) ou me contactar por qualquer outro meio citado acima. Para assuntos relativos a projetos específicos, verifique o campo de contato do projeto, caso não haja um adicione +nomedoprojeto ao meu endereço de E-mail (exemplo: adrianvictor+projetolegal@disroot.org).
-
-
-
-
-
Música
-
Sempre amei música, e tenho achado produção musical algo muito interessante ultimamente. Publico minhas músicas como tenkuma, junto com meus amigos formei a Margarina Records—uma label amadora.
-
Você pode conferir minhas músicas mais recentes no meu perfil do Genius.
Estou estudando informática no IFC (SC, Brazil) mas no meu tempo livre tenho projetos como programas de computador, plugins para Minecraft, servidores Minecraft, etc... Todos meus projetos públicos estão disponíveis no meu perfil do GitHub.
Reprodutor de música nativo para dispositivos Android que se conecta a servidores de mídia Jellyfin. O código é baseado no repositório arquivado do Gelli, que por sua vez se baseia em uma versão antiga do Phonograph.
Este plugin PaperMC integra-se ao VaultUnlocked para fornecer um sistema de economia único baseado em itens para o seu servidor Minecraft. Em vez de depender apenas de saldos virtuais, os jogadores usam itens do jogo como moeda física, adicionando uma camada de imersão e realismo à sua economia.
Eye of Nemesis é um plugin que permite aos administradores de servidores escrever políticas que negarão ou permitirão (lista negra/branca) que os jogadores façam coisas específicas com base no valor dos nós.
- Essa é uma coleção de mais de 6500 GIFs e PNGs no formato 88x31. No final dos anos 1990 e começo dos 2000 era muito comum usar essas imagens no seu site pessoal.
-
- Andrew é um engenheiro de software, entusiasta de malware e, mais importante, uma estranha e alta criatura. Cresci com os seus videos e ele é uma grande inspiração para mim.
-
- Com Lucida, você pode baixar musica diretamente de Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, e Yandex Music em alta qualidade de graça. Sem pegadinhas, sem anúncios obrigatórios, sem enrolação. Como que funciona?
-
A API do Prof. Rodrigo Ribeiro permite que o client envie uma imagem, assim retornando o resultado de uma leitura óptica realizada sobre a mesma com inteligência artificial. Esse client lê o resultado e o mostra de forma simples para o usuário.
Adrian Victor & Arthur Borges - 8/26/2025 (editado por último em )
-
-
-
-
-
-
O que é o protocolo, sua função e histórico
-
O Telnet (do inglês TELecommunication NETwork) é um protocolo de rede da pilha
-TCP/IP que permite a comunicação remota entre computadores em modo texto. Sua
-função principal é proporcionar uma sessão interativa, em que um usuário pode
-acessar e controlar outro dispositivo como se estivesse em um terminal local.
-
Criado em 1969, o Telnet foi um dos primeiros protocolos desenvolvidos para a
-ARPANET (a rede que deu origem à Internet) e tornou-se fundamental para a
-administração de sistemas e dispositivos nas décadas de 1970, 1980 e 1990. Com o
-tempo, caiu em desuso devido à falta de segurança, sendo substituído por
-alternativas mais modernas, como o SSH (Secure Shell).
-
Implementação
-
Porta padrão: 23/TCP.
-Funciona na camada de aplicação do modelo OSI.
-Formato: Baseado em troca de caracteres ASCII, sem criptografia.
-RFC: Definido pela RFC 854 (1983).
-Arquitetura: Segue o modelo cliente-servidor
-
Funcionamento
-
Na prática, o Telnet funciona de maneira relativamente simples. O processo começa
-quando o cliente estabelece uma conexão TCP com o servidor por meio da porta 23.
-Em seguida, uma sessão de terminal remoto é iniciada e o usuário deve fornecer
-suas credenciais, como nome de usuário e senha. Após a autenticação, os
-comandos digitados no cliente são transmitidos em texto puro ao servidor, que os
-processa e retorna a saída correspondente. A sessão permanece ativa enquanto o
-usuário desejar, sendo encerrada normalmente com comandos como exit ou logout
-
Cenários de uso
-
Durante muitos anos, o Telnet foi amplamente utilizado para acesso remoto a
-servidores Unix, Linux e Windows, especialmente em versões mais antigas desses
-sistemas. Também se tornou bastante comum na administração de dispositivos de
-rede, como roteadores e switches, até que o SSH passou a ser adotado como
-padrão. Além disso, grandes computadores centrais, conhecidos como mainframes,
-e alguns dispositivos legados ainda utilizam Telnet até hoje. Outra aplicação prática
-do protocolo está em ambientes educacionais e no diagnóstico de redes, onde é
-usado para testar portas abertas e verificar conectividade de serviços, como ao
-executar “telnet servidor.com 80” para checar se a porta de um servidor web está em
-funcionamento.
-
Criptografia: o problema inerente
-
O Telnet não possui criptografia nativa, o que o torna extremamente vulnerável. Para
-solucionar esse problema, surgiram alternativas mais seguras. A principal delas é o
-SSH (Secure Shell), desenvolvido nos anos 1990 como um substituto direto do
-Telnet. O SSH oferece as mesmas funcionalidades, mas garante a proteção dos
-dados por meio de autenticação forte e criptografia de todo o tráfego. Outra
-possibilidade, embora menos comum, é o uso de SSL/TLS para tunelar sessões
-Telnet, mas na prática essa abordagem raramente é utilizada.
-
Vantagens e desvantagens
-
Entre as vantagens do Telnet, destacam-se sua simplicidade, baixo consumo de
-recursos e compatibilidade com diferentes sistemas antigos, o que facilitou sua
-adoção ao longo dos anos. Contudo, essas qualidades são superadas por suas
-desvantagens. A principal é a ausência de criptografia, que expõe todos os dados
-transmitidos, incluindo senhas, em texto puro. Isso o torna vulnerável a ataques
-como o sniffing, que captura pacotes de rede, e o hijacking, que sequestra sessões
-ativas. Por esse motivo, o Telnet é considerado obsoleto e inseguro para uso em
-redes abertas, como a própria Internet.
-
Relação com outros protocolos
-
O Telnet faz parte da família de protocolos da pilha TCP/IP e utiliza o TCP para
-garantir a confiabilidade na comunicação. Assim como outros protocolos dessa pilha,
-como HTTP, FTP e SMTP, ele se baseia em conexões estáveis para realizar suas
-funções, mas seu diferencial sempre foi a interatividade em modo terminal. No
-entanto, devido às falhas de segurança, acabou sendo substituído por seu sucessor
-natural, o SSH, que manteve a mesma base conceitual do Telnet, mas adicionou
-camadas robustas de proteção.
-
Exemplo funcional
-
Abaixo há um simulador de conexão Telnet feito em JavaScript.
It seems that you have found my website! Hi, I am Adrian Victor (or tenkuma), a Brazilian guy who likes to mess around with computers, computer programs and enimatpyrtlyhtemids.
- My name is Adrian Victor, but I go by tenkuma on-line. I'm in high school's last year, also studying computing. My hobbies are music and music production, programming, selfhosting, Linux, and a lot more.
-
-
Tenkuma, or 天くま in japanese, means celestial bear and was given by a friend of mine that I lost contact a long time ago. Sakata is gone, but the name stayed and turned into an integral part of my digital self.
You can message me on my E-mail (adrianvictor@disroot.org) or feel free to get in touch through any of the other places mentioned above. For project-specific subjects, check for the project's contact field or if there's no such field add +projectname to my E-mail address (example: adrianvictor+coolproject@disroot.org).
-
Please, avoid reaching me through ways not mentioned above :)
-
-
-
-
-
My Music
-
I've always loved music, and lately I've been finding music production very interesting. I publish my songs as tenkuma, and have founded an amateur label called Margarina Records with my friends.
I am studying computing at IFC (SC, Brazil) but in my free time I have some projects like computer applications, Minecraft plugins, Minecraft servers, etc... Anything that is public should be in my GitHub profile.
Native music player for Android devices that connects to Jellyfin media servers. The code is based on Gelli's archived repository, which is based on an old version of Phonograph.
This PaperMC plugin integrates with VaultUnlocked to provide a unique, item-based economy system for your Minecraft server. Instead of relying solely on virtual balances, players use in-game items as physical currency, adding a layer of immersion and realism to your economy.
Eye of Nemesis is a plugin that allows server admins to write policies that will deny or allow (black/whitelist) players to do specific things based on the value of nodes.
- This website is a collection with over 6500 GIF's and PNG's in 88x31 format. In the late 1990 and begin of the 2000's it was very common to use these pictures on your personal website.
-
- Andrew is a software engineer, a malware enthusiast and most importantly, a weird tall creature. I've grown up with his videos and he's a great inspiration for me.
-
- With Lucida, you can download music directly from Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, and Yandex Music in high quality for free. No catches, no mandatory ads, no BS. How does it work?
-
+
\ No newline at end of file
diff --git a/misc/88x31/en.json b/misc/88x31/en.json
new file mode 100644
index 0000000..2149d7d
--- /dev/null
+++ b/misc/88x31/en.json
@@ -0,0 +1,6 @@
+{
+ "pageDescription": "My collection of 88x31 GIFs and images.",
+ "intro": "This is the collection of 88x31 GIFs and images I've downloaded across the web.",
+ "others": "Others",
+ "me": "Made by me"
+}
\ No newline at end of file
diff --git a/misc/88x31/index.njk b/misc/88x31/index.njk
new file mode 100644
index 0000000..144be82
--- /dev/null
+++ b/misc/88x31/index.njk
@@ -0,0 +1,29 @@
+---
+layout: base.njk
+pagination:
+ data: languages
+ size: 1
+ alias: langKey
+
+pageTitle: 88x31
+tags: misc
+---
+{% from "macros.njk" import i88x31 with context %}
+
+
+
+
88x31
+
{{ t.intro }}
+
+
+
{{ t.me }}
+
+ {{ i88x31("tenkuma.gif") }}
+
+
{{ t.others }}
+
+ {% for image in collections.88x31 %}
+ {{ i88x31(image.fileSlug) }}
+ {% endfor %}
+
+
\ No newline at end of file
diff --git a/misc/88x31/pt.json b/misc/88x31/pt.json
new file mode 100644
index 0000000..9beb933
--- /dev/null
+++ b/misc/88x31/pt.json
@@ -0,0 +1,6 @@
+{
+ "pageDescription": "Minha coleção de GIFs e imagens 88x31.",
+ "intro": "Essa é uma coleção de GIFs e imagens 88x31 que eu baixei pela internet.",
+ "others": "Outros",
+ "me": "Feitos por mim"
+}
\ No newline at end of file
diff --git a/misc/bookmarks/common.json b/misc/bookmarks/common.json
new file mode 100644
index 0000000..3f085ae
--- /dev/null
+++ b/misc/bookmarks/common.json
@@ -0,0 +1,158 @@
+{
+ "links": {
+ "downloads": {
+ "88x31": [
+ "iglooftp.gif",
+ "eftpbutton.gif"
+ ],
+ "links": [
+ {
+ "name": "MalwareWatch",
+ "link": "https://malwarewatch.org/",
+ "description": {
+ "pt": "Website do Enderman. Tem download de vários softwares úteis, imagens de sistemas operacionais e malware.",
+ "en": "Enderman's website. Provides download to various useful softwares, operating system images and malware."
+ }
+ },
+ {
+ "name": "Free Images",
+ "link": "https://free-images.com/",
+ "description": {
+ "pt": "Pesquise por milhões de imagens, artes e vetores. Todas as imagens são de domínio público ou sobre CC0. Livre para baixar e livre para usar.",
+ "en": "Search through millions of free stock photos, art and vector images. Every image is Public Domain or CC0. Free to Download and Free to Use."
+ }
+ },
+ {
+ "name": "88x31",
+ "link": "https://88x31.nl/",
+ "description": {
+ "pt": "Essa é uma coleção de mais de 6500 GIFs e PNGs no formato 88x31. No final dos anos 1990 e começo dos 2000 era muito comum usar essas imagens no seu site pessoal.",
+ "en": "This website is a collection with over 6500 GIF's and PNG's in 88x31 format. In the late 1990 and begin of the 2000's it was very common to use these pictures on your personal website."
+ },
+ "88x31": [
+ "WEBP.gif",
+ "blank.gif"
+ ]
+ }
+ ]
+ },
+ "profiles": {
+ "links": [
+ {
+ "name": "Mr. Nando",
+ "link": "https://www.youtube.com/@mrnandokk",
+ "description": {
+ "pt": "Meu amigo Fernando, ele faz músicas e vídeos de Minecraft e speedrun.",
+ "en": "My friend Fernando, he makes music and YouTube videos of Minecraft and speedrun."
+ }
+ },
+ {
+ "name": "Endermanch",
+ "link": "https://enderman.ch/",
+ "description": {
+ "pt": "Andrew é um engenheiro de software, entusiasta de malware e, mais importante, uma estranha e alta criatura. Cresci com os seus videos e ele é uma grande inspiração para mim.",
+ "en": "Andrew is a software engineer, a malware enthusiast and most importantly, a weird tall creature. I've grown up with his videos and he's a great inspiration for me."
+ }
+ }
+ ]
+ },
+ "tools": {
+ "links": [
+ {
+ "name": "Excalidraw",
+ "link": "https://excalidraw.com/",
+ "description": {
+ "pt": "Quadro branco sem distrações.",
+ "en": "Whiteboard with no bloat."
+ }
+ },
+ {
+ "name": "Postimages",
+ "link": "https://postimages.org/",
+ "description": {
+ "pt": "Gere links permantes de suas imagens para forums, blogs e redes sociais.",
+ "en": "Get permanent links of your images for forums, blogs, and social media."
+ }
+ },
+ {
+ "name": "uBlock Origin",
+ "link": "https://github.com/gorhill/uBlock#ublock-origin",
+ "description": {
+ "pt": "Um bloqueador eficiente para Chromium e Firefox. Rápido e pequeno.",
+ "en": "An efficient blocker for Chromium and Firefox. Fast and lean."
+ },
+ "88x31": ["ublock-now.png"]
+ }
+ ]
+ },
+ "games": {
+ "88x31": [
+ "gb.gif",
+ "amd_powered.gif"
+ ],
+ "links": [
+ {
+ "name": "SteamGridDB",
+ "link": "https://www.steamgriddb.com/",
+ "description": {
+ "pt": "Baixe e compartilhe recursos visuais de jogos e personalize sua biblioteca de jogos.",
+ "en": "Download and share custom video game assets and personalize your gaming library."
+ }
+ }
+ ]
+ },
+ "music": {
+ "88x31": [
+ "rave.gif",
+ "2014-rave.gif",
+ "wmpfree.gif",
+ "wmp.gif",
+ "wmp9.gif",
+ "wmp10.gif",
+ "wmp11.gif",
+ "ffmpeg.gif",
+ "ymusic.gif"
+ ],
+ "links": [
+ {
+ "name": "CVGM Radio",
+ "link": "https://radio.cvgm.net/demovibes/",
+ "description": {
+ "pt": "Seu lar para música relacionada a video games, demo scene e computadores.",
+ "en": "Your home for video game, demo scene and computer related music."
+ }
+ }
+ ]
+ },
+ "piracy": {
+ "88x31": ["piracy.png"],
+ "links": [
+ {
+ "name": "Nyaa",
+ "link": "https://nyaa.si/",
+ "description": {
+ "pt": "Um tracker de animes, mangás e coisas relacionadas.",
+ "en": "A tracker of animes, mangas and related stuff."
+ },
+ "88x31": ["rukia.gif"]
+ },
+ {
+ "name": "Lucida",
+ "link": "https://lucida.to/",
+ "description": {
+ "pt": "Com Lucida, você pode baixar musica diretamente de Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, e Yandex Music em alta qualidade de graça. Sem pegadinhas, sem anúncios obrigatórios, sem enrolação. Como que funciona?",
+ "en": "With Lucida, you can download music directly from Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, and Yandex Music in high quality for free. No catches, no mandatory ads, no BS. How does it work?"
+ }
+ },
+ {
+ "name": "DoubleDouble",
+ "link": "https://doubledouble.top/",
+ "description": {
+ "pt": "Baixe musica diretamente de Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, e Yandex Music em alta qualidade de graça.",
+ "en": "Download music directly from Amazon Music, Soundcloud, Qobuz, Deezer and Tidal for free."
+ }
+ }
+ ]
+ }
+ }
+}
\ No newline at end of file
diff --git a/misc/bookmarks/en.json b/misc/bookmarks/en.json
new file mode 100644
index 0000000..b7ae767
--- /dev/null
+++ b/misc/bookmarks/en.json
@@ -0,0 +1,11 @@
+{
+ "pageTitle": "Bookmarks",
+ "pageDescription": "My collection of interesting websites/pages.",
+ "intro": "A list of useful or cool websites/pages curated by me. Divided in sections for an easier navigation.",
+ "profiles": "Profiles",
+ "downloads": "Downloads",
+ "games": "Games",
+ "tools": "Tools",
+ "music": "Music",
+ "piracy": "Piracy"
+}
\ No newline at end of file
diff --git a/misc/bookmarks/index.njk b/misc/bookmarks/index.njk
new file mode 100644
index 0000000..ec34a11
--- /dev/null
+++ b/misc/bookmarks/index.njk
@@ -0,0 +1,49 @@
+---
+layout: base.njk
+pagination:
+ data: languages
+ size: 1
+ alias: langKey
+tags: misc
+background: towers.jpg
+backgroundOpacity: .2
+---
+{% from "macros.njk" import i88x31 with context %}
+
+
+
+
{{ t.pageTitle }}
+
{{ t.intro }}
+ {{ i88x31("BOOKMARKthispageNOW.png") }}
+
+
+ {% for sectionName, section in c.links %}
+
+
{{ t[sectionName] }}
+ {% if section.88x31 %}
+
+ {% for 88x31 in section.88x31 %}
+ {{ i88x31(88x31) }}
+ {% endfor %}
+
+---
+postTitle: "On the Recent Changes to App Distribution Requirements in the Android System by Google."
+postId: developer-verification
+langKey: en
+layout: post.njk
+date: 2025-08-30
+background: android-jellybean.jpg
+backgroundOpacity: .35
+---
+
Recap
Android is that open-source operating system that works well for users and is loved by developers. Always known for breaking barriers and being open, expandable, versatile, and even friendly to power users–something not every system dares to be (iOS, Windows Phone). For a long time, Android was seen this way compared to its competitors: a breath of fresh air against the abusive practices of companies like Apple. But it seems the Android we've nurtured for two decades no longer fits in the pockets of Google executives; it is too free, creating ethical and technical barriers to the profitable exploitation path adopted by its developer.
@@ -142,10 +48,4 @@ justify our API usage to their satisfaction. As such, the permission is now bloc
We must watch how these policies are applied and how they affect the Android ecosystem. An inevitable consequence is that countless abandoned apps, perfectly functional without the new requirements, will disappear overnight. Not all old software connects to the internet, and not all represents a constant threat. Google is taking away the option for experienced users to take responsibility and say: "I know what I'm doing!", treating us as if they know what's best for everyone.
-
The commercial Android on phones is based on the AOSP, meaning Android's core remains open, and Google hasn't taken that from users yet. I plan to write another post explaining how to regain control of your device through system modifications, from the simplest, safest, most stable methods to advanced approaches, if you feel confident.
-
-
-
-
-
-
\ No newline at end of file
+
The commercial Android on phones is based on the AOSP, meaning Android's core remains open, and Google hasn't taken that from users yet. I plan to write another post explaining how to regain control of your device through system modifications, from the simplest, safest, most stable methods to advanced approaches, if you feel confident.
\ No newline at end of file
diff --git a/posts/instalando-fl-studio-no-linux/index.html b/posts/instalando-fl-studio-no-linux.html
similarity index 64%
rename from posts/instalando-fl-studio-no-linux/index.html
rename to posts/instalando-fl-studio-no-linux.html
index 72006e8..1431010 100644
--- a/posts/instalando-fl-studio-no-linux/index.html
+++ b/posts/instalando-fl-studio-no-linux.html
@@ -1,127 +1,18 @@
-
-
-
-
-
-
- Adrian Victor - Instalando FL Studio no Linux.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+---
+postTitle: "Instalando FL Studio no Linux."
+postId: fl-linux-install
+postVideoLink: "https://www.youtube.com/watch?v=6bnNAnSY9Uo"
+postVideoTitle: "Como instalar o FL Studio no Linux?"
+postVideoImage: "/thumbnails/fl_studio_linux.png"
+postVideoWebsite: "YouTube"
+postVideoDuration: "5:53"
+langKey: pt
+layout: post.njk
+date: 2026-04-20
+background: fl_screenshot_no_text.png
+backgroundOpacity: .35
+---
+
Prólogo
Desde que mudei permanentemente para o Linux em 2024, venho me impressionando com a capacidade inabalável da comunidade open-source de trazer a vida no Linux softwares complexos feitos originalmente para Windows. Entretanto, um dos programas amaldiçoados com os mais ímpetos e abstratos erros na velha guarda do Wine é o FL Studio, caracteristica essa que fez com que eu, por muito tempo, achasse que a DAW da Image-Line não iria rodar de jeito nenhum no sistema do penguim.
Acontece que o FL roda no Linux, e roda muito bem, considerando a sua complexidade. Descartando uns problemas visuais, algumas VSTs que simplesmente não rodam e uma gambiarra para rodar plugins 32-bits, a experiência de usar o FL Studio no Linux é bem sólida. Parece que a Valve, Wine e comunidade open-source não estão para brincadeira mesmo.
Antes de ir às formalidades, gostaria de definir o escopo desse tutorial. Faço ele com tudo o que cabe na minha memória recente trabalhando com o FL no Linux. Mas também não é uma postagem estática; se estiver faltando alguma coisa me mande um e-mail e eu atualizo.
@@ -170,10 +61,4 @@
Conclusões
Não sou a pessoa mais apta para dizer até onde a usabilidade da DAW se extende no Linux; não sou nem de longe um usuário avançado do FL. Mas, a título de informação, consegui produzir a faixa Velkommen inteiramente no sistema do penguim e não tenho a intenção de voltar para o Windows.
É mesmo inconveniente quando um plugin ou outro não funciona, quando eu tenho que criar um Fruity Wrapper antes de usar um plugin 32bits, ou quando eu penso que talvez a DAW possa performar um pouco melhor nativamente no Windows. Porém, para mim, é um preço muito justo a se pagar para misturar nas minhas músicas um pouco desse suco de ideologia que é me desafiar a não usar o sistema da Microsoft.
-
Espero que você também encontre esse conforto—não na conveniência, mas em desafiar o molde com intenção. Excentricidade digna de um artista.
-
-
-
-
-
-
\ No newline at end of file
+
Espero que você também encontre esse conforto—não na conveniência, mas em desafiar o molde com intenção. Excentricidade digna de um artista.
\ No newline at end of file
diff --git a/posts/installing-fl-studio-on-linux/index.html b/posts/installing-fl-studio-on-linux.html
similarity index 66%
rename from posts/installing-fl-studio-on-linux/index.html
rename to posts/installing-fl-studio-on-linux.html
index 8491c89..623c1bf 100644
--- a/posts/installing-fl-studio-on-linux/index.html
+++ b/posts/installing-fl-studio-on-linux.html
@@ -1,107 +1,13 @@
-
-
-
-
-
-
- Adrian Victor - Installing FL Studio on linux.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+---
+postTitle: "Installing FL Studio on linux."
+postId: fl-linux-install
+langKey: en
+layout: post.njk
+date: 2026-04-20
+background: fl_screenshot_no_text.png
+backgroundOpacity: .35
+---
+
Prologue
Since I permanently moved to Linux in 2024, I have been impressed by the unwavering ability of the open-source community to bring to life in Linux complex software originally made for Windows. However, one of the programs cursed with the most stubborn and abstract errors in the old guard of Wine is FL Studio, a characteristic that made me, for a long time, think that Image-Line's DAW would not run at all on the penguin's system.
It turns out that FL runs on Linux, and runs very well, considering its complexity. Disregarding some visual problems, some VSTs that simply don't run, and a workaround to run 32-bit plugins, the experience of using FL Studio on Linux is quite solid. It seems that Valve, Wine, and the open-source community are not messing around.
Before getting into the formalities, I would like to define the scope of this tutorial. I'm making it with everything that fits in my recent memory working with FL on Linux. But it's also not a static post; if something is missing, send me an email and I'll update it.
@@ -153,10 +59,4 @@
Conclusions
I'm not the most apt person to say how far the DAW's usability extends on Linux; I'm far from an advanced FL user. But, for your information, I was able to produce the track Velkommen entirely on the penguin's system and have no intention of going back to Windows.
It's really inconvenient when one plugin or another doesn't work, when I have to create a Fruity Wrapper before using a 32-bit plugin, or when I think that maybe the DAW could perform a little better natively on Windows. However, for me, it's a very fair price to pay to mix into my music a little bit of that ideology juice that is challenging myself not to use Microsoft's system.
-
I hope you also find that comfort—not in convenience, but in challenging the mold with intention. Eccentricity worthy of an artist.
-
-
-
-
-
-
\ No newline at end of file
+
I hope you also find that comfort—not in convenience, but in challenging the mold with intention. Eccentricity worthy of an artist.
\ No newline at end of file
diff --git a/posts/posts.11tydata.js b/posts/posts.11tydata.js
new file mode 100644
index 0000000..9b619b7
--- /dev/null
+++ b/posts/posts.11tydata.js
@@ -0,0 +1,12 @@
+let data = {
+ layout: "_includes/post.njk",
+ eleventyComputed: {
+ lastModified: function(data) {
+ const fs = require('fs');
+ const stats = fs.statSync(data.page.inputPath);
+ return stats.mtime;
+ }
+ }
+};
+
+module.exports = data;
diff --git a/posts/verificacao-de-desenvolvedor-no-android/index.html b/posts/verificacao-de-desenvolvedor-no-android.html
similarity index 68%
rename from posts/verificacao-de-desenvolvedor-no-android/index.html
rename to posts/verificacao-de-desenvolvedor-no-android.html
index 7ec775a..f39b84a 100644
--- a/posts/verificacao-de-desenvolvedor-no-android/index.html
+++ b/posts/verificacao-de-desenvolvedor-no-android.html
@@ -1,107 +1,13 @@
-
-
-
-
-
-
- Adrian Victor - Sobre as recentes mudanças nos requisitos de distribuição de apps no sistema Android feitas pela Google.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+---
+postTitle: "Sobre as recentes mudanças nos requisitos de distribuição de apps no sistema Android feitas pela Google."
+postId: developer-verification
+layout: post.njk
+date: 2025-08-30
+background: android-jellybean.jpg
+backgroundOpacity: .35
+langKey: pt
+---
+
Recapitulando
Android é aquele sistema operacional open-source que funciona bem para os usuários, e que os desenvolvedores amam. Sempre conhecido por quebrar barreiras e por ser aberto, expansível, versátil e até amigável com os mais nerds, coisa que nem todo sistema tem a cara e coragem de ser (iOS, Windows Phone). É assim que, por muito tempo, o Android foi visto em relação aos seus concorrentes: Um suspiro de ar puro em relação às práticas abusivas de empresas como a Apple. Mas parece que o Android que cultivamos por duas décadas não cabe mais no bolso dos executivos da Google, é livre demais, e isso criou barreiras éticas e técnicas no lucrativo caminho de exploração adotado pela sua desenvolvedora.
@@ -141,10 +47,4 @@
Devemos ficar atentos a como essas novas políticas vão ser aplicadas, e como as mesmas afetarão o ecossistema do Android. Uma consequência inevitável das mudanças é que um número inestimável de aplicações abandonadas pelos desenvolvedores, que, se não fosse pelos novos requisitos, seriam perfeitamente funcionais serão perdidas de um dia para o outro. Nem todo software antigo se conecta à internet, nem todo software antigo representa um perigo constante ao usuário. A Google está tirando do usuário experiente a opção de assumir a responsabilidade e dizer: "Eu sei o que estou fazendo!", nos segurando como crianças, como se soubessem o que é melhor para todos.
-
O Android comercializado nos celulares é baseado no AOSP, o que significa que a força vital do Android é aberta, e isso a Google ainda não tirou dos usuários. Portanto pretendo fazer um outro post explicando como você pode recuperar o controle do seu dispositivo por meio de modificações no sistema, da forma mais simples, segura e estável possível, até as formas mais avançadas, caso você se sinta confiante.
-
-
-
-
-
-
\ No newline at end of file
+
O Android comercializado nos celulares é baseado no AOSP, o que significa que a força vital do Android é aberta, e isso a Google ainda não tirou dos usuários. Portanto pretendo fazer um outro post explicando como você pode recuperar o controle do seu dispositivo por meio de modificações no sistema, da forma mais simples, segura e estável possível, até as formas mais avançadas, caso você se sinta confiante.
\ No newline at end of file
diff --git a/pt/blog/index.html b/pt/blog/index.html
deleted file mode 100644
index 3be56fa..0000000
--- a/pt/blog/index.html
+++ /dev/null
@@ -1,115 +0,0 @@
-
-
-
-
-
-
- Adrian Victor
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Parece que você encontrou meu website! Olá, sou Adrian Victor (ou tenkuma), um cara brasileiro que gosta de mexer com computadores, programas de computadores e enimatpirtlitemídios.
- Meu nome é Adrian Victor, mas on-line eu uso o nickname tenkuma. Estou no último ano do ensino médio e estudo informática. Meus hobbies são escutar e produzir música, programação, selfhosting, Linux, e muito mais.
-
-
Tenkuma, ou 天くま em japonês, significa urso celestial e foi um nome dado a mim por um amigo que eu já perdi contato há muito tempo. Sakata se foi, mas o nome ficou e se tornou parte integral da personalidade do meu eu digital até hoje.
Você pode enviar um correio eletrônico para (adrianvictor@disroot.org) ou me contactar por qualquer outro meio citado acima. Para assuntos relativos a projetos específicos, verifique o campo de contato do projeto, caso não haja um adicione +nomedoprojeto ao meu endereço de E-mail (exemplo: adrianvictor+projetolegal@disroot.org).
-
-
-
-
-
Música
-
Sempre amei música, e tenho achado produção musical algo muito interessante ultimamente. Publico minhas músicas como tenkuma, junto com meus amigos formei a Margarina Records—uma label amadora.
-
Você pode conferir minhas músicas mais recentes no meu perfil do Genius.
Estou estudando informática no IFC (SC, Brazil) mas no meu tempo livre tenho projetos como programas de computador, plugins para Minecraft, servidores Minecraft, etc... Todos meus projetos públicos estão disponíveis no meu perfil do GitHub.
Reprodutor de música nativo para dispositivos Android que se conecta a servidores de mídia Jellyfin. O código é baseado no repositório arquivado do Gelli, que por sua vez se baseia em uma versão antiga do Phonograph.
Este plugin PaperMC integra-se ao VaultUnlocked para fornecer um sistema de economia único baseado em itens para o seu servidor Minecraft. Em vez de depender apenas de saldos virtuais, os jogadores usam itens do jogo como moeda física, adicionando uma camada de imersão e realismo à sua economia.
Eye of Nemesis é um plugin que permite aos administradores de servidores escrever políticas que negarão ou permitirão (lista negra/branca) que os jogadores façam coisas específicas com base no valor dos nós.
- Essa é uma coleção de mais de 6500 GIFs e PNGs no formato 88x31. No final dos anos 1990 e começo dos 2000 era muito comum usar essas imagens no seu site pessoal.
-
- Andrew é um engenheiro de software, entusiasta de malware e, mais importante, uma estranha e alta criatura. Cresci com os seus videos e ele é uma grande inspiração para mim.
-
- Com Lucida, você pode baixar musica diretamente de Qobuz, Tidal, Soundcloud, Deezer, Amazon Music, e Yandex Music em alta qualidade de graça. Sem pegadinhas, sem anúncios obrigatórios, sem enrolação. Como que funciona?
-
A API do Prof. Rodrigo Ribeiro permite que o client envie uma imagem, assim retornando o resultado de uma leitura óptica realizada sobre a mesma com inteligência artificial. Esse client lê o resultado e o mostra de forma simples para o usuário.
Adrian Victor - 1/12/2026 (editado por último em )
-
-
-
-
-
-
Antes de tudo, quero dar boas vindas a qualquer novato que esteja lendo esse documento, o IF é uma grande oportunidade que felizmente você não deixou passar! Não vou me extender muito nesse tópico pois tenho certeza que vocês vão ouvir depoimentos de ex-alunos bem-sucedidos ao longo do período letivo.
-
Estou organizando esse documento para evitar que os veteranos tenham que explicar tudo para cada novato que apresentar a mesma dúvida, centralizando o conteúdo para facilitar quando você dá aquela esquecida sobre como algo funciona. Ao mesmo tempo, não quero que ele substitua o contato que você poderia ter com um veterano, não deixe de conversar e fazer novas amizades!
-
Para correções ou dúvidas que não sanei aqui, você pode me mandar um e-mail (adrianvictor@disroot.org) ou me contactar por qualquer outro lugar que você conseguir, vou corrigir/adicionar o mais rápido possível. Caso algum veterano se interesse em escrever algo para complementar essa postagem, fico feliz em adicionar seu texto ou link aqui.
-
-
O SIGAA
-
SIGAA (Sistema Integrado Para Ferrar com os Alunos) vai ser o lugar onde você vê as suas notas, frequências, aplica para auxílios e entrega trabalhos – caso você encontre um professor que ainda tem sanidade pra usar essa coisa além do que se faz obrigatório.
-
Ofensas à parte, vamos dar uma olhada nas partes importantes do sistema.
-
Login e cadastro
-
-
-
1 - Tela de login do SIGAA.
-
-
Após acessar o site do SIGAA, você deve ver a tela de login mostrada na imagem. Antes de tudo, verifique se você está no SIGAA dos alunos.(1.1)
-
Caso você tenha um login, o acesso é bem simples, apenas preencha os campos de usuário e senha(1.2) e confirme. O login expira em 1 minuto de inatividade.
-
-
No caso de você não possuir um cadastro, use o link abaixo da tela de login(1.3) para abrir o formulário de cadastro.
-
-
Tela Principal
-
-
-
2 - Tela inicial do SIGAA
-
-
-
A tela principal do SIGAA é uma bagunça, mas você não vai usar nem metade do que tem nela, por isso vamos dar uma olhada somente nas funcionalidades principais dela.
-
-
No cabeçalho(2.1) você tem acesso a coisas como boletim, atestado de frequência, etc... Também é o lugar que você gerencia seus auxílios.
-
-
É possível gerenciar seu perfil público e dados na barra lateral(2.2), assim como acessar alguns links úteis (como o da biblioteca digital). O seu perfil fica visível em postagens e respostas enviadas no forum do SIGAA.(2.6) Por algum motivo, minha foto de perfil some toda hora, já não me dou mais o trabalho de colocar de volta.
-
-
Não cadastre um e-mail que você usa com frequência no SIGAA, pois ele vai entupir sua caixa de entrada com SPAM. E os e-mails que seriam úteis chegam tão tarde que perdem a utilidade (já recebemos e-mail sobre cancelamento de aulas com um mês de atraso). Se você quiser manter seu e-mail pessoal no SIGAA, já que eles realmente mandam alguma coisa importante uma vez ou outra por ano, configure um filtro para o endereço do IF (ifc.edu.br) que joga todos os e-mails do SIGAA para uma caixa diferente no seu e-mail.
-
-
Continuando, chegamos na lista de matérias do seu ano letivo(2.5), você vai usar ela para acessar a página da matéria.
-
-
E por fim, temos o forum(2.6), que eu incluí por dó, pois ninguém nunca usa ele. Em teoria ele serve para alunos tirarem suas dúvidas e/ou buscarem ajuda sobre algum tópico relevante do curso, mas acabou que ele virou uma bagunça empoierada que quase não tem atividade nenhuma.
-
-
Página da Matéria
-
-
-
3 - Página da matéria no SIGAA
-
-
-
Essa é, provavelmente, a página que você mais vai usar do SIGAA, ela mostra todas as atividades do ano na lista principal(3.2). Essa lista vai ficando mais bagunçada ao decorrer do ano, ela mostra as atividades das mais antigas para as mais novas, portanto quando o ano passar e o(a) professor(a) adicionar muitas atividades, você vai ter que rolar até o final para achar a mais recente. Se o seu professor adicionar atividades futuras na lista, você também terá que procurar a desse dia.
-
-
O Menu da Turma Virtual(3.1) também é importantíssimo, e dessa vez não tenho muito o que dizer, ele funciona como um menu. Os itens que você mais vai usar são Alunos > Frequência para ver sua frequência nessa matéria e Alunos > Ver notas, que mostra suas notas individuais dessa matéria, até mesmo as que não aparecem no boletim ainda.
-
-
Na barra lateral da direita(3.3) você encontra o andamento das aulas, que é a quantidade de aulas ministradas em relação ao total. O número de aulas ministradas pode exceder o número de aulas totais, porém as excedentes não vão afetar a sua média de faltas. Também tem algumas outras caixas de notícias, enquetes, atividades, avaliações e forum, mas nenhuma é usada com frequência.
-
-
Vale ressaltar que no celular é difícil rolar a página quando você dá zoom, para resolver isso você precisa rolar (arrastar) no Menu da Turma Virtual, porque na lista principal vai rolar apenas a lista de atividades.
-
-
Frequência
-
As frequências são contabilizadas pela chamada que os professores fazem no começo da aula. Eventos como a FICE e OLINCAC também contam presença e geralmente um professor fica encarregado de fazer a chamada da manhã, enquanto outro fica na tarde (é bem fácil pegar a chamada da manhã/tarde e ir embora).
-
O aluno não pode exceder em faltas 25% do total de aulas e o limite por matéria do SIGAA não conta no boletim, portanto se você exceder ele sem ultrapassar o limite total, você ainda passa. As matérias optativas são uma excessão, com essas você precisa tomar cuidado para não atingir o limite de faltas.
-
Por mais que o limite esteja entorno de 300 faltas, não recomendo que se acostume a faltar, pois temos 9 aulas por dia, ou seja, 9 faltas. Até as faltas em aulas específicas somam rápido.
Adrian Victor & Arthur Borges - 8/26/2025 (last edited in )
-
-
-
-
-
+---
+postTitle: "Telnet"
+layout: post.njk
+date: 2025-08-27
+background: redes.jpg
+authors: Adrian Victor & Arthur Borges
+langKey: en
+---
+
What the protocol is, its function and history
Telnet (from TELecommunication NETwork) is a TCP/IP stack network protocol that allows remote text-mode communication between computers. Its main function is to provide an interactive session where a user can access and control another device as if they were on a local terminal.
Created in 1969, Telnet was one of the first protocols developed for ARPANET (the network that gave rise to the Internet) and became fundamental for system and device administration in the 1970s, 1980s, and 1990s. Over time, it fell out of use due to lack of security, being replaced by more modern alternatives such as SSH (Secure Shell).
@@ -144,10 +58,4 @@ Ready to receive commands.
-
-
-
-
-
-
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/school/telnet-en/index.html b/school/telnet-en/index.html
deleted file mode 100644
index 78eec32..0000000
--- a/school/telnet-en/index.html
+++ /dev/null
@@ -1,153 +0,0 @@
-
-
-
-
-
-
- Adrian Victor - Telnet
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Adrian Victor & Arthur Borges - 8/26/2025 (last edited in )
-
-
-
-
-
-
What the protocol is, its function and history
-
Telnet (from TELecommunication NETwork) is a TCP/IP stack network protocol that allows remote text-mode communication between computers. Its main function is to provide an interactive session where a user can access and control another device as if they were on a local terminal.
-
Created in 1969, Telnet was one of the first protocols developed for ARPANET (the network that gave rise to the Internet) and became fundamental for system and device administration in the 1970s, 1980s, and 1990s. Over time, it fell out of use due to lack of security, being replaced by more modern alternatives such as SSH (Secure Shell).
-
Implementation
-
Default port: 23/TCP.
-Works at the application layer of the OSI model.
-Format: Based on ASCII character exchange, without encryption.
-RFC: Defined by RFC 854 (1983).
-Architecture: Follows the client-server model
-
How it works
-
In practice, Telnet works relatively simply. The process starts when the client establishes a TCP connection to the server via port 23. Then a remote terminal session is initiated and the user must provide credentials such as username and password. After authentication, commands typed on the client are transmitted in plain text to the server, which processes them and returns the corresponding output. The session remains active as long as the user wants, normally ending with commands like exit or logout
-
Use cases
-
For many years, Telnet was widely used for remote access to Unix, Linux, and Windows servers, especially older versions of these systems. It also became common in network device administration, such as routers and switches, until SSH became the standard. Additionally, mainframes and some legacy devices still use Telnet today. Another practical application is in educational environments and network diagnostics, where it is used to test open ports and check service connectivity, such as running “telnet server.com 80” to see if a web server port is operational.
-
Encryption: the inherent problem
-
Telnet has no native encryption, which makes it extremely vulnerable. To solve this problem, more secure alternatives were developed. The main one is SSH (Secure Shell), created in the 1990s as a direct Telnet replacement. SSH offers the same functionality while ensuring data protection through strong authentication and full traffic encryption. Another, less common approach is using SSL/TLS to tunnel Telnet sessions, but in practice this is rarely used.
-
Advantages and disadvantages
-
Telnet’s advantages include simplicity, low resource usage, and compatibility with various older systems, which facilitated its adoption over the years. However, these benefits are outweighed by its disadvantages. The main one is the lack of encryption, exposing all transmitted data—including passwords—in plain text. This makes it vulnerable to attacks such as sniffing, which captures network packets, and hijacking, which takes over active sessions. For this reason, Telnet is considered obsolete and unsafe for use on open networks like the Internet.
-
Relation to other protocols
-
Telnet is part of the TCP/IP protocol family and uses TCP to ensure reliable communication. Like other protocols in this stack, such as HTTP, FTP, and SMTP, it relies on stable connections to perform its functions, but its distinguishing feature has always been terminal-mode interactivity. Due to security flaws, it was replaced by its natural successor, SSH, which retained Telnet’s conceptual base but added robust protection layers.
-
Functional example
-
Below is a Telnet connection simulator written in JavaScript.
-
-
Loading...
-
-
-
-
-
-
-
-
-
-
Server
-
-
-
-
-
Client
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/school/telnet-pt/index.html b/school/telnet-pt.html
similarity index 61%
rename from school/telnet-pt/index.html
rename to school/telnet-pt.html
index 7de9b70..a798ccc 100644
--- a/school/telnet-pt/index.html
+++ b/school/telnet-pt.html
@@ -1,98 +1,12 @@
-
-
-
-
-
-
- Adrian Victor - Telnet
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Adrian Victor & Arthur Borges - 8/26/2025 (editado por último em )
-
-
-
-
-
+---
+postTitle: "Telnet"
+layout: post.njk
+date: 2025-08-27
+background: redes.jpg
+authors: Adrian Victor & Arthur Borges
+langKey: pt
+---
+
O que é o protocolo, sua função e histórico
O Telnet (do inglês TELecommunication NETwork) é um protocolo de rede da pilha
TCP/IP que permite a comunicação remota entre computadores em modo texto. Sua
@@ -186,10 +100,3 @@ Pronto para receber comandos.