Skip to content

Latest commit

 

History

History
61 lines (29 loc) · 2.38 KB

README.md

File metadata and controls

61 lines (29 loc) · 2.38 KB

Obsidian CLI

This command line interface provides an assortment of features for working with an Obsidian (or other markdown-based) knowledge base from the command line.

While it results in some duplication of functionality, this toolkit is designed to not require any Obsidian plugins, so you really don't even need Obsidian to use this (if you use FOAM, in VS Code, for instance).

Installation

Currently, you'll need to clone the repo and build it yourself. Once you have the resulting binaries, just make sure the Obsidian.exe is in your path.

Usage/Examples

> obsidian daily-note add --date 2025-01-01 --vault vault

This will create a new daily note, using your default daily note template, in the vault with an id of "vault".

License

Creative Commons BY-SA 4.0

FAQ

What is the templating syntax?

I am using Handlebars.NET to implement the templating, so you can visit their repo for more details on how to compose a template. Note that, currently, the only data being passed into the template is date which represents the date of the note being created.

If there are particular pieces of data that you would find helpful for use in a template, let me know.

Roadmap

  • Polish this MVP to make it more robust, with error handling, better documentation, etc.

  • Be more cross-platform-aware. I use Obsidian on MacOS at home, and on Windows at work, so I want this tool to work well on both operating systems.

  • Implement the recurrence pattern support so you can use different templates for different days, based on the patters defined in the settings file.

  • Implement template "inheritance". My thinking, at the moment, is to just do this by running templates in order from the top-down against the target note, so the "child" templates are just applying themselves over top of "parent" templates.

  • Implement configuration editing from the CLI.

  • Implement Task support, so when you create a new daily-note, we look at the last daily-note to find all the uncompleted tasks and pull them forward into the new note.

Running Tests

To run tests, write some and send me a PR, so we can all benefit!

Contributing

Contributions are always welcome!

See contributing.md for ways to get started.

Please adhere to this project's code of conduct.