1
0
mirror of https://github.com/ManyakRus/crud_generator.git synced 2024-11-24 08:22:42 +02:00
Go to file
2024-04-09 18:04:05 +03:00
bin сделал uuid 2024-04-09 18:04:05 +03:00
cmd/crud_generator сделал Read_ctx(ctx context.Context, db *gorm.DB, m *calendars.Calendar) 2024-04-02 11:54:01 +03:00
docs сделал FillRowsCount() 2024-03-22 14:17:07 +03:00
examples сделал объединил templates_main и templates 2024-02-09 15:17:57 +03:00
internal сделал uuid 2024-04-09 18:04:05 +03:00
pkg сделал readme 2023-11-14 17:07:41 +03:00
scripts сделал CopyAllFiles_Exclude_() 2023-11-15 17:59:21 +03:00
vendor сделал UUID 2024-04-05 16:53:35 +03:00
.gitignore сделал "public" 2024-04-08 13:54:14 +03:00
go.mod сделал UUID 2024-04-05 16:53:35 +03:00
go.sum сделал UUID 2024-04-05 16:53:35 +03:00
LICENSE Create LICENSE 2024-03-19 15:48:28 +03:00
Makefile сделал FillRowsCount() 2024-03-22 14:17:07 +03:00
README.md сделал readme 2024-03-15 16:43:40 +03:00
readme.rus сделал readme 2024-03-15 16:30:07 +03:00

The crud_generator application is designed to automatically generate source code files in golang language to perform CRUD operations. A completely ready-made microservice is created that can be launched immediately.

For each table in the Postgres SQL database, files will be created to perform crud operations:

  • Create(), Read(), Update(), Delete() (or Delete() + Restore(), if there is an is_deleted field)
  • Save() - creating a new record when ID=0, or updating a record when ID<>0
  • ReadFromCache() - reading from cache or database
  • Update_ColumnName() - changing only one column with the name ColumnName, separate function for each column of each table

files are generated:

  1. table - struct structure with all fields from the database, and gorm + json annotations Tables with fields in the database must be created manually in advance. The code generator will find all the tables and their fields in the database and use them.
  2. model - struct structure, including table, with crud operations functions
  3. crud - files for performing crud operations, exchange with the database, as well as files with tests
  4. grpc server - files for performing crud operations over the network, using the GRPC protocol, as well as files with tests
  5. grpc client - client files for using GRPC by third-party services, as well as files with tests
  6. nrpc server - files for performing crud operations over the network, using the NRPC protocol (via the NATS message broker), as well as files with tests
  7. nrpc client - client files for use by NRPC third-party services, as well as files with tests
  8. crud_starter - a file with functions for switching to the desired protocol db or grpc or nrpc
  9. main.go and other .go files
  10. Makefile - script launch configuration file
  11. .env - file for filling in the microservice configuration (database connection parameters, etc.)

Code templates are stored in the bin/templates folder. The code template is a .go file copied from the real project - so it’s easy to make a template (change it to your own) - just copy your file. The code generator replaces part of the code in the template with another code:

  • name of the database table
  • model name
  • adding and removing imports

Installation procedure:

  1. Compile this repository

make build

the crud_generator file will appear in the bin folder

  1. Fill in the settings in the file bin/templates/configs_/settings.txt
  • connections to your database
  • the name of your new service
  • URL of your new service
  • and etc.
  1. Tables in the database must be created in advance, manually.

  2. Launch crud_generator A new folder with the name of your service will appear in the bin folder, with subfolders and finished files inside.

  3. Fill in the configuration parameters in the .env file Start microservice:

make run

P.S. I generated myself 350,000 lines of code, from 70 tables in the database, for my service.

Source code in Golang language. Tested on Linux Ubuntu Readme from 11/14/2023

Made by Alexander Nikitin https://github.com/ManyakRus/crud_generator