Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paulocoutinhox/kaktos
Kaktos is a Python Static Site Generator
https://github.com/paulocoutinhox/kaktos
generator html jamstack python serverless site website
Last synced: about 2 months ago
JSON representation
Kaktos is a Python Static Site Generator
- Host: GitHub
- URL: https://github.com/paulocoutinhox/kaktos
- Owner: paulocoutinhox
- Created: 2021-10-30T08:06:10.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-08-29T21:53:34.000Z (4 months ago)
- Last Synced: 2024-09-11T08:49:16.505Z (4 months ago)
- Topics: generator, html, jamstack, python, serverless, site, website
- Language: HTML
- Homepage: https://kaktos.pages.dev
- Size: 3.49 MB
- Stars: 8
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
Python Static Site Generator for Serverless Applications π
# κάκΟΞΏΟ - Kaktos
[![Kaktos](https://github.com/paulocoutinhox/kaktos/actions/workflows/build.yml/badge.svg)](https://github.com/paulocoutinhox/kaktos/actions/workflows/build.yml)
Kaktos is a powerful **Python Static Site Generator** designed to create highly efficient **serverless** applications. Why pay for hosting when you can deploy a completely static site for free?
Create beautiful static websites, e-commerce stores, blogs, landing pages, and sales pages with **advanced pagination** and **dynamic features**, all without the hassle of server-side dependencies! π»
## β¨ Features
- **Static Website Generator** β Create responsive, fast, and secure static sites πΌοΈ
- **Static E-commerce** β Build fully functioning static shopping websites π
- **Static Blog** β Advanced blog with pagination and dynamic content π
- **Landing Pages & Sales Pages** β Perfect for creating high-conversion pages for any purpose ποΈ
- **Easy to Use** β Intuitive design that requires no server-side programming π‘
- **Serverless** β Deploy to platforms like Netlify, Cloudflare, or Render with no need for server management βοΈ
- **Many Free Hosting Options** β Many companies offer free hosting for static sites, as no server-side processing is required π
- **Fast & Secure** β Static sites are inherently faster and more secure β‘
- **No Hosting Fees** β Fully serverless deployment means **no hosting costs** π
- **SEO Optimized** β Generate clean, SEO-friendly pages π΅οΈββοΈ
- **Customizable Templates** β Based on the powerful Jinja2 templating engine π¨## π€ Why Kaktos?
With **Kaktos**, you can deploy your website without worrying about server management, database configuration, or paying for hosting. Focus on your content, and let Kaktos handle the rest. Enjoy the benefits of a **serverless architecture**, which has become a major trend in web development, reducing operational costs and simplifying the deployment process for companies of all sizes.
- No need to manage infrastructure
- No ongoing hosting fees
- Scalable and fast deployment
- Ideal for websites, blogs, e-commerce, and landing pages## π All-in-One Solution
Unlike most static site generators, which focus on specific tasks, **Kaktos** provides an **all-in-one** solution.
Whether you need to build a blog, an e-commerce store, a landing page, or any other static website, Kaktos brings it all together in one platform, simplifying your workflow and allowing you to manage everything in a single place.
## π¬ Demo
**Cloudflare:**
[https://kaktos.pages.dev](https://kaktos.pages.dev)
**Netlify:**
[https://kaktos.netlify.app](https://kaktos.netlify.app)
**Amplify:**
[https://main.d27ze19drzixy0.amplifyapp.com](https://main.d27ze19drzixy0.amplifyapp.com)
**Render:**
[https://kaktos.onrender.com](https://kaktos.onrender.com)
## Requirements
- Python 3.8+
## π How to Get Started
Install python dependencies:
```bash
python3 -m pip install -r requirements.txt
```## π» Development
To work in development mode, you only need execute one command:
```bash
python3 kaktos.py
```When you change any file locally, the server will `process` it again and `auto-refresh` on browser.
This command *always force* use development mode, with or without environment variable.
## π Production
To generate production files, you only need execute one command:
```bash
python3 kaktos.py build
```All files will be generated in `build` folder.
If you set environment variable `KAKTOS_DEBUG=True`, kaktos will build all files for development mode, example:
```bash
KAKTOS_DEBUG=True python3 kaktos.py build
```If you want start a web server to test files inside `build` folder use:
```bash
python3 kaktos.py serve
```## π¦ Deploying with One Click
**Netlify:**
[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/paulocoutinhox/kaktos)
**Render:**
[![Deploy to Render](https://render.com/images/deploy-to-render-button.svg)](https://render.com/deploy?repo=https://github.com/paulocoutinhox/kaktos/tree/render-support)
## ποΈ Project Structure
- `kaktos.py` = main file that process your command
- `requirements.txt` = python dependency list
- `templates/layouts` = folder for all layouts that pages can inherit
- `templates/pages` = folder for pages that will be generated
- `templates/shared` = folder for parts of layouts that can be shared with other layouts
- `modules` = kaktos modules
- `modules/config.py` = configuration file
- `files` = folder that contains all assets and custom files
- `extras/config` = folder that contains some configurations for dynamic sample data## π§ Commands
Each command supported by **Kaktos** is a Python file located in the `modules/commands/` folder.
To add new commands, simply create a new Python file in the `modules/commands/` folder and implement the `def run(params={})` method within it.
## π Templates
All templates (html files) are based on Jinja2 library. You can see it here:
https://jinja.palletsprojects.com/en/3.0.x/
## π οΈ Troubleshooting
#### **β’ Python version**
Each service that build the static content automatically use a specific python version.
If you need change the python version used to build all files and pages, edit file `runtime.txt` and change to `3.8`, `3.9` or other.
These services that im using have this python version:
- Netlify: Python 3.8 (https://docs.netlify.com/configure-builds/available-software-at-build-time/)
- Cloudflare Pages: Python 3.11.5 (https://developers.cloudflare.com/pages/configuration/language-support-and-tools)#### **β’ Template changed, but not reloaded**
Invalid Jinja2 syntax can prevent your HTML template from being built.
Check your terminal to see the error message, the HTML file and the line number where invalid syntax was detected.
## β Buy Me a Coffee
## πΌοΈ Images
All images for demo i got from:
https://unsplash.com/
## π License
[MIT](http://opensource.org/licenses/MIT)
Copyright (c) 2021-2024, Paulo Coutinho