IT Engineering - Development

This handbook page provides information about software development in the IT Engineering sub-department.

Overview

The IT Engineering Development team develops custom software applications, automation, APIs and integrations that support internal IT automation for business efficiency and processes managed by the IT department.

Many of our projects focus on providing self service access request provisioning to our tech stack applications and supporting IT Infrastructure services, including the Demo Systems and Sandbox Cloud.

Direction

See our IT Engineering Development Direction handbook page to learn more.

Team

Name Role
Peter Kaldis Senior Manager, IT Engineering
Jeff Martin Senior IT Systems Engineer
Dillon Wheeler Senior IT Systems Engineer

Repositories

We strongly believe in open source software and publish many of our repositories as open source. Some projects that are built as internal tools are not open sourced due to perceived security hardening risks.

Source Code Repositories

Internal Projects

Open Source Projects

History

The IT Engineering Development team was formed in April 2021.

From late 2019 to mid 2021, Jeff Martin was a Senior Demo Systems Engineer in the Customer Success department and was focused on automating ephemeral infrastructure access requests and provisioning for demo, experiment, sandbox, and training use cases by creating small Laravel applications for the v1 iteration of each standalone point solution.

Project Name (Handbook Page) URL Purpose Current Investment Future State
Demo Systems - Demo Cloud https://gitlabdemo.cloud Provisioning user accounts on several always-on Omnibus instances used for demos and internal experiments. None Replace with Archie
Demo Systems - Training Cloud https://gitlabdemo.com Customer, marketing prospect, partner, and internal students redeem an invitation code to generate temporary credentials for performing training hands-on labs in different always-on Omnibus instances used for training classes. Limited Maintenance Rewrite for GitLab.com and Instruqt Integration
HackyStack / Sandbox Cloud https://gitlabsandbox.cloud Provisioning AWS accounts, GCP projects, IAM users and roles, and automated Terraform scaffolding for sandbox experiments. 24x5 Support, Next-Gen Architecture Discovery in Progress

Dillon Wheeler joined GitLab as an IT Systems Engineer in April 2021, and Jeff transferred over to IT in June 2021 and the Demo Systems and Sandbox Cloud projects became an IT Engineering managed service.

In late 2021 and early 2022, we started creating GitLab Access Manager (GLAM)(internal), however we found the scope was bigger than what we needed and the project was cancelled in favor of a vendor solution or smaller iteration.

As part of GitLab Access Manager development, we discovered the need for standardized vendor API response parsing. We created several SDKs for the vendors that IT works with day-to-day to allow us to uniformly interact with each vendor. These SDKs have been invaluable across multiple code repositories and have been contributed to the PHP open source community on Packagist.

Project Name Current Investment Future State
gitlab-sdk v3 Dev Maintained
google-auth-sdk Maintained Maintained
google-cloud-sdk v3 Dev v3.x Dev
google-workspace-sdk v3 Dev v3.x Dev
okta-sdk v3 Dev Maintained
slack-sdk v1 Dev v1.x Dev

As part of the GitLab Access Manager retrospective, we came up with our Automation Philosophy which allows us to focus on keeping it super simple and catering to the skillsets and time available on our team.

In 2021 and 2022, we were able to efficiently iterate by adding scripts to the IT Ops Laravel CLI Scripts repository which was originally a developer scratch pad and became a boring solution that was adopted for IT production purposes. We now run several scripts in scheduled CI/CD pipelines and most IT team members use the CLI scripts in their local Terminal. This has had valuable benefits during incident response with our ability to implement new automation functionality in 15-60 minutes without any headaches.

In 2023 (FY24), we are focused on moving from our v1 viable architecture to a v2 mature ecosystem as we reduce our IT process tech debt and move towards next-generation automation. We’re continuing to consolidate our isolated scripts and manual processes, and refactoring our legacy applications (ex. Demo Systems and HackyStack) using the backend API, CLI, CI/CD, and Slackbot approaches.

As we learn more through the current iterations, we’ll evaluate what approach makes sense for future iterations. It is unclear yet whether we will continue focusing on isolated point solutions, consolidate into a unified backend API, or take a hybrid approach with modular microservices.

See the IT Engineering Development Direction handbook page to learn more.


IT Engineering Development Direction
This handbook page provides information about the IT Engineering sub-department.