Skip to content

RamonBecker/GraphQLCompras

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 

Repository files navigation

GraphQLCompras

ℹ️ Information

Project developed with SpringBoot and GraphQL. It was the object of study during development:

  • Creating a GraphQL API connected to the MYSQL database;
  • Creating custom queries with join between multiple tables to navigate the graph layers.
  • The use of paging in GraphQL queries;
  • Study on the GraphQL N+1 problem and how to use Cache;
  • Creating and Handling custom exceptions.

⚠️ Prerequisite

Java Badge >= 8

Spring Badge

JSON Badge

mysql

JPA-hibernate (1)

GRAPHQL

JUNIT

🔧 Install

https://github.com/RamonBecker/GraphQLCompras.git

git clone https://github.com/RamonBecker/GraphQLCompras.git
or install github https://desktop.github.com/ 

⚙️ Installing MySQL

Enter the following commands in the terminal.

sudo apt update
sudo apt install mysql-server

Configuring MySQL

For new installations, you will want to run the security script that is included. This changes some of the less secure default options for things like root logins and example users. Enter the command below.

sudo mysql_secure_installation

This will take you through a series of prompts where you can make some changes to the security options of your MySQL installation. The first prompt will ask you if you want to configure the Validate Password Plugin, which can be used to test the strength of your MySQL password. Regardless of your choice, the next prompt will be to set the password for the MySQL root user. Sign in and then confirm a secure password of your choice.

From there, you can press Y and then ENTER to accept the default answers for all subsequent questions. This will remove some anonymous users and the test database, disable remote login for root, and load all of these new rules so that MySQL immediately respects the changes you made.

Testing MySQL

To see if MYSQL is running, type the following command.

systemctl status mysql.service

If MySQL is not running, you can start it with the following command.

sudo systemctl start mysql

Now try to connect your root user to MySQL.

mysql -u root -p

Attention when creating and connecting the database

Check the application.properties file

spring.datasource.url=jdbc:mysql://localhost:3306/udemy_purchases?useSSL=false&allowPublicKeyRetrieval=true
spring.datasource.username=username
spring.datasource.password=password

You must create the database in MYSQL with the name udemy_compras

⚙️ Testing the project

Open your browser and type:

http://localhost:8080/graphiql

To test product features:

mutation{
saveProduto(produto:{id: "" ,nome:"teste", valor: 1000}){
      ...fragProduto
   }
 }

mutation{
   deleteProduto(id:6)
}

{
  produtos{
     ...fragProduto
   }
}

fragment fragProduto on Produto
{
    id, nome, valor
}

To test shopping features:

 mutation{
   saveCompra(compra:{
     clienteId:1,
     produtoId: 3,
     quantidade:30,
     status: "OK"
   }){
     id, quantidade, status
  }
 }
 
{
  compras{
    id,
    quantidade,
    status,
    cliente{
      id, nome
    },
    produto{
      id,nome, valor
    }
  }
}

 mutation{
  deleteCompra(id:1)
}

To test client features:

query GetCliente($id:ID!){
  
  cliente(id: $id){
    ...fragCliente
  }
}


mutation{
   saveCliente(cliente:{id:6, nome:"teste modelMappper ", email:"teste@gmail.com"}){
    id, nome, email
   }
}


mutation{
  deleteCliente(id:4)
}

{
   clientes{
     id, nome ,email
   }
}



{ 
c1: cliente(id:1){
     id, nome, email
},
c2:  cliente(id:2){
id, nome, email
 }
}


fragment fragCliente on Cliente
{
    id, nome, email
}

{
  
c1: cliente(id:1){
	...fragCliente
	},
   c2:  cliente(id:2){
 	...fragCliente 
   }
 }

⚡ Technologies

  • Java
  • JPA
  • Spring Boot
  • GraphQL
  • JUNIT
  • ModelMapper
  • MYSQL

📝 Developed features

  • CRUD Purchases
  • CRUD Client
  • CRUD product

🧑‍💻 Author

By Ramon Becker 👋🏽 Get in touch!

github linkedin Gmail Badge

About

Project developed with SpringBoot and GraphQL

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages