BlogFlex โœจ๐Ÿ“

Features ๐Ÿš€

  • User registration and authentication ๐Ÿ”
  • Session management with Gorilla Sessions ๐Ÿช
  • JWT-based authentication middleware ๐Ÿ”‘
  • Post creation, listing, and detail views ๐Ÿ“
  • Commenting system ๐Ÿ’ฌ
  • Real-time updates with HTMX โšก
  • Responsive design with Bootstrap ๐Ÿ“ฑ
  • TinyMCE advanced WYSIWYG HTML editor ๐Ÿ–‹๏ธ
  • Database management with Hasura using GraphQL with PostgreSQL ๐Ÿ—„๏ธ
  • Containerization with Docker ๐Ÿณ

Technologies Used

  • Backend: Go, GraphQL, PostgreSQL, Hasura
  • Frontend: HTMX, Templ, Bootstrap, TinyMCE WYSIWYG HTML editor
  • Containerization: Docker

Getting Started

Prerequisites ๐Ÿ“‹

  • Go (version 1.18 or later) ๐Ÿน
  • HTMX
  • Templ
  • Docker ๐Ÿณ
  • Hasura Account
  • Air for live reloading

Installation โš™๏ธ

  1. Clone the repository

    git clone https://github.com/yourusername/blogflex.git
    cd blogflex
  2. Register a Hasura Account

Register for an account at Hasura.

  1. Install Go dependencies

    go mod tidy
  2. Set Up Environment Variables

Create a .env file in the root directory and add the necessary environment variables. For example: HASURA_ENDPOINT= HASURA_ADMIN_SECRET=

Directory Structure

blogflex/
โ”œโ”€โ”€ .vscode/
โ”‚   โ””โ”€โ”€ launch.json
โ”œโ”€โ”€ internal/
โ”‚   โ”œโ”€โ”€ auth/
โ”‚   โ”‚   โ””โ”€โ”€ auth.go
โ”‚   โ”œโ”€โ”€ database/
โ”‚   โ”‚   โ””โ”€โ”€ database.go
โ”‚   โ”œโ”€โ”€ handlers/
โ”‚   โ”‚   โ”œโ”€โ”€ blog_handlers.go
โ”‚   โ”‚   โ”œโ”€โ”€ comment_handlers.go
โ”‚   โ”‚   โ”œโ”€โ”€ post_handlers.go
โ”‚   โ”‚   โ””โ”€โ”€ user_handlers.go
โ”‚   โ”œโ”€โ”€ helpers/
โ”‚   โ”‚   โ”œโ”€โ”€ format_time.go
โ”‚   โ”‚   โ”œโ”€โ”€ graphql.go
โ”‚   โ”‚   โ”œโ”€โ”€ logged_in.go
โ”‚   โ”‚   โ””โ”€โ”€ respond_error.go
โ”‚   โ”‚   โ””โ”€โ”€ truncate_words.go
โ”‚   โ””โ”€โ”€ middleware/
โ”‚   โ”‚   โ””โ”€โ”€ auth.go
โ”‚   โ””โ”€โ”€ models/
โ”‚       โ””โ”€โ”€ structs.go
โ”œโ”€โ”€ router/
โ”‚   โ””โ”€โ”€ router.go
โ”œโ”€โ”€ views/
โ”‚   โ”œโ”€โ”€ blog_list.templ
โ”‚   โ”‚   โ””โ”€โ”€ blog_list_templ.go
โ”‚   โ”œโ”€โ”€ blog_page.templ
โ”‚   โ”‚   โ””โ”€โ”€ blog_page_templ.go
โ”‚   โ”œโ”€โ”€ create.templ
โ”‚   โ”‚   โ””โ”€โ”€ create_templ.go
โ”‚   โ”œโ”€โ”€ detail.templ
โ”‚   โ”‚   โ””โ”€โ”€ detail_templ.go
โ”‚   โ”œโ”€โ”€ edit.templ
โ”‚   โ”‚   โ””โ”€โ”€ edit_templ.go
โ”‚   โ”œโ”€โ”€ index.templ
โ”‚   โ”‚   โ””โ”€โ”€ index_templ.go
โ”‚   โ”œโ”€โ”€ navbar_components.templ
โ”‚   โ”‚   โ””โ”€โ”€ navbar_components_templ.go
โ”‚   โ”œโ”€โ”€ navbar.templ
โ”‚   โ”‚   โ””โ”€โ”€ navbar_templ.go
โ”‚   โ””โ”€โ”€ post_list.templ
โ”‚       โ””โ”€โ”€ post_list_templ.go
โ”œโ”€โ”€ .air.toml
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ docker-compose.yml
โ”œโ”€โ”€ go.mod
โ”œโ”€โ”€ go.sum
โ”œโ”€โ”€ main.go
โ””โ”€โ”€ README.md

Running the Project Locally โ–ถ๏ธ

To run the project locally, you have 3 options:

  1. Launch Debugger:

    • Open your project in Visual Studio Code.
    • Set breakpoints as needed.
    • Launch the debugger by pressing F5 or by selecting Run > Start Debugging from the menu.
  2. Run Air:

    • Ensure you have Air installed for live reloading.

    • Start Air by running the following command in your terminal:

      air
  3. Run go run main.go Command:

    • Open your terminal.

    • Navigate to the project directory.

    • Run the following command to start the application:

      go run main.go

Note: Before running your project, make sure to generate the Templ files in the terminal to get the most updated UI. You can do this by running:

templ generate

Testing the API ๐Ÿงช

To test the API endpoints, use the GraphQL queries in Hasura. Follow these steps:

  1. Access Hasura Console:

    • Log in to your Hasura account at Hasura.
    • Navigate to your project's Hasura Console.
  2. Navigate to the API Tab:

    • In the Hasura Console, go to the "API" tab.
  3. Run GraphQL Queries:

    • Use the GraphQL query editor to write and execute your queries.
    • You can test various API endpoints by constructing appropriate GraphQL queries and mutations.
  4. Inspect Responses:

    • Check the responses returned by the server to ensure your API is functioning correctly.

For more advanced testing, you can also use tools like Postman or Insomnia to send GraphQL requests to your Hasura endpoints.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements


Contributing ๐Ÿค

We welcome contributions! Please follow these steps to contribute:

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature/your-feature-name).
  3. Make your changes.
  4. Commit your changes (git commit -m 'Add some feature').
  5. Push to the branch (git push origin feature/your-feature-name).
  6. Open a pull request.

Enjoy using BlogFlex! If you encounter any issues, please feel free to open an issue or submit a pull request.