Installation Manual

This is installation manual for tackler command line.

To use tackler cli you will need

  • Tackler command line binary

  • Valid configuration file (tackler.toml)

To build the tackler binary, you need to have Rust toolchain installed.

Build and install with Cargo

cargo install tackler

It will make the tackler command globally available, if you’ve allowed Rust toolchain installation to modify your PATH. If not, the binary is located at CARGO_HOME/bin, that’s typically ~/.cargo/bin/tackler on MacOS and Linux, and C:\Users\<UserName>\.cargo\bin on Windows.

You can uninstall tackler by running cargo uninstall tackler.

Build from source

# Get the source code
git clone --recurse-submodules https://github.com/e257-fi/tackler-ng

cd tackler-ng

# Check the releases
git tag -l

# Select the latest release, e.g. v25.01.1
git checkout v25.01.1

# Build the tackler
cargo build --release --locked --bin tackler

# Check the version info
target/release/tackler --version

tackler 25.1.1 (v25.01.1 - e730633c1ba23e6)

Minimal setup

Minimal initial installation and setup is described in Quickstart Guide.

Tackler could be used with minimal quickstart setup just fine, but to get most out of it (strict modes, git storage system, Audit trail functinality etc.), it must be configured properly. Below is recommended setup for production use.

Recommended Setup and layout

You can create default journal setup with tackler new journal command. This will create a new journal setup with default configuration files and example transactions, as laid out below:

Full setup would be:

.
├── bin
│   └── tackler
└── journal
    ├── conf
    │   ├── tackler.toml
    │   ├── accounts.toml
    │   ├── commodities.toml
    │   └── tags.toml
    └── txns
        ├── ...
        ├── 2020
        │   ├── ...
        │   └── 12
        │       ├── journal-1.txn
        │       └── journal-2.txn
        └── 2021
            └── 01
                ├── journal-1.txn
                └── journal-2.txn

This setup uses year/month based sharding for transactions (the directory structure under txns). It’s up to for each system to decide which is the best way to shard transaction data, or not to shard transactions at all.

Provide path to configuration with --config option.

tackler.toml

The tackler main configuration is file located under conf:

journal/conf/tackler.toml
[kernel.input]
storage = "fs"
fs  = { path = "..",      dir = "txns", suffix = "txn" }
git = { repo = "../.git", dir = "txns", suffix = "txn", ref = "main" }
...
[transaction]
accounts    = { path = "accounts.toml" }
commodities = { path = "commodities.toml" }
tags        = { path = "tags.toml" }

This setup makes it possible to separate journal setup and data, and store relevant configuration next to transaction data (and possibly under version control).

See Configuration Example: fs or git how combine git based transaction storage with this setup.

accounts.toml

If there is missing or mistyped account, that will cause an error and tackler will stop processing journal. See accounts.toml for full documentation of Chart of Accounts and commodity listing.

commodities.toml

If there is missing or mistyped commodities, that will cause an error and tackler will stop processing journal. See commodities.toml for full documentation of Chart of Accounts and commodity listing.

tags.toml

If there is missing or mistyped tag, that will cause an error and tackler will stop processing journal. See tags.toml for full documentation of Chart of Tags.

Next steps

See reference configuration files for full details:

Git Storage Guide has information how to use integrated version control features with Tackler.

Git and filesystem based production setup is described in Configuration Example

Transaction Data Sharding has ideas for different storage schemes.