Dart YouTube Music API

This package allows you to interact with YouTube Music data in Dart. You can search for songs, albums, artists, and playlists, retrieve detailed information, and get suggestions.

Note: This package is ported from ts-npm-ytmusic-api. Credits to the original author.

Getting Started

Installation

You can install the package in your Dart project using the following methods:

1. Using flutter pub (for Flutter projects)

flutter pub add dart_ytmusic_api

2. Using dart pub (for general Dart projects)

dart pub add dart_ytmusic_api

3. Modifying pubspec.yaml

Add the following line to your pubspec.yaml file under the dependencies section:

dependencies:
  dart_ytmusic_api: ^1.0.6

Then, run flutter pub get (for Flutter projects) or dart pub get (for general Dart projects) to install the package.

Usage

Here's a basic example of how to use the YouTube Music API in Dart:

import 'package:dart_ytmusic_api/yt_music.dart';

void main() async {
  // Create an instance of the YouTube Music API
  final ytmusic = YTMusic();

  // Initialize the API
  await ytmusic.initialize();

  // There's how you can use a method
  final albumResults = await ytmusic.searchAlbums('query');
}

API Methods

The following methods are available in the YTMusic class:

Initialization

  • initialize(cookies: String, gl: String, hl: String): Initializes the API with the provided cookies, geolocation, and language.

Search

  • getSearchSuggestions(query: String): Retrieves search suggestions for a given query.
  • search(query: String): Performs a general search for music with the given query.
  • searchSongs(query: String): Performs a search specifically for songs.
  • searchVideos(query: String): Performs a search specifically for videos.
  • searchArtists(query: String): Performs a search specifically for artists.
  • searchAlbums(query: String): Performs a search specifically for albums.
  • searchPlaylists(query: String): Performs a search specifically for playlists.

Retrieve Details

  • getSong(videoId: String): Retrieves detailed information about a song given its video ID.
  • getVideo(videoId: String): Retrieves detailed information about a video given its video ID.
  • getLyrics(videoId: String): Retrieves the lyrics of a song given its video ID.
  • getArtist(artistId: String): Retrieves detailed information about an artist given its artist ID.
  • getAlbum(albumId: String): Retrieves detailed information about an album given its album ID.
  • getPlaylist(playlistId: String): Retrieves detailed information about a playlist given its playlist ID.

Artist Methods

  • getArtistSongs(artistId: String): Retrieves a list of songs by a specific artist.
  • getArtistAlbums(artistId: String): Retrieves a list of albums by a specific artist.
  • getArtistSingles(artistId: String): Retrieves a list of singles by a specific artist.

Playlist Methods

  • getPlaylistVideos(playlistId: String): Retrieves a list of videos from a playlist given its playlist ID.

Home Section

  • getHomeSections(): Retrieves the home sections of the music platform.

Known Issues

  • getPlaylistVideos is not working as expected. The method currently returns an "Invalid request" error. This issue is under investigation.

Contributing

Contributions are welcome! Please feel free to open issues, submit pull requests, or reach out if you have any questions.

License

This project is licensed under the GNU General Public License version 3. See the LICENSE file for details.