Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andersonkrs/malheatmap
An extension for tracking your activities on myanimelist.net
https://github.com/andersonkrs/malheatmap
myanimelist rails ruby webcrawling
Last synced: 3 days ago
JSON representation
An extension for tracking your activities on myanimelist.net
- Host: GitHub
- URL: https://github.com/andersonkrs/malheatmap
- Owner: andersonkrs
- License: mit
- Created: 2020-03-01T20:43:46.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-12-22T14:54:09.000Z (30 days ago)
- Last Synced: 2024-12-22T15:20:47.758Z (30 days ago)
- Topics: myanimelist, rails, ruby, webcrawling
- Language: Ruby
- Homepage: https://malheatmap.com
- Size: 51.4 MB
- Stars: 99
- Watchers: 1
- Forks: 2
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-useful-projects - <img src="https://icon.horse/icon/github.com" height="20px" align="center"/>/andersonkrs/malheatmap - MyAnimeList activity heatmap (Jump To / Other)
- awesome-useful-projects - <img src="https://icon.horse/icon/github.com" height="20px" align="center"/>/andersonkrs/malheatmap - MyAnimeList activity heatmap (Jump To / Other)
README
MAL Heatmap
MAL Heatmap is a tool for tracking your anime/manga consumption based on your myanimelist.net recent history.
This app crawls the recent user history daily and generates a full visualization of all activities like Github contributions calendar.
It also generates an image of your activities calendar that you can embed into your myanimelist.net profile or forum signature extending your MAL experience.
App
Sign in
#### Profile examples
Here are some real user profiles to give you an idea of how it looks like in case you don't have an MAL account:
* [KanchiMoe](https://malheatmap.com/users/KanchiMoe)
* [RudeRedis](https://malheatmap.com/users/RudeRedis)
* [GDjkhp](https://malheatmap.com/users/GDjkhp)#### Motivation
At first, I made this experiment to play around with some cool Rails features, like [ActiveStorage](https://edgeguides.rubyonrails.org/active_storage_overview.html) and [ActionCable](https://guides.rubyonrails.org/action_cable_overview.html).
Also, I want to take this opportunity to try web scrapping with Ruby and have a pretty much vanilla Rails experience, which is very different from the apps that I have been working on.Building an app from zero to deployment has been a great experience, and I feel all its pain standing up from the ground. It's taught me a lot about sysadmin tasks, servers, docker, deployment, etc.
Over the years, I've made several upgrades, adding Turbo, SolidQueue, better caching with Russian Doll caching + HTTP Caching, etc.
#### How it works
The web app displays the processed data, and jobs do the hard and dirty work of crawling, processing, and saving data.
When users subscribe via OAuth, we capture some information based on the token and then start crawling their history. We periodically run the web crawler to keep the user's history current.
The users get a calendar image that can be embedded on their MAL profile or forum signature. The image is generated in the background by taking a screenshot of their profiles using a headless Chrome controlled by [Ferrum](https://github.com/rubycdp/ferrum).
### Future
The plan is to consume data solely from MAL's API and drop the web crawling. That will require some deep reorganization of the code and how the activities are calculated since MAL does not have an API for history usage, and they don't seem to have that in their roadmap.
#### Main Tools
* Ruby on Rails
* SQLite
* SolidQueue
* SolidCache
* Hotwire
* Bulma CSS#### Dependencies:
* SQLite
* Redis for action cable
* Ruby
* LibVips for ActiveStorageSince this app is a classical Rails project, there is nothing special here to set up or run the project.
### Deployment
This app is gloriously self-hosted with [Coolify](https://coolify.io/).
Since I keep this app running from my pocket, I use some space to run it on my tiny VPS. To keep costs low, we use the VPS storage to host the ActiveStorage files.
#### Other Inspirations
* [MAL Signature](https://malsignature.com)
* [anime.plus](https://anime.plus)