genviral Partner API Skill
TL;DR: Wraps genviral's Partner API into 50+ bash commands. Core flow:
get-pack→ analyze images (metadata + vision) →generatewithpinned_images→render→ visual review (hard gate) →create-post→ log toworkspace/performance/log.json. Studio AI:studio-models→studio-generate-image(sync) orstudio-generate-video→studio-video-status --poll(async). Auth viaGENVIRAL_API_KEY. Config indefaults.yaml. Instance data inworkspace/.
What This Skill Does
- Multi-Platform Posting: Video or slideshow posts across TikTok, Instagram, YouTube, Pinterest, LinkedIn, Facebook
- Studio AI Generation: Generate images (sync) and videos (async) via AI models through the API
- File Management: Upload videos/images to genviral's CDN
- AI Slideshow Generation: Photo carousels from prompts, rendered to images
- Template System: Reusable slideshow structures, convert winners to templates
- Pack Management: Image packs as slideshow backgrounds
- Analytics: KPIs, post-level metrics, tracked accounts, refresh triggers
- Niche Intelligence: One-call trend research (
trend-brief) for hashtags, sounds, creators, posting windows, and hook angles - Content Pipeline: Full automation from prompt to posted content
- Performance Tracking: Post log, hook tracking, weekly review
- Hook Library: Maintain and evolve a library of proven content hooks
How It Works
- Generate or upload media
- Create a post targeting one or more accounts
- Schedule or publish (for TikTok slideshows, optionally save as drafts so you can add trending audio before publishing — music selection requires human judgment for best results)
- Track performance via analytics
- Learn and optimize
All configuration in defaults.yaml. Secrets via environment variables. Everything posted shows up in the Genviral dashboard.
First-Time Setup
If fresh install, read docs/setup.md and walk the user through onboarding conversationally:
- Set API key and verify it works
- List accounts and pick which to post to
- Discuss image strategy (existing packs, create new, generate per post, or mix)
- Optionally set up product context and brand voice together
No hardcoded defaults. Ask the user what they prefer and adapt. Everything done through this skill shows up in the Genviral dashboard, so the user always has full visibility and control.
File Structure
genviral/
SKILL.md # This file (kernel + routing)
README.md # Human-facing overview
defaults.yaml # API config and defaults
docs/
setup.md # Onboarding guide (conversational, 5 phases)
api/
accounts-files.md # accounts, upload, list-files
posts.md # create-post, update-post, retry, list, get, delete
slideshows.md # generate, render, review, update, regenerate, duplicate, list + text styles
packs.md # pack CRUD + smart image selection (MANDATORY reading for any pack workflow)
templates.md # template CRUD + create-from-slideshow
analytics.md # all analytics commands
studio.md # Studio AI: generate images/videos, list models, poll status
subscription.md # subscription status, credits, tier
pipeline.md # content pipeline, performance loop, CTA testing, platform tips
errors.md # error codes and troubleshooting
references/
analytics-loop.md # Full analytics feedback loop and weekly review process
competitor-research.md # How to research competitors
prompts/
slideshow.md # Prompt templates for slideshow generation
hooks.md # Prompt templates for hook brainstorming
workspace/ # All instance/customer data (override with GENVIRAL_WORKSPACE_DIR)
content/
scratchpad.md # Working content plan and drafts
calendar.json # Upcoming planned posts
context/
product.md # Product description, value props, target audience
brand-voice.md # Tone, style, do's and don'ts
niche-research.md # Platform research for the niche
hooks/
library.json # Hook instances (grows over time, tracks performance)
formulas.md # Hook formula patterns and psychology
performance/
log.json # CANONICAL post record (single source of truth)
hook-tracker.json # Hook and CTA tracking with metrics (the feedback loop)
insights.md # Agent learnings from performance data
weekly-review.md # Weekly review notes
competitor-insights.md # Competitor research findings
scripts/
genviral.sh # Main API wrapper (all commands)
update-skill.sh # Self-updater
Command Routing
Load only what you need for the current task:
| Task | Read |
|---|---|
| Account discovery, file upload | docs/api/accounts-files.md |
| Create, update, list, delete posts | docs/api/posts.md |
| Slideshow generation, rendering, editing, text styles | docs/api/slideshows.md |
| Pack management, image selection (ANY pack workflow) | docs/api/packs.md |
| Template creation and management | docs/api/templates.md |
| Analytics queries and target management | docs/api/analytics.md |
| Studio AI: generate images, videos, list models | docs/api/studio.md |
| Subscription: check credits, tier, renewal dates | docs/api/subscription.md |
| Research a specific niche quickly (trend + competitors + hooks) | docs/api/analytics.md, docs/references/competitor-research.md, docs/prompts/hooks.md |
| Full content pipeline, performance loop, CTA testing | docs/api/pipeline.md |
| Error codes, troubleshooting | docs/api/errors.md |
Niche Research Mode (When user asks to research a niche)
When asked things like "research this niche", "find what works in this niche", or "give me niche intelligence":
- Run
trend-brieffirst for the niche keyword (7dbaseline, then24hfor freshness if needed). - Extract and report: top hashtags, top sounds, top creators, posting windows (UTC), recommended hook angles.
- Run competitor deep-dive using
docs/references/competitor-research.md(3-5 accounts minimum). - Produce a short actionable output with:
- 3 hook angles to test
- 2 CTA suggestions
- 2 best posting windows
- 5 hashtags to start with
- 1 "gap to exploit" insight
- Save findings to
workspace/performance/competitor-insights.mdand use them in subsequent content prompts.
Non-Negotiable Rules
These apply regardless of what docs you've loaded:
-
ALWAYS use
pinned_imageswhen generating a slideshow with a pack. Never callgeneratewith just--pack-id— the server will pick random images. Readdocs/api/packs.mdbefore any pack workflow. -
ALWAYS visually review every rendered slide before posting. If any slide fails readability, fix it. This is a hard gate — not a suggestion.
-
ALWAYS log to
workspace/performance/log.jsonimmediately after posting. This is the canonical record. -
ALWAYS add a hook-tracker entry after posting. No tracking = no learning.
-
Never use em-dashes in any generated content.
-
Respect
workspace/— all instance data lives here. Do not write state files to the skill root.
Script Usage
/path/to/genviral/scripts/genviral.sh <command> [options]
Requires GENVIRAL_API_KEY as an environment variable (format: public_id.secret). Loads defaults from defaults.yaml. Set GENVIRAL_WORKSPACE_DIR to override the workspace path (defaults to workspace/ relative to the skill dir).
Auto-Updates
This skill includes a self-updater that keeps skill-owned files in sync with the latest version from fdarkaou/genviral-skill.
bash scripts/update-skill.sh # check + apply if updates available
bash scripts/update-skill.sh --dry-run # preview only, no changes
bash scripts/update-skill.sh --force # force re-apply even if already current
What gets updated (skill-owned): SKILL.md, scripts/, docs/ (all subdirs)
What never gets touched (user-owned): workspace/ — your data, context, hooks, and performance logs are always preserved.
Notes
- Works with any platform genviral supports (TikTok, Instagram, etc.)
- Supports both video and slideshow posts
- Works with hosted and BYO accounts
- Posts can be scheduled or queued for immediate publishing
- TikTok slideshow drafts: use
post_mode: MEDIA_UPLOADto save to drafts inbox for audio addition