Star 历史趋势
数据来源: GitHub API · 生成自 Stargazers.cn
README.md

Meegle CLI

License: MIT Node.js npm version

English | 简体中文

Command-line tool for Meegle (Lark Project). Manage work items, schedules, and data from your terminal — no browser needed.

Install · Quick Start · Agent Skill · Commands · Auth · Config · Security · Contributing

Why Meegle CLI?

  • Agent-Native — Ships a bundled AI Agent Skill that teaches Trae, Claude Code, Cursor, Windsurf, Gemini CLI and other agents how to drive Meegle with one command. Every CLI command is designed for both humans and agents, with structured JSON output, --dry-run previews, and --device-code flows for non-TTY environments
  • Broad Coverage — 16 business domains (work items, workflow, subtasks, comments, work hours, relations, my-work, views, charts, team, user, project, attachments, deliverables, resource library, WBS plan tables) and 50+ commands mapping to Meegle's core capabilities
  • Two-Layer Parameters — Ergonomic --flag-name for everyday use, fallback --params <json> for complex payloads like fields[] — pick the right granularity per call
  • Flexible Outputjson / table / ndjson / raw, with --select dot-path projection for piping to other tools
  • Secure by Default — OS keychain credential storage, ${VAR} env-var templating so secrets never land in config files, multi-profile switching for staging / prod

Features

CategoryCapabilities
📋 Work ItemsCreate, read, update, batch-read, query (MQL), list operation records, inspect metadata
🔀 WorkflowTransition nodes & states, update node fields, list available transitions and required fields
SubtasksCreate, update, complete, rollback subtasks
💬 CommentsAdd and list comments on work items
⏱️ Work HoursList work hour records, view team-member schedules
🔗 RelationsList related work items, inspect relation-type definitions
📌 My WorkView this week / overdue / completed to-dos
👁️ ViewsCreate and update fixed views, search views by name
📊 ChartsList charts under a view, fetch chart details
👥 Team & UserList teams, team members, search users, view current login
🗂️ ProjectsSearch projects by keyword
📎 AttachmentsTwo-stage upload/download protocol — prepare-* basic commands plus +upload / +download end-to-end shortcuts
📦 DeliverablesList deliverables with their root and source work items
🧩 Resource LibraryCreate resource templates, inspect resource library configuration
🗓️ WBS Plan TablesList draft / published plan rows, create / edit / publish / reset drafts, query draft progress, list element templates
🔐 Auth & ConfigOAuth login, device-code flow, multi-profile config, env-var injection
🔗 URL ParsingOffline decode of Meegle / Feishu Project URLs into url_kind + structured fields
🤖 Agent SkillPre-built skill for Trae / Claude Code / Cursor / Windsurf / Gemini CLI / Copilot

Installation

Requirements

  • Node.js >= 16 (ships with npm / npx)

Install

npm install -g @lark-project/meegle

Quick Start (Human Users)

Note for AI assistants: if you are an AI Agent helping the user set this up, jump directly to Quick Start (AI Agent) — it contains the non-interactive steps you need.

# (Optional) Persist the host so future logins skip the arrow-key picker meegle config set host <host> # 1. Log in (arrow-key host picker + browser OAuth) meegle auth login # 2. View this week's to-dos meegle mywork todo --action this_week --page-num 1 # 3. View help meegle --help meegle workitem --help # 4. Inspect command parameters meegle inspect workitem.create

Quick Start (AI Agent / CI / Headless)

The default meegle auth login uses an arrow-key host picker plus a browser OAuth callback — both require a real TTY, so they will hang or fail in CI runners, pipes, and agent shells like Claude Code. Use the Device Code flow instead: it prints an authorization URL that the user opens in any browser.

Step 1 — Install the CLI

npm install -g @lark-project/meegle

Step 2 — Persist the host

meegle config set host <host>

Examples of <host>: project.feishu.cn, meegle.com, or your self-hosted tenant domain such as your-tenant.example.com.

Step 3 — Log in with Device Code

Run this command in the background. It prints an authorization URL — extract it and send it to the user. The command exits automatically once the user completes authorization in the browser.

meegle auth login --device-code

Alternatively, pass the host inline each time without persisting it:

meegle auth login --device-code --host <host>

Step 4 — Verify

meegle auth status

For fully unattended CI (no human-in-the-loop), inject a token via environment variables instead — see Sandbox / CI.

AI Agent Skill

skills/meegle/ is a drop-in skill that teaches AI Agents — Trae, Claude Code, Cursor, Windsurf, Gemini CLI, GitHub Copilot CLI — how to operate Meegle through this CLI. It bundles the command catalog, MQL syntax, field-value conventions, rich-text Markdown rules, and standard operating procedures for common write flows.

Install

# Install the CLI first (the skill calls `meegle` under the hood) npm install -g @lark-project/meegle # Then add the skill — auto-detects installed agents and registers in each npx skills add larksuite/meegle-cli -y -g

npx skills add reads skills/meegle/SKILL.md from the repo and drops it into the skill directory of every agent CLI it finds on the machine. Re-run any time to pick up updates.

What it covers

  • Command reference — every meegle resource / method with required parameters and examples
  • MQL search — syntax for workitem query, operators, scope keywords
  • Field values — how to shape complex field payloads (arrays, nested JSON, date ranges)
  • Rich text — Markdown subset supported by Meegle's rich-text editor
  • SOPs — step-by-step playbooks for creating work items, transitioning nodes, transitioning states, and updating fields
  • Auth guard — the skill refuses to run business commands until meegle auth status succeeds

See skills/meegle/SKILL.md and skills/meegle/references/ for the full contents.

Usage

Once installed, just ask the agent in natural language. For example, in Trae:

Show me this week's P0 stories in the PROJ space.

The agent consults the skill, picks the right meegle commands, and runs them for you. Pair with --dry-run (see Security) to preview side-effectful operations before the agent commits them.

Heads up: the skill name meegle is the same string as the CLI binary. When documentation refers to "the meegle skill" it means the files in skills/meegle/; when it refers to "the meegle CLI" it means the meegle command on your PATH.

Commands

workitem — Work Items

CommandDescription
workitem createCreate a work item
workitem getView work item details
workitem +batch-getBatch-read work items by IDs (client-side fan-out over workitem get; + marks scenario/sugar commands)
workitem updateUpdate work item fields
workitem querySearch work items using MQL
workitem list-op-recordsView operation records
workitem meta-typesList work item types
workitem meta-create-fieldsList fields available at creation
workitem meta-fieldsList field configurations
workitem meta-rolesList role configurations

workflow — Workflow

CommandDescription
workflow transitionTransition or rollback a node
workflow transition-stateTransition a state-flow state
workflow get-nodeView node details
workflow update-nodeUpdate a node
workflow meta-node-fieldsList node field configurations
workflow list-state-transitionsList available state transitions
workflow list-state-requiredList required fields for transitions

subtask — Subtasks

CommandDescription
subtask updateCreate / update / complete / rollback subtasks

comment — Comments

CommandDescription
comment addAdd a comment
comment listList comments

workhour — Work Hours

CommandDescription
workhour list-recordsList work hour records
workhour list-scheduleView team member schedules

relation — Relations

CommandDescription
relation listList related work items
relation meta-definitionsList relation type definitions

mywork — My Work

CommandDescription
mywork todoView my to-dos / completed items

view — Views

CommandDescription
view create-fixedCreate a fixed view
view getView details of a view
view update-fixedUpdate a fixed view
view searchSearch views by name
view list-multi-project-workitemsList work items under a multi-project (panoramic) view

chart — Charts

CommandDescription
chart getView chart details
chart listList charts under a view

team / user — People

CommandDescription
team listList teams in a project
team list-membersList team members
user meView current logged-in user information
user searchSearch user information

project — Projects

CommandDescription
project searchSearch projects

attachment — Attachments

CommandDescription
attachment prepare-uploadUpload preprocess — returns the signed object-storage URL and multipart plan
attachment prepare-downloadDownload preprocess — returns the signed object-storage URL and multipart plan
attachment +uploadEnd-to-end upload: preprocess + signed HTTP POST(s); returns the resulting file_token and file metadata
attachment +downloadEnd-to-end download: preprocess + signed HTTP GET(s) + atomic write — for file_urls embedded in workitem get / comment list responses

deliverable — Deliverables

CommandDescription
deliverable listList deliverables with their root and source work items

resource — Resource Library

CommandDescription
resource createCreate a resource template (resource instance) under a resource-library-enabled work item type
resource meta-fieldsList resource library configuration (resource fields and roles)

wbs — WBS Plan Tables

CommandDescription
wbs list-draft-rowsList rows in a WBS draft, filtered by query and projected to selected fields
wbs list-instance-rowsList rows in a published WBS instance, filtered by query and projected to selected fields
wbs create-draftCreate a new WBS draft for a work item instance
wbs edit-draftApply one atomic operation to a single draft row (add / delete / restore / sort / rename / owner / schedule); operation type via --params
wbs publish-draftPublish a WBS draft online
wbs reset-draftReset a draft to match the published instance, discarding unpublished changes
wbs get-draft-progressGet the execution progress of a WBS draft operation (create / edit / publish)
wbs list-element-templatesList element templates (resource nodes and tasks) from the flow resource library

auth — Authentication

CommandDescription
auth loginLog in (browser or --device-code)
auth logoutLog out
auth statusView login status

config — Configuration

CommandDescription
config initInitialize configuration
config showShow current configuration
config setSet a configuration value
config getGet a configuration value
config profile create|list|use|current|deleteManage configuration profiles

url — URL Parsing

Offline, no-network utility for parsing Meegle / Feishu Project URLs into structured fields. Skills and pipelines branch on the returned url_kind instead of guessing from raw paths.

CommandDescription
url decode --url <URL>Decode a URL into url_kind + simple_name / work_item_type / work_item_id / view_id / chart_id / query / redirected_from etc. Unrecognised URLs return url_kind: "unknown".

Other Commands

CommandDescription
inspect [command]Inspect command parameters
completion bash|zsh|fishGenerate shell completion script
completion installAuto-install shell completion

Common Examples

To-dos

# This week's to-dos meegle mywork todo --action this_week --page-num 1 # Completed items meegle mywork todo --action done --page-num 1 # Overdue items meegle mywork todo --action overdue --page-num 1

Querying Work Items

# View work item details meegle workitem get --work-item-id 12345 # View workflow node details meegle workflow get-node --work-item-id 12345 --need-sub-task

Batch Reading Work Items

workitem +batch-get fans out to workitem get for each ID and aggregates the results into one response. Shared flags (e.g. --project-key) apply to every per-item call. The + prefix marks it as a scenario/sugar command — the CLI composes multiple get calls client-side instead of mapping to a single backend endpoint.

# Comma-separated IDs in one invocation meegle workitem +batch-get --project-key PROJ --work-item-ids "12345,12346,12347" # Read IDs from a file (one per line; lines starting with '#' are comments) meegle workitem +batch-get --project-key PROJ --ids-file ./ids.txt # Stream one JSON row per item; summary row is emitted last meegle workitem +batch-get --project-key PROJ --work-item-ids "12345,12346" -o ndjson

Response envelope (JSON):

{ "summary": { "total": 3, "succeeded": 2, "failed": 1 }, "results": [ { "work_item_id": 12345, "data": { /* ... */ } }, { "work_item_id": 12346, "data": { /* ... */ } }, { "work_item_id": 12347, "error": { "code": "...", "message": "..." } } ] }

Constraints: up to 200 IDs per invocation, 3 concurrent workers (fixed). Partial failures do not abort the batch — check summary.failed or the per-item error field. A 401 from the server aborts the whole run.

Creating Work Items

# Pass fields[] via --params (JSON) meegle workitem create --project-key PROJ --work-item-type story \ --params '{"fields":[ {"field_key":"name","field_value":"Optimize login flow"}, {"field_key":"priority","field_value":"P1"} ]}' # Complex field values (arrays, nested JSON) also go through --params meegle workitem create --project-key PROJ --work-item-type story \ --params '{"fields":[ {"field_key":"name","field_value":"Scheduled task"}, {"field_key":"schedule","field_value":[1722182400000,1722355199999]} ]}'

Updating Fields

# Update work item name meegle workitem update --work-item-id 12345 \ --params '{"fields":[{"field_key":"name","field_value":"New title"}]}' # Update multiple fields at once meegle workitem update --work-item-id 12345 \ --params '{"fields":[ {"field_key":"name","field_value":"New title"}, {"field_key":"priority","field_value":"P0"} ]}'

Attachments

The attachment domain exposes Lark project's two-stage attachment protocol in two layers:

  • Basic commands (attachment prepare-upload, attachment prepare-download) return the raw signed-URL preprocess payload — handy for scripting your own HTTP transfer or inspecting the multipart plan.
  • Shortcuts (attachment +upload, attachment +download) chain the basic preprocess with the signed HTTP POST/GET to object storage end-to-end. The + prefix marks them as scenario commands — the CLI orchestrates the preprocess output plus the out-of-band byte transfer client-side.

--resource-type tells the backend what the file will be attached to:

--resource-typeTarget
15Workitem attachment field
16Image embedded in a workitem rich-text field
13Attachment on a comment
14Image embedded in a comment

Scoping the preprocess: every upload needs either --work-item-id or --work-item-type. Always prefer --work-item-id when the target workitem exists (update / comment scenarios); only use --work-item-type for the create-with-attachment path where the workitem hasn't been created yet. If both are supplied, --work-item-id wins and --work-item-type is ignored.

# Upload a file for a workitem attachment field (resource-type 15) meegle attachment +upload ./a.pdf \ --resource-type 15 \ --project-key PROJ --work-item-id 12345 --field-key files_field # Create-with-attachment path — workitem doesn't exist yet, pass --work-item-type meegle attachment +upload ./a.pdf \ --resource-type 15 \ --project-key PROJ --work-item-type story --field-key files_field # Upload an image for a rich-text field (resource-type 16) meegle attachment +upload ./diagram.png \ --resource-type 16 \ --project-key PROJ --work-item-id 12345 --field-key spec_field # Upload a comment attachment (resource-type 13) meegle attachment +upload ./report.pdf \ --resource-type 13 \ --project-key PROJ --work-item-id 12345 # Upload a comment image (resource-type 14) meegle attachment +upload ./screen.png \ --resource-type 14 \ --project-key PROJ --work-item-id 12345 # Download: pass the opaque file_url from another command's response. URL=$(meegle workitem get --project-key PROJ --work-item-id 12345 \ --fields files_field --format json \ | jq -r '.fields.files_field[0].url') meegle attachment +download "$URL" \ --project-key PROJ --work-item-id 12345 \ --output ./local.pdf --overwrite

+upload returns a JSON object with the file token and metadata:

{ "file_token": "...", "file_url": "https://...", "name": "a.pdf", "size": 12345, "mime_type": "application/pdf" }

To wire the result into a downstream command, parse the response with jq or your scripting language of choice:

# Comment attachment — comment add takes file_token directly TOKEN=$(meegle attachment +upload ./report.pdf --resource-type 13 \ --project-key PROJ --work-item-id 12345 | jq -r '.file_token') meegle comment add --work-item-id 12345 --content "See attached" --file-token "$TOKEN"

Field-level attachment formats (how to assemble --fields payloads):

  • Workitem attachment field (--resource-type 15) — field_value is a JSON string whose parsed form is [{"name","type","size","fileToken"}]. Note: fileToken is camelCase (other backend fields are snake_case) and size is a string, not a number.
  • Rich-text field / comment image (--resource-type 16 / 14) — embed images as ![name](file_url) <!-- file_token -->.
  • Comment attachment (--resource-type 13) — comment add --file-token takes file_token directly.

MQL Search

# Query P0 stories in a project meegle workitem query --project-key PROJ \ --mql "SELECT \`name\`, \`priority\` FROM \`ProjectName\`.\`Story\` WHERE \`priority\` = 'P0'"

Viewing Schedules

# View team member schedules meegle workhour list-schedule --project-key PROJ \ --start-time 2026-03-01 --end-time 2026-03-31 \ --user-keys "Alice,Bob,Charlie"

Searching Users

meegle user search --user-keys "Alice,Bob" --project-key PROJ

Parameter Passing

Basic Flags

Each command takes parameters via --flag-name:

meegle workitem get --work-item-id 12345 --project-key PROJ

--set key=value (Generic)

--set is an alternate syntax for writing top-level parameters — --set key=value is equivalent to typing --key value. Useful when scripting with a uniform key=value form, or for writing nested top-level params via dot-path. Values are auto-typed (int / float / bool / string).

# These two are equivalent: meegle mywork todo --action this_week --page-num 1 meegle mywork todo --set action=this_week --set page_num=1 # Dot-path builds nested maps (rarely used in Meegle, but supported): --set extra.flag=true # becomes {"extra":{"flag":true}}

--set only writes top-level parameters. To write a work item's fields[], use --params '{"fields":[...]}' (see below).

--params JSON

--params takes a JSON object; each top-level key is merged in as a CLI flag. The key must be a valid flag of the current command — it is not a free-form payload.

# These two are equivalent: meegle workitem get --work-item-id 12345 --project-key PROJ meegle workitem get --params '{"work_item_id":12345,"project_key":"PROJ"}'

Use --params when:

  • the value is a nested object or array (fields[], schedule{}) — too awkward to inline as a flag
  • you want to set many parameters at once, or feed a payload from a file (see @file.json below)
meegle workitem create --project-key PROJ --work-item-type story \ --params '{"fields":[{"field_key":"name","field_value":"Title"}]}'

Common pitfall: not every name is a top-level flag

Some values that look like top-level fields are actually work-item field values, and must be wrapped in fields[] rather than placed at the top level. For example, on workitem update the priority value belongs to the work item's fields, not to the command's flags:

# ❌ "priority" is not a flag of workitem update — CLI prints a stderr warning, backend ignores it meegle workitem update --work-item-id 12345 --params '{"priority":"P1"}' # ✓ Wrap field values inside fields[] meegle workitem update --work-item-id 12345 \ --params '{"fields":[{"field_key":"priority","field_value":"P1"}]}'

The CLI surfaces unknown top-level keys as a validation.unknown_params list under --dry-run, and as a one-line stderr warning at run time. They are still forwarded to the backend (in case your local tool-schema cache is stale — refresh with --refresh).

Run meegle workitem meta-fields --project-key PK --work-item-type TK to look up valid field_keys for a work item type.

Reading from a file (@file.json)

Inline JSON is unergonomic on Windows because CMD requires \" escaping and PowerShell mangles backslashes when forwarding native-command arguments. Prefix the value with @ to load the JSON from a file instead — works identically on macOS, Linux, and Windows shells:

# body.json: # {"fields":[{"field_key":"name","field_value":"Optimize login flow"}]} meegle workitem create --project-key PROJ --work-item-type story \ --params @body.json # Absolute path also works meegle workitem update --work-item-id 12345 --params @/tmp/patch.json # PowerShell — same syntax, no escaping headaches meegle workitem create --project-key PROJ --work-item-type story --params '@body.json'

The path is read with the OS's default encoding; both relative and absolute paths are accepted. A missing file fails with PARAM_INVALID; a file whose contents are not valid JSON fails with INVALID_PARAMS_JSON.

Priority

When --set, --params, and regular flags are used together:

  1. Regular CLI flags beat --params / --set for the same top-level key
  2. --set overrides the same top-level key from --params

Array Parameters

Separate multiple values with commas:

--user-keys "Alice,Bob,Charlie" --field-keys "name,status,priority"

Boolean Parameters

Add the flag to set true; omit it for false:

meegle workflow get-node --work-item-id 12345 --need-sub-task

Global Flags

FlagShortDescription
--format-oOutput format: json (default), table, ndjson, raw
--selectField projection with dot paths
--setSet nested parameters (repeatable)
--params-PFull JSON parameter body; prefix with @ to read from a file (e.g. --params @body.json)
--dry-runRender request without executing
--verbose-vVerbose output
--profileUse a specific configuration profile
--refreshRefresh cached commands from server (bypass the local 24 h cache)

Advanced Usage

Output Formats

# JSON (default) meegle workitem get --work-item-id 12345 # NDJSON (suitable for piping) meegle mywork todo --action this_week --page-num 1 -o ndjson # Table meegle mywork todo --action this_week --page-num 1 -o table

Field Projection with --select

--select projects fields using . notation. A segment after an array broadcasts the remaining path over every record of the array and collects the results while preserving the enclosing structure.

ExpressionResponseProjection
list{"list":[{"a":1}], "total":1}{"list":[{"a":1}]}
list.a{"list":[{"a":1,"b":2},{"a":3,"b":4}]}{"list":[{"a":1},{"a":3}]}
list.a,list.bsame as above{"list":[{"a":1,"b":2},{"a":3,"b":4}]} (merged per index)
list.work_item_info.work_item_name{"list":[{"work_item_info":{"work_item_name":"x"}}]}{"list":[{"work_item_info":{"work_item_name":"x"}}]}
nodes.0{"nodes":[{"id":"a"},{"id":"b"}]}{"nodes":{"0":{"id":"a"}}} (numeric = index)
# Top-level selection meegle workitem get --work-item-id 12345 --select "id,name,status" # Broadcast across arrays — extract fields from nested records meegle mywork todo --action done --page-num 1 \ --select "list.work_item_info.work_item_name,list.state_info.end_state_key_name" # Mix top-level metadata with broadcast — total is retained alongside projected list items meegle mywork todo --action done --page-num 1 \ --select "total,list.work_item_info.work_item_name"

Metadata preservation

The default render preserves the full response shape across every --format: list endpoints return {"list":[...], "total":N, "pagination":{...}} verbatim — you see total / pagination even when you do not project them. Drill into records explicitly via --select (and the broadcast syntax above). Under --format table and --format ndjson, a single-key wrapper like {"list":[...]} (no sibling metadata) is still peeled into rows — the peel is loss-less.

Dry Run

For commands with side effects, preview the rendered request with --dry-run before executing:

meegle workitem create --project-key PROJ --work-item-type story \ --params '{"fields":[{"field_key":"name","field_value":"Test"}]}' --dry-run

Command Introspection

Use inspect to view full parameter information for any command:

# List all commands meegle inspect # View parameters for a specific command meegle inspect workitem.create

Authentication

Browser Login (Default)

meegle auth login

Automatically opens the browser for OAuth authorization. If the browser doesn't open, the terminal displays the authorization URL for manual copying.

Device Code Login (No Browser)

meegle auth login --device-code

The terminal displays a QR code and authorization code. Scan with your phone to authorize. Ideal for SSH remote servers and other headless environments.

Other Auth Commands

# Check login status meegle auth status # Log out meegle auth logout

Configuration

Config File

Configuration is stored in ~/.meegle/config.json:

# Initialize config meegle config init # View current config meegle config show # Set a config value meegle config set host project.feishu.cn # Get a config value meegle config get host

Main config options:

FieldDescriptionExamples
hostSite domainproject.feishu.cn, meegle.com
user_access_tokenUser access token; use ${VAR} to read from an environment variable${CI_MEEGLE_TOKEN}
access_token_headerCustom HTTP header name that carries the token; empty falls back to default Authorization: Bearer <token>x-meegle-auth
user_agentCaller suffix appended to the default User-Agent (form: meegle-cli/<ver> <user_agent>); supports ${VAR} template; overridden by the MEEGLE_USER_AGENT env varmy-service/1.0

Sandbox / CI: Direct Environment-Variable Injection

Two well-known environment variables are read directly at CLI startup and override the matching profile fields without requiring any config set:

export MEEGLE_HOST=project.feishu.cn export MEEGLE_USER_ACCESS_TOKEN=<your-user-token> export MEEGLE_USER_AGENT=ci-runner # optional; appended to User-Agent, highest priority over config.user_agent meegle workitem get --work-item-id 123

Either variable may be set independently. When MEEGLE_USER_ACCESS_TOKEN is set, the CLI bypasses the keychain and does not attempt to refresh on 401 — the caller is responsible for rotating the env value. Setting only MEEGLE_HOST (without a token) still uses the keychain-stored credentials.

Custom Auth Header

By default the token is sent via the standard Authorization: Bearer <token> header. If the backend requires a different header (and rejects requests that carry Authorization), opt in with access_token_header:

meegle config set access_token_header x-meegle-auth

Or override at runtime via env var:

export MEEGLE_ACCESS_TOKEN_HEADER=x-meegle-auth

When enabled the CLI sends <header>: <token> with the raw token (no Bearer prefix) and omits Authorization entirely — suitable for backends that reject requests carrying both headers.

Environment Variable Templates

If your runtime exposes a variable with a name other than MEEGLE_*, bind it through config.json using a ${VAR} placeholder. The placeholder is resolved against the process environment at runtime. This keeps secrets out of config.json while adapting to whatever variable name your runtime (Docker, Kubernetes, CI system) already injects.

{ "current": "prod", "profiles": { "prod": { "host": "project.feishu.cn", "user_access_token": "${PROD_CI_TOKEN}" }, "staging": { "host": "staging.feishu.cn", "user_access_token": "${STAGING_CI_TOKEN}" } } }

Rules:

  • Only whole-string placeholders are recognized. "${X}" is expanded; "Bearer ${X}" is treated as a literal.
  • When a referenced variable is unset or empty, the CLI fails fast and reports the field path and variable name.
  • When user_access_token is configured, it takes precedence over any token stored locally by meegle auth login. Because this mode has no refresh path, rotate the environment value yourself when the server returns 401.

Multi-Environment Profiles

Manage multiple environment configurations (different sites, different accounts). Each profile stores its own host and auth credentials independently.

# Create a new profile (interactive host selection + login) meegle config profile create staging # List all profiles meegle config profile list # Switch default profile meegle config profile use staging # View current profile meegle config profile current # Temporarily use another profile (without changing default) meegle mywork todo --action this_week --page-num 1 --profile staging # Delete a profile meegle config profile delete staging

FAQ

Empty Command List

The CLI fetches available commands from the server at startup. If the network is unreachable or you're not logged in, dynamic commands won't be registered. Make sure you're logged in first:

meegle auth login

The command list is cached automatically and refreshed silently in the background when expired.

Security & Risk Warnings

This tool is designed to be called by AI Agents to automate Meegle operations, which carries inherent risks — model hallucinations, unpredictable execution, and prompt injection. Once you authorize Meegle permissions, the Agent will act under your user identity within the granted scope, and may perform high-impact actions (field updates, status transitions, work item creation) on your behalf. Use with care.

Recommended safeguards:

  • Preview side-effectful commands with --dry-run before running them
  • Use a dedicated profile (meegle config profile create) for Agent-driven sessions so you can audit and revoke independently
  • For CI / shared environments, prefer short-lived env-var token injection (MEEGLE_USER_ACCESS_TOKEN) and rotate on 401 — do not relax default security settings

By using this tool you are deemed to voluntarily assume all related responsibilities.

Star History

Star History Chart

Contributing

Community contributions are welcome. For bugs and feature requests, open an Issue or Pull Request. For major changes, please start a discussion via an Issue first.

License

This project is licensed under the MIT License.

When running, it calls Lark/Feishu Open Platform APIs. To use these APIs, you must comply with the following agreements and privacy policies:

关于 About

Command-line tool for Meegle (Lark Project). Manage work items, schedules, and data from your terminal — no browser needed.
clilarklark-projectproject-management

语言 Languages

Go98.8%
Makefile0.6%
Shell0.3%
JavaScript0.2%

提交活跃度 Commit Activity

代码提交热力图
过去 52 周的开发活跃度
4
Total Commits
峰值: 2次/周
Less
More

核心贡献者 Contributors