Error: Could not find org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.60-eap-25 in Ionic 3

AndroidCordovaIonic FrameworkIonic3build.gradle

Android Problem Overview


I am getting the following error suddenly while building Ionic 3 app for Android.

Could not find org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.60-eap-25

We have one solution from Android Studio here but after I did change in my build.gradle with the following code I am still getting the error.

buildscript {
    repositories {
        ...
        maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
    }
}

allprojects {
    repositories {
        ...
        maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
    }
}

My build.gradle file looks like this after I updated my Cordova and added the above solution.

buildscript {
    repositories {
        google()
        jcenter()
        maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
    }

    dependencies {
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files

        classpath 'com.android.tools.build:gradle:3.3.0'
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
    }

    //This replaces project.properties w.r.t. build settings
    project.ext {
      defaultBuildToolsVersion="28.0.3" //String
      defaultMinSdkVersion=19 //Integer - Minimum requirement is Android 4.4
      defaultTargetSdkVersion=28 //Integer - We ALWAYS target the latest by default
      defaultCompileSdkVersion=28 //Integer - We ALWAYS compile with the latest by default
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

Still the same error.

Android Solutions


Solution 1 - Android

The problem lies in the cordova-support-google-services plugin for Cordova.

This plugin's build.gradle looks like this as of today (October 24th, 2019):

dependencies {
	classpath 'com.android.tools.build:gradle:+'
	classpath 'com.google.gms:google-services:4.2.0'
}

More exactly the problem lies in this dependency:

classpath 'com.android.tools.build:gradle:+'

That is an extremely brittle way of specifying dependencies. The '+' sign here means "fetch the most recent version available in the repo". If a newer version is published in the repo, and it breaks the build, then everyone with this plugin has their projects broken. This happened today. The broken version that is being fetched is com.android.tools.build:gradle:4.0.0. It requires some Kotlin stuff.

That is why you need to ALWAYS freeze dependencies to reliably build your project. Never trust the newer stuff. This dependency compiles fine just as it did yesterday:

classpath 'com.android.tools.build:gradle:3.5.1'

For those using Cordova or Ionic, you can make a quick fix to be able to build the project by freezing the dependency in the file:

<projectroot>/platforms/android/cordova-support-google-services/<project>-build.gradle

This is not a definitive solution though. If you reinstall the android platform via Cordova the error will show up again. The project maintainer should either freeze the dependency or fix it to support gradle 4.0.0. In the meantime just use a fixed fork of this plugin.

Solution 2 - Android

EDIT 10/28/19:

cordova-support-google-services was updated today to version 1.3.2 which changes the classpath from classpath 'com.android.tools.build:gradle:+'

to

classpath 'com.android.tools.build:gradle:3.+'

which seems to fix the kotlin error

Original Answer

I got mine to build successfully by doing the following:

I edited platforms->android->cordova-support-google-services->myAppName-build.gradle

and changed

maventCentral()

to

    maven { url "https://maven.google.com" }
    maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }

That solved the kotlin error then I was getting a different error that I resolved by changing

classpath 'com.google.gms:google-services:4.2.0'

to

classpath 'com.google.gms:google-services:4.1.0'

It then built successfully.

Solution 3 - Android

Here is the solution.

The problem was exactly the maven repository (here), but the issue was with the build.gradle from the cordova-support-google-services plugin, so I added the required line and everything is ok now, I've already created a pull request to the original repo (here). But in the meantime you can do what I did, just replace in the package.json the current versión with my repo:

Before:

...
"cordova-support-google-services": "^1.3.1",
...

After:

...
"cordova-support-google-services": "https://github.com/LuisEGR/cordova-support-google-services.git",
...

after that you will have to:

  • Remove folders platforms and plugins
  • run npm install

> This is a temporal solution while the pull request to the main repo gets accepted and the npm package updated

and that's it, now you can build your project again.


I'm using Ionic 4, and some plugins require cordova-support-google-services, in case you don't have it in your package.json the error could be with another plugin, if so please add the package.json so we can find out which one is the problem.


UPDATE 24/OCT:

I've changed the solution in my repo as many of you suggested, now the solution consinst just in fixing the dependency: from: com.android.tools.build:gradle:+ to classpath com.android.tools.build:gradle:3.+, this is already in my repo if you want to see what's changed

Solution 4 - Android

in my project i fix like this.(my project in kotlin)

buildscript{

    repositories {
         google()
         jcenter()
         ......
         maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
    }

}

allprojects {
    repositories {
         google()
         jcenter()
         ......
         maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' }
   }
}

Solution 5 - Android

Solution for ionic v3 and cordova

@Mister Smith solution solved my problem

you have to go to the file

platforms/android/cordova-support-google-services

then

Replace

classpath 'com.android.tools.build:gradle:+'

by

classpath 'com.android.tools.build:gradle:3.5.1'

@Alternative solution I have found is to

setup kotlin in your system :)

Solution 6 - Android

As a further temporary fix to follow-up on the suggestion from @MisterSmith, use a hook to re-apply the lock:

<hook src="scripts/fix_android_dep.sh" type="after_platform_add"/>

with this overly wordy bash code:

#!/usr/bin/env bash

## temporary fix for android studio EAP issue
## SOURCE: https://stackoverflow.com/a/58536638/56545
if [ -d "platforms/android/cordova-support-google-services" ]; then
  file="platforms/android/cordova-support-google-services/app-build.gradle"
  from="classpath 'com.android.tools.build:gradle:+'"
  to="classpath 'com.android.tools.build:gradle:3.5.1'"

  change=`sed "s/$from/$to/" < "$file"`
  echo "$change" > "$file"
fi

Solution 7 - Android

I had to add maven { url 'https://dl.bintray.com/kotlin/kotlin-eap' } both into the top-level build.gradle and into the app module build.gradle. In both cases both into the buildscripts.repositories and in allprojects.repositories

Solution 8 - Android

None of the above worked for me. I ended up removing the google-services plugin and add it.

cordova plugin rm cordova-support-google-services cordova plugin add cordova-support-google-services

Solution 9 - Android

In my case I had the same error first, then a whole bunch of other packages (org.ow2.asm:asm-analysis:4.0@jar, etc...) that could also not be resolved.

The problem was that I upgraded Gradle to v5 (to be able to support the new version of Crashlytic). Doing so, I upgraded the repository to Google(), and deleted the old maven { url ... } entries.

But I also deleted jcenter(), which was still required for a lot of nodes.

Now my repository section looks like this:

buildscript {
    repositories {
	    maven { url "$rootDir/../node_modules/react-native/android" }
        google() // Google Maven repository
	    jcenter()
    }
    //...

So if someone else is reading this but was not happy with the current accepted solution of downgrading Gradle, check if you have jcenter().

Ps.: I realize this is an old issue but I recently found it while searching on google.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionTapas MukherjeeView Question on Stackoverflow
Solution 1 - AndroidMister SmithView Answer on Stackoverflow
Solution 2 - AndroidDanielReadView Answer on Stackoverflow
Solution 3 - AndroidLuis GonzalezView Answer on Stackoverflow
Solution 4 - AndroidVen RenView Answer on Stackoverflow
Solution 5 - AndroidSayed Mohd AliView Answer on Stackoverflow
Solution 6 - AndroidGreg HaygoodView Answer on Stackoverflow
Solution 7 - AndroidAlexander KulyakhtinView Answer on Stackoverflow
Solution 8 - AndroidMan Called HaneyView Answer on Stackoverflow
Solution 9 - AndroidFMaz008View Answer on Stackoverflow