Private, Personal AI Backend Service
Topos is a private, personal AI and database management service. It comes as an easy-to-install server for your AI apps to connect to.
It is a personal intelligence service, using your own computer to power private conversations with friends, family, and coworkers, collect/store your own private data, and use AI privately.
Apps Using Topos:
- chat arena #desktop #mobile
Tech: nixOS, ollama, postgres, FastAPI, huggingface-transformers
Runs the Terminal User Interface provided by [F1bonacc1](https://github.com/F1bonacc1/process-compose)
(Experimental): This is new, and should work on most MacOS machines! Simply double click the topos.dmg file, and drag the app into your Applications directory. You should be able to launch the Topos service anywhere from your machine.
If nix is not installed:
- Install nix:
macos/linux:
sh <(curl -L https://nixos.org/nix/install)
windows:sh <(curl -L https://nixos.org/nix/install) --daemon
- Run Topos and all its dependencies:
This will start all services including Topos, Postgres, Kafka, and Ollama.
nix run github:jonnyjohnson1/topos-cli
Clone the repository:
git clone https://github.com/jonnyjohnson1/topos-cli
cd topos-cli
For development, you have several options:
First build topos binary (only usable on machines with nix installed)
nix build .#topos
run built binary
./result/bin/topos
(You might also try this)
nix build --extra-experimental-features nix-command --extra-experimental-features flakes --show-trace
./result/bin/services-flake-topos
nix develop
topos run
nix develop .#poetry
- If postgres is already running, running the bin fails, shut it down first.
- Nix will manage postgres' start/stop function itself when you use it, but if you have started the database elsewhere, it won't be able to manage it, and will fail to start up.
requires brew install just
requires brew install poetry
brew install neo4j brew services start neo4j
install the topos package with the command just build
Set the size of the spacy model you wish to use on your system. There are 'small', 'med', 'large', and 'trf'.
Use the tag like this.
topos set --spacy small
topos set --spacy trf
topos run
topos run --local
We are going to expose our backend service to a public network so our phone/tablet can use it. In this case, we use zrok. Below is are the guides to set up ngrok.
zrok is opensourced and free. ngrok has a gated requests/month under its free tier, then requires you pay for it.
- Be sure you have the
topos
server running already in another terminal. - Install zrok command
zrok enable <given_key>
zrok status
should show you information- Route local path through zrok:
zrok share public http://0.0.0.0:13341
This will take you to a new screen with an https:// at the top. Insert this url into the field under settings-> "Api Endpoints" -> "Custom API" - After you've insert it into the field, press the test button, and "hello world" should appear next to the button.
[ ] Enable permanent sharing of zrok url docs (requires Docker)