← 返回
数据分析 Key 中文

Biver Builder

Integration skill for Biver Landing Page Builder API. Use when: (1) Creating, updating, or deleting landing pages (2) Managing subdomains (.lp.biver.id) or c...
{"answer":"Biver落地页构建器API集成技能。使用场景:(1) 创建、更新或删除落地页 (2) 管理子域名 (.lp.biver.id) 或c..."}
ramaaditya49
数据分析 clawhub v1.0.4 1 版本 99791.7 Key: 需要
★ 3
Stars
📥 898
下载
💾 7
安装
1
版本
#latest

概述

Biver Builder API Skill

Before You Install

> Security Checklist

>

> Before installing or supplying credentials, please review:

>

> 1. Credential Required: This skill requires BIVER_API_KEY to operate

> 2. Start with Test Keys: Use bvr_test_ prefix keys for initial testing — never use bvr_live_ keys until you trust the skill

> 3. Verify Scopes: Check required API key scopes below and use least-privilege principle

> 4. Rotate Keys: Periodically rotate your API keys for security

> 5. Inspect Source: If using manual installation, inspect the GitHub repository code before cloning


Installation

Via ClawdHub (Recommended)

clawdhub install biver-builder

Manual

> Warning: Cloning external repositories can introduce arbitrary code. Inspect the repository first before running:

>

> ```bash

> # Step 1: Review the source code

> git clone https://github.com/RamaAditya49/biver-builder.git /tmp/biver-builder-review

> # Review files in /tmp/biver-builder-review before proceeding

>

> # Step 2: Only after review, install to your skills directory

> git clone https://github.com/RamaAditya49/biver-builder.git ~/.openclaw/skills/biver-builder

> ```


Credential Configuration

Required Environment Variables

VariableDescriptionExample
--------------------------------
BIVER_API_KEYYour Biver API keybvr_live_xxxxx or bvr_test_xxxxx

Optional Environment Variables

VariableDescriptionDefault
--------------------------------
BIVER_API_BASE_URLCustom API base URLhttps://api.biver.id

Setting Up Credentials

Via OpenClaw Dashboard:

  1. Navigate to Settings > Environment Variables
  2. Add BIVER_API_KEY with your API key value
  3. (Optional) Add BIVER_API_BASE_URL for custom endpoints

Security Best Practices:

  • Use bvr_test_ prefix keys for development/testing
  • Use bvr_live_ prefix keys only in production after you trust the skill
  • Verify required scopes before creating your API key — only grant minimum permissions needed
  • Never commit API keys to version control
  • Rotate keys periodically
  • Do not supply credentials until you have reviewed the skill or confirmed it from a verified source

How to Get Your API Key

  1. Log in to Biver Dashboard
  2. Go to Settings > API Keys
  3. Click Generate New Key
  4. Select required scopes (see Required Scopes section below — grant only what you need)
  5. Choose key type: bvr_test_ for testing, bvr_live_ for production
  6. Copy and store securely (shown only once)

> Scope Recommendation: Start with read-only scopes (*:read) for testing. Add write scopes only when needed.


Quick Reference

Base URL

https://api.biver.id

Authentication Headers

// Use environment variables for security
const apiKey = process.env.BIVER_API_KEY;

// Headers configuration
{
  'X-API-Key': apiKey,
  'Authorization': `Bearer ${apiKey}`
}

API Key Prefixes

PrefixEnvironmentUsage
----------------------------
bvr_live_ProductionReal data operations
bvr_test_SandboxTesting without affecting real data

Endpoint Lookup

TaskEndpointMethodAuthScope
-------------------------------------
List pages/v1/pagesGETYespages:read
Create page/v1/pagesPOSTYespages:write
Get page/v1/pages/:idGETYespages:read
Update page/v1/pages/:idPATCHYespages:write
Delete page/v1/pages/:idDELETEYespages:write
Deploy page/v1/pages/:id/deployPOSTYespages:write
List subdomains/v1/subdomainsGETYespages:read
Create subdomain/v1/subdomainsPOSTYespages:write
Update subdomain/v1/subdomains/:idPATCHYespages:write
Delete subdomain/v1/subdomains/:idDELETEYespages:write
List domains/v1/domainsGETYesdomains:read
Add custom domain/v1/domainsPOSTYesdomains:write
Set primary domain/v1/domains/:id/primaryPOSTYesdomains:write
Delete domain/v1/domains/:idDELETEYesdomains:write
List sections/v1/sectionsGETYessections:read
Create section/v1/sectionsPOSTYessections:write
Update section/v1/sections/:idPATCHYessections:write
Delete section/v1/sections/:idDELETEYessections:write
List products/v1/productsGETYesproducts:read
Create product/v1/productsPOSTYesproducts:write
Update product/v1/products/:idPATCHYesproducts:write
Delete product/v1/products/:idDELETEYesproducts:write
List forms/v1/formsGETYesforms:read
Create form/v1/formsPOSTYesforms:write
Get submissions/v1/forms/:id/submissionsGETYesforms:read
Submit form/v1/forms/:id/submitPOSTNo-
List gallery/v1/galleryGETYesgallery:read
Upload asset/v1/galleryPOSTYesgallery:read
Delete asset/v1/gallery/:idDELETEYesgallery:read
Get workspace/v1/workspace/settingsGETYesworkspace:read
Update workspace/v1/workspace/settingsPUTYesworkspace:write
Update branding/v1/workspace/brandingPUTYesworkspace:write
Update SEO/v1/workspace/seoPUTYesworkspace:write
AI generate page/v1/ai/pagesPOSTYesai:generate
AI generate section/v1/ai/sectionsPOSTYesai:generate
Health check/healthGETNo-

Authentication

Required Scopes

ScopeDescription
--------------------
pages:readRead pages
pages:writeCreate, update, delete pages
sections:readRead sections
sections:writeCreate, update, delete sections
products:readRead products
products:writeManage product catalog
forms:readRead forms and submissions
forms:writeCreate/update forms
gallery:readAccess gallery assets
domains:readView custom domains
domains:writeAdd/remove custom domains
subdomains:readView subdomains
subdomains:writeCreate/update/delete subdomains
workspace:readRead workspace settings
workspace:writeUpdate workspace settings
ai:generateGenerate pages/sections with AI

Common Workflows

Workflow 1: Create Landing Page with Subdomain

const API_KEY = process.env.BIVER_API_KEY;
const BASE_URL = process.env.BIVER_API_BASE_URL || 'https://api.biver.id';

// Step 1: Create subdomain
const subdomain = await fetch(`${BASE_URL}/v1/subdomains`, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    subdomain: 'my-store',
    title: 'Summer Sale 2026',
    description: 'Our biggest sale event',
    pathSlug: 'summer-sale'
  })
});
// Result: my-store.lp.biver.id/summer-sale

// Step 2: Create sections for the page
const section = await fetch(`${BASE_URL}/v1/sections?pageId=PAGE_ID`, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    type: 'hero',
    name: 'Hero Section',
    htmlContent: '<div class="hero">...</div>',
    cssContent: '.hero { ... }',
    visible: true,
    order: 0
  })
});

// Step 3: Update subdomain status to publish
await fetch(`${BASE_URL}/v1/subdomains/${subdomainId}`, {
  method: 'PATCH',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    status: 'published'
  })
});

Workflow 2: Setup Custom Domain

const API_KEY = process.env.BIVER_API_KEY;
const BASE_URL = process.env.BIVER_API_BASE_URL || 'https://api.biver.id';

// Step 1: Add custom domain
const domain = await fetch(`${BASE_URL}/v1/domains`, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    domain: 'example.com',
    isPrimary: true,
    landingPageId: 'page_123'
  })
});

// Step 2: Configure DNS (outside API)
// Add verification token to DNS records
// Token provided in response: verificationToken

// Step 3: Set as primary (optional)
await fetch(`${BASE_URL}/v1/domains/${domainId}/primary`, {
  method: 'POST',
  headers: { 'X-API-Key': API_KEY }
});

Workflow 3: Generate Page with AI

const API_KEY = process.env.BIVER_API_KEY;
const BASE_URL = process.env.BIVER_API_BASE_URL || 'https://api.biver.id';

const aiPage = await fetch(`${BASE_URL}/v1/ai/pages`, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    prompt: 'Create a landing page for a coffee shop called Morning Brew',
    style: 'modern',
    industry: 'fnb',
    language: 'en'
  })
});
// Returns: title, content.sections[], suggestedSlug

Workflow 4: Upload Asset and Create Page

const API_KEY = process.env.BIVER_API_KEY;
const BASE_URL = process.env.BIVER_API_BASE_URL || 'https://api.biver.id';

// Step 1: Upload image to gallery
const formData = new FormData();
formData.append('file', imageFile);

const asset = await fetch(`${BASE_URL}/v1/gallery`, {
  method: 'POST',
  headers: { 'X-API-Key': API_KEY },
  body: formData
});

// Step 2: Use asset URL in page content
const page = await fetch(`${BASE_URL}/v1/pages`, {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
    'X-API-Key': API_KEY
  },
  body: JSON.stringify({
    title: 'Product Catalog',
    slug: 'catalog',
    content: {
      sections: [{
        type: 'image',
        imageUrl: asset.data.url
      }]
    }
  })
});

API Reference

Pages API

Base: /v1/pages | Scope: pages:read / pages:write

EndpointMethodDescriptionQuery Params / Body
----------------------------------------------------
/v1/pagesGETList pagespage, limit, status, search
/v1/pagesPOSTCreate pagetitle, slug, content, meta, status
/v1/pages/:idGETGet page detail-
/v1/pages/:idPATCHUpdate pagePartial body
/v1/pages/:idDELETEDelete page-
/v1/pages/:id/deployPOSTPublish page-

Page Object:

{
  "id": "page_123",
  "title": "Summer Sale",
  "slug": "summer-sale",
  "status": "published",
  "publishedAt_ms": 1708704000000,
  "createdAt_ms": 1708617600000
}

Create Page Body:

{
  "title": "Page Title",
  "slug": "page-slug",
  "content": { "sections": [] },
  "meta": {
    "description": "SEO description",
    "keywords": "keyword1, keyword2"
  },
  "status": "draft"
}

Sections API

Base: /v1/sections | Scope: sections:read / sections:write

EndpointMethodDescription
-------------------------------
/v1/sectionsGETList sections (?type=, ?pageId=)
/v1/sectionsPOSTCreate section
/v1/sections/:idGETGet section detail
/v1/sections/:idPATCHUpdate section
/v1/sections/:idDELETEDelete section

Section Types: hero, text, image, image_slider, faq, features, pricing, cta, testimonials, contact

Create Section Body:

{
  "type": "hero",
  "name": "Hero Section",
  "htmlContent": "<div>...</div>",
  "cssContent": ".class { ... }",
  "visible": true,
  "order": 0,
  "customClass": "my-custom",
  "anchorId": "hero"
}

Products API

Base: /v1/products | Scope: products:read / products:write

EndpointMethodDescription
-------------------------------
/v1/productsGETList products (?page, ?limit, ?category)
/v1/productsPOSTCreate product
/v1/products/:idGETGet product detail
/v1/products/:idPATCHUpdate product
/v1/products/:idDELETEDelete product

Create Product Body:

{
  "name": "Product Name",
  "description": "Full description",
  "price": 99000,
  "compareAtPrice": 149000,
  "sku": "PROD-001",
  "stock": 100,
  "category": "electronics",
  "images": ["url1", "url2"],
  "isActive": true
}

Forms API

Base: /v1/forms | Scope: forms:read / forms:write

EndpointMethodDescriptionAuth
-------------------------------------
/v1/formsGETList formsYes
/v1/formsPOSTCreate formYes
/v1/forms/:idGETGet form detailYes
/v1/forms/:idPATCHUpdate formYes
/v1/forms/:idDELETEDelete formYes
/v1/forms/:id/submitPOSTSubmit formNo
/v1/forms/:id/submissionsGETGet submissionsYes

Submit Form Body (Public - No Auth):

{
  "data": {
    "name": "John Doe",
    "email": "john@example.com",
    "message": "Hello!"
  }
}

Gallery API

Base: /v1/gallery | Scope: gallery:read

EndpointMethodDescription
-------------------------------
/v1/galleryGETList items (`?type=imagevideodocument, ?search`)
/v1/galleryPOSTUpload asset (multipart/form-data)
/v1/gallery/:idGETGet asset detail
/v1/gallery/:idDELETEDelete asset

Gallery Item Response:

{
  "id": "gallery_123",
  "filename": "hero-image.png",
  "url": "https://cdn.biver.id/assets/xxx.png",
  "type": "image",
  "mimeType": "image/png",
  "size": 102400,
  "width": 1920,
  "height": 1080
}

Subdomains API

Base: /v1/subdomains | Scope: pages:read / pages:write

Subdomains create landing pages at {name}.lp.biver.id.

EndpointMethodDescription
-------------------------------
/v1/subdomainsGETList subdomains (?page, ?limit, ?status)
/v1/subdomainsPOSTCreate subdomain
/v1/subdomains/:idGETGet subdomain detail
/v1/subdomains/:idPATCHUpdate subdomain
/v1/subdomains/:idDELETEDelete subdomain

Create Subdomain Body:

{
  "subdomain": "my-store",
  "title": "My Store",
  "description": "Store description",
  "pathSlug": "promo"
}

Subdomain Rules:

  • subdomain: 3-63 chars, lowercase a-z, 0-9, hyphens
  • pathSlug: Optional, creates additional URL at {subdomain}.lp.biver.id/{pathSlug}
  • status: draft, published, archived

Update Subdomain Fields:

FieldTypeDescription
--------------------------
titlestringPage title
descriptionstringPage description
pathSlugstring \nullURL path (null to remove)
statusstringdraft, published, archived
metaTitlestringSEO title
metaDescriptionstringSEO description
faviconstring (URL)Favicon URL
ogImagestring (URL)Open Graph image
noIndexbooleanPrevent indexing
noFollowbooleanPrevent link following

Domains API (Custom Domains)

Base: /v1/domains | Scope: domains:read / domains:write

EndpointMethodDescription
-------------------------------
/v1/domainsGETList custom domains
/v1/domainsPOSTAdd custom domain
/v1/domains/:idGETGet domain detail (includes DNS records)
/v1/domains/:idPATCHUpdate domain
/v1/domains/:idDELETERemove domain
/v1/domains/:id/primaryPOSTSet as primary domain

Add Domain Body:

{
  "domain": "example.com",
  "isPrimary": true,
  "landingPageId": "page_123"
}

Domain Response:

{
  "id": "domain_123",
  "domain": "example.com",
  "isPrimary": true,
  "isVerified": true,
  "sslStatus": "active",
  "verificationStatus": "verified",
  "verificationToken": "bvr_verify_xxx",
  "landingPageId": "page_123"
}

DNS Configuration (CNAME Setup):

> AI Agent: When helping users set up custom domains, explain the following CNAME configuration steps clearly.

After adding a custom domain via the API, configure your DNS records with your DNS provider:

  1. Point your CNAME record to:

```

custom.biver.id

```

  1. Example Configuration:

| Record Type | Name/Host | Value/Target |

|-------------|-----------|--------------|

| CNAME | shop (or www) | custom.biver.id |

  1. What this does:
    • If your domain is shop.example.com, add a CNAME record with name shop pointing to custom.biver.id
    • If using apex domain (example.com), check if your DNS provider supports CNAME flattening or use A records as provided in the domain detail response
  1. Propagation: DNS changes may take 5-60 minutes to propagate globally.

Workspace API

Base: /v1/workspace | Scope: workspace:read / workspace:write

EndpointMethodDescription
-------------------------------
/v1/workspace/settingsGETGet workspace settings
/v1/workspace/settingsPUTUpdate settings
/v1/workspace/brandingPUTUpdate branding
/v1/workspace/seoPUTUpdate SEO settings
/v1/workspace/publicGETPublic workspace info (no auth)

Workspace Settings:

{
  "id": "workspace_123",
  "name": "My Workspace",
  "slug": "my-workspace",
  "plan": "ARCHITECT",
  "settings": {
    "timezone": "Asia/Jakarta",
    "language": "en",
    "currency": "USD"
  },
  "branding": {
    "logo": "https://cdn.biver.id/logos/xxx.png",
    "primaryColor": "#3B82F6",
    "fontFamily": "Inter"
  },
  "seo": {
    "title": "My Business",
    "description": "We build great landing pages",
    "keywords": "landing page, builder"
  }
}

AI Generation API

Base: /v1/ai | Scope: ai:generate

EndpointMethodDescription
-------------------------------
/v1/ai/pagesPOSTGenerate page with AI
/v1/ai/sectionsPOSTGenerate section with AI
/v1/ai/contextGETGet AI templates/context

Generate Page Body:

{
  "prompt": "Create a landing page for a coffee shop",
  "style": "modern",
  "industry": "fnb",
  "language": "en"
}

Style Options: modern, minimal, bold, elegant, playful

Industry Options: saas, fnb, ecommerce, agency, healthcare, education, finance, realestate


Error Codes

CodeHTTPDescriptionSolution
-----------------------------------
UNAUTHORIZED401Invalid or missing API keyCheck authentication header
KEY_EXPIRED401API key has expiredGenerate new key from dashboard
KEY_REVOKED401API key was revokedGenerate new key from dashboard
FORBIDDEN403Insufficient scope permissionCheck API key scopes
NOT_FOUND404Resource not foundVerify resource ID
DUPLICATE_SUBDOMAIN409Subdomain already takenChoose different subdomain
DUPLICATE_DOMAIN409Domain already existsUse different domain
VALIDATION_ERROR422Request validation failedCheck request body format
RATE_LIMIT_EXCEEDED429Too many requestsWait for reset or upgrade plan
INTERNAL_ERROR500Server errorRetry or contact support

Error Response Format:

{
  "success": false,
  "error": {
    "code": "VALIDATION_ERROR",
    "message": "Request validation failed",
    "details": {
      "fields": [
        { "field": "title", "message": "Title is required", "code": "required" }
      ]
    }
  }
}

Rate Limits

PlanRequests/MinuteTarget User
------------------------------------
SCOUT30Free tier
CRAFTSMAN60Small businesses
ARCHITECT120Growing businesses
ENGINEER300Medium businesses
FOUNDER600Agencies
CHIEF2000Enterprise

Rate Limit Headers:

X-RateLimit-Limit: 60
X-RateLimit-Remaining: 45
X-RateLimit-Reset: 1708704000000
X-RateLimit-Plan: CRAFTSMAN

Response Format

All responses follow this structure:

Success:

{
  "success": true,
  "data": { ... }
}

Paginated:

{
  "success": true,
  "data": {
    "items": [...],
    "pagination": {
      "page": 1,
      "limit": 10,
      "total": 25,
      "totalPages": 3
    }
  }
}

Security Considerations

API Key Safety

  • Never hardcode API keys in source code
  • Always use environment variables or secure secret stores
  • Use test keys (bvr_test_) for development
  • Limit scopes to minimum required for your use case

DNS Configuration

  • Custom domain setup requires DNS changes outside this API
  • Always verify domain ownership before making DNS changes
  • Keep DNS verification tokens secure

Rate Limiting

  • Respect rate limits based on your plan
  • Implement retry logic with exponential backoff
  • Monitor X-RateLimit-Remaining header

Support

  • Dashboard: https://biver.id/dashboard
  • Email: support@biver.id
  • Health Check: GET /health (no auth required)

版本历史

共 1 个版本

  • v1.0.4 当前
    2026-03-29 14:29 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

Tutur Humanizer

ramaaditya49
对印尼语文字进行改写、编辑或审校,使其语言自然、符合人类表达习惯且切合语境。当用户要求使印尼文写作更自然、去除不自然之处时使用。
★ 0 📥 260
data-analysis

A股量化 AkShare

mbpz
A股量化数据分析工具,基于AkShare库获取A股行情、财务数据、板块信息等。用于回答关于A股股票查询、行情数据、财务分析、选股等问题。
★ 164 📥 59,883
data-analysis

Excel / XLSX

ivangdavila
创建、检查和编辑 Microsoft Excel 工作簿及 XLSX 文件,支持可靠的公式、日期、类型、格式、重算及模板保留功能。
★ 367 📥 140,276