fechanique / cordova-plugin-fcm

Google FCM Push Notifications Cordova Plugin
624 stars 990 forks source link

google-services plugin could not detect any version for com.google.android.gms or com.google.firebase, default version: 9.0.0 will be used. please apply google-services plugin at the bottom of the build file. #256

Open anuragetech opened 7 years ago

anuragetech commented 7 years ago

I am getting this error when build my app

FAILURE: Build failed with an exception.

Cannot add task ':processDebugGoogleServices' as a task with that name already exists.

BUILD FAILED

Total time: 35.537 secs

Error: /var/www/html/fq_app_ionic/platforms/android/gradlew: Command failed with exit code 1 Error output: FAILURE: Build failed with an exception.

build.gradle file code

/* Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing,
   software distributed under the License is distributed on an
   "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
   KIND, either express or implied.  See the License for the
   specific language governing permissions and limitations
   under the License.

*/

apply plugin: 'com.android.application'

buildscript { repositories { mavenCentral() jcenter() }

// Switch the Android Gradle plugin version requirement depending on the
// installed version of Gradle. This dependency is documented at
// http://tools.android.com/tech-docs/new-build-system/version-compatibility
// and https://issues.apache.org/jira/browse/CB-8143
dependencies {
    classpath "com.android.tools.build:gradle:2.1.2"
    classpath "com.google.gms:google-services:3.0.0"
}

}

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

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

// Configuration properties. Set these via environment variables, build-extras.gradle, or gradle.properties. // Refer to: http://www.gradle.org/docs/current/userguide/tutorial_this_and_that.html 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: "cordova-plugin-fcm/fashioniq-FCMPlugin.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.facebook.android:facebook-android-sdk:4.14.+" compile "com.google.firebase:firebase-core:+" compile "com.google.firebase:firebase-messaging:+" compile "com.google.android.gms:play-services-analytics:+" // SUB-PROJECT DEPENDENCIES END } 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() } apply plugin: "com.google.gms.google-services"

JackThomson2 commented 7 years ago

Hi guys, I was having the same issue as you however I managed to fix it doing the following process:

Under 'platforms/android' open the file 'project.properties'. Here edit the lines so they look similar to mine :

cordova.system.library.1=com.android.support:appcompat-v7:23.4.0 cordova.system.library.2=com.facebook.android:facebook-android-sdk:4.14.+ cordova.system.library.3=com.google.firebase:firebase-core:9.0.0 cordova.system.library.4=com.google.firebase:firebase-messaging:9.0.0 cordova.system.library.5=com.google.android.gms:play-services-auth:9.0.0 cordova.system.library.6=com.google.android.gms:play-services-identity:9.0.0

Once you have edited this go too 'plugins/cordova-plugin-fcm' and open the file 'plugin.xml' in there edit the tags so they look like this now:

<framework src="com.google.firebase:firebase-core:9.0.0" /> <framework src="com.google.firebase:firebase-messaging:9.0.0" /> Finally go too 'plugins/cordova-plugin-googleplus' and open the file plugin.xml' in there edit the tags so they look now like this: <framework src="com.google.android.gms:play-services-auth:9.0.0" /> <framework src="com.google.android.gms:play-services-identity:9.0.0" />

Then after that I ran a ionic prepare and the app ran successfully. If this doesn't fix it let me know and I'll check if I did some other changes (spent a while fixing this)

Thanks Jack

anuragetech commented 7 years ago

@jack i have tried with the above solution but it still giving error and build failed. I think the issue is because of "cordova-plugin-google-analytics" plugin.

Found com.google.android.gms:play-services-analytics:+, but version 9.0.0 is needed for the google-services plugin. :processDebugGoogleServices FAILED FAILURE: Build failed with an exception.

After removing "cordova-plugin-google-analytics" plugin its working but with this plugin its not working

JackThomson2 commented 7 years ago

Apply the changes also to the google analytics in the same way see if that solves it

leobrch commented 7 years ago

i was having the same issue.

google-services plugin could not detect any version for com.google.android.gms or com.google.firebase, default version: 9.0.0 will be used.

please apply google-services plugin at the bottom of the build file.

FAILURE: Build failed with an exception.

Lazar955 commented 7 years ago

Try replacing FCM with cordova-plugin-firebase by: https://github.com/EddyVerbruggen/cordova-plugin-googleplus/issues/349#issuecomment-285248483

marlosirapuan commented 7 years ago

Yes! In my case, with cordova-plugin-firebase works. In Android i changed this properties in project.properties (platforms/android/) file too:

cordova.system.library.5=com.google.android.gms:play-services-maps:9.8.0
cordova.system.library.6=com.google.android.gms:play-services-location:9.8.0

to

cordova.system.library.5=com.google.android.gms:play-services-maps:+
cordova.system.library.6=com.google.android.gms:play-services-location:+
xardit commented 7 years ago

@JackThomson2 solution WORKED
Also remove the line apply plugin: "com.google.gms.google-services" from file build.grandle because it brings errors on build.

leobrch commented 7 years ago

i find my way with OneSignal, ty guys anyway.

siempay commented 7 years ago

got it working by trying cordova-plugin-firebase as @Lazar955 said plus removing cordova-plugin-googlemaps

gkiran1 commented 7 years ago

@JackThomson2 I did everything as suggested by you. The build is successful but the app keeps crashing when deployed.

elewin commented 7 years ago

I'm having the same problem, if anyone has more insight it would be greatly appreciated

mufniarz commented 6 years ago

cordova plugin remove cordova-plugin-fcm reinstalling cordova-plugin-fcm worked for me

gkiran1 commented 6 years ago

Setting the following properties under platforms/android/project.properties fixed my issue cordova.system.library.1=com.android.support:support-v4:23.0.1 cordova.system.library.2=com.google.firebase:firebase-core:9.0.0 cordova.system.library.3=com.google.firebase:firebase-messaging:9.0.0 cordova.gradle.include.1=cordova-plugin-fcm/io-FCMPlugin.gradle cordova.system.library.4=com.android.support:support-v4:23.0.1

Thanks.

nnabike commented 6 years ago

In FCM Gradle, comment the last line with Googleservicesplugin buildscript { repositories { jcenter() mavenLocal() } dependencies { classpath 'com.android.tools.build:gradle:+' classpath 'com.google.gms:google-services:3.0.0' } } // apply plugin: 'com.google.gms.google-services' <---- COMMENT THIS LINE TOO, add to Root gradle file // class must be used instead of id(string) to be able to apply plugin from non-root gradle file //apply plugin: com.google.gms.googleservices.GoogleServicesPlugin <---- COMMENT THIS LINE

webantz commented 6 years ago

Hi all, I too faced the same issue, I did the following and it works now.

cordova plugin remove cordova-plugin-fcm cordova plugin add cordova-plugin-fcm

In platforms> android> cordova-plugin-fcm> xxxxx-FCMPlugin.gradle

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

In plugins> cordova-plugin-fcm> plugin.xml

    <framework src="com.google.firebase:firebase-core:+" />
    <framework src="com.google.firebase:firebase-messaging:+" />

In platforms> android> project.properties

com.google.android.gms:play-services-location:11.4.2 com.google.firebase:firebase-core:11.4.2 com.google.firebase:firebase-messaging:11.4.2

finally, build ionic cordova build android

PriceFallin commented 6 years ago

I had this issue when I added the cordova-plugin-firebase-dynamiclinks plugin to my ionic3 app.

I was able to solve the issue by commenting out apply plugin: com.google.gms.googleservices.GoogleServicesPlugin found in /platforms/android/cordova-plugin-fcm/project-FCMPlugin.gradle

Similar to what @nnabike said, but without commenting out apply plugin: 'com.google.gms.google-services'

alexbonhomme commented 5 years ago

The only solution working for me is this fork (recommended by Ionic doc) : https://github.com/andrehtissot/cordova-plugin-fcm-with-dependecy-updated