index.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. <!DOCTYPE HTML>
  2. <html lang="fr">
  3. <head>
  4. <title>C.V. Olivier Massot</title>
  5. <meta charset="utf-8" />
  6. <meta name="robots" content="noindex">
  7. <meta name="viewport" content="width=device-width, initial-scale=1" />
  8. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  9. <meta name="description" content="Curriculum Vitae">
  10. <meta name="author" content="Olivier Massot">
  11. <link rel="stylesheet" href="assets/css/bootstrap.min.css" />
  12. <link rel="stylesheet" href="assets/css/main.css" />
  13. <script src="assets/js/jquery.min.js"></script>
  14. <script src="assets/js/bootstrap.min.js"></script>
  15. <script src="assets/js/skel.min.js"></script>
  16. <script src="assets/js/util.js"></script>
  17. <script src="assets/js/main.js"></script>
  18. </head>
  19. <body>
  20. <a id="scrolltop" class="scroll" title="Retour"><i class="fa fa-arrow-circle-o-up"></i></a>
  21. <!-- Header -->
  22. <header id="header">
  23. <div class="inner">
  24. <a href="index.php" class="logo"><strong>C.V.</strong> Olivier Massot</a>
  25. <nav id="nav">
  26. <a class="scroll" href="#cursus">Formation / Compétences</a>
  27. <a class="scroll" href="#realisations">Réalisations</a>
  28. <a class="scroll" href="#contact">Contact</a>
  29. </nav>
  30. <a href="#navPanel" class="navPanelToggle"><span class="fa fa-bars"></span></a>
  31. </div>
  32. </header>
  33. <!-- Banner -->
  34. <section id="banner">
  35. <div class="inner">
  36. <header>
  37. <h1>Fullstack Developer</h1>
  38. </header>
  39. <p>8 ans d'expérience, Ingénieur territorial, Chef de projet en développement SI</p>
  40. <p><i class="fa fa-quote-left" aria-hidden="true"></i>
  41. Agile fullstack dev, I worked for the last 10 years on various subjects, from web to desktop applications, data-science, qgis plugins,
  42. CI / CD and unit-testing, deep-learning and NLP, network diagnosis and so on. I like to learn, to work with a team, and to be proud
  43. of a well-working solution that users and maintainers can enjoy.
  44. <i class="fa fa-quote-right" aria-hidden="true"></i>
  45. </p>
  46. <p>Retrouvez moi sur
  47. <a href='https://stackoverflow.com/story/olivier-massot' target='blank_' style='vertical-align: -10px;'>
  48. <img src="images/so-logo.svg" width='170px;' alt="Stackoverflow">
  49. </a>
  50. et sur
  51. <a href='https://www.codingame.com/profile/75dcc329745def530c02ddb4485f22235683081' target='blank_' style='vertical-align: -10px;'>
  52. <img src="images/CodinGame_Logo.svg" width='170px;' alt="CodeInGame">
  53. </a>
  54. </p>
  55. <br/>
  56. <a href="assets/CV_Olivier_Massot.pdf" class="button alt" target="_blank"><i class="fa fa-file-pdf-o"></i> Version PDF</a>
  57. </div>
  58. </section>
  59. <!-- Main -->
  60. <section id="main" class="wrapper align-left">
  61. <div class="inner container">
  62. <section id="cursus" class="row">
  63. <div id="competences" class="col-md-8">
  64. <header>
  65. <h2>Compétences</h2>
  66. </header>
  67. <table class="table-wrapper">
  68. <caption>Gestion</caption>
  69. <tbody>
  70. <tr>
  71. <th>Projet</th>
  72. <td>
  73. Méthode AGILE, Définition des besoins, Gantt, Uml
  74. </td>
  75. </tr>
  76. <tr>
  77. <th>Gestion</th>
  78. <td>Animation de réunions, Gestion du temps, Communication, Reporting</td>
  79. </tr>
  80. </tbody>
  81. </table>
  82. <table class="table-wrapper">
  83. <caption>Développement</caption>
  84. <tbody>
  85. <tr>
  86. <th>Serveurs et Systèmes d'Exploitation</th>
  87. <td>Ubuntu, Debian, CentOS, Windows, Windows Server</td>
  88. </tr>
  89. <tr>
  90. <th>Langages</th>
  91. <td>Python, C#/.Net, Html5/CSS/Javascript, SQL, Node.js, Shell, Php7</td>
  92. </tr>
  93. <tr>
  94. <th>Frameworks Web</th>
  95. <td>.Net MVC, Django, Flask, JQuery</td>
  96. </tr>
  97. <tr>
  98. <th>IDE</th>
  99. <td>Eclipse, Visual Studio, VsCode, Qt Creator</td>
  100. </tr>
  101. <tr>
  102. <th>Systèmes de Gestion de Bases de Données</th>
  103. <td>Postgres / Postgis, SQL Server, SQLite, Mysql, Oracle</td>
  104. </tr>
  105. <tr>
  106. <th>SCM et Repositories Managers</th>
  107. <td>Git, Github, Bitbucket, Gitlab</td>
  108. </tr>
  109. <tr>
  110. <th>Intégration continue (CI /CD)</th>
  111. <td>Gitlab CI /CD, Travis, Jenkins, unittest, mkdocs</td>
  112. </tr>
  113. <tr>
  114. <th>Divers</th>
  115. <td>Umbraco (CMS), NLP et chatbots, moteurs de recherche (SolR), Nextcloud</td>
  116. </tr>
  117. </tbody>
  118. </table>
  119. <table class="table-wrapper">
  120. <caption>Formation Initiale</caption>
  121. <tbody>
  122. <tr>
  123. <th>Sciences de l'ingénieur</th>
  124. <td>Gestion, Droit, Economie, Génie civil, Urbanisme et Travaux Publics, Développement durable, Aménagement</td>
  125. </tr>
  126. <tr>
  127. <th>Réseaux</th>
  128. <td>AEP, Assainissement, Hydraulique, Traitement des eaux</td>
  129. </tr>
  130. <tr>
  131. <th>Milieux naturels</th>
  132. <td>Hydrologie, Hydrogéologie, Gestion des déchets, Dépollution des sols, Biologie des milieux aquatiques</td>
  133. </tr>
  134. </tbody>
  135. </table>
  136. <table class="table-wrapper">
  137. <caption>Divers</caption>
  138. <tbody>
  139. <tr>
  140. <th>Véhicules</th>
  141. <td>Permis B</td>
  142. </tr>
  143. <tr>
  144. <th>Langues</th>
  145. <td>Anglais (bon), Espagnol et Allemand (bases)</td>
  146. </tr>
  147. <tr>
  148. <th>Centres d'intérêt</th>
  149. <td>Musique, Informatique, Histoire</td>
  150. </tr>
  151. </tbody>
  152. </table>
  153. <footer>
  154. <!-- <a href="#" class="button">Full Article</a> -->
  155. </footer>
  156. </div>
  157. <div id="timeline" class="col-md-4 table-wrapper">
  158. <header>
  159. <h2>Cursus</h2>
  160. </header>
  161. <table>
  162. <tbody>
  163. <tr>
  164. <th>2007-2008</th>
  165. <td>Classe préparatoire (Physique-Chimie)</td>
  166. </tr>
  167. <tr>
  168. <th class="important">2008-2011</th>
  169. <td>
  170. Ecole Nationale du Génie de l’Eau et de l’Environnement de Strasbourg (ENGEES)
  171. </td>
  172. </tr>
  173. <tr>
  174. <th>2010</th>
  175. <td>Mission de mise en place d’un plan de gestion des déchets,
  176. avec l’IRCOD Alsace (ONG), à Bafia (Cameroun)
  177. </td>
  178. </tr>
  179. <tr>
  180. <th>2011</th>
  181. <td>Validation d’une thèse sur la modélisation du comportement des micropolluants
  182. en zone humides artificielles,
  183. à l’Université de Strasbourg
  184. (Institut de mécanique des fluides)
  185. </td>
  186. </tr>
  187. <tr>
  188. <th>2012</th>
  189. <td>Concours d’admission dans la fonction publique. </td>
  190. </tr>
  191. <tr>
  192. <th class="important">2011-2016</th>
  193. <td>Chef de projet Systèmes d’informations appliqués à l’Environnement,
  194. au Conseil Départemental du Bas-Rhin (67)</td>
  195. </tr>
  196. <tr>
  197. <th class="important">2013</th>
  198. <td>Titularisation au grade d’ingénieur territorial.</td>
  199. </tr>
  200. <tr>
  201. <th>2013</th>
  202. <td>Formation: Management</td>
  203. </tr>
  204. <tr>
  205. <th>2014</th>
  206. <td>Formation: Communication et Reporting</td>
  207. </tr>
  208. <tr>
  209. <th>2015</th>
  210. <td>Formation: SQL</td>
  211. </tr>
  212. <tr>
  213. <th class="important">2016-2018</th>
  214. <td>Chef de projet Développement SI,
  215. au Conseil Départemental du Bas-Rhin (67)</td>
  216. </tr>
  217. <tr>
  218. <th>2016</th>
  219. <td>Formation: .Net MVC</td>
  220. </tr>
  221. <tr>
  222. <th>2017</th>
  223. <td>Formation: Umbraco</td>
  224. </tr>
  225. <tr>
  226. <th class="important">2018-2019</th>
  227. <td>Chef de projet Développement SI,
  228. à Manche Numérique (50)</td>
  229. </tr>
  230. </tbody>
  231. </table>
  232. <footer>
  233. </footer>
  234. </div>
  235. </section>
  236. <section id="realisations" class="row">
  237. <header>
  238. <h2>Exemples de réalisations</h2>
  239. <span class="btn-bar disabled">
  240. <a class="slider-btn btn-left icon fa fa-arrow-left"></a>
  241. <a class="slider-btn btn-right icon fa fa-arrow-right"></a>
  242. </span>
  243. </header>
  244. <div class="galerie-container">
  245. <div class="galerie">
  246. <div class="card">
  247. <div class="img-container"><img src="images/pimp.png" alt=""></div>
  248. <p><b>Marchés Publics</b><br/>Application Web de suivi des marchés publics, développée en .Net MVC + Moteur SolR</p>
  249. </div>
  250. <div class="card">
  251. <div class="img-container"><img src="images/pardit.png" alt=""></div>
  252. <p><b>DICT</b><br/>Génération automatisée de réponses aux DICT, développée en Python/Qt5</p>
  253. </div>
  254. <div class="card">
  255. <div class="img-container"><img src="images/backlog.png" alt=""></div>
  256. <p><b>Backlog</b><br/>Edition du backlog des projets et suivi de sprints (Python + Django)</p>
  257. </div>
  258. <div class="card">
  259. <div class="img-container"><img src="images/csig.png" alt=""></div>
  260. <p><b>Contrôles de Réseaux</b><br/>Génération automatisée de la cartographie des contrôles de réseaux d'assainissement (Plugin QGis, développé en Python)</p>
  261. </div>
  262. <div class="card">
  263. <div class="img-container"><img src="images/mncheck.png" alt=""></div>
  264. <p><b>MnCheck</b><br/>Plugin de contrôle et d'intégration des données des entreprises (Plugin QGis, développé en Python)</p>
  265. </div>
  266. <div class="card">
  267. <div class="img-container"><img src="images/doc.png" alt=""></div>
  268. <p><b>Déploiement continu</b><br/>Déploiement automatisé de documentations (Gitlab CI / CD)</p>
  269. </div>
  270. <div class="card">
  271. <div class="img-container"><img src="images/script_pde.png" alt=""></div>
  272. <p><b>Factures</b><br/>Script de génération des factures des contrôles de réseaux d'assainissement, écrit en Python</p>
  273. </div>
  274. <div class="card">
  275. <div class="img-container"><img src="images/mobiparc.png" alt=""></div>
  276. <p><b>Suivi d'Activités</b><br/>Application Web portable (PWA) de saisie du suivi d'activité sur chantiers</p>
  277. </div>
  278. <div class="card">
  279. <div class="img-container"><img src="images/librh.png" alt=""></div>
  280. <p><b>Documents RH</b><br/>Bibliothèques de documents pour la RH (Python + Qt5)</p>
  281. </div>
  282. </div>
  283. </div>
  284. </section>
  285. </div>
  286. </section>
  287. <div id="img-modal" class="modal">
  288. <span class="close">&times;</span>
  289. <img>
  290. <div class="caption"></div>
  291. </div>
  292. <!-- Footer -->
  293. <footer id="footer">
  294. <div class="inner">
  295. <section id="contact">
  296. <h3>Contact</h3>
  297. <form id="contactform" name="contactform" method="post" accept-charset="utf-8">
  298. <div class="field half first">
  299. <label for="email">Votre Adresse E-Mail</label>
  300. <input name="email" id="email" type="email" placeholder="Email">
  301. </div>
  302. <div class="field half">
  303. <label for="name">Nom, Collectivité, Organisme... (facultatif)</label>
  304. <input name="name" id="name" type="text" placeholder="Nom, Collectivité, Organisme...">
  305. </div>
  306. <div class="field">
  307. <label for="message">Message</label>
  308. <textarea name="message" id="message" rows="6" placeholder="Message"></textarea>
  309. </div>
  310. <input name="iehack" type="hidden" value="&#9760;" />
  311. <ul class="actions">
  312. <li><input value="ENVOYER" class="button alt" type="submit"></li>
  313. </ul>
  314. </form>
  315. <?php
  316. if(isset($_POST['email'])) {
  317. $email_to = "olivier.massot@ogene.fr";
  318. $email_subject = "Message de cv.ogene.fr";
  319. function died($error) {
  320. // your error code can go here
  321. echo "<p>Un problème est survenu lors de la validation des données:<br /><br />";
  322. echo $error."<br /><br />";
  323. die();
  324. }
  325. // validation expected data exists
  326. if(!isset($_POST['name']) ||
  327. !isset($_POST['email']) ||
  328. !isset($_POST['message'])) {
  329. died("<p>Des erreurs se sont produites lors de l'envoi de votre message, veuillez vérifier les données saisies</p>");
  330. }
  331. $name = $_POST['name']; // required
  332. $email_from = $_POST['email']; // required
  333. $message = $_POST['message']; // required
  334. $error_message = "";
  335. $email_exp = '/^[A-Za-z0-9._%-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}$/';
  336. if(!preg_match($email_exp,$email_from)) {
  337. $error_message .= 'Une adresse Email valide est nécessaire<br />';
  338. }
  339. if(strlen($message) < 2) {
  340. $error_message .= "Aucun message n'a été saisi<br />";
  341. }
  342. if(strlen($error_message) > 0) {
  343. died($error_message."</p>");
  344. }
  345. $email_message = "Envoyé depuis le CV en ligne:\n\n";
  346. function clean_string($string) {
  347. $bad = array("content-type","bcc:","to:","cc:","href");
  348. return str_replace($bad,"",$string);
  349. }
  350. $email_message .= "Nom: ".clean_string($name)."\n";
  351. $email_message .= "Email: ".clean_string($email_from)."\n";
  352. $email_message .= "Message: ".clean_string($message)."\n";
  353. // create email headers
  354. $headers = 'From: '.$email_from."\r\n".
  355. 'Reply-To: '.$email_from."\r\n" .
  356. 'X-Mailer: PHP/' . phpversion();
  357. @mail($email_to, $email_subject, $email_message, $headers);
  358. ?><p>Votre message a bien été envoyé</p><?php
  359. }
  360. ?>
  361. </section>
  362. <div class="copyright">
  363. &copy; Credits - Template: <a href="https://templated.co">templated.co</a>
  364. </div>
  365. </div>
  366. </footer>
  367. </body>
  368. </html>