- Senior Java DeveloperAustralia Post2015 - 2016
Technologies: Java8, Spring, Apache Camel, AngularJS, AWS, Docker
- Designed a public facing REST API using Spring and Apache Camel.
- Designed and implemented CI pipeline using Docker Swarm.
- Integrating legacy internal systems with API using Apache Camel.
- Worked with Java 8, Spring, and JPA-Hibernate.
- Senior Java DeveloperMessageMedia2014 - 2015
Technologies: Java, Amazon Web Services (AWS), Docker
- Integrated Spring Cache and Ehcache with the application to add an extra in-memory cache layer between the application and Redis.
- Developed a distributed system using RabbitMQ as messaging backbone.
- Designed a balanced publisher to Amazon SQS.
- Developed a message transmitter component based on SMPP communication protocol and integrated with various providers such as Telstra and Optus.
- Designed and implemented an efficient message consumer (semi-lock free to be called by multiple threads).
- Senior Java DeveloperGenapsys2014 - 2014
Technologies: Java, Spring, Storm, Git, Jenkins
- Designed and implemented CI pipeline of the company using Docker and Jenkins.
- Set up Network File System and configured embedded linux to copy files to NFS in an optimised way.
- Refactored application to use Spring.
- Added New Relic to publish measurements.
- Setup a data processing pipeline using Twitter Storm and integrated it with Matlab.
- Senior Java DeveloperSAMAT (financial banking)2012 - 2013
Technologies: Java, Spring, Hibernate, REST, AngularJS, Netty, ElasticSearch
- Architected an innovative in-memory electronic fund transfer switch capable of processing 1800 transactions per second with the following characteristics: failover clustering, horizontal scalability, low latency, and high throughput.
- Designed and implemented the full stack of a web-based monitoring application using JPA2/Hibernate, Spring, Spring Security, and RESTEasy.
- Designed an advanced CI pipeline to build, test, and deploy an application on VMware ESX using Puppet.
- Developed effective unit, integration, and functional tests using JUnit, Mockito, and Cucumber.
- Integrated an ElasticSearch server with the application to index incoming transactions data at run time.
- Set up a HAProxy to load balance EFTPOS TCP connections between distributed computing nodes.
- Senior Java DeveloperJavaneh2012 - 2012
Technologies: Java, Spring, Vaadin, Activiti BPM, JPA/HIbernate
- Worked in a deadline driven environment with an Agile team to develop a CRM solution based on the Activiti business process engine.
- Designed an effective model-driven architecture which helped reduce development costs by generating UI components from the data model at run time.
- Designed an application stack using Spring Core, Spring AOP, Vaadin, and JPA2/Hibernate, as well as configured a data access layer to communicate with the Oracle 11g database.
- Helped the analysis team to model their business processes based on BPMN 2.
- Set up a CI pipeline using TeamCity and Nexus to run the project's unit tests, build artifacts, and finally deploy on testing servers for testing by the QA team.
- Senior Java DeveloperKhobreh Pardaz2011 - 2012
Technologies: Java, Spring, Hibernate, JSP, jQuery, Tomcat, MS SQL 2008
- Implemented robust tamper-proof RESTful web services for a high traffic social web site using Spring MVC, Spring Security, JPA/Hibernate, and Jackson.
- Provided management with a list of social features to engage users more extensively.
- Worked closely with the UI team to fix communication issues between the jQuery AJAX-based client and Java back-end server.
- Developed optimized algorithms to calculate customers' scores based on various loyalty programs.
- Fixed several applications' memory and performance issues by profiling with JProfiler.
- Profiled and optimized SQL queries using the Query Analyzer of MS SQL Server 2008.
- Set up and configured Jenkins to build and run unit (JUnit) and functional (Selenium) tests.
- Set up and integrated a JasperReports Server with MS SQL Server and developed customized reports using a JasperReports Library.
- Java DeveloperTwenies2008 - 2011
Technologies: Java, Google App Engine, AWS, jQuery
- Worked in a distributed Agile team to develop a social web application capable of handling a high number of user requests.
- Provided management with a list of cloud opportunities in order to address scalability and performance issues.
- Migrated a part of the internally hosted application to Amazon EC2 and integrated it with Amazon S3 to store user assets.
- Moved the main part of the application to Google App Engine, and refactored DAOs to be compatible with GAE.
- Modified and recompiled the source code of Spring Security to be compatible with a GAE environment.
- Migrated the project’s build scripts from Ant to Maven.
- .NET DeveloperFarineh2007 - 2008
- Designed and implemented an interactive task scheduling panel in C# to be used in the reporting panel of a SCADA system.
- Designed an optimized task scheduling algorithm considering dependencies and other constraints to reschedule tasks on new changes.