Vimeo OTT Promotions
As part of the Vimeo OTT team, I worked on implementing the ability to offer promotions to existing subscribers, which involved adding a React form to a legacy page and updating our backend logic to correctly discount renewal prices and expire promotions at the appropriate time.
I planned and designed this multi-phased project to migrate our legacy billing system into the Registrar app. Phase 1 included building out a payment options selection page and flow for the in-person student experience, which accounted for different pricing and payment options depending on the course and location. Phase 2 included migrating the online experience to the new flow without breaking existing functionality. The challenges here included delivering value incrementally to our students and internal stakeholders while paying down technical debt and shaping our billing code to fit the correct abstraction.
Salesforce, Stripe, Hubspot
Along with a team, I built out an internal tool to help serve our growing admissions and enrollments departments. Our projects focused on streamlining admissions and billing workflows at scale as Flatiron School launched new campuses around the world. For example, we built out support for deposit as well as tuition invoices, in either installments or lump sums.
GitHub Enterprise Migration
The Learn.co platform is deeply integrated with GitHub.com and initially required all users to have GitHub accounts in order to do work. Users were tightly coupled to their GitHub accounts, so much so that we identified users by their GitHub.com usernames. In order to remove friction from the sign-up process, we decided to create an alternate workflow where users could be linked to accounts on either or both GitHub.com and our own GitHub Enterprise server. Doing so enabled us to provision accounts for our users on sign up and create new repositories on the fly without worrying about rate limiting. This project involved rewriting our core app and associated services to be aware of both GitHub servers and enable users to switch between either platform to do work. Among the challenges were migrating user accounts from the Users table to a newly created Identities::GitHubAccounts table, and building out a Learn username generator to decouple users from their GitHub identities.
Jupyter Notebooks on Learn
Phoenix, Docker, Jupyter Notebooks, React
Learn-co Gem Suite, Internal broker service
As the Flatiron School planned on launching a data science curriculum, we began putting infrastructure in place to support serving Jupyter notebook lesson content in Learn. Leveraging the same backend as the Learn IDE in browser, we spun up containers running Jupyter notebook servers and served that notebook content through an iframe on a Learn lesson page. This project involved writing custom Dockerfiles to create compatible images for Jupyter notebooks, putting support for python lesson payloads into our Learn-co gem and our event broker service, and also figuring out how to securely serve content in an iframe over SSL.
Learn IDE in Browser Persistent Sandbox
Learn-co Gem Suite, GitHub
This project leveraged the IDE backend to persist work done in a sandbox repository. It uses most of the same tech as the regular old IDE for lessons with labs, except work follows students around through readmes as they navigate through the curriculum hierarchy on Learn.co.
Learn-co Gem Suite, GitHub
One of the problems we faced as our business grew was keeping track of one-off assignments for in-person immersive students. Although the core of Learn.co is a learning management system, it delivers a rigid hierarchy of curriculum to groups of students and does not allow for tasks to be assigned to individuals. The Assignments feature addresses that problem by providing a way to assign individual students things to do, from one-off confirmable tasks to code challenges. Working closely with a team of engineers and the educational staff, I served as the project lead on this feature and ensured that we were delivering the highest value feature sets as quickly as possible.
Learn In-browser IDE
React, Phoenix, Phoenix Sockets
For years, the engineering team has been serving the needs of students by finding ways to help them get their development environments set up as quickly and easily as possible. That journey began with an environmentalizer bash script, led to the Learn IDE Atom fork, the Learn IDE packages for Atom, and finally the Learn IDE in browser, which connects to a Phoenix backend over websockets and pipes input and output to and from a Docker container running on a remote server.
Enrollments: Pausing & Fixed Pricing
Online courses on Learn.co are billed using Stripe Subscriptions in a domain we call Enrollments. Along with our architect, I worked on migrating to a new subscription-based workflow where students can enroll for an online course with financing. This required a number of changes to the existing enrollment flow, including giving the student a 14-day window or trial period to obtain financing, creating admin-facing tools to change the student's status upon loan approval, and setting up new banners and emails to help students understand where they were in the enrollment process. In addition to that work, I paired with another developer to create a set of admin-facing tools that would enable enrollment pauses in the event that a student needed to take a leave of absence from the program.
Rails, Backbone, Marionette
In one of the first features I led as a developer, I implemented a new onboarding flow to coincide with the launch of a redesigned marketing website. This flow touched nearly all parts of our monolith application and allowed students to sign up for Learn.co and get dropped into a new intro course called Welcome to Learn. This onboarding flow enabled students to experience the magic of Learn and the Learn IDE without a GitHub account. After creating a password and connecting their GitHub account to Learn via modal prompts, students would be dropped into their program of interest.
Blogging & Magazine
Rails, Backbone, Marionette
Because blogging as a developer is a good way to solidify your knowledge and share knowledge with the community, we integrated blogging into the Learn.co platform using GitHub and GitHub pages. I assisted with the initial implementation of blogging in Learn, and then built out a publicly available magazine to showcase our students' posts.