Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emarifer/flashmessages-demo
Full-stack application simple for flash messages demonstration after page redirects, with HTML template rendering and using _hyperscript to handle deletions and transitions CSS from flash messages
https://github.com/emarifer/flashmessages-demo
daisyui echo-framework flash-messages go golang hyperscript jwt-authentication jwt-go jwt-middleware protected-routes refresh-token tailwindcss template-engine template-engine-html webapp
Last synced: 1 day ago
JSON representation
Full-stack application simple for flash messages demonstration after page redirects, with HTML template rendering and using _hyperscript to handle deletions and transitions CSS from flash messages
- Host: GitHub
- URL: https://github.com/emarifer/flashmessages-demo
- Owner: emarifer
- License: mit
- Created: 2023-11-13T13:30:36.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-13T14:46:50.000Z (about 1 year ago)
- Last Synced: 2024-11-16T12:17:58.742Z (2 months ago)
- Topics: daisyui, echo-framework, flash-messages, go, golang, hyperscript, jwt-authentication, jwt-go, jwt-middleware, protected-routes, refresh-token, tailwindcss, template-engine, template-engine-html, webapp
- Language: Go
- Homepage:
- Size: 57.6 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Full Stack Golang Web App – Flash Messages Demo
#### Full-stack application simple for flash messages demonstration after page redirects, with HTML template rendering and using _hyperscript to handle deletions and transitions CSS from flash messages.
#### This is an application developed in Go with the minimalist Echo framework for the backend and the frontend rendering with the native Go template package (html/template). On the other hand, _hyperscript is used to improve the appearance of alert openings and closings. The messages remain for 5 seconds and then are automatically deleted. Likewise, Tailwind CSS and daisyUI are used from their respective CDNs.
#### For demonstration purposes and to simplify the code, the use of a database is simulated using a function that generates a user ("Test User") and its password ("test").
#### The application has the expiration time for the token set to 1 hour. This means that after 1 hour the user session will be automatically logged out. This is something we want to avoid, especially if the user is still active and working on our resource. This can be solved by introducing a refresh token. This token will have a much longer lifespan and will be used to refresh the access token.
###### **Note**: the documentations of the Echo framework and the _hyperscript JavaScript library, you can see them [here](https://echo.labstack.com/) and [here](https://hyperscript.org/), respectively.
---
### Screenshots:
###### Login Page with errors alert:
###### Admin Page with success alert:
---
### Setup:
Besides the obvious prerequisite of having Go! on your machine, you must have Air installed for hot reloading when editing code.
Start the app in development mode:
```
$ air # Ctrl + C to stop the application
```Build for production:
```
$ go build -ldflags="-s -w" -o ./bin/main . # ./bin/main to run the application
```### Happy coding 😀!!