Simple Twitter - Chapter 1: Setup

1639 words 9 min read minutes

This is the start of a series of posts to build Twitter like website. But why did I even want to do that? Because I saw a gap in software engineering blog universe about bring software to production level. Nobody explain what we need to do it and didn't do it with the reader, together, while keep it as simple and stupid as one can so even the most junior software engineer can understand why and how to get his next project to production.

So this is what I'm planning to do here. To get you from the basic to production. This will not be an easy journey, or even short one. But I can promise you one thing, you'll learn a lot!

Disclaimer: I'm not going to teach you web development, but I'm going to start from the very basic. So you need to know HTML, CSS and JavaScript up front. But that's pretty much it.

The first things we're going to do is the most basic, install the things we need to develop our website on our computer.

1. Git Setup

I think the most important software for development is git. We gonna use git for version control from day one, and we'll host our code on GitHub - because it's free for open source repositories and it's where everyone is at right now.

While I'm using Mac and I'll show how to install everything on a Mac, it should be pretty easy to install everything in this series on Linux and Windows too. Everyone of the tools we'll use is well known and should be plenty of resources and help on the internet.

1.1. Install git

I recommend to use a package manager to install everything on your machine, on mac it's brew. Once you have brew installed on your machine all you need to do to install git is:

brew install git

That's it, now if you'll write git on your command line of choice you'll get as an output all the git commands you can use.

git bash output

1.2. Open a GitHub account

GitHub is a web based git with some extra features. We don't need to install anything to use GitHub, just open an account and configure some stuff. So let's do it! Let's go to https://github.com and pick a username, email, and password and click on the big green button says Sign up for GitHub.

GitHub Sign Up Page

After you sign up you'll need to confirm your account, so check your email. Now we need to config our local git with our email and username. We can do it by typing those command:

git config --global user.name "Nir Galon"
git config --global user.email nir@galon.io

That's it for now. Once we'll have some code, we'll open a new repository, commit the code to GitHub and talk about issues and pull requests.

1.3. Atom

My code editor of choice is Atom. But you have plenty of choice and everyone love something else. Most of them are pretty much the same and we're not going to use any specific features to any code editor, so choose what ever you like.

To install Atom with brew we need to add cask, cask extends brew (Homebrew) and let us install macOS applications with brew. So let's add cask:

brew update
brew tap caskroom/cask

And now we can install Atom

brew cask install atom

2. Database Setup

Our Database of choice will be MongoDB. MongoDB is a NoSQL database which only means it's not a SQL one, but if it's not SQL what it is? It's a document-oriented database, it uses JSON-like documents with schema to store data. What it's actually means is that everything in our database is JSON valid and we use a key=value schema for it.

MongoDB has it's advantages and disadvantages, but for our use case it fits the bill. When you go to choose a database for a new project you need to choose the best database for the job in hand, and not force the database you love and know on the project. You may (even most likely) need to use couple of databases and everyone of them will do something else with the same or different data. But this is a topic for another post.

2.1. MongoDB

To install MongoDB we'll head over to the MongoDB documentation and go through the instructions. First we'll add their tap to brew, then we'll install the mongodb community edition, and finally start the database through brew services.

brew tap mongodb/brew
brew install mongodb-community
brew services start mongodb-community

Now we have MongoDB installed and running on our local machine. But how can we see and run stuff?

2.2. Robo 3T

Robo 3T is a free and open-source cross-platform MongoDB GUI. With it we can see our databases, collections and even documents in a nice and easy way with a GUI (Graphical User Interface). Let's continue to install things with the same convenient way, with brew. This is a GUI software so it will no be on brew, but we already have the cask extension for brew, so let's search it there: https://formulae.brew.sh.

Homebrew Cask Robo 3T Search

Success! so let's install it with brew cask

brew cask install robo-3t

3. Backend Setup

To build our backend we'll use Typescript. TypeScript is an open source programming language developed and maintained by Microsoft. It is a superset of JavaScript that adds a few things to the language and transcompiles to JavaScript. To write Javascript in the backend (not in the browser) we'll use Node.js runtime environment.

3.1. Node.js

I want to believe you already understand how useful is a package manager by now, but if you haven't let's use it again and install Node.js.

brew install node

3.2. NPM

When you installed Node.js something else was installed on your machine in the same time, it's NPM. NPM is a Package Manager for the JavaScript programming language and is the default package manager for the JavaScript runtime environment Node.js. We'll use it exclusively to download new packages for our Backend as well as for our Frontend project.

3.3 API Client

When we'll build our backend we'll want to make requests to it and tests our code from time to time (this is not to write tests, it's to test our code while developing). We can do it in multiple ways, but the easiest one is with an API client. It let you quickly and easily send REST requests against your API.

Insomnia is one of the most popular ones out there, it's free and has a lot more features, so let's install it

brew cask install insomnia

4. Frontend Setup

To build our Frontend we'll use Vue.js. Vue is a JavaScript framework for building user interfaces. Okay, this is a lot of words, we know what is a web application (a user interface and logic that runs in a web browser), but what is a framework?

A framework is an abstraction layer that may include support programs, compilers, code libraries, tool sets, and more. it's aim to facilitate software developments by allowing us to devote our time to meeting software requirements rather than dealing with the more standard low-level details of providing a working system.

4.1 The official Vue scaffolding tool

create-vue is the official Vue.js project scaffolding tool. It'll present to you some prompts for a number of optional features such as TypeScript and testing support, and will help us create a new project with everyting already configured.

it help us create a new project and components in the way. It saves us time and guide us in the "right" direction.

npm init vue@latest

example output:

✔ Project name: … <your-project-name>
✔ Add TypeScript? … No / Yes
✔ Add JSX Support? … No / Yes
✔ Add Vue Router for Single Page Application development? … No / Yes
✔ Add Pinia for state management? … No / Yes
✔ Add Vitest for Unit testing? … No / Yes
✔ Add Cypress for both Unit and End-to-End testing? … No / Yes
✔ Add ESLint for code quality? … No / Yes
✔ Add Prettier for code formatting? … No / Yes

Scaffolding project in ./<your-project-name>...
Done.

5. Cloud / Devops Setup

When it'll be time to upload our project to the cloud (it'll be sooner then you might think), we'll use couple of tools to connect to our cloud provider and setup our infrastructure. The first will be gcloud because we'll use GCP as our cloud provider (we'll talk about it more in the next chapter), the second will be Docker because we'll use Docker as part of our infrastructure to build isolated images and we'll run them on Cloud Run.

5.1 Google Cloud

To use GCP (Google Cloud Platform) from the command line we need to install gcloud which is the primary CLI tool to create and manage Google Cloud resources.

To install it, we just use brew cask command. This is a cli tool, so it probably should be just brew, but brew doesn't have a formulae for gcloud (don't ask me why, but I'm sure the internet has an answer for that somewhere), so lucky for us, cask has us cover.

brew cask install google-cloud-sdk

5.2 Docker

Docker is a set of platform as a service products that use OS-level virtualization to deliver software in packages called containers. This is a lot of buzz words, I know. But Docker is worth it. We'll use it to build and deploy our backend on top of GCP (Cloud Run service). And to interact with it we need it's CLI (do you see a pattern here yet?), and we can install it like any other CLI tool, with brew.

brew install --cask docker

6. Summary

To recap, we installed everything we need to start developing our web application / website. We have a GitHub account, a text editor, a database and a GUI to check what is going on inside it, our software for backend and client development (including a software to help us debug our backend API), and even the tools we need to deploy our software to the cloud.

In the next chapter we'll start planning our Twitter website and the architecture of it. I'm sure you are excited as me right now, and I hope to meet you on the comment section.


📖 You might also like

Change your email in GitHub

`${post.title} post hero image`

Once in a lifetime a man changes his email address. Maybe you didn't changed your email even once, I completely understand you, but I did. And let me tell you - it's not an easy process!

published on tutorials

A Practical Guide to Design System

`${post.title} post hero image`

It's no secret that design systems are taking over the web development world and that's a good thing IMO. But non the less, it's still a challenge to setup one. I myself encounter it when I created our own design system in the startup I work for, so

published on development