Peter Steinberger
c37cc5ffad
test: trim redundant markdown strip and table layout checks
2026-02-16 07:07:07 +00:00
Peter Steinberger
b83ccfba13
test: remove redundant line flex baseline checks
2026-02-16 07:04:56 +00:00
Peter Steinberger
8ea890e8fb
test: remove duplicate line quick-reply assertions
2026-02-16 07:03:51 +00:00
Peter Steinberger
ae6060d777
test: remove redundant line markdown conversion smoke checks
2026-02-16 07:02:37 +00:00
Peter Steinberger
ec708b6ab5
test: trim redundant line action helper smoke checks
2026-02-16 07:01:43 +00:00
Peter Steinberger
944a32cf02
test: remove redundant line flex smoke checks
2026-02-16 06:59:46 +00:00
Peter Steinberger
c4880675e1
test: prune redundant line template constructor checks
2026-02-16 06:58:33 +00:00
Peter Steinberger
8b6537d857
test: trim redundant line template shape checks
2026-02-16 06:57:15 +00:00
Peter Steinberger
12c3821acb
test: prune low-signal line flex template checks
2026-02-16 06:55:49 +00:00
Peter Steinberger
18bb242316
test: remove duplicate line action creator coverage
2026-02-16 06:46:21 +00:00
Peter Steinberger
a8084b24d6
test: trim additional low-signal flex template checks
2026-02-16 06:40:26 +00:00
Peter Steinberger
97d5ff3500
test: remove low-signal flex template option-only assertions
2026-02-16 06:38:41 +00:00
Peter Steinberger
abb7618b0f
test: remove pass-through rich menu action mode checks
2026-02-16 06:37:38 +00:00
Peter Steinberger
702b94fe8f
style(line): format files to unblock ci check
2026-02-16 03:39:41 +00:00
Vignesh Natarajan
c7bc7249c3
test (security/line): cover missing webhook auth startup paths
2026-02-15 19:25:33 -08:00
Vignesh Natarajan
beb77229c0
fix (security/line): fail closed when webhook auth is missing
2026-02-15 19:25:33 -08:00
Peter Steinberger
39d5590230
refactor(line): reuse reply chunk deps type
2026-02-16 02:29:07 +00:00
Peter Steinberger
32221e194a
refactor(probe): share withTimeout
2026-02-16 00:39:11 +00:00
Peter Steinberger
60ce38d216
perf(test): drop redundant line signature unit test
2026-02-16 00:18:27 +00:00
Shadow
c6b3736fe7
fix: dedupe probe/token base types ( #16986 ) (thanks @iyoda)
2026-02-15 11:36:54 -06:00
Peter Steinberger
9f393a045c
fix(line): restore bot-message-context types
2026-02-15 16:58:52 +00:00
Peter Steinberger
1ab5fcc325
refactor(line): share source info parsing
2026-02-15 16:57:58 +00:00
Peter Steinberger
c906121ad3
fix(line): build config schema from common base
2026-02-15 16:55:35 +00:00
Peter Steinberger
fabe4807a6
refactor(line): dedupe config schema
2026-02-15 16:55:01 +00:00
Peter Steinberger
dda3026d13
refactor(line): dedupe schedule card header
2026-02-15 16:39:45 +00:00
Peter Steinberger
0f4036b0f6
refactor(test): share line auto-reply deps
2026-02-15 15:26:17 +00:00
Peter Steinberger
abb4b7c91c
refactor(line): share messaging client setup
2026-02-15 13:49:37 +00:00
Peter Steinberger
216f4d4669
refactor(line): dedupe schedule card header + bubble
2026-02-15 12:47:03 +00:00
Peter Steinberger
eb79785b36
refactor(line): share channel access token resolver
2026-02-15 07:01:05 +00:00
Peter Steinberger
45f7ef1bfc
refactor(line): dedupe route resolution
2026-02-15 05:46:20 +00:00
Peter Steinberger
01247723c7
refactor(line): share inbound context builder
2026-02-15 01:46:51 +00:00
Peter Steinberger
2493455f08
refactor(line): extract node webhook handler + shared verification
2026-02-15 00:59:32 +01:00
Peter Steinberger
abf42abd41
fix: LINE webhook verification 200; fix tsgo error ( #16582 ) (thanks @arosstale)
2026-02-15 00:27:12 +01:00
artale
4f2f641950
fix(line): return 200 for webhook verification requests without signature
...
LINE Platform sends POST {"events":[]} without an X-Line-Signature
header when the user clicks 'Verify' in the LINE Developers Console.
Both webhook.ts and monitor.ts rejected this with 400 'Missing
X-Line-Signature header', causing verification to fail.
Now detect the verification pattern (no signature + empty events array)
and return 200 OK immediately, while still requiring valid signatures
for all real webhook deliveries with non-empty events.
Fixes #16425
2026-02-15 00:27:12 +01:00
Peter Steinberger
684c18458a
perf(test): speed up line, models list, and memory batch
2026-02-14 16:36:15 +00:00
Peter Steinberger
9f84afc992
refactor(line): share flex footer helper
2026-02-14 15:39:45 +00:00
Peter Steinberger
d71f6afb7f
refactor(line): centralize action helpers
2026-02-14 15:39:45 +00:00
Peter Steinberger
5429f2e635
refactor(line): split flex template builders
2026-02-13 19:08:37 +00:00
Peter Steinberger
3cbcba10cf
fix(security): enforce bounded webhook body handling
2026-02-13 19:14:54 +01:00
Peter Steinberger
53273b490b
fix(auto-reply): prevent sender spoofing in group prompts
2026-02-10 00:44:38 -06:00
max
223eee0a20
refactor: unify peer kind to ChatType, rename dm to direct ( #11881 )
...
* fix: use .js extension for ESM imports of RoutePeerKind
The imports incorrectly used .ts extension which doesn't resolve
with moduleResolution: NodeNext. Changed to .js and added 'type'
import modifier.
* fix tsconfig
* refactor: unify peer kind to ChatType, rename dm to direct
- Replace RoutePeerKind with ChatType throughout codebase
- Change 'dm' literal values to 'direct' in routing/session keys
- Keep backward compat: normalizeChatType accepts 'dm' -> 'direct'
- Add ChatType export to plugin-sdk, deprecate RoutePeerKind
- Update session key parsing to accept both 'dm' and 'direct' markers
- Update all channel monitors and extensions to use ChatType
BREAKING CHANGE: Session keys now use 'direct' instead of 'dm'.
Existing 'dm' keys still work via backward compat layer.
* fix tests
* test: update session key expectations for dmdirect migration
- Fix test expectations to expect :direct: in generated output
- Add explicit backward compat test for normalizeChatType('dm')
- Keep input test data with :dm: keys to verify backward compat
* fix: accept legacy 'dm' in session key parsing for backward compat
getDmHistoryLimitFromSessionKey now accepts both :dm: and :direct:
to ensure old session keys continue to work correctly.
* test: add explicit backward compat tests for dmdirect migration
- session-key.test.ts: verify both :dm: and :direct: keys are valid
- getDmHistoryLimitFromSessionKey: verify both formats work
* feat: backward compat for resetByType.dm config key
* test: skip unix-path Nix tests on Windows
2026-02-09 09:20:52 +09:00
mudrii
5d82c82313
feat: per-channel responsePrefix override ( #9001 )
...
* feat: per-channel responsePrefix override
Add responsePrefix field to all channel config types and Zod schemas,
enabling per-channel and per-account outbound response prefix overrides.
Resolution cascade (most specific wins):
L1: channels.<ch>.accounts.<id>.responsePrefix
L2: channels.<ch>.responsePrefix
L3: (reserved for channels.defaults)
L4: messages.responsePrefix (existing global)
Semantics:
- undefined -> inherit from parent level
- empty string -> explicitly no prefix (stops cascade)
- "auto" -> derive [identity.name] from routed agent
Changes:
- Core logic: resolveResponsePrefix() in identity.ts accepts
optional channel/accountId and walks the cascade
- resolveEffectiveMessagesConfig() passes channel context through
- Types: responsePrefix added to WhatsApp, Telegram, Discord, Slack,
Signal, iMessage, Google Chat, MS Teams, Feishu, BlueBubbles configs
- Zod schemas: responsePrefix added for config validation
- All channel handlers wired: telegram, discord, slack, signal,
imessage, line, heartbeat runner, route-reply, native commands
- 23 new tests covering backward compat, channel/account levels,
full cascade, auto keyword, empty string stops, unknown fallthrough
Fully backward compatible - no existing config is affected.
Fixes #8857
* fix: address CI lint + review feedback
- Replace Record<string, any> with proper typed helpers (no-explicit-any)
- Add curly braces to single-line if returns (eslint curly)
- Fix JSDoc: 'Per-channel' → 'channel/account' on shared config types
- Extract getChannelConfig() helper for type-safe dynamic key access
* fix: finish responsePrefix overrides (#9001 ) (thanks @mudrii)
* fix: normalize prefix wiring and types (#9001 ) (thanks @mudrii)
---------
Co-authored-by: Gustavo Madeira Santana <gumadeiras@gmail.com >
2026-02-04 16:16:34 -05:00
cpojer
935a0e5708
chore: Enable typescript/no-explicit-any rule.
2026-02-02 16:18:09 +09:00
cpojer
f06dd8df06
chore: Enable "experimentalSortImports" in Oxfmt and reformat all imorts.
2026-02-01 10:03:47 +09:00
cpojer
59cfff02f6
chore: Emit TypeScript declaration files so that we can type-check the extensions folder soon.
2026-01-31 21:57:21 +09:00
cpojer
5ceff756e1
chore: Enable "curly" rule to avoid single-statement if confusion/errors.
2026-01-31 16:19:20 +09:00
cpojer
9c4cbaab7b
chore: Enable eslint/no-unused-vars.
2026-01-31 16:06:39 +09:00
cpojer
15792b153f
chore: Enable more lint rules, disable some that trigger a lot. Will clean up later.
2026-01-31 16:04:04 +09:00
Peter Steinberger
9a7160786a
refactor: rename to openclaw
2026-01-30 03:16:21 +01:00
Peter Steinberger
6d16a658e5
refactor: rename clawdbot to moltbot with legacy compat
2026-01-27 12:21:02 +00:00