Skip to content

Commit

Permalink
Merge branch 'main' into sqlite
Browse files Browse the repository at this point in the history
  • Loading branch information
leomorpho committed Sep 18, 2024
2 parents 65d3e1d + d927561 commit 73175ec
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 2 deletions.
92 changes: 92 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ This started as a fork of [pagoda](https://github.com/mikestefanello/pagoda), fo
<p align="center"><img alt="Logo" src="https://user-images.githubusercontent.com/552328/147838644-0efac538-a97e-4a46-86a0-41e3abdf9f20.png" height="100px"/></p>


### Getting Started

To get up and running with GoShip:
```bash
# The below command will:
Expand All @@ -38,6 +40,96 @@ make watch

For in-depth info on the architecture of the project, please see the [mikestefanello/pagoda](https://github.com/mikestefanello/pagoda) repo. There are some key differences, but since this was originally a fork, 99% of it still applies. I am working on creating clear and actionable documentation, but that is quite time-consuming, so don't hold your socks.

### Motivation

Build the same rich interfaces you would build with Javascript frameworks, but with HTML and Go. Limit the number of tools you use. Develop rapidly.

#### Why the Hell Do We Need Another Boilerplate?

Well, I noticed that there were none for Go. Now, I know most Go folks like to build it all themselves. And while I love doing that myself, I have many project ideas for which I just want to build that specific project, not the entire infra surrounding it, like auth, notifications, payments, file uploads etc. This project has served me well in bringing to production many projects so far. It has evolved far beyond what I originally planned for, though there is still so much potentional to expand on and implement for.

If you'd like a no-nonesense (or not too much?) starter kit to get your next project to production ASAP, while also using awesome technologies like Go, you've found a suitable starting point!

> **Warning alert!** this project is in active development as I am adding things after first trying them out in prod for [Chérie](https://cherie.chatbond.app/), a relationship app to grow your couple. Note that I would welcome any help to develop this boilerplate ❤️.
### Features

#### 🌩 Realtime
- Support for HTMX SSE extension
- Can be used with vanilla JS

#### 📬 Email Sending
- Support for SMTP and Resend API
- Pre-made templates for account activation, password reset, and newsletter.

#### 💸 Payments
- Stripe integration for monthly subscriptions
- Internal subscription management

#### 🏗 Background Tasks
- Offload heavy tasks to background
- Realtime or scheduled

#### 🔔 Notifications
- Real-time or scheduled
- Supports push notifications to PWA, native iOS, and native Android

#### 🔐 Auth Done For You
- Email/Password logins
- Ready-made private user area

#### 📂 File Uploads with AWS APIs
- Internal management of uploaded files
- Host files and images on any S3 compatible service (e.g. Backblaze)
- Pre-signed URLs!

#### 📱 Mobile Ready App
- Fully PWA-ready with internal FCM and push subscriptions management
- IOS native wrapper with push notifications and payments
- Pre-signed URLs!
- Styled with mobile/tablet/desktop in mind

#### 💅 Components and Styles
- Light + Dark mode
- Many components available (HTMX, AlpineJS, Hyperscript)
- 20+ themes with DaisyUI

#### 🪂 Drop-in any JS App
- Designed for island architecture. Drop in any JS app and take advantage of already built infra
- Currently has SvelteJS and VanillaJS build step and static file serving

#### 🛢 AI-ready Database Layer
- Postgres support (i.e. Supabase, Neon etc)
- Vector-ready (PGVector integrated) for your AI/ML applications!

#### 🧪 Go Tests and E2E Tests with Playwright
- Go tests with automatic setup/teardown of DB container
- Playwright integration tests to make sure you don't break your previously working UIs!

#### 🚀 Deploy Anywhere. Easily.
- Deploy from bare metal to Cloud VMs with Kamal
- Single-command deploy after quick setup

### Tech Stack

#### Backend
- **[Echo](https://echo.labstack.com/)** - High-performance, extensible, minimalist Go web framework.
- **[Ent](https://entgo.io/)** - Simple yet powerful ORM for modeling and querying data.
- **[Asynq](https://github.com/hibiken/asynq)** - Simple, reliable, and efficient distributed task queue in Go.
- **[Stripe](https://stripe.com/)** - Payments solution.

#### Frontend
- **[HTMX](https://htmx.org/)** - Build modern user interfaces with minimal JavaScript.
- **[Templ](https://templ.build/)** - A powerful type-safe Go templating language.
- **[Tailwind CSS](https://tailwindcss.com/)** - A utility-first CSS framework for rapid implementation.
- **[Hyperscript](https://hyperscript.org/)** - A lightweight JavaScript framework to sprinkle localized logic and state.
#### Storage
- **Postgres** - Host your DB on Supabase or any other hosting platform compatible with Postgres.
- Currently making optional, with **SQLite** as replacement for single binary deployments
- **[S3](https://aws.amazon.com/s3/)** - Host files and images on any S3-compatible service (e.g., Backblaze).
- **Redis** - used for task queuing, caching, and SSE events.
- Currently making optional for single binary deployments
>>>>>>> main
## WIP Documentation

Expand Down
2 changes: 1 addition & 1 deletion templates/pages/documentation.templ
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ templ GoshipFeatures() {
@singleOpenAccordionEntry("Styles", "💅 Components and Styles", stylesContent())
@singleOpenAccordionEntry("DropJSApp", "🪂 Drop-in any JS App", jsIslandsContent())
@singleOpenAccordionEntry("DB", "🛢 AI-ready Database Layer", databaseContent())
@singleOpenAccordionEntry("DB", "🧪Go Tests and E2E Tests with Playwright", testingContent())
@singleOpenAccordionEntry("e2eTests", "🧪 Go Tests and E2E Tests with Playwright", testingContent())
@singleOpenAccordionEntry("Deploy", "🚀 Deploy Anywhere. Easily.", deployContent())
// @singleOpenAccordionEntry("Authorization", "👮 Authorization", accordionNotificationsContent())
}
Expand Down
2 changes: 1 addition & 1 deletion templates/pages/documentation_templ.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 73175ec

Please sign in to comment.