Compose + Youtube Data Api (2024/07/03)

Have you ever want to hook your Android App with Youtube API and try to make something cool? I do, and Google’s document kind of sucks, so I am making my own version for people that stumble in the process. Come along!

TL;DR, Source code: YoutubeDataApiDemo

I have simplify the project so the target is to choose a account, login, and get 50 of its’ liked videos.

Table of content:

Android Project and library setup

Let start by creating a Empty Android Project, open up your gradle.kts in app and add the following to dependencies

    // For viewmodel (You can use hilt)
    implementation("androidx.lifecycle:lifecycle-viewmodel-compose:2.8.3")
    // Permission
    implementation("com.google.accompanist:accompanist-permissions:0.34.0")
    // Google play service
    implementation ("com.google.android.gms:play-services-auth:21.2.0")
    implementation("com.google.api-client:google-api-client-android:2.0.0") {
        exclude("org.apache.httpcomponents")
    }
    implementation("com.google.apis:google-api-services-youtube:v3-rev20240514-2.0.0") {
        exclude("org.apache.httpcomponents")
    }

after add it, if you are using version catalog, “alt + enter” on each of these implementation to replace it with version catalog declaration, and click sync on the top right.

Next we open AndroidManifest.xml and add the three permission we need above <application> :

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />

<application
    ...

Now we will need the package name and SHA1 for our next step. For package name we can find in build.gradle.kts in app, applicationId is what we are looking for.

The SHA1 can be found by clicking the sidebar “Gradle” > open “Tasks” folder > open “android” folder > double click “signingReport”

After double click “signingReport”, when finish building, you should be able to see the SHA1 here

Copy both package name and SHA1 for later usage, now we are set for the next step.

Google Cloud Project setup

Head to Google Cloud and create a project. Then perform the following

A walk through to setup Google Cloud Platform

Now we can start coding.

App coding

I don’t want to make this project to complex, so I will only use a YoutubeScreen.kt for display UI, a LoginViewModel to process login.

We need to know the flow of OAuth login. Here is what we will do.

  1. Check if google service available.
  2. Check if we have GET_ACCOUNTS permission, if not, ask for it.
  3. Prompt user to select an account.
  4. Try to get credential, if we need consent from user, show it.
  5. Get the credential token, use Youtube Data Api to get User’s liked video

We do first step in MainActivity, others in YoutubeScreen and YoutubeViewModel.

Sound easy, right?

Well, you can try for yourself, but I already done it twice, first time for my App, second time for this post. So let me introduce you our error friends.

Go to This Github project and look for how I set it up.

My Error journey

2 files found with path ‘META-INF/INDEX.LIST’.

In build.gradle.kts(:app), find packaging and edit like following

packaging {
        resources {
            excludes += "/META-INF/{AL2.0,LGPL2.1}"
            excludes += "/META-INF/INDEX.LIST"
        }
    }

Duplicate class com.google.common.util.concurrent.ListenableFuture found in modules guava-jdk5-17.0.jar

Update your gradle dependecies like following:

    // For viewmodel (You can use hilt)
    implementation("androidx.lifecycle:lifecycle-viewmodel-compose:2.8.3")
    // Permission
    implementation("com.google.accompanist:accompanist-permissions:0.34.0")
    // Google play service
    implementation ("com.google.android.gms:play-services-auth:21.2.0")
    implementation("com.google.api-client:google-api-client-android:2.0.0") {
        exclude("org.apache.httpcomponents")
    }
    implementation("com.google.apis:google-api-services-youtube:v3-rev20240514-2.0.0") {
        exclude("org.apache.httpcomponents")
    }

Permission prompt for contacts not showed

Make sure you add this is AndroidManifest.xml

<uses-permission android:name="android.permission.GET_ACCOUNTS" />

Access Blocked: XXX has not completed the Google verification process

Add this email to Test users in your Google Cloud project.

com.google.android.gms.auth.GoogleAuthException: UNREGISTERED_ON_API_CONSOLE

Check your Google Cloud, maybe your package name and SHA1 is wrong. Or check your test user.

Resources

Google’s Youtube Android Guide

API reference so you can test the api online

Conclusion

Although Youtube Data Api is a free api, the limitation quota seems to be too low even for a small project to work on it. You can see for yourself here.

As for playing Youtube video, I tried

android-youtube-player: Very detailed documents and functions, but work better with old Android Views.

YouTubePlayer: A compose based library, easy to use and suit compose very well.

As for me, this is a fun experience, I worked with Youtube api and still trying to figure out what I can do with it, hope this post provide some aid to my fellow tryharders! I will see you next time.

Author: Dean

A dude that is enjoy/suffering at the same time. An Otaku and an engineer, coffee and sweet lover. Also can write Android and other code.