Music API by Popnable

Popnableのグローバルチャートにアクセス - 160以上の国の曲、アーティスト、動画、トレンドを単一のAPIで。

何ができますか?
即時オートコンプリート

タイプミスに対応したプレフィックス検索で素早い結果。

精密なジオフェンシング

都市、バウンディングボックス、半径で検索。

豊富な場所メタデータ

OSM識別子、人口、表示名などを返します。

99.9 % 稼働時間
1239.6ms レスポンス
10 req/s
0.01 クレジット / リクエスト

Popnable Music API

Single endpoint that proxies Popnable API and returns normalized data for songs, trends, artists, charts and YouTube videos. The behavior is controlled by the action parameter.


POST https://api.yeb.to/v1/music/popnable

Common parameters

パラメータ 必須 説明
api_key string はい Your YEB API key.
action string はい Selects which Popnable v2 method to call. Supported values:
search, get-trends, get-songs, get-songs-by-trend, get-artists, get-artist-by-trend, get-daily-chart, get-weekly-chart, get-monthly-chart, get-artist-chart, get-videos.

Parameters by action

action Parameter Type Required Description
search keyword string はい Search term (song/artist). Short text (~20 chars recommended).
get-trends ids string 任意 Comma-separated list of trend IDs. If omitted, Popnable may return all trends (depending on provider rules).
get-songs ids string はい Comma-separated list of song IDs.
stats string 任意 yes / no – include Popnable stats.
charts string 任意 Comma-separated list of chart types, e.g. daily,weekly.
get-songs-by-trend trend string はい Trend ID (country/region ID in Popnable).
day string はい Date in YYYY-MM-DD format.
stats string 任意 yes / no – include stats.
charts string 任意 Charts for the returned songs, e.g. daily,weekly,monthly.
get-artists ids string はい Comma-separated list of artist IDs.
stats string 任意 yes / no – include artist stats.
charts string 任意 Chart type, e.g. artists.
songs string 任意 yes / no – include songs for each artist.
get-artist-by-trend trend string はい Trend ID (country/region).
day string はい Date in YYYY-MM-DD format.
stats string 任意 Artist stats (yes/no).
charts string 任意 Chart type (usually artists).
get-daily-chart trend string はい Trend ID (country/region).
day string はい Date for the daily chart (YYYY-MM-DD).
get-weekly-chart trend string はい Trend ID (country/region).
day string はい Date for the weekly chart (YYYY-MM-DD).
get-monthly-chart trend string はい Trend ID (country/region).
day string はい Date for the monthly chart (YYYY-MM-DD).
get-artist-chart trend string はい Trend ID (country/region).
day string はい Date for the artist chart (YYYY-MM-DD).
get-videos yt_codes string はい Comma-separated list of YouTube video codes (e.g. AbCdE123).
charts string 任意 Chart types, e.g. daily,weekly.
dailyStats string 任意 yes / no – include daily breakdown stats.
day string 任意 Reference day (YYYY-MM-DD). If omitted, current date may be used.

リクエスト例

1) Search by keyword (action=search)
{
  "api_key": "YOUR_KEY",
  "action" : "search",
  "keyword": "preslava"
}
2) Song details by ID (action=get-songs)
{
  "api_key": "YOUR_KEY",
  "action" : "get-songs",
  "ids"    : "123",
  "stats"  : "yes",
  "charts" : "daily,weekly"
}
3) Video stats by YouTube code (action=get-videos)
{
  "api_key"   : "YOUR_KEY",
  "action"    : "get-videos",
  "yt_codes"  : "AbCdE123",
  "charts"    : "daily,weekly",
  "dailyStats": "yes",
  "day"       : "2025-01-05"
}

API連携

curl -X POST https://api.yeb.to/v1/music/popnable \
  -H "Content-Type: application/json" \
  -d '{"api_key":"YOUR_KEY","action":"search","keyword":"preslava"}'
use Illuminate\Support\Facades\Http;

Route::post('/music-popnable-demo', function () {
    $response = Http::post('https://api.yeb.to/v1/music/popnable', [
        'api_key' => config('services.yeb.api_key'),
        'action'  => 'search',
        'keyword' => 'preslava',
    ]);

    return $response->json();
});
use Illuminate\Support\Facades\Http;

$r = Http::post('https://api.yeb.to/v1/music/popnable', [
    'api_key' => 'YOUR_KEY',
    'action'  => 'get-songs',
    'ids'     => '123',
    'stats'   => 'yes',
    'charts'  => 'daily,weekly',
]);

print_r($r->json());
fetch('https://api.yeb.to/v1/music/popnable', {
  method: 'POST',
  headers: {'Content-Type': 'application/json'},
  body: JSON.stringify({
    api_key   : 'YOUR_KEY',
    action    : 'get-videos',
    yt_codes  : 'AbCdE123',
    charts    : 'daily,weekly',
    dailyStats: 'yes',
    day       : '2025-01-05'
  })
})
  .then(r => r.json())
  .then(console.log);
import requests, json

payload = {
    "api_key": "YOUR_KEY",
    "action" : "get-songs-by-trend",
    "trend"  : "35",
    "day"    : "2025-01-05",
    "stats"  : "yes",
    "charts" : "daily,weekly"
}

r = requests.post('https://api.yeb.to/v1/music/popnable',
                  headers={'Content-Type': 'application/json'},
                  data=json.dumps(payload))

print(r.json())

Response example

{
  "data": [
    {
      "id": 123,
      "song_name": "Some Song",
      "day_released": "2025-01-05 12:34:56",
      "trend": "Bulgaria",
      "trend_flag": "https://popnable.com/images/flags/circle/bg.svg",
      "trend_id": 35,
      "singers": [
        { "singer_id": 777, "artist_name": "Preslava" }
      ],
      "videos": [
        { "yt_code": "AbCdE123" }
      ]
    }
  ],
  "meta": {
    "provider": "popnable",
    "upstream_response_code": 200,
    "upstream_error_number": null,
    "endpoint": "search"
  }
}
{
  "error": "Popnable: Access Denied.",
  "code": 403
}

レスポンスコード

コード説明
200 Successリクエスト処理成功。
400 Bad Request入力バリデーション失敗。
401 UnauthorizedAPIキーが不足または不正。
403 Forbiddenキーが無効または許可されていません。
429 Rate Limitリクエストが多すぎます。
500 Server Error予期しないエラー。

music-popnable

music-popnable 0.0100 credits

Parameters

API Key
body · string · required
Action
body · string · required
Keyword
body · string
Trend IDs
body · string
Song IDs
body · string
Include Stats
body · string
Charts
body · string
Trend ID
body · string
Day
body · string
Artist IDs
body · string
Include Songs
body · string
YouTube Codes
body · string
Daily Stats
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

Music API by Popnable — Practical Guide

A hands-on guide to Music API by Popnable. Learn what each action does, the real-world problems it solves, which parameters actually matter, and how to read normalized responses for songs, artists, charts, trends and YouTube videos.

#What this API solves

One POST endpoint that proxies Popnable API and returns normalized JSON for search, trends, songs, artists, charts and YouTube videos. Use it when you need consistent data structures across multiple upstream calls, stable field names, predictable errors, and idempotent behavior suitable for caching.

#Endpoint & call model

#POST https://api.yeb.to/v1/music-popnable

  • Best for: Unified access to Popnable data with opinionated normalization.
  • How it works: You send an action plus its parameters; we call the corresponding Popnable v2 method and normalize the response.
  • Idempotent: Same input → same output; safe for caching and retries.
  • Billing: Each request costs a fixed amount of credits (see chip above), regardless of the action.

#Quick start

# 1) Search (songs/artists) by keyword
curl -X POST "https://api.yeb.to/v1/music-popnable" \
  -H "Content-Type: application/json" \
  -d '{ "api_key": "YOUR_KEY", "action": "search", "keyword": "preslava" }'
# 2) Songs by trend (country/region) for a specific day
curl -X POST "https://api.yeb.to/v1/music-popnable" \
  -H "Content-Type: application/json" \
  -d '{ "api_key": "YOUR_KEY", "action": "get-songs-by-trend",
        "trend": "35", "day": "2025-01-05", "stats": "yes", "charts": "daily,weekly" }'
# 3) YouTube videos (normalized + optional charts/daily breakdown)
curl -X POST "https://api.yeb.to/v1/music-popnable" \
  -H "Content-Type: application/json" \
  -d '{ "api_key": "YOUR_KEY", "action": "get-videos",
        "yt_codes": "AbCdE123,ZXCV987", "charts": "daily,weekly",
        "dailyStats": "yes", "day": "2025-01-05" }'

#Common parameters (used by all actions)

ParamRequiredWhat to pass (practical)Why it matters
api_key Yes Send server-side or via edge; avoid exposing in browser code. Auth & rate limiting.
action Yes One of: search, get-trends, get-songs, get-songs-by-trend, get-artists, get-artist-by-trend, get-daily-chart, get-weekly-chart, get-monthly-chart, get-artist-chart, get-videos. Selects the upstream Popnable v2 method.

#Actions explained (what each one solves)

Solves: quick lookup when you have a name fragment and need likely candidates (songs/artists).

ParamTypeReqNotes (practical)
keywordstringYesShort text (~20 chars). Use user input as-is (trimmed).
{
  "api_key": "YOUR_KEY",
  "action" : "search",
  "keyword": "preslava"
}
{
  "data": [
    { "id": 123, "song_name": "Some Song", "trend_id": 35, "singers": [ { "singer_id": 777, "artist_name": "Preslava" } ] }
  ],
  "meta": { "provider": "popnable", "upstream_response_code": 200, "endpoint": "search" }
}

Solves: obtain available trend IDs (countries/regions) to drive UI pickers or scheduled fetches.

ParamTypeReqNotes
idsstringNoComma-separated list of trend IDs to filter; omit to fetch all (subject to provider rules).

#action=get-songs

Solves: fetch details for known song IDs (e.g., to refresh a small cached set, or hydrate UI cards).

ParamTypeReqNotes
idsstringYesComma-separated song IDs.
statsstringNoyes/no include Popnable stats.
chartsstringNoComma list, e.g. daily,weekly.

#action=get-songs-by-trend

Solves: build daily feeds per country/region for discovery, newsletters, or archives.

ParamTypeReqNotes
trendstringYesTrend ID (country/region).
daystringYesDate YYYY-MM-DD.
statsstringNoyes/no.
chartsstringNoe.g. daily,weekly,monthly.

#action=get-artists

Solves: hydrate artist cards and detail pages from known IDs.

ParamTypeReqNotes
idsstringYesComma-separated artist IDs.
statsstringNoyes/no include artist stats.
chartsstringNoChart type (usually artists).
songsstringNoyes/no include songs for each artist.

#action=get-artist-by-trend

Solves: discover artists by country/region for a given day; useful for editorial picks.

ParamTypeReqNotes
trendstringYesTrend ID.
daystringYesDate YYYY-MM-DD.
statsstringNoyes/no.
chartsstringNoUsually artists.
songsstringNoyes/no include songs.

#Charts — daily/weekly/monthly/artist

Solves: pull historical chart snapshots for analytics, leaderboards, or recap posts.

ActionParamsNotes
get-daily-chart trend (string, req), day (YYYY-MM-DD, req) Country/region daily chart.
get-weekly-chart trend (string, req), day (YYYY-MM-DD, req) Weekly chart snapshot.
get-monthly-chart trend (string, req), day (YYYY-MM-DD, req) Monthly chart snapshot.
get-artist-chart trend (string, req), day (YYYY-MM-DD, req) Artists chart for the given trend/day.

#action=get-videos

Solves: normalize YouTube video data and optionally enrich with chart context and daily breakdowns.

ParamTypeReqNotes
yt_codesstringYesComma-separated video codes (AbCdE123).
chartsstringNoe.g. daily,weekly.
dailyStatsstringNoyes/no include daily breakdown.
daystringNoReference day YYYY-MM-DD.

#Reading & acting on responses

{
  "data": [
    {
      "id": 123,
      "song_name": "Some Song",
      "day_released": "2025-01-05 12:34:56",
      "trend": "Bulgaria",
      "trend_flag": "https://popnable.com/images/flags/circle/bg.svg",
      "trend_id": 35,
      "singers": [ { "singer_id": 777, "artist_name": "Preslava" } ],
      "videos":   [ { "yt_code": "AbCdE123" } ]
    }
  ],
  "meta": {
    "provider": "popnable",
    "upstream_response_code": 200,
    "upstream_error_number": null,
    "endpoint": "search"
  }
}
  • data — normalized records. Use directly in UI and storage.
  • meta.providerpopnable for transparency/debug.
  • meta.upstream_response_code — HTTP-equivalent status from upstream.
  • meta.endpoint — which upstream path we called (e.g., songs/by-trend).

#Typical errors & how to fix

{ "error": "Missing \"action\" parameter", "code": 422 }
{ "error": "Missing or empty \"ids\"", "code": 422 }
{ "error": "Popnable: Access Denied.", "code": 403 }
  • 422 missing/invalid: Ensure required params for the chosen action are present and non-empty.
  • 401 invalid key: Rotate your YEB key; call only from server/edge.
  • 502 availability: Upstream temporarily unavailable; retry with backoff.
  • 403 upstream denial: Access rules on provider side; validate your upstream configuration and inputs.

#Troubleshooting & field notes

  1. Dates: All day params are YYYY-MM-DD. Keep a single timezone (prefer UTC) in your app.
  2. Batching: For bulk imports, cap at ≤100 rps and reuse connections. Cache idempotent requests by full payload hash.
  3. Partial enrichment: Use stats/charts/dailyStats only when needed to keep latency and cost predictable.
  4. Stability: Field names are normalized; upstream changes are absorbed where possible and reflected in the Changelog below.

#API Changelog (latest changes)

2025-11-25
Improved error passthrough for upstream logical errors (meta.upstream_response_code now always set). Hardened input validation messages for all actions.
2025-11-10
Added optional dailyStats to get-videos. Unified day format across actions (YYYY-MM-DD).
2025-10-20
Normalized lists for singers and videos in song payloads. Deduplicated repeated fields.
2025-10-01
Public v1 release: search, get-trends, get-songs, get-songs-by-trend, get-artists, get-artist-by-trend, get-daily-chart, get-weekly-chart, get-monthly-chart, get-artist-chart, get-videos.

よくある質問

曲、アーティスト、国/地域トレンド、日次/週次/月次チャート、YouTube動画統計を単一の統合エンドポイントで照会できます。

APIはPopnable v2を使用 - Popnableの公開音楽チャートと統計を支える同じデータセットです。

チャートはPopnable独自の更新サイクルに従います。日次チャートは約24時間ごとに更新されます。

はい。エラーが発生したリクエストを含め、すべてのリクエストがクレジットを消費します。クレジットは成功・失敗に関係なくリクエスト数に紐づいています。エラーが明らかに当社のプラットフォーム側の問題による場合は、影響を受けたクレジットを復元します(現金での返金はありません)。

[email protected]までご連絡ください。フィードバックを真摯に受け止めています。バグレポートや機能リクエストが意味のあるものであれば、APIを迅速に修正・改善し、お礼として50の無料クレジットを付与します。

APIやエンドポイントによって異なります。一部のエンドポイントは外部ソースのデータを使用しており、より厳しい制限がある場合があります。また、不正利用の防止とプラットフォームの安定性維持のために制限を設けています。各エンドポイントの具体的な制限についてはドキュメントをご確認ください。

クレジットシステムで運営しています。クレジットは前払いの返金不可の単位で、API呼び出しやツールに使用します。クレジットはFIFO(古いものから順に)消費され、購入日から12か月間有効です。ダッシュボードに各購入日とその有効期限が表示されます。

はい。購入したすべてのクレジット(端数残高を含む)は購入から12か月間有効です。未使用のクレジットは有効期間終了時に自動的に期限切れとなり、永久に削除されます。期限切れのクレジットは復元や現金その他の価値への変換はできません。経過措置:2025年9月22日以前に購入したクレジットは2025年9月22日購入として扱われ、2026年9月22日に期限切れとなります(購入時により早い期限が記載されていない限り)。

はい—有効期間内で繰り越されます。未使用のクレジットは利用可能な状態のまま月ごとに繰り越され、購入後12か月で期限切れになります。

クレジットは返金不可です。必要な分だけ購入してください—後からいつでもチャージできます。プラットフォーム側のエラーで課金に失敗した場合、調査後に影響を受けたクレジットを復元する場合があります。現金での返金はありません。

料金はドルではなくクレジットで設定されています。各エンドポイントには独自のコストがあります—上記の「クレジット / リクエスト」バッジをご覧ください。常に正確な支出額がわかります。
← APIに戻る