A new code base to Anilist bot in Telegram.
This bot helps you to send info in your Telegram chats about:
- Animes
- Mangas
- Characters
- Studios
- Staffs
- etc
More than this it also notifies you when new episodes are released and lets you have a:
- Watchlist
- Readlist
- Countdown from new episodes
- Time watching anime calculator
- Anime and manga filters in your lists by: airing/publishing, completed, cancelled & soon
- News when released from ANN about your mangas and animes
- And much more features that are under development
All of the data about it is fetched from Anilist & Anichart.
- JoshStar was kind to allow me to store the translated info about the content in different languages, improving the user experience;
- This project is a new implementation, the old code base is here;
- Also, I've removed the command option when talking to the to the bot from the old version due to low usage.
By default all the commands are in English, but you can see if the same command is available in your language. Only English and Portuguese had some kind of review, the others are automatic translation from Google Translate.
- Arabic
- Chinese
- Dutch
- English
- French
- German
- Indonesian
- Italian
- Japanese
- Portuguese - Brazil
- Russian
- Spanish
Want a new language? Talk to me through an issue about it or hit me up at Telegram: @farmy.
First of all, talk to @AnilistBot.
The inline searches works in any chat conversation:
@AnilistBot search content
Example:
@AnilistBot One Piece
Shows info about anime, manga, characters and staff.
Add to your list to watch or read later.
Shows a countdown of your next content releases.
If you have any other questions about it just use it the help command in a bot chat talk:
/help
I've made all the artwork for it, Studio Ghibli was my inspiration.
You can see more in the img folder.
Right now, this project has the following total lines of code (loc):
And this bot uses four paid services:
All of your support actually makes a difference to help me maintain this project up and running. I really would love if anyone who uses it could support it helping one time with any value that think it worth it or even supporting it each month with one dollar through my Patreon. And this would allow me to improve this project more and more, adding a ton of features that I've planned.
You don't think that money is the best option to help out? It's okay, I'm open to translations request and code also! Just take a look at Contributing.
Also, I explain better the "Why" receive donations instead of selling ads at SUPPORT.md.
Consider buy me a coffee:
Or even becoming a patron:
To all of my fellow countrymen, starting at one real each month:
Please, I'm not a native/fluent english speaker, so whether you see a variable name wrote the wrong way or even some comment where I've wrote something with the wrong "past perfect way of life" or something like that, please let me know it. Not always is just about the code, but rather making it more clear to other people to learn from it.
So, whether is code or not you can help me out making this code more accessible or even supporting trough a new language or fixing some mistranslated content. Just read the CONTRIBUTING.md.
Since I will be keeping this README up to date with any major change and I don't use any versioning system to log all the fixed bugs or previous projects updates, you can still have a taste of what comes next and what is being under analysis right in the Projects tab. But I can give you a taste what I have in mind:
- Caching most requested requisitions
- Improve metric in time watching Anime:
- Add a pattern matching like "Did you mean?" of Google. Probably I will use it didyoumean package
- Anilist connection
- Anime/manga review
- Support to anime/manga news besides ANN -- to improve news accessibility
- Natural Language Processing -- You can really have a talk to this bot
- Anime and Manga recommendation -- Create a engine to it:
- Create a site displaying info about:
- Trending animes/mangas
- A graph showing anime/mangas distances between users likes
- The site must be a PWA to allow new users besides the Telegram user base
This bot is up and running at Heroku in a Docker container. You can also deploy yourself this bot into Heroku through:
But if you use Azure:
Or even deploy it in Docker Cloud:
Note: You must be logged in to Docker Cloud for the button to work. Otherwise, the link results in a 404 error.
I would love to say that SemVer or anything like that is used but, in my personal experience, this kind of approach doesn't work very well with me, the guy who could be committing in this project for two weeks in a roll and leave it for almost one year with no simple npm update
... No versioning system is used.
You can build yourself a bot similar to this one, I've wrote a tutorial about it in my Podesearch Bot just follow the procedures listed in BUILDING.md.
Plain and simple Typescript and the Microsoft linter standards for it.
"JUST WHY???" -- everybody
As the Anilist API V2 was written with GraphQL, as I was using it, the needed queries as JS imports
was a option but only with Webpack and the webpack-graphql-loader. And since this makes the code more cleaner and easier to maintain that's why it was used; that's the GREAT difference and could seen a little bit off to see this kind of decision and that's the answer.
- city-timezones
- dotenv
- endeavor
- emoji-regex
- google-translate
- moment
- moment-timezone
- mongoose
- node-google-timezone
- node schedule
- striptags
- telegraf
- telegraf-i18n
- telegraf-session-redis
Since there's a Travis CI integration and Codecov. All of the tests were written with Jest with the help of ts-jest.
To run all tests just:
npm test
If you ran into some errors related to package dependencies and want to know how to handle it, read the Security info.
There's a pattern to do testing based on using JSON files describing the tests to be done. That being said, the doTesting
function has a unneeded argument, the name of the function to be tested.
Node runs using V8 engine, but since this project uses TS, the compiled code doesn't have the name property in the anonymous function. The problem is a known issue; the folks at Jest and ts-jest helped a lot to understand this -- once this issue is fixed there won't be this anymore.
I've added a integration with Snyk to ensure the Continuos Development (CD).
When Snyk report some errors or bugs that can be fixed, just follow the CLI command to fix them before running -- more info at their docs.
- Only me for now.
Like many Open-Source Software (OSS) the MIT license is used, more about it in LICENSE.