Created project for Credit Card Tokenization.
The Project is organized into three maven modules as follows under a parent project. The parent project is called tokenization-project
Contains the Code to Expose a Restful service for posting the Payment information. Creates a unique transactionID, and sends the message to data-input kafka topic,and responds with the status message to Restful client.
Contains the code to consume the message sent from source module on the data-input topic. Extracts the message and encrypts the Credit Card Information(Token) and stores the TransactionId as Key and the Token as the value to the Redis store. The TransactionId and TokenId information is sent along to the topic data-output.
Consumes TransactionId, and Token information from data-output topic, using the TransactionId as the Key looks into the Redis datastore and finds the Token. Once the Token is found the Token data is decrypted, and both the TransactionID and decrypted CreditCard information are printed on the screen, in the follwing format.
{"transactionId":{"cardNumber":"4444444444444448","expirationDate":"02/20","cvvNumber":"130"}}
- JDK 1.8
- Maven 3+ version
- Mac Operating System(May work on any *nix System, but tested only on Mac OS)
- Other dependencies like Redis and Kafka are bundled with the project to make the setup and testing effortless.
-
Git Clone or download the project - tokenization-project
-
Navigate to the downloaded/cloned tokenization-project folder
-
Open a new Terminal tab and execute this script to setup Kafka and Redis, and start them $./start_kafka_redis.sh
- Open a new Terminal tab and execute this command $mvn clean install, This command builds all the 3 modules(source,flow,proof) that are present under tokenization-project
- Open a new Terminal tab and type this command to show source module logs $java -jar source/target/source-1.0.0.jar
- Open a new Terminal tab and type this command to show flow module logs $java -jar flow/target/flow-1.0.0.jar
- Open a new Terminal tab and type this command to show proof module logs $java -jar proof/target/proof-1.0.0.jar
- Open a new Terminal tab and type this command - curl -X POST http://localhost:9000/api/auth -H 'Content-Type: application/json' -d '{"cardNumber": "4444444444444448","expirationDate": "02/20","cvvNumber": "130"}'
- Notice the logs on the source, flow, and proof Terminal tabs as they were opened in the previous steps.
- The CreditCard Information is passed in from the curl command and reaches the source module which returns a status message and TransactionId to the caller.
- The Credit Card Information is sent from source module to the flow module using data-input topic. The CreditCard information is captured in the flow module, encrypted(Tokenized) and stored into redis data store using TransactionId as the Key.
- The TransactionId and Token information is passed to the proof module from the flow module using data-output topic.
- The proof module reads the data-output topic data and gets the transactionID from the message and uses that transactionId to fetch the Token information from Redis data store.The token information is decrypted and displayed on the screen in the follwing format.
{"transactionId":{"cardNumber":"4444444444444448","expirationDate":"02/20","cvvNumber":"130"}}
The following items can be added in the RoadMap and for future enhancements.
- We can add more test coverage.
- Extract some common logic among the modules into a library, like security related code into a common library.
- Perform PCI scanning for the code using tools like Fortify, as the code is PCI related.