feat: add body modification flags and GraphQL mutations#60
Merged
hmans merged 3 commits intohmans:mainfrom Jan 19, 2026
Merged
Conversation
hmans
approved these changes
Jan 17, 2026
Owner
hmans
left a comment
There was a problem hiding this comment.
Thanks for the PR, this is looking very good now. I've taken the liberty of removing the change in README.md, I hope you don't mind.
Owner
|
@matleh Had some unexpected merge conflicts when updating this branch with the latest stuff from |
- Add --body-replace-old/--body-replace-new flags for partial text replacement - Add --body-append flag for appending content (supports stdin with -) - Add require_if_match config option to enforce ETag usage - Mutual exclusivity with existing --body/--body-file flags - Update prompt template with body modification and concurrency control docs Usage: beans update <id> --body-replace-old "- [ ] Task" --body-replace-new "- [x] Task" beans update <id> --body-append "## Notes" echo "content" | beans update <id> --body-append -
- Add replaceInBody mutation to replace exactly one occurrence of text - Add appendToBody mutation to append content with blank line separator - Extract shared logic to internal/bean/content.go (ReplaceOnce, AppendWithSeparator) - Refactor CLI to use shared functions - Add GraphQL API section to README with examples
ccf4bb7 to
cbb5cbb
Compare
Contributor
Author
|
@hmans I updated the branch and ran some manual tests to verify that the functionality works as expected. |
Owner
|
Thank you! 🙏 |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Adds CLI flags and GraphQL mutations for partial body modifications, enabling agents to update bean content without direct file access. Builds on #59 (ETag support) and supersedes #57.
Changes
CLI: Body Modification Flags
--body-replace-old/--body-replace-newfor exact text replacement (must match exactly once)--body-appendfor appending content (supports stdin with-)--body/--body-fileflagsGraphQL: Partial Body Mutations
replaceInBody(id, old, new, ifMatch)- replace exactly one occurrence of textappendToBody(id, content, ifMatch)- append content with blank line separatorifMatchfor optimistic lockingShared Logic
ReplaceOnceandAppendWithSeparatortointernal/bean/content.goDocumentation
Usage
Why This Matters for Agents
Agents can now modify bean bodies entirely through CLI/GraphQL without needing:
.beans/directoryTesting
internal/bean/content_test.go