Currently, in most cases when I use LLMs for coding, it can only help with implementation of individual functions and components. There are multiple tools and startups working on adding a full code repository to the model's context, so it can make suggestions based on it, but complex multi-file changes are still clunky for models.
I wanted to see if it would be simpler and more reliable for the model to work on a repository with a known and more rigid structure, and this is where Mify comes in. Mify CLI can generate backend service templates with a predefined directory structure based on OpenAPI schema. Assuming that all services in the repository are generated by Mify we can pass the project structure in the prompt and help the model with the code generation.
- Local web app to chat with LLM
- LLM can work with multiple projects and keep context on files
- Local agent that can do actions on your repository:
- Read/update/search files and directories
- Create Python services using Mify
itworks.mp4
In this demo, I'm asking LLM to create an Echo service.
- It calls Mify to create workspace and service
- Updates the OpenAPI schema with the /echo handler
- Updates the handler code to return the message sent in the request
And the service is working fine after these updates!
- Python 3.7+
- Mify 0.1.19+
- Anthropic API key
Python setup:
$ virtualenv venv
$ . ./venv/bin/activate
$ pip install -r llm-worker/requirements.txt
Prepare the environment for worker:
$ export DATABASE_URL="sqlite:///$PWD/storage.db"
$ export ANTHROPIC_API_KEY="sk-ant-api<Your key>"
Prepare database:
cd llm-worker && alembic upgrade head && cd -
Run llm-worker:
$ uvicorn llm-worker.main:app --port 3001
Run webapp:
$ cd webapp
$ npm run start
After opening the chat in your browser try asking it to create a service. LLM should ask for the project location and service name, after you provide them it will run mify to create a service. It could take a bit of back and forth with the LLM, but most of the time if you just tell it to continue, it will finish running the commands. Then ask it to update the OpenAPI schema for the service and it should be able to locate it and the corresponding handler and update the code there.
To run the generated service go to /py-services and run:
$ . ./venv/bin/activate
$ python -m <service-name>
And hopefully, it will work. If not you can try asking LLM to fix the issue.
Claude AI is really good at editing Tailwind-based pages, so you can use the chat to work on any other project. The web app for this agent is generated with it!
We welcome contributions to this project! Check out the GitHub issues to get started.
This project is licensed under the MIT License.
For questions and suggestions, you can ping me via email or via Twitter. If you have any issues just post them on the GitHub repository.