PayTok leverages agent networks and cash-in/cash-out points, users can deposit and withdraw money from their digital wallets using physical locations such as retail stores, kiosks, and partner agents.
Disclaimer: Paytok is a web app designed for mobile view.
Paytok is inspired by prepaid services such as gift cards and prepaid sim.
PayTok is a digital payment platform to offer customers the option to pay cashless without requiring a debit or credit card. PayTok acts as a 'bank account' where users 'deposit' money into the app via agents. An agent can deposit money into their account either by connecting to their bank account or by depositing cash from another agent. An agent is then able to sell top-up services to other users by transferring money from the agent to user's account and the user pays by cash.
Our project was developed using a combination of React and Node.js, with the Google Gmail OAuth API integrated for a seamless login experience.
- React: Used to build the UI and components, ensuring a responsive and dynamic user experience.
- Google Gmail OAuth API: Provides secure and smooth user authentication.
- Node.js with Express: Manages server-side logic and API endpoints.
- MongoDB: Serves as the database, storing user data and transaction histories.
- Deployment: The backend is deployed on Render, ensuring reliability and scalability.
- Balance Transfer: Securely handles the transfer of balances between users.
- PIN Authentication: Adds an extra layer of security for transactions.
- Transaction History: Maintains a detailed log of all user transactions.
- Top Up via Credit Card: Agents have the exclusive ability to top up their accounts using credit cards, enhancing convenience and flexibility.
- API security: We secure the API payload with API keys
- PIN security: PINs are stored in db using SHA256
This setup ensures a robust, secure, and user-friendly platform for managing digital transactions, catering to both regular users and agents with additional functionalities.
One of the significant challenges we faced was not fully understanding the domain initially. This lack of familiarity made it difficult to make informed decisions regarding the architecture and specific requirements of the payment service. Additionally, integrating various third-party APIs presented a steep learning curve, especially in ensuring they worked seamlessly together. We also encountered issues with ensuring data security and maintaining a smooth user experience across different devices and platforms.
- We are proud to have created a functional payment service that operates without the need for a debit or credit card. This achievement demonstrates our ability to innovate and develop solutions for users who may not have access to traditional banking services.
- Successfully integrating the Google Gmail OAuth API to provide a seamless and secure login experience for users.
- Implementing a backend system using Node.js, Express.js, and MongoDB, which efficiently handles balance transfers, PIN authentication, transaction histories, and more.
- Developing a user-friendly interface with React that makes navigating the payment service intuitive and straightforward.
- Enabling top-up functionality via credit card exclusively for agents, adding an extra layer of utility for specific user roles.
- We gained a deep understanding of the intricate details involved in creating a mobile payment service, from ensuring secure transactions and user authentication to managing transaction histories and integrating third-party APIs.
- We learned the importance of thorough domain research before diving into development, which helps in making informed architectural and design decisions.
- We enhanced our skills in full-stack development, particularly in using React for front-end development and Node.js, Express.js, and MongoDB for back-end development.
- We learned how to effectively manage and synchronise different components of a project, ensuring that the frontend and backend work together seamlessly.
- We improved our problem-solving skills by overcoming various technical challenges and ensuring a smooth and secure user experience.
- We gained experience in deploying applications on platforms like Render, understanding the deployment process, and handling post-deployment issues.
We hope that PayTok will be deployed into TikTok as an actual service to be used worldwide and reach parts of the world where bank accounts are uncommon. We hope that through PayTok, the TikTok community will grow via the continued engagement of users through transactions. Subsequently, we hope to expand our services to other companies.