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 !
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.
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.