← Back to Skills Marketplace
dingsunrise

Feishu Rate Limit

by Dingsunrise · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ Security Clean
152
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install feishu-rate-limit
Description
Feishu/Lark API rate limit handling strategy. Automatically activates during Feishu API calls to implement smart interval control and 429 error handling. Ess...
README (SKILL.md)

Feishu Rate Limit Skill

Intelligent rate limit handling for Feishu/Lark API. Avoid 429 errors and ensure batch operations complete successfully.

Quick Reference

Situation Action
API call fails with 429 Parse Retry-After, wait, retry (max 3 times)
Batch write operations Split into batches of 10, 1s interval per item
Document API calls Use 2-3s interval (stricter limits)
High call frequency Increase interval dynamically
Rate limit reached Wait 10s, then gradually reduce interval

Trigger Conditions

Activate this skill when:

  • All Feishu API calls (feishu_doc, feishu_bitable_*, feishu_drive, feishu_wiki, etc.)
  • Encountering 429 (rate limit) errors
  • Batch operations on Feishu data
  • Large data writes/queries to Feishu
  • User mentions "Feishu API", "Lark API", "429", "rate limit", "飞书限流"

Feishu API Limits

Custom App Limits

Limit Type Quota Description
Per minute 100 calls/min/app App-level minute limit
Per day 10,000 calls/day/app App-level daily limit
Per minute (per user) 5 calls/min/user/app User-level limit

Document API Special Limits

API Type Special Limit
Document writes Stricter, recommend 2-3s interval
Bitable batch write ≤100 per batch, ≥1s interval
File uploads Large files need longer intervals

Official Docs: https://open.feishu.cn/document/platform-notices/platform-updates-/custom-app-api-call-limit

Call Strategy

Basic Interval Rules

Initial interval: 1 second
Minimum interval: 1 second
Maximum interval: 10 seconds
Warning threshold: 50 calls/minute

Sliding Window Strategy

class FeishuRateLimiter:
    """Feishu API Rate Limiter"""
    
    def __init__(self):
        self.base_interval = 1.0      # Base interval 1s
        self.current_interval = 1.0   # Current interval
        self.max_interval = 10.0      # Max interval
        self.recent_calls = []        # Recent call records
        self.window_size = 60         # Stats window 60s
        self.max_retries = 3          # Max retries
    
    def before_call(self):
        """Wait before call"""
        time.sleep(self.current_interval)
        self.recent_calls.append(time.time())
        self._adjust_interval()
    
    def _adjust_interval(self):
        """Dynamically adjust interval based on recent call frequency"""
        now = time.time()
        # Count calls in last 60s
        recent = [t for t in self.recent_calls if now - t \x3C self.window_size]
        self.recent_calls = recent
        call_count = len(recent)
        
        # Adjust interval based on frequency
        if call_count > 50:  # Near limit (100/min)
            self.current_interval = min(self.current_interval * 1.5, self.max_interval)
        elif call_count > 30:
            self.current_interval = min(self.current_interval * 1.2, self.max_interval)
        elif call_count \x3C 10 and self.current_interval > self.base_interval:
            # Reduce interval when calls are infrequent
            self.current_interval = max(self.current_interval * 0.9, self.base_interval)
    
    def on_rate_limit(self, retry_after=None):
        """Called when 429 error occurs"""
        if retry_after:
            wait_time = retry_after
        else:
            wait_time = self.current_interval * 2
        
        self.current_interval = min(wait_time, self.max_interval)
        time.sleep(self.current_interval)
    
    def on_success(self):
        """Gradually restore normal interval after success"""
        if self.current_interval > self.base_interval:
            self.current_interval = max(self.current_interval * 0.8, self.base_interval)

Retry Strategy

When 429 error occurs:
1. Parse Retry-After header (if present)
2. Wait specified time OR current_interval × 2
3. Retry (max 3 times)
4. If still fails, log error and notify user

Implementation Guide

1. Batch Operation Processing

❌ Wrong approach:
Write 100 records at once

✅ Correct approach:
for batch in chunks(records, 10):
    for record in batch:
        feishu_bitable_create_record(record)
        sleep(1)  # 1s per record
    sleep(5)  # Extra 5s between batches

2. Prefer Batch APIs

Priority:
1. Batch APIs (create_records, batch_update)
2. Single API + smart interval
3. Concurrent requests (reads only, use cautiously)

3. Smart Caching Strategy

For frequently queried data:
- User info: Cache 24 hours
- Field definitions: Cache 1 hour
- Document structure: Cache 30 minutes
- Department list: Cache 2 hours

Error Handling Flow

┌─────────────────┐
│   API Call      │
└────────┬────────┘
         ▼
┌─────────────────┐
│   Check Response│
└────────┬────────┘
         ▼
    ┌────┴────┐
    │ 429?    │
    └────┬────┘
         │
    ┌────┴────────────────────────────┐
    │ Yes                             │ No
    ▼                                 ▼
┌─────────────────┐          ┌─────────────────┐
│ Check Retry-After│          │   Continue      │
└────────┬────────┘          └─────────────────┘
         ▼
┌─────────────────┐
│  Wait specified │
│  OR interval×2  │
└────────┬────────┘
         ▼
┌─────────────────┐
│  Retries \x3C 3?   │
└────────┬────────┘
         │
    ┌────┴────┐
    │ Yes     │ No
    ▼         ▼
┌─────────┐  ┌─────────────────┐
│ Retry   │  │ Log error, notify│
└─────────┘  └─────────────────┘

Configuration Parameters

feishu_rate_limit:
  enabled: true
  base_interval_ms: 1000      # Base interval 1s
  max_interval_ms: 10000      # Max interval 10s
  max_retries: 3              # Max retries
  window_size_sec: 60         # Stats window 60s
  warning_threshold: 50       # Warning threshold (calls/min)
  batch_size: 10              # Batch size
  batch_delay_ms: 5000        # Delay between batches

Common Scenarios

Scenario 1: Batch Create Bitable Records

Task: Create 200 records

Strategy:
1. Split: 10 records per batch
2. Batch interval: 5 seconds
3. Record interval: 1 second
4. Estimated time: ~40 seconds

Implementation:
batch_1: 10 records → wait 5s
batch_2: 10 records → wait 5s
...
batch_20: 10 records → Done

Scenario 2: Document Batch Write

Task: Write 50 paragraphs to document

Strategy:
1. Paragraph interval: 2-3s (Document API stricter)
2. Every 10 paragraphs: Extra 10s wait
3. Estimated time: ~3-4 minutes

Notes:
- Document API limits are stricter
- Double wait time on 429

Scenario 3: Mixed Operations

Task: Read 100 records + update 50 records

Strategy:
1. Read operations: Can be concurrent
2. Update operations: Serial + 1s interval
3. Mixed: Wait after read before update

Recommendation:
- Batch read first (cacheable)
- Split updates into batches

Best Practices

Practice Description
Estimate call volume Calculate API calls before batch operations
Batch execution Split large operations into multiple runs
Off-peak calls Avoid peak hours (9-10am, 2-3pm) for intensive calls
Monitor usage Check Feishu backend API usage stats periodically
Graceful degradation Log progress on limit, continue later
Log records Track call count and duration for optimization
Archive errors Log 429 errors to .learnings/ERRORS.md

Troubleshooting

Problem: Frequent 429 Errors

Analysis:

  • Call frequency too high
  • No interval control implemented
  • Batch operations not split

Solution:

  1. Increase base interval to 2 seconds
  2. Reduce batch size
  3. Implement sliding window monitoring

Problem: Operation Timeout

Analysis:

  • Wait time too long
  • Too many retries

Solution:

  1. Adjust max_interval parameter
  2. Reduce single operation data volume
  3. Use async processing

Integration with Other Skills

Skill Integration
problem-solving Trigger fix workflow on errors
feishu-doc Apply rate limit to document operations
feishu-archive Apply rate limit to archive operations
self-improving-agent Log rate limit events to learning journal

Related Resources


Version: 1.0.0
License: MIT

Usage Guidance
This skill is a text-only strategy guide for handling Feishu/Lark API rate limits and appears low-risk. Before installing: ensure your agent's Feishu integration already handles authentication securely (this skill does not request credentials), test the suggested intervals in a staging environment (API limits can vary by app), and confirm your client libraries can parse Retry-After headers and implement the recommended sleeps/retries without blocking other important agent work. If you want stricter guarantees, implement the logic inside your own codebase rather than relying on free-form instructions executed autonomously.
Capability Analysis
Type: OpenClaw Skill Name: feishu-rate-limit Version: 1.0.0 The skill provides a comprehensive strategy and logic for handling Feishu/Lark API rate limits (429 errors). It includes a Python-based sliding window rate limiter implementation and instructions for the AI agent to manage batch operations and retry logic. No indicators of data exfiltration, malicious execution, or harmful prompt injection were found in SKILL.md or _meta.json.
Capability Assessment
Purpose & Capability
Skill name and description match the runtime instructions: guidance and example code for handling Feishu/Lark rate limits, batching, retry logic, and caching. Nothing requested (no env vars, binaries, or installs) is out of scope for a rate-limit strategy.
Instruction Scope
SKILL.md confines actions to API-call timing, parsing Retry-After, batching, sleeping between requests, retry logic, and caching recommendations. It does not instruct the agent to read unrelated files, access unrelated services, or exfiltrate data.
Install Mechanism
No install spec and no code files — instruction-only. No downloads or installs are required, which minimizes footprint and risk.
Credentials
The skill declares no credentials, environment variables, or config paths. The guidance naturally applies to Feishu API clients without needing additional secrets. No disproportionate access is requested.
Persistence & Privilege
The skill is not always-enabled and does not request persistent system presence or modify other skills. Autonomous invocation is allowed by platform default but this skill's scope is limited and appropriate for that capability.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install feishu-rate-limit
  3. After installation, invoke the skill by name or use /feishu-rate-limit
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
- Initial release of Feishu Rate Limit Skill. - Implements dynamic interval control and 429 error handling for Feishu/Lark API calls. - Supports smart batching strategies for batch operations, document writes, and bitable actions. - Automatically adjusts call intervals based on recent usage to prevent hitting rate limits. - Retry logic with parsing of Retry-After headers, supporting up to 3 retries per 429 error. - Provides quick configuration parameters and best practices for stable, large-scale Feishu API usage.
Metadata
Slug feishu-rate-limit
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Feishu Rate Limit?

Feishu/Lark API rate limit handling strategy. Automatically activates during Feishu API calls to implement smart interval control and 429 error handling. Ess... It is an AI Agent Skill for Claude Code / OpenClaw, with 152 downloads so far.

How do I install Feishu Rate Limit?

Run "/install feishu-rate-limit" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Feishu Rate Limit free?

Yes, Feishu Rate Limit is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Feishu Rate Limit support?

Feishu Rate Limit is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Feishu Rate Limit?

It is built and maintained by Dingsunrise (@dingsunrise); the current version is v1.0.0.

💬 Comments