Google services version conflict (Maps / FCM)

Thank you so much, this worked for me

this helped me in two projects, both combining FCM and background-location plugins
although the error in console wanted me to install 9.0.0, I only got it working when I used the exact versions mentioned in the post (9.9.0&3.1.0)

Thank you so much. I got working FCM, Google Analytics and Social-sharing with your solution (same version, 9.8.0 and 3.1.0).
I add this step at the end of your solution:

In platforms/android/project.properties, replace
cordova.system.library.3=com.google.android.gms:play-services-analytics:+
with
cordova.system.library.3=com.google.android.gms:play-services-analytics:9.8.0

Thanks again !

Can you please try this solution? Maybe it can help.

Hello, I did as you said, but when i try to run then i get following error:

A problem occurred evaluating root project ‘android’.

Failed to apply plugin [id ‘com.google.gms.google-services’]
For input string: “+”

As the title of my favorite website suggests, Let me google that for you:

You’ve probably got a + somewhere that needs to be replaced by a digit, as the last answer on that page suggests.

Actually, I did replace + with numbers in build.gradle, project.properties file. Still, it gives me this error. I did google and applied lots of solution but none is working for me.

For us to help you, we need to see these and other relevant files. Without a look into these files, it’s guesswork.

Here is build.gradle file:

apply plugin: ‘com.android.application’

buildscript {
repositories {
mavenCentral()
jcenter()
}

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

}

// Allow plugins to declare Maven dependencies via build-extras.gradle.
allprojects {
repositories {
mavenCentral();
jcenter()
}
}

task wrapper(type: Wrapper) {
gradleVersion = ‘2.14.1’
}

ext {
apply from: ‘CordovaLib/cordova.gradle’
// The value for android.compileSdkVersion.
if (!project.hasProperty(‘cdvCompileSdkVersion’)) {
cdvCompileSdkVersion = null;
}
// The value for android.buildToolsVersion.
if (!project.hasProperty(‘cdvBuildToolsVersion’)) {
cdvBuildToolsVersion = null;
}
// Sets the versionCode to the given value.
if (!project.hasProperty(‘cdvVersionCode’)) {
cdvVersionCode = null
}
// Sets the minSdkVersion to the given value.
if (!project.hasProperty(‘cdvMinSdkVersion’)) {
cdvMinSdkVersion = null
}
// Whether to build architecture-specific APKs.
if (!project.hasProperty(‘cdvBuildMultipleApks’)) {
cdvBuildMultipleApks = null
}
// .properties files to use for release signing.
if (!project.hasProperty(‘cdvReleaseSigningPropertiesFile’)) {
cdvReleaseSigningPropertiesFile = null
}
// .properties files to use for debug signing.
if (!project.hasProperty(‘cdvDebugSigningPropertiesFile’)) {
cdvDebugSigningPropertiesFile = null
}
// Set by build.js script.
if (!project.hasProperty(‘cdvBuildArch’)) {
cdvBuildArch = null
}
// Plugin gradle extensions can append to this to have code run at the end
cdvPluginPostBuildExtras = []
}

// PLUGIN GRADLE EXTENSIONS START
apply from: "com-sarriaroman-photoviewer/ManyTutors-photoviewer.gradle"
apply from: "cordova-plugin-badge/ManyTutors-badge.gradle"
apply from: "cordova-plugin-fcm/ManyTutors-FCMPlugin.gradle"
apply from: "cordova-plugin-firebase/ManyTutors-build.gradle"
apply from: “phonegap-plugin-barcodescanner/ManyTutors-barcodescanner.gradle”
// PLUGIN GRADLE EXTENSIONS END

def hasBuildExtras = file(‘build-extras.gradle’).exists()
if (hasBuildExtras) {
apply from: ‘build-extras.gradle’
}

// Set property defaults after extension .gradle files.
if (ext.cdvCompileSdkVersion == null) {
ext.cdvCompileSdkVersion = privateHelpers.getProjectTarget()
}
if (ext.cdvBuildToolsVersion == null) {
ext.cdvBuildToolsVersion = privateHelpers.findLatestInstalledBuildTools()
}
if (ext.cdvDebugSigningPropertiesFile == null && file(‘debug-signing.properties’).exists()) {
ext.cdvDebugSigningPropertiesFile = ‘debug-signing.properties’
}
if (ext.cdvReleaseSigningPropertiesFile == null && file(‘release-signing.properties’).exists()) {
ext.cdvReleaseSigningPropertiesFile = ‘release-signing.properties’
}

// Cast to appropriate types.
ext.cdvBuildMultipleApks = cdvBuildMultipleApks == null ? false : cdvBuildMultipleApks.toBoolean();
ext.cdvMinSdkVersion = cdvMinSdkVersion == null ? null : Integer.parseInt(’’ + cdvMinSdkVersion)
ext.cdvVersionCode = cdvVersionCode == null ? null : Integer.parseInt(’’ + cdvVersionCode)

def computeBuildTargetName(debugBuild) {
def ret = 'assemble’
if (cdvBuildMultipleApks && cdvBuildArch) {
def arch = cdvBuildArch == ‘arm’ ? ‘armv7’ : cdvBuildArch
ret += ‘’ + arch.toUpperCase().charAt(0) + arch.substring(1);
}
return ret + (debugBuild ? ‘Debug’ : ‘Release’)
}

// Make cdvBuild a task that depends on the debug/arch-sepecific task.
task cdvBuildDebug
cdvBuildDebug.dependsOn {
return computeBuildTargetName(true)
}

task cdvBuildRelease
cdvBuildRelease.dependsOn {
return computeBuildTargetName(false)
}

task cdvPrintProps << {
println(‘cdvCompileSdkVersion=’ + cdvCompileSdkVersion)
println(‘cdvBuildToolsVersion=’ + cdvBuildToolsVersion)
println(‘cdvVersionCode=’ + cdvVersionCode)
println(‘cdvMinSdkVersion=’ + cdvMinSdkVersion)
println(‘cdvBuildMultipleApks=’ + cdvBuildMultipleApks)
println(‘cdvReleaseSigningPropertiesFile=’ + cdvReleaseSigningPropertiesFile)
println(‘cdvDebugSigningPropertiesFile=’ + cdvDebugSigningPropertiesFile)
println(‘cdvBuildArch=’ + cdvBuildArch)
println(‘computedVersionCode=’ + android.defaultConfig.versionCode)
android.productFlavors.each { flavor ->
println(‘computed’ + flavor.name.capitalize() + ‘VersionCode=’ + flavor.versionCode)
}
}

android {

sourceSets {
    main {
        manifest.srcFile 'AndroidManifest.xml'
        java.srcDirs = ['src']
        resources.srcDirs = ['src']
        aidl.srcDirs = ['src']
        renderscript.srcDirs = ['src']
        res.srcDirs = ['res']
        assets.srcDirs = ['assets']
        jniLibs.srcDirs = ['libs']
    }
}

defaultConfig {
    versionCode cdvVersionCode ?: new BigInteger("" + privateHelpers.extractIntFromManifest("versionCode"))
    applicationId privateHelpers.extractStringFromManifest("package")

    if (cdvMinSdkVersion != null) {
        minSdkVersion cdvMinSdkVersion
    }
}

lintOptions {
  abortOnError false;
}

compileSdkVersion cdvCompileSdkVersion
buildToolsVersion cdvBuildToolsVersion

if (Boolean.valueOf(cdvBuildMultipleApks)) {
    productFlavors {
        armv7 {
            versionCode defaultConfig.versionCode*10 + 2
            ndk {
                abiFilters "armeabi-v7a", ""
            }
        }
        x86 {
            versionCode defaultConfig.versionCode*10 + 4
            ndk {
                abiFilters "x86", ""
            }
        }
        all {
            ndk {
                abiFilters "all", ""
            }
        }
    }
}
/*

ELSE NOTHING! DON'T MESS WITH THE VERSION CODE IF YOU DON'T HAVE TO!

else if (!cdvVersionCode) {
  def minSdkVersion = cdvMinSdkVersion ?: privateHelpers.extractIntFromManifest("minSdkVersion")
  // Vary versionCode by the two most common API levels:
  // 14 is ICS, which is the lowest API level for many apps.
  // 20 is Lollipop, which is the lowest API level for the updatable system webview.
  if (minSdkVersion >= 20) {
    defaultConfig.versionCode += 9
  } else if (minSdkVersion >= 14) {
    defaultConfig.versionCode += 8
  }
}
*/

compileOptions {
    sourceCompatibility JavaVersion.VERSION_1_6
    targetCompatibility JavaVersion.VERSION_1_6
}

if (cdvReleaseSigningPropertiesFile) {
    signingConfigs {
        release {
            // These must be set or Gradle will complain (even if they are overridden).
            keyAlias = ""
            keyPassword = "__unset" // And these must be set to non-empty in order to have the signing step added to the task graph.
            storeFile = null
            storePassword = "__unset"
        }
    }
    buildTypes {
        release {
            signingConfig signingConfigs.release
        }
    }
    addSigningProps(cdvReleaseSigningPropertiesFile, signingConfigs.release)
}
if (cdvDebugSigningPropertiesFile) {
    addSigningProps(cdvDebugSigningPropertiesFile, signingConfigs.debug)
}

}

dependencies {
compile fileTree(dir: ‘libs’, include: ‘*.jar’)
// SUB-PROJECT DEPENDENCIES START
debugCompile(project(path: “CordovaLib”, configuration: “debug”))
releaseCompile(project(path: “CordovaLib”, configuration: “release”))
compile "com.android.support:support-v4:24.1.1+"
compile "com.soundcloud.android:android-crop:1.0.0@aar"
compile "com.facebook.android:facebook-android-sdk:4.+"
compile "com.google.firebase:firebase-core:+"
compile "com.google.firebase:firebase-messaging:+"
compile "com.google.gms:google-services:9.8.0"
compile "com.google.firebase:firebase-core:9.8.0"
compile "com.google.firebase:firebase-messaging:9.8.0"
compile "com.google.firebase:firebase-crash:+"
compile "com.google.firebase:firebase-config:+"
compile “com.google.android.gms:play-services-analytics:9.8.0”
// SUB-PROJECT DEPENDENCIES END
}
apply plugin: ‘com.google.gms.google-services’

def promptForReleaseKeyPassword() {
if (!cdvReleaseSigningPropertiesFile) {
return;
}
if (’__unset’.equals(android.signingConfigs.release.storePassword)) {
android.signingConfigs.release.storePassword = privateHelpers.promptForPassword(‘Enter key store password: ‘)
}
if (’__unset’.equals(android.signingConfigs.release.keyPassword)) {
android.signingConfigs.release.keyPassword = privateHelpers.promptForPassword('Enter key password: ');
}
}

gradle.taskGraph.whenReady { taskGraph ->
taskGraph.getAllTasks().each() { task ->
if (task.name == ‘validateReleaseSigning’ || task.name == ‘validateSigningRelease’) {
promptForReleaseKeyPassword()
}
}
}

def addSigningProps(propsFilePath, signingConfig) {
def propsFile = file(propsFilePath)
def props = new Properties()
propsFile.withReader { reader ->
props.load(reader)
}

def storeFile = new File(props.get('key.store') ?: privateHelpers.ensureValueExists(propsFilePath, props, 'storeFile'))
if (!storeFile.isAbsolute()) {
    storeFile = RelativePath.parse(true, storeFile.toString()).getFile(propsFile.getParentFile())
}
if (!storeFile.exists()) {
    throw new FileNotFoundException('Keystore file does not exist: ' + storeFile.getAbsolutePath())
}
signingConfig.keyAlias = props.get('key.alias') ?: privateHelpers.ensureValueExists(propsFilePath, props, 'keyAlias')
signingConfig.keyPassword = props.get('keyPassword', props.get('key.alias.password', signingConfig.keyPassword))
signingConfig.storeFile = storeFile
signingConfig.storePassword = props.get('storePassword', props.get('key.store.password', signingConfig.storePassword))
def storeType = props.get('storeType', props.get('key.store.type', ''))
if (!storeType) {
    def filename = storeFile.getName().toLowerCase();
    if (filename.endsWith('.p12') || filename.endsWith('.pfx')) {
        storeType = 'pkcs12'
    } else {
        storeType = signingConfig.storeType // "jks"
    }
}
signingConfig.storeType = storeType

}

for (def func : cdvPluginPostBuildExtras) {
func()
}

// This can be defined within build-extras.gradle as:
// ext.postBuildExtras = { … code here … }
if (hasProperty(‘postBuildExtras’)) {
postBuildExtras()
}

project.properties file:

target=android-25
android.library.reference.1=CordovaLib
cordova.gradle.include.1=com-sarriaroman-photoviewer/ManyTutors-photoviewer.gradle
cordova.gradle.include.2=cordova-plugin-badge/ManyTutors-badge.gradle
cordova.system.library.1=com.android.support:support-v4:24.1.1+
cordova.system.library.2=com.soundcloud.android:android-crop:1.0.0@aar
cordova.system.library.3=com.android.support:support-v4:24.1.1+
cordova.system.library.4=com.facebook.android:facebook-android-sdk:4.+
cordova.system.library.5=com.google.firebase:firebase-core:+
cordova.system.library.6=com.google.firebase:firebase-messaging:+
cordova.gradle.include.3=cordova-plugin-fcm/ManyTutors-FCMPlugin.gradle
cordova.gradle.include.4=cordova-plugin-firebase/ManyTutors-build.gradle
cordova.system.library.7=com.google.gms:google-services:9.8.0
cordova.system.library.8=com.google.firebase:firebase-core:9.8.0
cordova.system.library.9=com.google.firebase:firebase-messaging:9.8.0
cordova.system.library.10=com.google.firebase:firebase-crash:9.8.0
cordova.system.library.11=com.google.firebase:firebase-config:9.8.0
cordova.system.library.12=com.google.android.gms:play-services-analytics:9.8.0
cordova.system.library.13=com.android.support:support-v4:24.1.1+
cordova.gradle.include.5=phonegap-plugin-barcodescanner/ManyTutors-barcodescanner.gradle

Please use code blocks to make it readable.

I encountered the same error now with a newer version of Ionic. Every time I update to new versions, I pray for the best, but Ionic keeps amazing me. However, the problem is the + at cordova.system.library.6=com.google.firebase:firebase-messaging:+. It needs to be 9.8.0, the same as the other versions below this line.

i got this problem also. you may need to specific 'com.google.gms.google-services' version insted of “+”.

In my case, i need to change play-services-location from “+” to “11.0.4”.

dependencies {
    ....
    compile "com.google.android.gms:play-services-location:11.0.4"
   ....
    compile "com.google.firebase:firebase-core:11.0.4"
    compile "com.google.firebase:firebase-messaging:11.0.4"
    // SUB-PROJECT DEPENDENCIES END
}

apply plugin: 'com.google.gms.google-services'

I got the same problem. After updating the versions in FCM’s and Google Maps’s plugin.xml to 11.0.4, I get the following error.

Found com.google.firebase:firebase-core:11.0.4, but version 9.0.0 is needed for the google-services plugin.
Found com.google.firebase:firebase-messaging:11.0.4, but version 9.0.0 is needed for the google-services plugin.
Found com.google.android.gms:play-services-maps:11.0.4, but version 9.0.0 is needed for the google-services plugin.
Found com.google.android.gms:play-services-location:11.0.4, but version 9.0.0 is needed for the google-services plugin.
:processDebugGoogleServices
FAILED
FAILURE: Build failed with an exception.

  • What went wrong:
    Execution failed for task ‘:processDebugGoogleServices’.
    Please fix the version conflict either by updating the version of the google-services plugin (information about the latest version is available at Service End for Bintray, JCenter, GoCenter, and ChartCenter | JFrog) or updating the version of com.google.android.gms to 9.0.0.

If I change the versions to 9.0.0, I get all sorts of errors in the google maps plugins. Probably due to deprecated/updated method/code

If version 9.0.0 doesn’t work, then change the version everywhere to 11.0.4.

However, I encourage everyone to stop using the FCM plugin. It doesn’t work correctly with the newest Apple devices. On those devices, a registration token isn’t even generated. Besides, it seems like the plugin isn’t being improved anymore, as the number of issues stays the same and the developer doesn’t respond.

The phonegap-push-plugin is a better alternative. When you use that, you get rid of al the version conflicts too.

2 Likes

Hi,
I have this problem, and I have done that you say, but I have the next error:

Error: /Users/projects/project_name/platforms/android/gradlew: Command failed with exit code 1 Error output:
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
/Users/projects/project_name/platforms/android/src/plugin/google/maps/PluginGroundOverlay.java:161: error: cannot find symbol
groundOverlay.setTag(null);
^
symbol: method setTag()
location: variable groundOverlay of type GroundOverlay
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
1 error

FAILURE: Build failed with an exception.

Somebody can help me? Thanks.

It says: “Note: Some input files use or override a deprecated API.”
So, the version of Google Maps you’re using is deprecated. It explains itself.

See the solution

However, I encourage everyone to stop using the FCM plugin. It doesn’t work correctly with the newest Apple devices. On those devices, a registration token isn’t even generated. Besides, it seems like the plugin isn’t being improved anymore, as the number of issues stays the same and the developer doesn’t respond.

The phonegap-push-plugin is a better alternative. When you use that, you get rid of al the version conflicts too.

I solved the last issue but now I hace the next error. I remove the plugin cordova-google-maps and I have this:

  • What went wrong:
    Execution failed for task ‘:transformClassesWithDexForDebug’.

com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.dex.DexException: Multiple dex files define Lorg/apache/cordova/BuildHelper;

  • Try:
    Run with --stacktrace option to get the stack trace. Run with
    –info or --debug option to get more log output.

BUILD FAILED

Total time: 24.158 secs
Error: /Users/projects/project_name/platforms/android/gradlew: Command failed with exit code 1 Error output:
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.

FAILURE: Build failed with an exception.

  • What went wrong:
    Execution failed for task ‘:transformClassesWithDexForDebug’.

com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.dex.DexException: Multiple dex files define Lorg/apache/cordova/BuildHelper;

Can you help me? Thanks.

The Solution Of This Problem Is Very Simple. Just edit the project.properties located in platform/android on Ionic 2 Application. Replace the + sign into a version name like 9.0.1 something like that. Hope that work. It works for me.

1 Like