People have been asking me a lot lately about my phone, my Android setup and how I manage to use my smartphone without Google Services. Well, this is a post that aims to address precisely that. I would like to make this article really beginner-friendly so I’ll try to go slow, going through things one by one and including screenshots so you can have a better view on how things happen and work like.

At first I’ll start with why Google Services are (imo) bad for your device. I could cut it short and guide you to this post by Richard Stallman, but I’m grabbing a few main points from it and adding them here.

  • Nonfree software required
    • In general, most Google services require running nonfree Javascript code. Nowadays, nothing whatsoever appears if Javascript is disabled, even making a Google account requires running nonfree software (Javascript sent by the site), same thing for logging in.
  • Surveillance
    • Google quietly combines its ad-tracking profiles with its browsing profiles and stores a huge amount of data on each user.
  • Terms of Service
    • Google cuts off accounts for users that resell Pixel phones. They lose access to all of their mail and documents stored in Google servers under that account.
  • Censorship
    • Amazon and Google have cut off domain-fronting, a feature used to enable people in tyrannical countries to reach communication systems that are banned there.
    • Google has agreed to perform special censorship of Youtube for the government of Pakistan, deleting views that the state opposes. This will help the illiberal Pakistani state suppress dissent.
    • Youtube’s “content ID” automatically deletes posted videos in a way copyright law does not require.

These are just a few reasons, but you can read the post by RMS I linked above in which he tries to explain these points in detail. Although it may look like a tinfoil hat reaction to you, all these actions already happen everyday in real life.

Next on the list, my setup and a tutorial on how I achieved it#

I own a Xiaomi Redmi Note 5 Pro smartphone (codename whyred), produced in China by Xiaomi, which I bought for around 185 EUR 4 months ago (from the time of writing this post).

Now you might be thinking, ‘but why did you buy a Chinese brand, they are not reliable’. Yes, it is not made from the usuals as you would expect, such as Samsung (which people often associate with Android, and is plain wrong), OnePlus, Nokia etc, but you should know almost every phone is produced in China.

There were a few reasons I chose this phone, first one of course being the price. It is a quite budget-friendly device, so most people are able to afford it. Next one would be the specs, which on paper (not only) are pretty decents for the price tag. With a 6 inch screen (Full HD resolution), a 4000 mAh battery (superb battery life), 4GB of RAM, 64GB of storage, dual back cameras (12MP + 5MP), a front camera with flash (13MP) and a decent efficient Snapdragon 636, it was probably the best choice at that moment.

The issue with it was that it came with MIUI, the Android skin that Xiaomi ships with most of its devices (except the Android One project devices). Yes, it is not that horrible, it has some extra features, but the problems lie deeper within. One of the reasons these devices from Xiaomi are so cheap (afaik they only have 5-10% win margin from sales) is that they include data mining and ads in the system altogether with MIUI. In this way, the system apps requires extra unnecessary permissions that mine your data and bombard you with ads, from which Xiaomi earns money.

Funnily enough, the Weather app included wanted access to my contacts and to make calls, why would it need that if it would just show the weather? Another case was with the Recorder app, it also required contacts and internet permissions, probably to send those recordings back to Xiaomi.

To fix this, I’d have to format the phone and get rid of MIUI. This has become increasingly difficult with the latest phones in the market.

The concept of formatting a phone is simple, you remove the existing system and install a new one of your preference (Android-only in this case). To do that, you have to have your bootloader unlocked.

A bootloader is a computer program that loads an operating system (OS) or runtime environment for the computer after completion of the self-tests. — Wikipedia

The problem here is that Xiaomi has a specific policy about the bootloader unlocking. A few months ago, the process was like this. You would have to make a request to Xiaomi to obtain an unlock code for your phone, by giving a valid reason, but this would not always work, as they could just refuse your request without reasons and explanation.

Now, that process has changed. You’ll have to download a specific software from Xiaomi, called Mi Unlock, install it in your Windows, Mac or Linux PC, activate Debugging Settings in Developer Options on your phone, reboot to the bootloader mode (by holding the Volume Down + Power button while the phone is off) and connect the phone to your computer to start a process called “Approval”. This process starts a timer on the Xiaomi servers that will allow you to unlock the phone only after a period of 15 days (or a month in some rare cases, totally random) goes by.

Mi Unlock app

After this period of 15 days has passed, you have to re-connect your phone and do the same procedure as above, then by pressing the Unlock button your bootloader will be unlocked and this will allow you to install other ROM-s (systems). Careful, make sure to backup your data because unlocking the bootloader deletes everything in the phone.

The next step would be finding a system (ROM) that works for your device. I searched through the XDA Developers Forum, which is a place where Android developers and users exchange ideas, apps etc. Fortunately, my phone is quite popular so it had its own forum category. There, I skimmed through some popular ROM-s for my device and decided to use the AOSiP ROM (AOSiP standing for Android Open Source illusion Project).


EDIT: Someone emailed me to say that my article is exactly what /e/ does and is targeted to. I wanted to say thank you for reaching out but that is not true at all. The reasoning behind my opinion about /e/ can also be found in this website, but I’ll list a few of the reasons here.

eelo is a “foundation” that got over 200K € in funding from Kickstarter and IndieGoGo, promising to create a mobile OS and web services that are open and secure and protect your privacy.

  1. Their OS is based on LineageOS 14.1 (Android 7.1) with microG and other open source apps with it, which already exists for a long time now and it’s called Lineage for microG.
  2. Instead of building all apps from the source code, they download the APKs from APKPure and put them in the ROM, without knowing if those APKs contain proprietary code/malware in them.
  3. At one point, they were literally just removing the Lineage copyright header from their code and adding theirs.
  4. They love to delete negative feedback and censor their users’ opinions in their Telegram group chat.

In conclusion, I don’t recommend using /e/ ROM-s (at least until now).


Another thing you would likely want to do is have root access to your phone, to make it truly yours and modify files in the system, such as use a system-wide adblocker etc. To do this, I decided to use Magisk, a godsend app developed by a student to help you gain root access on your device and install what are called modules, basically software.

After downloading the ROM and Magisk, I had to install them on my phone. To do that, I moved the files to my SD card on the phone. Now, to install the system, I had to use something called a recovery system. The one I use is called TWRP (standing for TeamWin Recovery Project), a popular solution.

To install the recovery system (sounds hard, I know), I had to flash the file on the phone. To do that, I connected my phone with the computer (Fedora Linux system) and with something called ADB Tools I issued a command that overwrites the system recovery with the custom one I had.

fastboot flash recovery twrp.img

After this was done, I turned off the phone and kept Volume Up + Power button pressed until I saw the TWRP screen show up. That meant I was good to go and it was ready to receive my commands.

TWRP screen

Next step was to issue a Wipe command, necessary when you first install a custom ROM on your phone. As you can see from the image above, the Wipe command clears the Data, Cache and Dalvik (there is also an advanced option that allows us to tick a box to delete the System one too, as we don’t need the old one anymore).

This takes a few moments and after that, your phone is basically clean. Now it’s time to install the system. By pressing the Install button on the main screen, we select the zip file we added there before (the ROM file) and swipe the screen to install it. Next, we have to install Magisk, which gives us root access to the device.


EDIT: As some more experienced/power Android users might have noticed until now, there is no GApps (Google Apps) included. This is what we call GApps-less in the Android world, not having those packages installed at all.

Note that one of the downsides of not having Google Services installed is that some of your apps might not work, for example their notifications might take longer to arrive or might not even work at all (this is what happens with Mattermost app for me). This happens because these apps use Google Cloud Messaging (now called Firebase) to wake the phone and push notifications to your phone.

You can solve this (partially) by installing and using microG which provides some features of Google Services but allows for more control on your side. I don’t recommend using this because it still helps Google Services and you don’t really give up on them, but it’s a good start if you want to quit Google slowly and not go cold turkey on it.


After successfully installing both, now we reboot the phone and tada 🎉, we are in the main screen.

Next part, installing the apps and configuring everything#

This is where things start to get easier. To install the apps, I use F-Droid, an alternative app store that includes only free and open source apps. If you need apps that are not available there, you can use Aurora Store, a client to download apps from the Play Store without using your Google account or getting tracked.

F-Droid has what are called repos, a “storehouse” that contains apps you can install. I use the default ones and have added another one from IzzyOnDroid, that contains some more apps not available from the default F-Droid repo and is updated more often.

My repos

Below you will find a list of the apps I have installed, what they replace and their use.

  • AdAway > AdBlocker for the system, blocks ads everywhere using hosts file
  • AfWall+ > A firewall that allows me to block unwanted connections
  • Amaze > Replaces the system file manager, allows for root access to files and also has zip/unzip capabilities
  • Ameixa > Icon pack that has many icons for your apps
  • andOTP > Replaces Google Authenticator/Authy, a TOTP app you can use to login on sites and accounts where you have 2FA enabled, allows backups and locking with PIN
  • AnySoftKeyboard/AOSP Keyboard > Open Source keyboard, it has many themes and language packs, I am also part of this project
  • Audio Recorder > Does what it says, allows you to record audio files in different formats from the microphone
  • Battery Charge Limit > Automatically stops charging the phone when it reaches 80% to lower battery wear and increase longevity
  • DAVx5 > This is one of my most-used apps, it basically replaces Google Contacts, Google Calendar and Google Tasks for me, it is connected to my Nextcloud instance and I have control over my data
  • Document Viewer > A viewer app that can open hundreds of file formats, fast and lightweight
  • Deezloader Remix (an app that allows me to download high quality MP3 files from Deezer)
  • Easy xkcd > An xkcd comics reader, I love these comics
  • Etar > Calendar app, replaces Google Calendar, works with DAVx5
  • FastHub-Libre > A GitHub client, entirely FOSS, useful if you use GitHub extensively like I do
  • Fennec F-Droid > Alternative to Google Chrome and others, a branded Firefox browser for F-Droid, without proprietary blobs/binaries that is updated and allows to install extensions to improve browsing experience
  • Gadgetbridge > Alternative to Mi Fit, application that is used to pair Xiaomi hardware with the phone and track your health, steps, sleep etc.
  • K-9 Mail > Email client, replaces GMail app, customizable and can add as many email accounts as you wish
  • Lawnchair > Launcher, can replace Nova Launcher or Pixel Launcher, allows customization and various changes, also supports icon packs and more
  • Mattermost > App that allows you to connect to a Mattermost server, Mattermost is an alternative to Slack
  • NewPipe > The best YouTube client IMO, replaces YouTube, it is entirely FOSS, gets rid of YouTube ads, lowers data usage, allows for background play, allows you to download video/audio etc. JUST TRY IT
  • Nextcloud SMS > Allows me to backup/sync my SMS to my Nextcloud instance
  • Nextcloud Notes > Allows me to create, edit, delete, share notes and sync/backup to my Nextcloud instance
  • OpenTasks > Allows me to create, edit, delete tasks and sync them up with my Nextcloud instance
  • OsmAnd~ > A map app, alternative to Google Maps, uses OpenStreetMap, allows for offline maps download and navigation
  • QKSMS > My favorite SMS app, replaces stock Messaging app, has a beautiful interface, allows backups, customization, has delayed sending feature etc.
  • Resplash/Mysplash > Allows you to download beautiful and endless wallpapers from Unsplash, all free to use and modify
  • ScreenCam > A screen recorder, allows various customizations and recording modes, no ads and free
  • SecScanQR > A QR scanner app, really fast and lightweight
  • Send Reduced Free > This app allows you to share big images instantly by reducing them and removing PII (personally identifiable information) before sending them to someone
  • Slide > Open source Reddit client
  • Telegram FOSS > A clean version of Telegram Android client without trackers and Google Services
  • TrebleShot > This ingenius app allows you to share files over a WiFi connection, in a really fast way, without even having internet access, to other devices
  • Tusky > Tusky is a client for the Mastodon platform (Mastodon replaces Twitter)
  • Unit Converter Ultimate > This app allows me to convert between 200 units in a snap, it works fully offline and it’s fast
  • Vinyl Music Player > My preferred music player app, replaces Google Play Music or whatever you have already installed on your phone, it has a beautiful interface and many features
  • VPN Hotspot > This app allows me to share my VPN while I have enabled my phone to be a hotspot, so I can browse securely even on my laptop without doing anything else

This is pretty much my list of the most useful F-Droid apps I use, but unfortunately these are NOT the only apps I use. The proprietary apps I use (I know, I might sound a hypocrite, but not everything is replaceable, not yet at least) are as below:

  • Google Camera (coupled with Camera API 2, needs basic microG from F-Droid to work)
  • MyVodafoneAL (the carrier app)
  • ProtonMail (email app)
  • Titanium Backup (to backup my app data, wifi passwords, calls log etc.)
  • WhatsApp (E2E proprietary messaging app, almost everyone I know has it)

This is pretty much it, all the apps I use on my phone. The configs are then pretty simple and straightforward and I can give a few tips.

  1. Read and check the permissions of apps carefully, don’t click ‘Install’ mindlessly.
  2. Try to use as many open source apps as possible, they both respect your privacy and are free (as in both free beer and freedom).
  3. Use a VPN as much as you can, find a reputable one and don’t use free ones, otherwise you get to be the product and you’ll get your data harvested.
  4. Don’t keep your WiFi/mobile data/location on all the time, it might be a security risk.
  5. Try not to rely on fingerprint unlock only, or better yet use only PIN/password/pattern unlock, as biometric data can be cloned and used against you, for example to unlock your phone and steal your data.

And as a bonus for reading far down here, a screenshot of my home screen right now.

Screenshot

All content is licensed under CC BY-NC-SA 4.0. (Attribution-NonCommercial-ShareAlike 4.0 International).