-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprofessional-projects.html
20 lines (16 loc) · 12.3 KB
/
professional-projects.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<html><head><meta charset="UTF-8"/><meta name="viewport" content="initial-scale=1.0"/><meta name="description" content="Welcome to my personal website. Find here a quick presentation of my professional projects."/><title>Sylvain DOIGNON | Professional projects</title><link rel="stylesheet" href="./css/all.min.css"/><link rel="icon" href="favicon.ico"/></head><body><header><div id="me"><img src="https://avatars2.githubusercontent.com/u/4440388?v=3&s=150"/><h1>Sylvain DOIGNON</h1></div><div id="links"><a href="https://www.linkedin.com/in/sylvain-doignon" title="LinkedIn"><i class="fa fa-linkedin"></i>
LinkedIn</a><a href="https://github.com/sd65" title="Github"><i class="fa fa-github"></i>
Github</a><a href="https://github.com/sd65/CV/raw/master/CV_Sylvain-Doignon.pdf" title="My resume"><i class="fa fa-file-text"></i>
Resume</a></div><div id="about"><p>Technology enthusiast. Love to solve all kinds of problems.</p></div><ul id="nav"><a href="/" title="Personal projects"><li><i class="fa fa-home"></i>
Personal projects</li></a><a href="/professional-projects.html" title="Professional projects"><li class="active"><i class="fa fa-briefcase"></i>
Professional projects</li></a><a href="/about.html" title="About"><li><i class="fa fa-info"></i>
About</li></a><a href="/blog.html" title="Blog"><li><i class="fa fa-list"></i>
Blog</li></a></ul></header><div class="intro"><p>You can find here some of my best projects I took part in during some of my jobs. In many of cases, I can't disclose the project name or details. Nevertheless, skills & technologies are exposed here.</p><p class="warning">WARNING: this page is completly outdated. I may update it at some point.</p></div><div id="glossary"><p> There are currently
<span id="nbProjects">?</span>
projects presented here with the following tags (click to filter):
<span id="tags">empty</span></p><p id="tagsMatchingInfo">Viewing the
<span id="nbOfProjectsMatching"></span>
<span id="wordProject"> <span>project</span></span>
with the <span id="wordTag"> <span>tag</span></span>
:<span id="selectedTags"></span></p></div><section id="projects"><svg id="redLine"><line x1="0" y1="0" x2="0" y2="100%"></line></svg><svg id="redCircle"><circle cx="40" cy="40" r="40"></circle><text x="50%" y="58%">Now</text></svg><article class="project" id="virtualmachinesdeploymentautomation"><div class="info"><span class="date"><i class="fa fa-calendar"></i> May 2017</span><a href="#"><h2>Virtual machines deployment automation</h2></a><p class="company">For Société Générale Bank & Trust.</p><p>Writing in progress, request for disclosure pending.</p><span class="tag">Powershell</span><span class="tag">VMWare</span><span class="tag">Shell scripts</span><span class="tag">PXE</span><a href="#"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="#"><img src="img/in-progress.png"/></a></div></article><article class="project" id="centralizedloggingsystem"><div class="info"><span class="date"><i class="fa fa-calendar"></i> April 2017</span><a href="#"><h2>Centralized logging system</h2></a><p class="company">For Société Générale Bank & Trust.</p><p>Writing in progress, request for disclosure pending.</p><span class="tag">Syslog</span><span class="tag">ELK</span><span class="tag">Shell scripts</span><span class="tag">Grafana</span><span class="tag">InfluxDB</span><a href="#"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="#"><img src="img/in-progress.png"/></a></div></article><article class="project" id="automationwithawebappapi"><div class="info"><span class="date"><i class="fa fa-calendar"></i> June 2016 - April 2017</span><a href="#"><h2>Automation with a Web App & API</h2></a><p class="company">For Société Générale.</p><p>On June 2016, I was welcomed by a functional specification describing the automation of accounts, groups and access management. I was designed to take care of everything: infrastructure choice, technologies used, etc.</p><p>The goal was to create an API to allow CRUD operations on Unix accounts, groups and machine access/authorization. Furthermore, an Web app had to be developped to facilitate the use of the API. I took a week to choose the ideal architecture: I had many choices. At the end, I retained a solution that obviously evolved a bit, but not too much!</p><p>Let's explain the project from the client perspective: first, you are welcomed by a login page on the web app. The authentification system use the entreprise OAuth SSO and deliver a JWT token. Now, that you're authenticated you're free to use the web app that's basically a website with many forms. On each page, as you type in input fields, the content is validated on the fly by the browser and displayed next to the field. This prevents users from submitting errors. To avoid duplicating the form/field validation system on the client and on the server, the client send its "incomplete" data to the server that returns a status. Thanks to this, the Web app can be kept as small as possible. The Javascript code for the client was wrote from scratch because it is basic and using React or Angular.js was overkill in my opinion. Obvisouly, I had to write my own small JS library, which was instructive.</p><p>Next, the API. Written in Node.js, it's probably the biggest app/program I ever wrote. First, express is used to handle requests. After that, ES6 classes (the API is written with cutting-edge JS: async/await, arrows functions, etc) are used to handle the request. The majority of those creates an LDAP request started by the native library ldap.js. Then the LDAP requests are added to a message broker that prevents the DDoS of the AD server. A lot of actions are available so this app had to be well organized and written. Additionally, an Swagger endpoint was created for documentation. As the code quality was important, I integrated a JS linter in the project that helped me write it consistently. Furthermore, some errors can be revealed thanks to the linter.</p><p>Speaking of infrastructure and redundancy, let's explain it bottom-up. The Web app and the API are hosted in a Docker container. Thanks to a Docker Swarm cluster, multiple API instances are created and are load-balanced/managed by a local reverse-proxy Nginx instance. Finally, a fontal TCP load-balancer distribute the request over two physical site with the infrastructure described above.</p><p>This project was amazingly instructive. My Node.js skills skyrocketed. Moreover, I enjoyed the responsibility of tooking care of everything in this project thanks to the trust of my superiors: code, hardware choices, security, deployment, etc.</p><p>To my pleasure, since February 2017, this project is in production.</p><span class="tag">Node.js</span><span class="tag">JS</span><span class="tag">ESLint</span><span class="tag">Bootstrap</span><span class="tag">OAuth</span><span class="tag">JWT</span><span class="tag">Ldap</span><span class="tag">AD</span><span class="tag">Docker</span><span class="tag">Nginx</span><span class="tag">Load Balancer</span><span class="tag">Infrastructure</span><span class="tag">ELK</span><span class="tag">API</span><span class="tag">Swagger</span><a href="#"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="#"><img src="img/projectSG02.png"/></a></div></article><article class="project" id="vmasaservice"><div class="info"><span class="date"><i class="fa fa-calendar"></i> May 2016 - June 2016</span><a href="#"><h2>VM as a service</h2></a><p class="company">For Société Générale.</p><p>I love to tweak everything for my computer setup. Unfortunately, in a big company some tools are mandatory. For my workflow, I dislike working on Windows as no great window managers are available and no terminals are great.</p><p>My stubborness decided to fix the problem one day. If having Windows on your comporate laptop is mandatory, nothing stops you from booting a Linux VM on it. For my own usage, I decided to revive an old project where this was possible thanks to VirtualBox. The original code was a bit messy so I cleaned it up and organized the code in such way that it was modular.</p><p>Few days later, as I discussed about this with my coworkers, they seemed interested too! That's how I decided to automate the creation of this Linux VM and make it usable for a new user as fast as possible. Some days later, the only thing you had to do was to install VirtualBox and launch a Powershell script that took care of everything: download my prepacked OVA (with corporate settings), deploy it locally and post-install it with the settings entered by the user. Then, it worked out of the box at the first boot.</p><p>Months pass by and one day I got a call from the internal Docker Team. For some reason not described here, they needed to offer to many developpers an Docker environment ASAP. With the standard proccess, they would have waited for weeks before they get anything. They wondered if I could add an Docker environment in those VMs and were very pleased to discover 24 hours later that... it was done & ready.</p><p>Since then, I improved this solution a lot. For example, a main monitoring server is used to supervise all (numerous!) installations and take care of updates and other security concerns for the VMs.</p><p>I love this project, because what stated as a initiative became a well used application unexpectedly!</p><span class="tag">Docker</span><span class="tag">VirtualBox</span><span class="tag">Powershell</span><span class="tag">Shell scripts</span><span class="tag">PHP</span><span class="tag">SQlite</span><a href="#"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="#"><img src="img/projectSG01.png"/></a></div></article><article class="project" id="webportalshellscripts"><div class="info"><span class="date"><i class="fa fa-calendar"></i> June 2015 - February 2016</span><a href="#"><h2>Web portal & Shell Scripts</h2></a><p class="company">For Société Générale.</p><p>This project was for myself, the first time I worked in a team. </p><p>In fact, a team of two was set up some months earlier to build an API. They chose Python with the great Django REST Framework and began to create it. My role here was to develop a practical frontend to this API. In this way, I created a PHP website with some JS goodness with an authentification system, multiple roles, etc. Form submissions called shell scripts that called the API and performed other actions too.</p><p>This project was nice thanks to the team facet. I joined a team of two and after some months introduced a new coworker to this project. It was both rewarding and very instructive to work with such a thorough team.</p><span class="tag">PHP</span><span class="tag">Bootstrap</span><span class="tag">Shell scripts</span><span class="tag">JS</span><span class="tag">API</span><span class="tag">TCL</span><a href="#"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="#"><img src="img/projectSG00.png"/></a></div></article><article class="project" id="wysiwygwebsitebuilder"><div class="info"><span class="date"><i class="fa fa-calendar"></i> May 2014 - June 2014</span><a href="http://services-publics-33.girondenumerique.fr/default"><h2>WYSIWYG Website builder</h2></a><p class="company">For Gironde Numérique.</p><p>During this great internship, I learned the fundamental sysadmin tools that I mixed it with my Web experience.</p><p>My mission was to develop an centralized website manager for regional cities internal websites. Thanks to this Website builder, creating a custom website was only made through an easy drag'n drop experience. Batch updating the websites was also made simple with this tool.</p><p>Creating it by the side of an experienced sysadmin was enlightning and confirmed my interests in both back & front ends.</p><span class="tag">PHP</span><span class="tag">Bootstrap</span><span class="tag">Shell scripts</span><span class="tag">JS</span><a href="http://services-publics-33.girondenumerique.fr/default"><h3><i class="fa fa-link"></i> More details</h3></a></div><div class="visual"><a href="http://services-publics-33.girondenumerique.fr/default"><img src="img/projectGN.png"/></a></div></article></section><footer><a href="https://github.com/sd65/sd65.github.io"><i class="fa fa-code-fork"></i>
This website is homemade & open-source</a></footer><div class="scripts"><script src="js/all.min.js"></script></div></body></html>