Skip to content

Latest commit

Β 

History

History
152 lines (123 loc) Β· 7.9 KB

README.md

File metadata and controls

152 lines (123 loc) Β· 7.9 KB

ConcertBuddy

Your personal Telegram bot for discovering artists, setlists, and lyrics. Perfect for music enthusiasts and concert-goers! 🎡

CodeFactor

Table of contents

General info

Are you planning to go to a concert? This Telegram bot will be your companion, like a good buddy! 😎

With ConcertBuddy, you can:

  • Explore artist and band biographies.
  • Check out setlists from recent concerts.
  • Listen to tracks and read their lyrics.

Just write the artist/band name to the ConcertBuddy bot and enjoy!

Features

A few of the things you can do with ConcertBuddy:

  • βœ… Search artist / band by name
    • MusicBrainz
  • βœ… Read artist / band biography
    • Last.fm
  • βœ… View setlists from recent concerts
    • Setlist.fm
  • βœ… Listen to tracks
    • Directly from: Yandex
    • External link: Spotify
  • βœ… Read the lyrics of the tracks
    • Different lyric providers: AZLyrics, Genius, SongLyrics, MusixMatch, LyricFind

Feedback

For bug reports, suggestions, or feature requests, please use the issue tracker.

For direct feedback, reach out on Telegram.

Feature requests are always welcome.

Technologies

Project is created with:

  • .NET: 6.0
  • Microsoft Visual Studio Community 2022
  • docker

Built with

  • Telegram.Bot - the most popular .NET Client for πŸ€– Telegram Bot API
  • LyricsScraperNET - 🎼 a library for .NET that provides an API to search for lyrics of a song from the web
  • SpotifyAPI-NET - a client for Spotify's Web API, written in .NET
  • MusicBrainzAPI - Implementation of the MuzicBrainz API v2
  • Hqub.Last.fm - Implementation of the Last.fm API for .NET Standard 2.0 or above
  • Genius.NET - C# library to access the Genius REST API in .NET
  • HtmlAgilityPack - agile HTML parser that builds a read/write DOM and supports plain XPATH or XSLT (you actually don't HAVE to understand XPATH nor XSLT to use it, don't worry...)
  • Serilog - simple .NET logging with fully-structured events
  • Yandex.Music API - unofficial wrapper for the Yandex.Music API

Documentation

Hosting

The bot is hosted on an Ubuntu 22.10 64-bit server using a DigitalOcean droplet and runs in a Docker container from docker hub repository. Hosting costs $6/month.

Deployment

  1. Create and configure ConcertBuddy/ConcertBuddy.ConsoleApp/appsettings.json file with settings Configuration.cs from template appsettings.template.json.
  2. Build and publish docker image usingn the Dockerfile to docker hub registry.
  3. Use docker-compose.yml to run the container.

Environments

Name Link
Development TestConcertBuddy
Production ConcertBuddy

Logging

Event logging is managed by Serilog, with logs written to console, debug, and file. Log rotation is configured. Logging settings can be found in appsettings.json. Example: appsettings.template.json

Roadmap

See the full roadmap on the Github project page or Issue board

Release Notes

v1.1.0 (01.01.25):

  • Use Hqub.Last.fm instead of Inflatable.Lastfm.
  • Updated external libraries to the latest version.
  • Refactoring. Added data validation in commands. In the model, properties are now nullable.

v1.0.0 (15.09.24):

  • Migration from .NET 6 to .NET 8
  • Use FakeItEasy instead of Moq
  • Optimize docker image size by using alpine in dockerfile
  • Updated external libraries to the latest version

v0.1.1 (03.09.23):

  • Fixed a problem with lyric searching (Issue 33)
  • Use LyricsScraperNET library instead of LyricsScraper project.
  • Updated external libraries to the latest version (Spotify, Telegram, Yandex)

v0.1.0 (28.10.22):

BreakingChanges:

  • Refactoring. MusicSearcherClient has many responsibilities and bottleneck (Issue 30)
  • Use nuget package of Yandex api instead of project reference (Issue 21)

Bugfixes:

  • Map properly MusicBrainz to Spotify track while searching (Issue 29)
  • Track searching will return nothing if track not found in spotify (Issue 27)
  • Can't find Wu tang artist's information and tracks (Issue 28)
  • Can't initialize Yandex client! System.Net.WebException: The remote server returned an error: (400) Bad Request. (Issue 31)

v0.0.8 (04.02.22. It's my Bday πŸŽ‚):

Bugfixes:

  • Track searching will return nothing if track not found in spotify (Issue 27)
  • Disable page navigation if nothing found (Issue 26)

v0.0.7 (30.01.22):

  • Added receiving artist's top 10 tracks from Spotify (Issue 9)

v0.0.6 (25.01.22):

  • Catch unhandled exceptions and log them. (Issue 24)
  • Configure write logs to file with rotation with docker volume. (Issue 25)

v0.0.5 (24.01.22):

  • Listening to the track directly in the telegram. Use Yandex track storage. (Issue 8)

v0.0.4 (21.01.22):

Bugfixes:

  • Made SearchLyric async. (Issue 16)
  • Remove async from telegram messages validation. Move callback messages in MessageHelper. (Issue 18)

v0.0.3 (21.01.22):

  • Migrate app.config to appsettings.json with DI.

v0.0.2 (19.01.22):

  • Fixed async task order in SearchArtistByMBID method.
  • Rename methods with Async.
  • Added some TODO comments.

v0.0.1 (12.01.22):

  • Added MemoryCache when searching for artists by mbid to reduce API calls.
  • Fixed logs format with date and scope.
  • Publish docker version 0.0.1 and deploy on server. πŸŽ‰

Support

If you want to support this project or my work in general, you can donate via the link below.

This is always optional! Thank you! πŸ˜‰

  • "Buy Me A Coffee"
  • "Tinkoff Donate Button"