Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/patrickkfkan/soundcloud-fetch
Fetches SoundCloud resources through API v2.
https://github.com/patrickkfkan/soundcloud-fetch
api scraper soundcloud
Last synced: about 2 months ago
JSON representation
Fetches SoundCloud resources through API v2.
- Host: GitHub
- URL: https://github.com/patrickkfkan/soundcloud-fetch
- Owner: patrickkfkan
- Created: 2021-01-01T20:15:57.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-09-21T15:54:30.000Z (over 1 year ago)
- Last Synced: 2024-11-16T20:46:36.358Z (2 months ago)
- Topics: api, scraper, soundcloud
- Language: TypeScript
- Homepage:
- Size: 521 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# soundcloud-fetch
Fetches SoundCloud resources through API v2.
This project was created primarily for use with the [SoundCloud plugin for Volumio](https://github.com/patrickkfkan/volumio-soundcloud). Its scope of application might therefore be limited. If you need a more general-purpose API, you might want to take a look at [soundcloud.ts](https://github.com/Tenpi/soundcloud.ts).
```
npm i --save soundcloud-fetch
``````
import SoundCloud from 'soundcloud-fetch';const api = new SoundCloud({
accessToken: ...
});const album = await api.getPlaylistOrAlbum(...);
const myLikes = await api.me.getLikes({ type: 'track'});
...```
## API
### Constructor
new SoundCloud([args])
Constructs an instance of the SoundCloud API.
`args`: (*optional*)
- `clientId`: (string) (*optional*) Client ID for making API requests. If not specified, value will be obtained from SoundCloud website.
- `accessToken`: (string) (*optional*) Token for accessing your private resources. See [How to obtain an access token](https://github.com/patrickkfkan/soundcloud-fetch/wiki/How-to-obtain-an-access-token).
- `locale`: (string) (*optional*) Locale code as defined in [Constants](./docs/api/modules/Constants.md).### Config
getClientId()
**Returns**
The Client ID used by the API.
---
static generateClientId()
Fetches the Client ID from SoundCloud website. Normally, you don't have to call this method as it is automatically called during initialization of the API (unless you provided one yourself in constructor args).
**Returns**
Client ID from SoundCloud website.
---
setLocale([locale])
Sets the locale.
**Params**
- `locale`: (string) (*optional*) The locale to set. If `undefined`, the locale will be determined by SoundCloud.
---
setAccessToken([value])
Sets the access token.
**Params**
- `value`: (string) (*optional*) The access token to be used by the API. If `undefined`, access to your private resources will trigger an error.
---
### Selections
getMixedSelections([options])
Fetches mixed selections.
**Params**
`options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Selection](./docs/api/classes/Selection.md) objects.
---
### Playlists / Albums / Tracks
getPlaylistOrAlbum(id)
Fetches a playlist or album with the given `id`.
In SoundCloud, an album is a type of playlist with overlapping and distinct properties. To check whether an item returned by this method is a playlist or album, inspect its `type` property or use `instanceof`:
```
const item = await api.getPlaylistOrAlbum(id);if (item && item.type === Album.type) { // <-- item is an Album
const album = item as Album; // Type assertion
const genre = album.genre; // Access Album-specific properties
}// or
if (item instanceof Album) {
const genre = item.genre; // No need to do type assertion here
}
```**Params**
- `id`: (number) The ID of the playlist or album to fetch.
**Returns**
Promise that resolves to an instance of [Album](./docs/api/classes/Album.md) or [Playlist](./docs/api/classes/Playlist.md), or `null` if fetched result is neither an album nor a playlist.
---
getSystemPlaylist(id)
Fetches a system playlist with the given `id`.
**Params**
- `id`: (string) The ID of the system playlist to fetch.
**Returns**
Promise that resolves to an instance of [SystemPlaylist](./docs/api/classes/SystemPlaylist.md), or `null` if fetched result is not a system playlist.
---
getPlaylistsByUser(userId, [options])
Fetches the playlists created by the user with the given `userId`. The fetched items do **not** include albums.
**Params**
- `userId`: (number) The ID of the user.
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Playlist](./docs/api/classes/Playlist.md) objects.
---
getAlbumsByUser(userId, [options])
Fetches the albums created by the user with the given `userId`. The fetched items do **not** include playlists.
**Params**
- `userId`: (number) The ID of the user.
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Album](./docs/api/classes/Album.md) objects.
---
getTopFeaturedTracks([options])
Fetches the top-featured tracks.
**Params**
`options` (*optional*)
- `genre`: (string) (*optional*) The genre of tracks to fetch.
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Track](./docs/api/classes/Track.md) objects.
---
getTracks(ids)
Fetches the track(s) with the given `ids`.
**Params**
- `ids`: (number | number[]) The IDs of the tracks to fetch. If `ids` is a number, as oppose to an array of numbers, then result will contain a single track matching it.
**Returns**
Promise that resolves to a [Collection](#collections) of [Track](./docs/api/classes/Track.md) objects.
---
getTracksByUser(userId, [options])
Fetches the tracks uploaded by the user with the given `userId`.
**Params**
- `userId`: (number) The ID of the user.
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Track](./docs/api/classes/Track.md) objects.
---
getTrack(id)
Fetches the track with the given `id`.
**Params**
- `ids`: (number) The ID of the track to fetch.
**Returns**
Promise that resolves to a [Track](./docs/api/classes/Track.md) object, or `null` if no result.
---
getLikesByUser(userId, options)
Fetches the items liked by the user with the given `userId`.
**Params**
- `userId`: (number) The ID of the user.
- `options`:
- `type`: (string) The type of resource to fetch. Can be one of the following values: `track` | `playlistAndAlbum`.
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Like](./docs/api/classes/Like.md) objects. For each `Like`:
- if `type` is `track`, `Like.item` points to a [Track](./docs/api/classes/Track.md) object;
- if `type` is `playlistAndAlbum`, `Like.item` points to an [Album](./docs/api/classes/Album.md) or [Playlist](./docs/api/classes/Playlist.md) object.Note that `Like.item` can also be `null` if the item could not be parsed.
---
getStreamingUrl(transcodingUrl)
Fetches the streaming URL from `transcodingUrl`.
Transcoding URLs are embedded in the `mediaInfo.transcodings` property of a `Track` object. See [example](./examples/getTrackAndStreamingUrl.ts).
**Params**
- `transcodingUrl`: (string) The transcoding URL for a `Track`.
**Returns**
Promise that resolves to the streaming URL, or `null` if no result.
---
### Users
getUser(id)
Fetches the user given by `id`.
**Params**
- `id`: (number) The ID of the user to fetch.
**Returns**
Promise that resolves to a [User](./docs/api/classes/User.md) object, or `null` if no result.
---
getFollowing(userId, [options])
Fetches the list of users followed by the user with the given `userId`.
**Params**
- `userId`: (number) The ID of the user.
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [User](./docs/api/classes/User.md) objects.
---
### Search
search(q, options)
Performs a search.
**Params**
- `q`: (string) Search query.
- `options`:
- `type`: (string) The type of resource to search for. Can be one of the following values: `playlist` | `album` | `track` | `user`.
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [Playlist](./docs/api/classes/Playlist.md), [Album](./docs/api/classes/Album.md), [Track](./docs/api/classes/Track.md) or [User](./docs/api/classes/User.md) objects (depending on `type` you passed in `options`) matching the given search query.
---
### Private resources
These methods require a valid access token, which you can provide in the constructor or through `setAccessToken()`. Private resources methods are grouped under `me`:
```
import SoundCloud from 'soundcloud-fetch';const api = new SoundCloud({
accessToken: ...
});const profile = await api.me.getProfile();
...
```
me.getProfile()
Fetches your user profile.
**Returns**
Promise that resolves to a [User](./docs/api/classes/User.md) object representing your user profile, or `null` if no result.
---
me.getPlayHistory(options)
Fetches items from your play history.
**Params**
- `options`:
- `type`: (string) The type of resource to fetch. Can be one of the following values: `track` | `set`.
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [PlayHistoryItem](./docs/api/classes/PlayHistoryItem.md) objects. For each `PlayHistoryItem`:
- if `type` is `track`, `PlayHistoryItem.item` points to a [Track](./docs/api/classes/Track.md) object;
- if `type` is `set`, `PlayHistoryItem.item` points to an [Album](./docs/api/classes/Album.md), [Playlist](./docs/api/classes/Playlist.md) or [SystemPlaylist](./docs/api/classes/SystemPlaylist.md) object.Note that `PlayHistoryItem.item` can also be `null` if the item could not be parsed.
---
me.getLibraryItems([options])
Fetches items from your library.
**Params**
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [LibraryItem](./docs/api/classes/LibraryItem.md) objects. Each `LibraryItem` wraps around an [Album](./docs/api/classes/Album.md), [Playlist](./docs/api/classes/Playlist.md) or [SystemPlaylist](./docs/api/classes/SystemPlaylist.md) object, as well as `null` if an item could not be parsed. You can obtain the wrapped item through `LibraryItem.item`, as well as inspect the `itemType` property to get its exact type (such as whether it is liked).
---
me.getLikes(options)
Fetches items you have liked.
This is a convenience method that passes your User ID to `getLikesByUser(userId, options)`, and thus have the same return type and `options` param as that method.
---
me.getStations([options])
Fetches the artist stations added to your library. An artist station is represented by a `SystemPlaylist`.
> Note that `me.getLibraryItems()` also returns artist stations. If you are presenting results from both method calls, you might want to check the type of `SystemPlaylist` through its `playlistType` property to filter out overlaps.
**Params**
- `options`: (*optional*)
- `limit`: (number) (*optional*) The number of items to return.**Returns**
Promise that resolves to a [Collection](#collections) of [LibraryItem](./docs/api/classes/LibraryItem.md) objects. Use `LibraryItem.item` to obtain the `SystemPlaylist` object representing an artist station.
---
me.getFollowing([options])
Fetches the users you are following.
This is a convenience method that passes your User ID to `getFollowing(userId, [options])`, and thus have the same return type and `options` param as that method.
---
me.addToPlayHistory(trackOrUrn, [setOrUrn])
Adds the track given by `trackOrUrn`, and optionally the album, playlist or system playlist given by `setOrUrn`, to your play history.
**Params**
- `trackOrUrn`: (`Track` | string) The track or URN of the track to add to play history. You can obtain the URN of a `Track` through its `apiInfo.urn` property.
- `setOrUrn`: (`Album` | `Playlist` | `SystemPlaylist` | string) (*optional*) The album, playlist, system playlist or URN of system playlist to add to play history. You can obtain the URN of a `SystemPlaylist` through its `apiInfo.urn` property.Note that albums and playlists do not have URNs, at least not from data returned by SoundCloud. If you must pass an URN for an album or playlist, you can provide a string in the following format (this is what the API generates internally):
```
// Substitute with playlist or album ID
soundcloud:playlists:
```---
### Fetching tracks of playlists, albums and system playlists
You will note that the `Playlist`, `Album` and `SystemPlaylist` classes do not define a `tracks` property. To obtain the tracks of these items, call the `getTracks()` method:
```
const api = new SoundCloud();
const playlist = api.getPlaylistOrAlbum(...);
if (playlist) {
const tracks = await playlist.getTracks();
...
}
```In the above example, `getTracks()` returns an array of `Track` objects.
### Accessing underlying data
Call `getJSON()` to access the underlying data of a fetched item:
```
const api = new SoundCloud();
const track = await api.getTrack(...);
if (track) {
// Gets the 'track_authorization' field of underlying data
const trackAuthorization = track.getJSON('track_authorization');// Gets the full underlying data
const fullData = track.getJSON();
}
```## Collections
When a method returns a collection of items, it does so through an instance of the [Collection](./docs/api/classes/Collection.md) class. A `Collection` has the following key properties:
- `items`: (Array) The items fetched.
- `continuation`: ([CollectionContinuation](./docs/api/classes/CollectionContinuation.md) | `null`) An object encapsulating the data required by the API for fetching the next set of items; `null` if there are no more items available.The `continuation` property can be used to obtain further items as follows:
```
const api = new SoundCloud();
const tracks = await api.getTopFeaturedTracks();
if (tracks.continuation) { // More items available
const moreTracks = await api.getContinuation(tracks.continuation);
...
}
```In the above example, `getContinuation()` returns another instance of `Collection` containing the next set of `Track` objects.
# Changelog
1.0.2:
- Fix connection error in `getClientId()`1.0.1:
- Apply access token in `getStreamingUrl()`1.0.0:
- Initial release# License
MIT