-
Notifications
You must be signed in to change notification settings - Fork 22
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: create code challenge java (#1)
- Loading branch information
1 parent
a73a5ed
commit 51dc1c1
Showing
2 changed files
with
109 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,84 @@ | ||
# app-java-codechallenge | ||
Code challenge for potential Yaperos | ||
# Yape Code Challenge :rocket: | ||
|
||
Our code challenge will let you marvel us with your Jedi coding skills :smile:. | ||
|
||
Don't forget that the proper way to submit your work is to fork the repo and create a PR :wink: ... have fun !! | ||
|
||
- [Yape Code Challenge :rocket:](#yape-code-challenge-rocket) | ||
- [Problem](#problem) | ||
- [Tech Stack](#tech-stack) | ||
- [Optional](#optional) | ||
- [Send us your challenge](#send-us-your-challenge) | ||
|
||
# Problem | ||
|
||
Every time a financial transaction is created it must be validated by our anti-fraud microservice and then the same service sends a message back to update the transaction status. | ||
For now, we have only three transaction statuses: | ||
|
||
<ol> | ||
<li>pending</li> | ||
<li>approved</li> | ||
<li>rejected</li> | ||
</ol> | ||
|
||
Every transaction with a value greater than 1000 should be rejected. | ||
|
||
```mermaid | ||
flowchart LR | ||
Transaction -- Save Transaction with pending Status --> transactionDatabase[(Database)] | ||
Transaction --Send transaction Created event--> Anti-Fraud | ||
Anti-Fraud -- Send transaction Status Approved event--> Transaction | ||
Anti-Fraud -- Send transaction Status Rejected event--> Transaction | ||
Transaction -- Update transaction Status event--> transactionDatabase[(Database)] | ||
``` | ||
|
||
# Tech Stack | ||
|
||
<ol> | ||
<li>Java. You can use any framework you want</li> | ||
<li>Any database</li> | ||
<li>Kafka</li> | ||
</ol> | ||
|
||
We do provide a `Dockerfile` to help you get started with a dev environment. | ||
|
||
You must have two resources: | ||
|
||
1. Resource to create a transaction that must containt: | ||
|
||
```json | ||
{ | ||
"accountExternalIdDebit": "Guid", | ||
"accountExternalIdCredit": "Guid", | ||
"tranferTypeId": 1, | ||
"value": 120 | ||
} | ||
``` | ||
|
||
2. Resource to retrieve a transaction | ||
|
||
```json | ||
{ | ||
"transactionExternalId": "Guid", | ||
"transactionType": { | ||
"name": "" | ||
}, | ||
"transactionStatus": { | ||
"name": "" | ||
}, | ||
"value": 120, | ||
"createdAt": "Date" | ||
} | ||
``` | ||
|
||
## Optional | ||
|
||
You can use any approach to store transaction data but you should consider that we may deal with high volume scenarios where we have a huge amount of writes and reads for the same data at the same time. How would you tackle this requirement? | ||
|
||
You can use Graphql; | ||
|
||
# Send us your challenge | ||
|
||
When you finish your challenge, after forking a repository, you **must** open a pull request to our repository. There are no limitations to the implementation, you can follow the programming paradigm, modularization, and style that you feel is the most appropriate solution. | ||
|
||
If you have any questions, please let us know. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
version: "3.7" | ||
services: | ||
postgres: | ||
image: postgres:14 | ||
ports: | ||
- "5432:5432" | ||
environment: | ||
- POSTGRES_USER=postgres | ||
- POSTGRES_PASSWORD=postgres | ||
zookeeper: | ||
image: confluentinc/cp-zookeeper:5.5.3 | ||
environment: | ||
ZOOKEEPER_CLIENT_PORT: 2181 | ||
kafka: | ||
image: confluentinc/cp-enterprise-kafka:5.5.3 | ||
depends_on: [zookeeper] | ||
environment: | ||
KAFKA_ZOOKEEPER_CONNECT: "zookeeper:2181" | ||
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:29092,PLAINTEXT_HOST://localhost:9092 | ||
KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,PLAINTEXT_HOST:PLAINTEXT | ||
KAFKA_BROKER_ID: 1 | ||
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1 | ||
KAFKA_JMX_PORT: 9991 | ||
ports: | ||
- 9092:9092 |