Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mrtkp9993/SimpleCRUDApp
Simple CRUD Application with Go, Gorilla/mux, MariaDB, Redis.
https://github.com/mrtkp9993/SimpleCRUDApp
backend crud crud-application golang golang-application gorilla-mux mariadb redis rest-api
Last synced: 2 months ago
JSON representation
Simple CRUD Application with Go, Gorilla/mux, MariaDB, Redis.
- Host: GitHub
- URL: https://github.com/mrtkp9993/SimpleCRUDApp
- Owner: mrtkp9993
- License: gpl-3.0
- Created: 2019-03-30T16:11:39.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-02-25T00:13:04.000Z (almost 2 years ago)
- Last Synced: 2024-11-17T22:12:36.360Z (2 months ago)
- Topics: backend, crud, crud-application, golang, golang-application, gorilla-mux, mariadb, redis, rest-api
- Language: Go
- Homepage:
- Size: 58.6 KB
- Stars: 72
- Watchers: 5
- Forks: 13
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Simple CRUD App w/ Gorilla/Mux, MariaDB, Redis
[![Go Report Card](https://goreportcard.com/badge/github.com/mrtkp9993/SimpleCRUDApp)](https://goreportcard.com/report/github.com/mrtkp9993/SimpleCRUDApp)
[![CodeFactor](https://www.codefactor.io/repository/github/mrtkp9993/simplecrudapp/badge)](https://www.codefactor.io/repository/github/mrtkp9993/simplecrudapp)
![](https://img.shields.io/endpoint.svg?url=https%3A%2F%2Fastronomer.ullaakut.eu%2Fshields%3Fowner%3Dmrtkp9993%26name%3DSimpleCRUDApp)## NOTE
> This project is not longer maintained. I'll make a new better project.
## Features
Basic CRUD operations (Create-Read-Update-Delete).
## Database Scheme
Data table:
```sql
create table products
(
id int(11) unsigned auto_increment primary key,
name tinytext null,
manufacturer tinytext null
);
```You can generate data from http://filldb.info/.
Users table:
```sql
CREATE TABLE `users` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`username` text NOT NULL,
`saltedpassword` text NOT NULL,
`salt` text NOT NULL,
PRIMARY KEY (`id`)
);
```````Password+Salt```` is encrypted with ``bcrypt``with 10 rounds and stored in ``saltedpassword``column.
## Caching
You can edit cache time from [this line](https://github.com/mrtkp9993/SimpleCRUDApp/blob/master/app.go#L204):
```
err = a.Cache.Set(r.RequestURI, content, 10*time.Minute).Err()
```## Example Requests
To get all entries from table:
```
curl --user user1:pass1 127.0.0.1:8000/api/products/list
```To get an entry with `id` (where id equals 10):
```
curl --user user1:pass1 127.0.0.1:8000/api/products/10
```To create an entry:
```
curl --header "Content-Type: application/json" \
--request POST \
--data '{"name": "ABC", "manufacturer": "ACME"}' \
--user user1:pass1 127.0.0.1:8000/api/products/new
```To update an entry:
```
curl --request PUT \
--data '{"name": "ABC", "manufacturer": "ACME"}' \
--user user1:pass1 127.0.0.1:8000/api/products/11
```To delete an entry:
```
curl --request DELETE --user user1:pass1 127.0.0.1:8000/api/products/10
```