Dmitry Borody

Dmitry Borody

Moscow, Russia
Hire Dmitry
Scroll To View More
Dmitry Borody

Dmitry Borody

Moscow, Russia
Member since February 24, 2017
Dmitry is a versatile full-stack developer with solid skills in the modern web (React, Angular 2+), Python, and Linux as well as having a good algorithmic mind. He enjoys developing the front and back-end as well as dealing with databases, deployments, and automatization. While working on a project, he communicates clearly and always strives for a deep understanding of his client's needs to address their problems most efficiently.
Dmitry is now available for hire
Portfolio
Experience
  • JavaScript, 6 years
  • Python, 5 years
  • C++, 4 years
  • Node.js, 3 years
  • React.js, 2 years
Moscow, Russia
Availability
Part-time
Preferred Environment
Linux/OS X, Git,VS Code, Vim, WebStorm
The most amazing...
...thing I've made is a web platform for an HFT trading algorithms contest with a cluster infrastructure for a performance simulation using real historical data.
Employment
  • Full-Stack Web Developer
    Audantic (via Toptal)
    2017 - PRESENT
    • Implemented a reusable production-quality skeleton for building Flask APIs including authentication with API keys, filtering, pagination, validation, Swagger docs, and more.
    • Implemented a heat map visualization of property prices with Google Maps.
    • Designed and implemented a product page with embedded Looker data dashboards.
    • Measured and optimized the performance of certain API calls—optimizing the database query performance.
    • Consulted with my client regarding the technology choices for the web and API.
    Technologies: SPAs, React, Python, Flask, MySQL
  • Student Mentor (HTML, CSS, JavaScript)
    HTML Academy (Online Front-End Courses)
    2017 - PRESENT
    • Took part in one of the best online education projects on front-end technologies in Russian.
    • Mentored more than ten students: reviewing code, conducting Q&A Skype calls, giving advice on how to write better JavaScript, HTML5, and CSS3 code, and following best practices such as BEM or progressive enhancement.
    Technologies: HTML5, CSS3, JavaScript, ES6, Webpack, Less, BEM, Progressive Enhancement
  • Full-Stack Web Developer
    Reporter Suite (via Toptal)
    2017 - 2017
    • Conducted a complete rewrite of a legacy AngularJS app to modern React stack resulting in a much more fast, robust, user-friendly and maintainable web app.
    • Set up the infrastructure, deployment processed, and monitoring for the updated application on AWS cloud platform; integrated user analytics and client-side error tracking.
    • Migrated old users and data to the new app, ensuring a smooth transition for the existing customers.
    • Implemented many new features while working closely with the project owner, such as Stripe payments processing, a notifications functionality, invoice PDF generation, data export, admin UI, and many others.
    Technologies: ES6, React, Redux, Webpack, Node.js, AWS, Stripe, Docker, Ansible
  • Full-Stack Web Developer
    Baleen Labs (via Toptal)
    2017 - 2017
    • Developed a proof-of-concept SPA: visual block editor for code and business logic, akin to Microsoft micro:bit.
    • Adapted a drag-n-drop library Dragula to play well with React.
    • Implemented a markup after being provided Sketch designs for Baleen.io (a promo page for the company and their product).
    • Developed another demo SPA that heavily used Google Maps API.
    • Adapted an existing API for this second demo to be more RESTful-like, and integrated this API with the front-end.
    • Took care of the dockerization and deployment of the developed apps to EC2 and documented the process of the deployment.
    Technologies: React, Redux, Vue.js, ES6, Webpack, Python, Flask, AWS, EC2, Docker
  • Full-Stack Web Developer
    Smarkets
    2016 - 2017
    • Optimized the app load time and client-side performance using such techniques like above-the-fold rendering, code splitting, caching of server-side rendered React components, and more.
    • Consolidated localization messages between the web and mobile app—implemented tooling for intracompany collaborative crowd-sourced localization.
    • Worked closely with UX designers to optimize the web-app for desktop experience—implemented responsive desktop layout, improved keyboard navigation, and more.
    • Implemented and integrated with our Jenkins CI end-to-end Selenium tests running on the BrowserStack cloud platform on different browsers and different types of OS.
    • Created tools for stress-testing and performance reports (max requests per second, CPU/memory utilization, and more) of the server-side rendering server.
    • Participated in technical interviews for candidates for the generalist software engineer position.
    • Ported a number of critical features from the older monolithic website.
    Technologies: React, Redux, GraphQL, React Native, ES6, Webpack, Node.js, Express, Python, Flask, AWS, Docker, Linux
  • Software Engineer
    AIM Tech Algotrading
    2015 - 2016
    • Developed a scalable cluster system for easier scheduling of simulations of trading strategies on historical data to boost the productivity of our quantitative analysts.
    • Designed and implemented the web front-end for this system so that that the quantitative analysts can launch their simulations, compare the performance of different approaches, visualize the results, and export data for further analysis.
    • Adapted the same back-end and developed a new front-end for a student contest of HFT (high-frequency trading) strategies. This lasted two months and attracted ~1,000 participants, mainly Russian math/computer science students which allowed the company to created simulations of its pool of quantitative analyst candidates.
    • Set up the infrastructure for the logging and monitoring of the system using open source technologies such as Prometheus, Grafana, and Graylog for the better visibility, user analytics, performance monitoring, and debugging ease.
    • Implemented a number of high-performant data parsers for different trading data formats (FIX, FAST, and more).
    • Participated in the technical interviews involving our team by designing interview questions and test projects for the candidates.
    Technologies: ES6, React, Webpack, Python, Flask, Django, Redis, RabbitMQ, Postgres, MongoDB, AWS, Ansible, Docker, Graylog, Prometheus
  • R&D Software Simulation Intern
    Intel
    2013 - 2014
    • Developed a performance simulator for a new, experimental computer architecture in a small team of researchers.
    • Investigated the impact of several architectural features on the performance of the modeled architecture, implemented these features in the simulator, and presented the report at the end of the internship.
    • Learned a great deal about low-level programming, compilers, computer architecture, and code optimizations.
    Technologies: Linux, C, C++, CMake, Makefile, Bash
  • Freelance Software Enginneer
    Freelance Work
    2012 - 2014
    • Developed a cross-platform desktop application for testing and developing electronic devices working with ARINC429 protocol (a protocol used in avionics). I worked on it together with another engineer, doing both low-level and UI programming as well as handling the communication with the client and presenting the product. Technology stack: C, C++, Qt4, serial ports.
    • Prototyped various algorithms for discrete optimization (route-planning, TSP) and classification problems. Technology stack: Python, Cython, Numpy, SciPy.
    • Supported and improved five different web apps for small-to-medium enterprises.
    • Refactored legacy code, reduced technical debt and added new features; all the while working in a small distributed team. Technology stack: Java EE, GWT, PHP, JavaScript, MySQL, WordPress, and phpBB.
    Technologies: Python, Cython, NumPy, SciPy, C, C++, Qt4, JavaScript, PHP, MySQL, Apache, Java EE, GWT, Tomcat
Experience
  • Reporter Suite App (via Toptal) | SPA and Back-End (Development)
    https://www.reportersuite.com/

    About the Reporter Suite app:
    This is the app of choice for US court reporters and it greatly simplifies their day-to-day routines.

    Some Features:
    • Invoice management system with built-in payment. processing time, expenses, case log tracking, and more
    • Generating official reports based on the tracked data.
    • Public shareable profile pages for court reporters with contact and order forms.
    • Social features.

    My Role:
    My client asked me to do a complete rewrite of the AngularJS legacy app running on the Stamplay platform to something more modern, maintainable, and scalable and also to expand the app functionality based on the feedback from users of the old version.

    Work Highlights:
    • Set up the AWS infrastructure, the staging environment, monitoring, user analytics dashboards and error tracking; conducted load-testing.
    • Added Stripe payments processing.
    • Enabled authentication with Google accounts
    • Added new user roles and user interactions: e.g. users receive notifications of incoming invoices that other users create for them, etc.
    • Added an admin UI to simplify app maintenance.

    Technologies: AWS, Docker, React, Redux, PostgreSQL, Node.js, Hapi, Sequelize, Metabase, TrackJS, Stripe, Redis

  • Smarkets Web App (Development)
    https://next.smarkets.com

    The new mobile-first real-time web app for Smarkets, a London-based prediction market (aka betting) exchange.
    Being a part of a very tight team with daily standup meetings and frequent cross-team communication, there was a lot of responsibility on my shoulders and I contributed a great deal to the app's functionality and performance.

    The project itself is meant to replace the older monolithic legacy website. It now has a much more maintainable code base (some parts of which are shared with our React Native mobile app), a top-notch technology stack, and is built upon the best practices for modern high-performant mobile sites.

  • HFT Battle | Trading Strategies Contest Platform (Development)

    This project is an online contest platform for high-frequency trading strategies, simulated on real historical data. The idea is to popularize (especially among students) the traditionally secretive field of HFT (high-frequency trading) to spot and attract talent to join the company's quantitative analyst pool.

    Participants can implement their trading strategies in either C++ or Python, and then run it either locally with a provided SDK (for debugging) or use the web-interface to schedule their simulations to be run on a cluster infrastructure. After the simulation is finished, they can see charts visualizing the trading behavior of their algorithms, test and compare different approaches, and export the data for further analysis.

    I started working on this project on my own (including the initial prototype and the refined microservice architecture), and after several months, two people joined in and we've been working together on it since then. I designed the back-end architecture (a pool of simulation nodes, microservices, a storage layer, and message queues between them), developed the API and the web-interface for participants (Django/Flask, JavaScript), and took care of the infrastructure, CI, and automation.

  • Visual Code Block Editor (via Toptal) (Development)

    A demo SPA (front-end only) which is a drag-n-drop visual editor for back-end logic, similar to micro:bit from Microsoft. Users could use visual blocks, rearrange (with possible nesting), and configure them so that they express required business logic.

    I've implemented only the front-end part of the project with the back-end being mocked for the demo purposes.

    Technology Stack: React, Redux, Vanilla JavaScript, ES6, Webpack, AWS, and Docker.

  • Decision Trees Machine Learning Library (Development)
    https://github.com/dmitru/pines

    A library that implements CART decision trees as well as lesser-known Oblivious Decision Trees for classification and regression problems; it's fully compatible with the popular ML package Scikit-learn.

    This project is the result of my interest in machine learning—implementing decision trees from scratch allowed me to deeply understand the concept.

  • Time Tracker - Full-stack Toptal Test Project (SPA and API) (Development)
    https://toptal-test-time-tracker.herokuapp.com/

    A two-week test project done as a part of the Toptal onboarding process.

    This is a multi-user time tracker SPA. I've implemented both the front- and back-end following the project requirements and working on it during the evenings and the weekends.

    Test credentials:
    login: user@test.com
    password: password

    Technologies: React, Redux, MongoDB, Sequelize, Heroku.

  • Personal Expenses Tracker (Web SPA, API and Chatbot) (Development)

    A web app and a chat bot for tracking income/expenses, suitable for personal use or for collaboration in small groups (e.g. families, or a joint holiday trip with friends). It creates the visualization of your spending habits and allows the importation and exportation of data for further analysis.

    Technology Stack: Node.js, LoopBack.io, ES6, Webpack, React, Redux, HTML5, Sass, Python 3, PyMongo, MongoDB, AWS, Docker, Linux, Bash Scripts.

  • Blog Post: Theming Apps in Sass (Other amazing things)
    https://medium.com/@dmitriy.borodiy/easy-color-theming-with-scss-bc38fd5734d1

    A post explaining the approach that I took while working for Smarkets in supporting the different color themes in their web application.

Skills
  • Languages
    Python, CSS3, JavaScript, EcmaScript 2015 (ES6), HTML5, TypeScript 2, C, GraphQL, SQL, CoffeeScript, Sass, Bash, C++, Java, R, Processing, C#, Google Apps Script, Lisp, PHP, Scheme
  • Frameworks
    Next.js, Django, Jest, Mocha, Redux, Express.js, Flask, Twisted, StrongLoop, Angular 2+, Angular 4, Bootstrap, Hapi.js, Loopback, Qt, Selenium, Boost C++, React Native, JUnit
  • Libraries/APIs
    React.js, Immutable.js, Node.js, Stripe API, NumPy, jQuery, Pthreads, Web Audio API, Sockets, D3.js, Pandas, Highcharts JS, OpenMP, Telegram Messenger API, Scikit-learn, VK API, Firebase Web SDK, Three.js, RxJS, MailChimp API, Vue.js
  • Paradigms
    REST, Unit Testing, Test-driven Development (TDD), Reactive Programming, Stress Testing, Parallel programming, Asynchronous Programming, Web Application Architecture, Responsive Layout, Responsive, BEM, Continuous Integration (CI), Rapid Prototyping, Prototype-based OOP, Object-oriented Design (OOD), Functional Programming, Continuous Delivery (CD), Compiler Design
  • Misc
    SPA, Responsive UI, Source Code Reviews, Bash Scripting, Web Performance, Debugging, Server-side Rendering, ESLint, Data Structures, Algorithms, Computer Networking, Client-server Model, Microservices Architecture, Code Splitting, Apollo, Semantic UI, Rendering Performance, Gulp, Prometheus, Crontab, MPI Programming, Chatbots, Celery, SVG, JWT, OAuth2, Web App Security, GitFlow, Distributed Systems, Data Analysis, Scraping, Data Visualization
  • Tools
    Tmux, Graphviz, Ansible, Adobe Lightroom, RabbitMQ, LaTeX, Sequelize, Mongoose, Jupyter, Slack, Nginx, Bitbucket, SVN, Webpack 2, Git, Jenkins, Makefile(s), Graylog, NPM, GitHub, Apache, Asana, Pivotal Tracker, JIRA, GitLab, Grunt, Stash, Gimp, GDB, Flex/Bison, Vim Text Editor, Karma, CMake, Valgrind, Grafana, Adobe Photoshop, Travis CI, Vagrant, NewRelic, BrowserStack, Docker Compose
  • Platforms
    Firebase, Ngrx, OS X, AWS EC2, Docker, Linux, Amazon Web Services (AWS), Windows, CUDA, Arduino, Heroku, OpenCart
  • Storage
    PostgreSQL, Redis, Relational Databases, MongoDB, MySQL, Memcached, Oracle PL/SQL, Oracle SQL, Microsoft SQL Server
Education
  • Bachelor's degree in Computer Science & Applied Mathematics
    Moscow Institute of Physics and Technology - Moscow, Russia
    2011 - 2015
I really like this profile
Share it with others