Skip to content

Latest commit

 

History

History
211 lines (153 loc) · 5.81 KB

README.md

File metadata and controls

211 lines (153 loc) · 5.81 KB

SimpleChat

This is a simple chat application that allows user to:

- [x] register
- [X] login implements JWT
- [x] view profile
- [x] edit profile 
- [x] create a chat
- [x] edit a chat
- [x] edit profile/chat implements security(Only owner can edit)
- [x] list all chats
- [x] view all messages in a chat
- [x] create a message in a chat
- [x] logout

Technologies

- Java
- Spring Boot, Spring: Data JPA, Rest, Validator, MVC, ...
- JUnit, Mockito
- Maven
- MySQL
- Log4j2
- JSON Web Token
- Redis

Requirements

What you will need: - JDK 1.8 - Maven 3.5+ - MySQL 5.7+ - Redis

Database configuration

  • You can change the database's connection and name in application.properties, you can find it inside resources directory
  • Here I'm using root as my username and password, you can change according to your current configuration

Using Docker for MySQL and Redis

Build

From the root of project directory (you will find pom.xml file there) run the following command

	mvn clean install

	java -jar target/simplechat-0.0.1.jar

You also use the following command

	mvn spring-boot:run

Note: confirm your maven is pointing to correct java version, in our case it should be JDK 1.8, you can do so by running

mvn --version

Test

The application will initialize some data from sample data set in import.sql in resource directory.

  • Note: register and login request won't be filter with jwt. Other request required a valid token from successful login

Using POSTMAN

Register

curl --location --request POST 'http://localhost:8080/register' \
 --header 'Content-Type: application/json' \
 --data-raw '{
 "username": "reg1234",
 "password": "1234",
 "firstName": "Jane",
 "lastName": "Dawn",
 "email": "test@gmail.com"
 }'

Login

curl --location --request POST 'http://localhost:8080/login' \
--header 'Content-Type: application/json' \
--data-raw '{
"username": "reg1234",
"password": "1234"
}'
  • Upon successful login it will return jwt token

Logout

curl --location --request GET 'http://localhost:8080/logout'
  • It should return successfully logout message

Start from here, below APIs required successfully user login

  • if you using different browser you have to include Cookie in your header with token

  • eg: gettting list of users

    curl --location --request GET 'http://localhost:8080/api/users'
    --header 'Cookie: coco={{YOUR_AUTHENTICATED_TOKEN}}'

  • YOUR_AUTHENTICATED_TOKEN this is generated cookies after loggin

User list

view user

url: http://localhost:8080/api/users/1 (GET), 1 is user id

update user

url: http://localhost:8080/api/users (PATCH), sample data

	 {
	"id":"7",
	"username": "uzer7",
	"password": "1234",
	"firstName": "Python Update",
	"lastName": "Piper",
	"email": "test@gmail.com"
	}

Chat list

create chat

url: http://localhost:8080/api/chats (POST) , sample data

curl --location --request POST 'http://localhost:8080/api/chats' \
--header 'Content-Type: application/json' \
--data-raw '{
"id":"5",
"owner": "1",
"message": "Hello Chat message number 5 by user 1",
"postedDate": "2024-10-04T22:44:30.652"
}'

view chat

url: http://localhost:8080/api/chats/5 (GET), 5 is chat id

update chat

url: http://localhost:8080/api/chats (PATCH), Sample data

	{
	"id":"1",
	"owner": "1",
	"message": "Update chat id 1 chat date",
	"postedDate": "2016-10-04T22:44:30.652"
	}

Message list

create message

url: http://localhost:8080/api/messages (POST) , sample data

curl --location --request POST 'http://localhost:8080/api/messages' \
--header 'Content-Type: application/json' \
--data-raw '{
"id": "5",
"user": "1",
"chat": "1",
"message": "Hello Message reply to chat id 1",
"postedDate": "2024-05-04T22:44:30.652"
}'

view message

url: http://localhost:8080/api/messages/1 (GET), 1 is chat message id

update message

url: http://localhost:8080/api/messages (PATCH), Sample data

	{
	"id":"1",
	"owner": "1",
	"chat": "1",
	"message": "Update message id 1 chat date",
	"postedDate": "2016-11-04T22:44:30.652"
	}

Versioning

The api path '/api/' can be change in application.properties file. You can find the file under resources directory

	api.path: api

Contributor