RapidVideoMaker
アカウントを作成

API RapidVideoMaker

REST APIを使用すると、PythonスクリプトやN8nワークフローなどあらゆるHTTPクライアントからビデオを処理できます。5つのモード: 動画を結合(複数MP4)、音声を編集(1 MP4 + 1 MP3)、動画を作成(1 JPG/PNG + 1 MP3)、ビデオオーバーレイ(2 MP4 ピクチャーインピクチャー)。処理は非同期です。

無料でAPIトークンを取得
APIトークンを取得するためにアカウントを作成してください — 1日20リクエスト含む
無料アカウントを作成 アカウントをお持ちですか?ログイン

完全なワークフロー

すべての統合は同じ4ステップのシーケンスに従います:

1
ジョブを作成 — POST /api/v1/render.php
Bearerトークンと共にファイルをmultipart/form-dataとして送信します。1枚のJPG/PNG画像 + 1つのMP3 + mode=image_to_video → 動画生成。1つのMP4 + 1つのMP3 → 音声編集。複数のMP4 → 結合。サーバーは一意のjob_idを返します。
2
ジョブを待機 — GET /api/v1/jobs.php?job_id=…
このエンドポイントを定期的(5〜10秒ごと)にポーリングします。ジョブはqueuedprocessingready(またはerror)と進みます。
3
ダウンロードURLを取得
ステータスがreadyになると、レスポンスに使用可能なdownload_urlフィールドが含まれます。
4
ファイルをダウンロード — GET /api/download.php?job_id=…
最終MP4をダウンロードします。ファイルはジョブ完了後2時間利用可能で、その後自動的に削除されます。

認証

すべてのリクエストにAPIトークンを含める必要があります。2つの形式が受け入れられます:

# 認証 — すべてのリクエストにAPIトークンを含める必要があります。2つの形式が受け入れられます: Authorization: Bearer rvm_your_token_here # Alternative X-API-Key: rvm_your_token_here

トークンはメンバーエリアで利用可能です — アカウントごとに1つのトークン、登録時に自動的に作成されます。

クォータ

各メンバーアカウントはWebインターフェースとAPI間で共有される1日20リクエストを持ちます。失敗したジョブはクォータを消費しません。カウンターはUTC深夜にリセットされます。

POSTレスポンスにはquota_usedquota_remainingが含まれます。制限を超えると、サーバーは429で応答します。

インターフェース + API = 同じカウンター。Webインターフェースから作成した動画とAPIリクエストは、それぞれ同じ1日クォータから1クレジットを消費します。

キュー

一度に1つのジョブが処理されます。複数のジョブが同時に送信された場合、キューに入れられ順番に処理されます。待機中、ステータスレスポンスには以下が含まれます:

レート制限が適用されます:/api/v1/jobs.phpエンドポイントはトークンあたり1分間に12回までの呼び出しを受け入れます。推奨:呼び出し間隔10秒。

利用可能なトランジション

直接マージにはtransition_type=none(デフォルト)を指定し、クリップ間のフェードには以下のいずれかの種類を使用します:

none fade fadeblack dissolve wipeleft wiperight slideleft slideright zoomin circleclose

期間(transition_duration)は0.2〜2.0秒です。

エンドポイント

POST /api/v1/render.php 動画処理ジョブを作成します

5つのモードをmodeフィールドで指定します(複数MP4でmodeを省略するとfusionを自動検出):

使用法APIモード必要なファイル説明
動画を結合 fusion 2〜20個のMP4ファイル クリップは提供された順序で端から端へ組み立てられます。クリップ間にオプションのトランジションを設定できます。
音声を編集 add_audio または mix_audio 1つのMP4 + 1つのMP3 動画の音声トラックを置き換えまたは強化します。動画トラックは再エンコードされません。

add_audio — 元の音声が削除され、MP3に完全に置き換えられます。
mix_audio — 元の音声が保持され、MP3がオーバーレイされます。
動画を作成 image_to_video 1枚のJPG/PNG + 1つのMP3 静止画像と音声ファイルから動画を生成します。テキストオーバーレイ、フェード、解像度、fpsはoptionsフィールドで設定可能です。
ビデオオーバーレイ overlay_video 2 MP4 メイン動画の上に2本目の動画を重ねます。位置・サイズ・不透明度・音声はoptionsフィールドで設定できます。
テキストをMP3に text_to_mp3 (テキストのみ) テキストを音声に変換してMP3ファイルを返します。ファイルのアップロード不要 — mode=text_to_mp3textlang をフォームフィールドとして送信してください。サイトの20言語すべてをサポート。
厳密な検証:各モードには正確な数とファイルの種類が必要です。add_audiomix_audioは1つのMP4 + 1つのMP3のみを受け入れます。image_to_videoは1枚のJPG/PNG + 1つのMP3のみを受け入れます。
期間ルール:音声モードとimage_to_videoモードでは、結果の期間はMP3の期間にロックされます。

共通パラメータ(multipart/form-data)

フィールド種類必須説明
videos[]File[]はい処理するファイル。モードによって異なります:2〜20個のMP4、または1つのMP4 + 1つのMP3、または1枚の画像(JPG/PNG)+ 1つのMP3。1ファイルあたり最大500 MB。
modestring*image_to_video | add_audio | mix_audio。これら3つのモードには必須です。すべてのファイルがMP4の場合のみ無視されます(fusion)。
orderJSONfusionモードのみ — クリップの順序を定義するインデックスのJSON配列。
transition_typestringfusionモードのみ。デフォルト:none
transition_durationfloatfusionモードのみ。期間0.2〜2.0秒。デフォルト:0.5
optionsJSONimage_to_videoモードのみ — レンダリングパラメータのJSONオブジェクト。
callback_urlstringジョブ完了時に呼び出される公開URL(http/https)。レスポンスにはwebhook_secretが含まれます。

optionsパラメータ — image_to_videoモード

すべてオプションです。指定されていない値 → ワーカーによってデフォルトが適用されます。

キー種類デフォルト説明
textstring""オーバーレイとして表示されるテキスト。空 = テキストなし。最大500文字。
font_sizeint60ピクセル単位のフォントサイズ。範囲:10〜300。
text_colorstring"white"テキストカラー(例:whiteyellow#ffffff)。
text_positionstring"center"テキスト位置:centertopbottom
boxbooltrueテキストの後ろの半透明の背景。
box_colorstring"black@0.4"FFmpeg形式の色 + 不透明度:color@opacity
fade_durationfloat0.5秒単位のフェードイン/アウト期間(0〜2)。0 = エフェクトなし。
widthint1080ピクセル単位の動画幅(64〜3840、偶数に強制)。
heightint1920ピクセル単位の動画高さ(64〜3840、偶数に強制)。
fpsint24フレームレート(1〜60)。
image_fitstring"contain"フレーミングモード:contain = 画像全体が表示される;cover = フレーム全体を埋めるようにズーム。
bg_colorstring"black"画像がターゲット解像度を満たさない場合の背景色。
enable_image_motionboolfalse写真アニメーションを有効にします。falseの場合、画像は静止したままです。
image_motion_effectstring"ken_burns"アニメーションエフェクト。受け入れられる値:zoom_inzoom_outpan_left_to_rightken_burnsなど。
motion_intensityfloat1.0写真アニメーションの強度(0.25〜2.0)。ズーム振幅とパン速度を乗算します。
text_effectstring"none"テキストオーバーレイアニメーション。受け入れられる値:nonefade_inslide_upslide_downbounce
text_effect_intensityfloat1.0テキストアニメーション強度(0.25〜2.0)。text_effectnoneの場合は無視されます。
text_border_widthint0ピクセル単位の文字の黒いアウトラインの太さ(0 = 無効)。
text_modestring"static"テキストの表示モード。static(デフォルト):最初のフレームからテキスト全体を表示。word_by_wordword_reveal_speedの速度で1語ずつ表示。text_effectとは同時使用不可:text_mode=word_by_wordの場合、text_effectは無視されます。
word_reveal_speedfloat1.51秒あたりの単語表示速度(0.3〜5.0、デフォルト1.5)。text_mode=word_by_word時のみ使用。OpenAI TTS同期の推奨値:2.0。
word_animstring"none"各単語の表示アニメーション。none(デフォルト):即座に表示。fade:各単語が0.2秒のフェードで表示されクロスフェード。text_mode=word_by_wordのみ。

optionsパラメータ — overlay_videoモード

すべて任意。アップロード順が重要: 1ファイル目はメイン動画(背景)、2ファイル目はオーバーレイ(前景)。chroma_keyでオーバーレイのグリーンスクリーンを除去できます。

キー種類デフォルト説明
positionstring"bottom-right"オーバーレイを配置するコーナー: top-lefttop-rightbottom-leftbottom-right、またはcenter
scalefloat0.30メイン動画幅に対するオーバーレイのサイズ比率。0.25 = 幅の25%。範囲: 0.05–1.0。
opacityfloat1.0オーバーレイの透明度。1.0 = 完全不透明、0.0 = 不可視。
marginint10オーバーレイとフレーム端の間のピクセル数。position=centerの場合は無視。範囲: 0–200。
audiostring"main"保持するオーディオ。main: メイン動画のみ。overlay: オーバーレイのみ。mix: 両方をミックス。
chroma_keyboolfalsetrueに設定するとオーバーレイの純緑色(#00FF00)の背景を除去します。グリーンスクリーンで撮影したウェブカメラや映像に有効です。
chroma_similarityfloat0.20グリーンスクリーンの許容範囲。低い = 厳密な一致。高い = より広い除去。推奨: デジタルグリーンは0.10–0.20、物理スクリーンは0.25–0.45。範囲: 0.01–0.60。

optionsパラメータ — 音声編集(mix_audio

mode=mix_audioでのみ利用可能。add_audioでは無視されます。

キー種類デフォルト説明
mp3_volumefloat1.0オーバーレイされたMP3の音量(0.0 = ミュート、1.0 = 元の音量、2.0 = 2倍)。

成功レスポンス(HTTP 200)

{ "success": true, "job_id": "a3f1c8d2e5b09471...", "mode": "fusion", // "fusion" | "add_audio" | "mix_audio" | "image_to_video" | "overlay_video" "file_count": 2, "transition": null, "quota_used": 1, "quota_remaining": 9, "status_url": "https://rapidvideomaker.com/api/v1/jobs.php?job_id=a3f1c8..." }

curlの例 — image_to_videoモード

curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@scene.jpg" \ -F "videos[]=@narration.mp3" \ -F "mode=image_to_video" \ -F 'options={"text":"Chapter 1","font_size":72,"text_color":"white","text_position":"bottom","box":true,"box_color":"black@0.4","fade_duration":0.5,"width":1080,"height":1920,"image_fit":"contain","bg_color":"black","enable_image_motion":true,"image_motion_effect":"ken_burns","motion_intensity":1.0,"text_effect":"slide_up","text_effect_intensity":1.0}' # image_fit : "contain" | "cover" # bg_color : ignored if image_fit="cover" # enable_image_motion : true = animation on, false (default) = static image # image_motion_effect : zoom_in | zoom_out | pan_left_to_right | pan_right_to_left | pan_top_to_bottom | pan_bottom_to_top | zoom_pan_soft | ken_burns # motion_intensity : 0.25–2.0 — photo animation amplitude (default 1.0) # text_effect : none | fade_in | slide_up | slide_down | slide_left | bounce (ignored if text_mode=word_by_word) # text_effect_intensity : 0.25–2.0 — text animation intensity (default 1.0) # text_border_width : 0–10 px — black outline around characters (0 = disabled) # text_mode : "static" (default) | "word_by_word" — reveal words one by one # word_reveal_speed : 0.3–5.0 w/s — speed for word_by_word mode (default 1.5, ~2.0 for OpenAI TTS) # word_anim : "none" (default) | "fade" — fade-in crossfade on each word (word_by_word only)

curlの例 — 音声編集

# Replace audio (deletes original) curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@my_video.mp4" \ -F "videos[]=@my_music.mp3" \ -F "mode=add_audio" # Keep original audio + overlay MP3 curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@my_video.mp4" \ -F "videos[]=@my_music.mp3" \ -F "mode=mix_audio" \ -F 'options={"mp3_volume":0.7}' # mp3_volume : 0.0 (muted) → 1.0 (original volume, default) → 2.0 (amplified)

curlの例 — overlay_videoモード

curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@main_video.mp4" \ -F "videos[]=@overlay_video.mp4" \ -F "mode=overlay_video" \ -F 'options={"position":"bottom-right","scale":0.25,"opacity":1.0,"margin":20,"audio":"main"}' # Green screen overlay curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@main_video.mp4" \ -F "videos[]=@webcam_greenscreen.mp4" \ -F "mode=overlay_video" \ -F 'options={"position":"bottom-left","scale":0.35,"chroma_key":true,"chroma_similarity":0.15,"audio":"mix"}' # position : top-left | top-right | bottom-left | bottom-right | center (default: bottom-right) # scale : 0.05–1.0 — overlay width as fraction of main video (default 0.30) # opacity : 0.0–1.0 — overlay transparency (default 1.0) # margin : 0–200 px — gap from frame edge, ignored if center (default 10) # audio : main | overlay | mix — audio to keep (default: main) # chroma_key : true | false — remove green (#00FF00) background from overlay (default false) # chroma_similarity : 0.01–0.60 — green screen tolerance (default 0.20)

curlの例 — 動画結合

curl -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@clip1.mp4" \ -F "videos[]=@clip2.mp4" \ -F "transition_type=fade" \ -F "transition_duration=0.5"
GET /api/v1/jobs.php?job_id=<hex32> ジョブステータス

可能なステータス

ステータス意味追加フィールド
queued キュー待ち、未処理 queue_position, queue_total, eta_minutes
processing FFmpeg処理中
ready 完了 — ファイル利用可能 download_url, created_at, expires_at
error 処理失敗 error (message)

ステータス別レスポンス

{ "job_id": "a3f1c8...", "status": "queued", "queue_position": 2, "queue_total": 3, "eta_minutes": 7 }
{ "job_id": "a3f1c8...", "status": "ready", "download_url": "https://rapidvideomaker.com/api/download.php?job_id=a3f1c8...", "created_at": "2026-06-02T10:00:00+00:00", "expires_at": "2026-06-02T12:00:00+00:00" }

curlの例

curl -H "Authorization: Bearer rvm_your_token" \ "https://rapidvideomaker.com/api/v1/jobs.php?job_id=a3f1c8..."
GET /api/v1/jobs.php List all jobs created with this token (paginated, sorted by date desc)

共通パラメータ(multipart/form-data)

apidocs_th_param種類デフォルトapidocs_th_desc
pageinteger1Page number (starts at 1)
limitinteger20Results per page (max 50, default 20)

ステータス別レスポンス

{ "success": true, "jobs": [ { "job_id": "a3f1c8...", "status": "ready", "mode": "fusion", "created_at": "2026-06-02T10:00:00+00:00", "expires_at": "2026-06-02T12:00:00+00:00", "download_url": "https://..." }, ... ], "total": 12, "page": 1, "limit": 20 }
POST /api/v1/publish.php YouTubeまたはTikTokに動画を投稿

1つ以上のソーシャルアカウントに、完了したジョブ(status=ready)を投稿します。トークンはメンバーアカウントのものである必要があります(管理者トークン不可)。

前提条件: このエンドポイントを使用する前に、メンバーエリアの投稿ページでOAuth経由のソーシャルアカウント(YouTube、TikTok)の連携が必要です。各アカウントのaccount_idはそのページに表示されます。

共通パラメータ(multipart/form-data)

apidocs_th_param種類apidocs_th_requiredapidocs_th_desc
job_idstringapidocs_required完了した動画のジョブID(hex 32文字)
publicationsarrayapidocs_required投稿オブジェクトの配列(最大10件)

投稿オブジェクト

apidocs_th_param種類apidocs_th_requiredapidocs_th_desc
account_idintegerapidocs_required接続済みソーシャルアカウントのID — メンバーエリアの投稿ページで確認できます
titlestring動画タイトル(最大512文字)
descriptionstring動画説明(最大5,000文字)
tagsstringカンマ区切りのタグ(最大1,024文字)
visibilitystringpublic | private | unlisted — デフォルト: public
tiktok_modestringdraft | direct — TikTokのみ — デフォルト: direct
tiktok_privacystringdirectモードTikTokのみ — directモードで必須
allow_commentbooleanTikTokのみ — コメントを許可
allow_duetbooleanTikTokのみ — デュエットを許可
allow_stitchbooleanTikTokのみ — ステッチを許可
your_brandbooleanTikTokのみ — オーガニック広告コンテンツ(「自社ブランド」)。
branded_contentbooleanTikTokのみ — ブランドコンテンツの開示
tiktok_cover_msintegerTikTokのみ — カバーフレームのタイムスタンプ(ms、0~60,000、デフォルト1,000)

ステータス別レスポンス

{ "success": true, "results": [ { "account_id": 12, "pub_id": 47, "status": "published", "provider": "youtube", "url": "https://youtu.be/abc123" } ] }

投稿ごとのエラーコード

apidocs_th_code意味
job_not_readyジョブがまだ完了していません
mode_not_supportedtext_to_mp3ジョブは投稿できません
account_not_foundアカウントが見つからないか接続されていません
tiktok_privacy_requireddirectモードにはプライバシーレベルが必要です
publication_failedアップロード中にプロバイダーがエラーを返しました

cURL例

curl -X POST https://rapidvideomaker.com/api/v1/publish.php \ -H "Authorization: Bearer rvm_your_token" \ -H "Content-Type: application/json" \ -d '{ "job_id": "a3f1c8...", "publications": [ { "account_id": 12, "title": "My video", "description": "Created with RapidVideoMaker", "visibility": "public" } ] }'
GET /api/download.php?job_id=<hex32> 最終ファイルをダウンロード

最終MP4ファイルをストリームとして返します(Content-Type: video/mp4)。トークン不要。ステータスがreadyの場合のみ利用可能。

ファイルはジョブ完了後2時間保持され、その後削除されます。ステータスがreadyになったらすぐにダウンロードしてください。

オプションパラメータ

パラメータ説明
filenameダウンロードするファイルの推奨名(例:my-video.mp4

curlの例

curl -o "output.mp4" \ "https://rapidvideomaker.com/api/download.php?job_id=a3f1c8...&filename=output.mp4"

Webhooks

Webhookはポーリングの代替手段です:X秒ごとにステータスを確認する代わりに、URLを指定するとサーバーがジョブ完了時に自動的に通知します。

仕組み

  1. callback_url/api/v1/render.phpへのPOSTに含めます
  2. レスポンスにはwebhook_secretが含まれます — 署名の検証のために保存してください
  3. ジョブがreadyまたはerrorになると、サーバーはあなたのURLに署名されたJSON POSTを送信します
  4. HMAC-SHA256(webhook_secret, raw_body)で署名を検証します
制約:callback_urlは公開アクセス可能なURL(httpまたはhttps)である必要があります。プライベート、ループバック、予約済みIPアドレスはサーバー側でブロックされます。タイムアウト:10秒。

受信ペイロード

{ "job_id": "a3f1c8...", "status": "ready", "download_url": "https://rapidvideomaker.com /api/download.php?job_id=a3f1c8...", "timestamp": "2026-04-04T12:00:00+00:00" }
{ "job_id": "a3f1c8...", "status": "error", "error": "FFmpeg xfade failed:...", "timestamp": "2026-04-04T12:00:00+00:00" }

サーバーが送信するヘッダー

ヘッダー
Content-Typeapplication/json
X-RVM-Signaturesha256=<hmac_hex> — 生のボディのHMAC-SHA256署名
X-RVM-Job-Id関連するjob_id

署名の検証

# Python import hmac, hashlib def verify_webhook(secret: str, body: bytes, signature_header: str) -> bool: expected = "sha256=" + hmac.new( secret.encode(), body, hashlib.sha256 ).hexdigest() return hmac.compare_digest(expected, signature_header) # Flask/FastAPI endpoint: sig = request.headers.get("X-RVM-Signature", "") if not verify_webhook(WEBHOOK_SECRET, request.data, sig): return "Invalid signature", 403 data = request.get_json()

エラーコード

HTTPJSONコード原因
401unauthorizedトークンが不足、無効、または取り消されています
400missing_filesファイルが受信されていません
400too_few_files送信されたファイルが2個未満です
400too_many_files送信されたファイルが20個を超えています
400invalid_mimeサポートされていないファイル — MP4、MP3、JPG/PNGのみ受け入れられます
400wrong_file_countファイル数が選択したモードに一致しません
400wrong_file_typesファイルの種類が選択したモードに一致しません
400invalid_file_combination指定されたモードなしのファイルの組み合わせがサポートされているモードに一致しません
400invalid_optionsoptionsフィールドが有効なJSONではありません
400invalid_optionoptions内の値が無効です
400file_too_largeファイルが500 MBを超えています
400invalid_orderorder配列が有効な順列ではありません
400invalid_job_idjob_idの形式が正しくありません(32文字の16進数である必要があります)
404job_not_foundジョブが見つかりません — job_idが不明または存在したことがありません
410job_expiredジョブが期限切れ — 存在しましたが2時間の回復ウィンドウが過ぎています
429quota_exceeded1日20件の成功ジョブ制限に達しました
429rate_limited/api/v1/jobs.phpで1分あたり12回を超える呼び出しがありました
500server_error内部サーバーエラー

統合例

各モードの例 — pip install requestsrequestsをインストール。

共通設定

import requests, time, sys, json API_BASE = "https://rapidvideomaker.com" API_TOKEN = "rvm_your_token_here" HEADERS = {"Authorization": f"Bearer {API_TOKEN}"}

image_to_videoモード — 画像 + 音声 → 動画

with open("scene.jpg", "rb") as fi, open("narration.mp3", "rb") as fa: resp = requests.post( f"{API_BASE}/api/v1/render.php", headers=HEADERS, files=[ ("videos[]", ("scene.jpg", fi, "image/jpeg")), ("videos[]", ("narration.mp3", fa, "audio/mpeg")), ], data={ "mode": "image_to_video", "options": json.dumps({ "text": "Chapter 1", "font_size": 72, "text_color": "white", "text_position": "bottom", "box": True, "box_color": "black@0.4", "fade_duration": 0.5, "width": 1080, "height": 1920, "image_fit": "contain", # "contain" | "cover" "bg_color": "black", # ignored if image_fit="cover" "enable_image_motion": True, "image_motion_effect": "ken_burns", "motion_intensity": 1.0, # 0.25–2.0 — photo animation amplitude "text_effect": "slide_up", # none | fade_in | slide_up | slide_down | slide_left | bounce (ignored if text_mode=word_by_word) "text_effect_intensity": 1.0, # 0.25–2.0 — text animation intensity # word-by-word reveal (mutually exclusive with text_effect): # "text_mode": "word_by_word", "word_reveal_speed": 2.0, "word_anim": "fade" }), }, )

音声編集

# Replace audio (deletes original) — mode=add_audio with open("video.mp4", "rb") as fv, open("music.mp3", "rb") as fa: resp = requests.post( f"{API_BASE}/api/v1/render.php", headers=HEADERS, files=[ ("videos[]", ("video.mp4", fv, "video/mp4")), ("videos[]", ("music.mp3", fa, "audio/mpeg")), ], data={"mode": "add_audio"}, ) # Keep original audio + overlay MP3 — mode=mix_audio with open("video.mp4", "rb") as fv, open("music.mp3", "rb") as fa: resp = requests.post( f"{API_BASE}/api/v1/render.php", headers=HEADERS, files=[ ("videos[]", ("video.mp4", fv, "video/mp4")), ("videos[]", ("music.mp3", fa, "audio/mpeg")), ], data={"mode": "mix_audio", "options": json.dumps({"mp3_volume": 0.7})}, # mp3_volume : 0.0 = muted, 1.0 = original volume (default), 2.0 = amplified )

overlay_videoモード — ピクチャーインピクチャー

with open("main.mp4", "rb") as fm, open("overlay.mp4", "rb") as fo: resp = requests.post( f"{API_BASE}/api/v1/render.php", headers=HEADERS, files=[ ("videos[]", ("main.mp4", fm, "video/mp4")), ("videos[]", ("overlay.mp4", fo, "video/mp4")), ], data={ "mode": "overlay_video", "options": json.dumps({ "position": "bottom-right", # top-left | top-right | bottom-left | bottom-right | center "scale": 0.25, # 0.05–1.0 — overlay width fraction "opacity": 1.0, # 0.0–1.0 — transparency "margin": 20, # 0–200 px — gap from frame edge "audio": "main", # main | overlay | mix # green screen: "chroma_key": True, "chroma_similarity": 0.15 }), }, )

動画結合

with open("clip1.mp4", "rb") as f1, open("clip2.mp4", "rb") as f2: resp = requests.post( f"{API_BASE}/api/v1/render.php", headers=HEADERS, files=[ ("videos[]", ("clip1.mp4", f1, "video/mp4")), ("videos[]", ("clip2.mp4", f2, "video/mp4")), ], data={"transition_type": "fade", "transition_duration": "0.5"}, )

ポーリング + ダウンロード(すべてのモードに共通)

resp.raise_for_status() job_id = resp.json()["job_id"] print(f"Job created: {job_id}") for _ in range(120): # timeout 10 min (120 × 5s) r = requests.get( f"{API_BASE}/api/v1/jobs.php", headers=HEADERS, params={"job_id": job_id}, ) data = r.json() status = data["status"] if status == "queued": pos = data.get("queue_position", "?") eta = data.get("eta_minutes", "?") print(f"Queued — position {pos}, ETA ~{eta} min") elif status == "processing": print("Processing…") elif status == "ready": download_url = data["download_url"] break elif status == "error": sys.exit(f"Error: {data.get('error')}") time.sleep(5) else: sys.exit("Timeout: job not completed after 10 min") r = requests.get(download_url, stream=True) with open("output.mp4", "wb") as f: for chunk in r.iter_content(65536): f.write(chunk) print("Downloaded: output.mp4")

n8nでの2つのアプローチ:ポーリング(ステータスループ)またはWebhook(サーバーがn8nを呼び出す)。Webhookを推奨。

アプローチA — Webhook(推奨)

ノード3つのみ、ループなし。

ノード1 — Webhookトリガー
ワークフロー入力としてWebhookノードを追加します(メソッドPOST)。

ノード2 — ジョブを作成(HTTPリクエスト)

メソッドPOST
URLhttps://rapidvideomaker.com/api/v1/render.php
認証Header Auth — Authorization: Bearer rvm_…
ボディコンテンツタイプForm-Data Multipart
Body params各クリップのバイナリフィールドvideos[] + テキストフィールドcallback_url

署名を検証するために、レスポンスのwebhook_secretをワークフロー変数に保存してください。

ノード3 — 結果を処理(Webhookがトリガーするワークフロー内)
n8nがサーバーのPOSTを受信すると、$json.statusreadyまたはerrorです。

署名を検証するには:{{ $headers['x-rvm-signature'] }}webhook_secretからHMAC-SHA256を比較します。

アプローチB — ポーリング(Webhookなし)

5ノード、10秒ごとのステータスループ。

ノード1 — ジョブを作成callback_urlなしで同じ設定。

ノード2 — 待機 — 10秒。

ノード3 — ステータスをポーリング(HTTPリクエストGET)

URLhttps://rapidvideomaker.com/api/v1/jobs.php
クエリパラメータjob_id = {{ $('ノード1').item.json.job_id }}
認証ヘッダー認証 — 同じトークン

ノード4 — If{{ $json.status }} === 'ready' → true:ノード5 / false:ノード2に戻る。

無限ループを避けるため、Setノードに繰り返しカウンターを追加してください。

ノード5 — ダウンロード{{ $json.download_url }}でHTTPリクエストGET。

ステップ1 — ジョブを作成(モードを選択)

# fusion JOB=$(curl -s -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@clip1.mp4" -F "videos[]=@clip2.mp4") # add_audio (replace audio) JOB=$(curl -s -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@video.mp4" -F "videos[]=@music.mp3" \ -F "mode=add_audio") # mix_audio (overlay music at 70% volume) JOB=$(curl -s -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@video.mp4" -F "videos[]=@music.mp3" \ -F "mode=mix_audio" -F 'options={"mp3_volume":0.7}') # image_to_video JOB=$(curl -s -X POST https://rapidvideomaker.com/api/v1/render.php \ -H "Authorization: Bearer rvm_your_token" \ -F "videos[]=@scene.jpg" -F "videos[]=@narration.mp3" \ -F "mode=image_to_video" \ -F 'options={"text":"Chapter 1","font_size":72,"text_position":"bottom","fade_duration":0.5,"width":1080,"height":1920}') JOB_ID=$(echo $JOB | grep -o '"job_id":"[^"]*"' | cut -d'"' -f4) echo "Job ID: $JOB_ID"

ステップ2 — ポーリング

while true; do STATUS=$(curl -s \ -H "Authorization: Bearer rvm_your_token" \ "https://rapidvideomaker.com/api/v1/jobs.php?job_id=$JOB_ID") STATE=$(echo $STATUS | grep -o '"status":"[^"]*"' | cut -d'"' -f4) echo "Status: $STATE" [ "$STATE" = "ready" ] && break [ "$STATE" = "error" ] && { echo "Error"; exit 1; } sleep 10 done

ステップ3 — ダウンロード

DOWNLOAD_URL=$(echo $STATUS | grep -o '"download_url":"[^"]*"' | cut -d'"' -f4) curl -o output.mp4 "$DOWNLOAD_URL"

ベストプラクティス

結果ファイルはジョブ完了後2時間保持され、その後自動的に削除されます。