Advanced Reporting System
The project involves storing and managing accounts, resources, and fields related to six different media Ads APIs. These resources and fields may change with API updates. The system defines settings, including accounts, resources, and fields, and transfers these settings to another system for file downloading, conversion, and uploading to Amazon S3. Additionally, the solution synchronizes media accounts to the database daily and submits jobs every 30 minutes.
- Implement Username/Password authentication with session management, utilizing BCrypt for hashing and verifying passwords.
- Grant permissions for three roles: System User, Organization Owner, and Admin, using ActionFilter.
- Paginate and list all report settings based on database limits and offsets.
- Display report settings that match user-defined search criteria, such as run status, run result, media, reporter, account, and name, with a debounce feature for user input in search text boxes.
- Maintain search criteria when navigating away from and returning to the page, using URL Search Params.
- Develop media and account selection features with debounce typeahead search in the report setting creation/editing screen.
Technologies: Scala, Play Framework, Skinny-ORM, Akka Actor, Akka Quartz Scheduler, HTML, Bootstrap 5, Vue 3, Typescript, Bootstrap Studio, PostgreSQL, Amazon EC2