Assigned
Status Update
Comments
va...@google.com <va...@google.com>
ku...@google.com <ku...@google.com> #2
After getting copies of Github's runner images, and simulating the environment in a docker image- I've managed to reproduce the issue. This occurs when the CPUs are limited to 2 cores; as is the case with standard github runner machines. It seems to be a deadlock. Logging into the deadlocked container, I've managed to get stack traces.
Relevant Running Processes:
root 205 199 1 20:12 pts/1 00:00:13 /opt/hostedtoolcache/Java_Zulu_jdk/11.0.18-10/x64/bin/java -Xmx64m -Xms64m -Dorg.gradle.appname=gradlew -classpath /usr/local/google/home/daymxn/Documents/repos/firebase-android-sdk/gradle/wrapper/gradle-wrapper.jar org.gradle.wrapper.GradleWrapperMain --no-daem
on :firebase-common:kotlindoc
root 241 205 25 20:13 ? 00:05:42 /opt/hostedtoolcache/Java_Zulu_jdk/11.0.18-10/x64/bin/java -XX:MaxPermSize=8g --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.prefs/java.util.prefs=ALL-UN
NAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.util.concurrent.atomic=ALL-UNNAMED -Xms2g -Xmx8g -Dfile.encoding=UTF-8 -Duser.country -Duser.language=en -Duser.variant -cp /root/.gradle/wrapper/dists/gradle-7.6-all/9f832ih6bniajn45pbmq
hk2cw/gradle-7.6/lib/gradle-launcher-7.6.jar org.gradle.launcher.daemon.bootstrap.GradleDaemon 7.6
root 343 241 3 20:14 ? 00:00:39 /opt/hostedtoolcache/Java_Zulu_jdk/11.0.18-10/x64/bin/java -cp /root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-compiler-embeddable/1.7.10/909803167c98606fcf22b4c848647c68e351d48d/kotlin-compiler-embeddable-1.7.10.jar:/root/.gradle/caches/mod
ules-2/files-2.1/org.jetbrains.kotlin/kotlin-reflect/1.7.10/165e600dfea6185cf5efa700756294cc4904dbeb/kotlin-reflect-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/1.7.10/d2abf9e77736acc4450dc4a3f707fa2c10f5099d/kotlin-stdlib-1.7.10.jar:/root/.gradle/caches/modules-2/files-2
.1/org.jetbrains.kotlin/kotlin-script-runtime/1.7.10/c99c87a6988d8fd8d5142e9ed5c9f34a7cf561ee/kotlin-script-runtime-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-daemon-embeddable/1.7.10/3a9f7aef7080d3ae63126cbba4f827ed664f32fa/kotlin-daemon-embeddable-1.7.10.jar:/root/.gradle/ca
ches/modules-2/files-2.1/org.jetbrains.intellij.deps/trove4j/1.0.20200330/3afb14d5f9ceb459d724e907a21145e8ff394f02/trove4j-1.0.20200330.jar:/root/.gradle/caches/modules-2/files-2.1/net.java.dev.jna/jna/5.6.0/330f2244e9030119ab3030fc3fededc86713d9cc/jna-5.6.0.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbra
ins.kotlin/kotlin-stdlib-common/1.7.10/bac80c520d0a9e3f3673bc2658c6ed02ef45a76a/kotlin-stdlib-common-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9/annotations-13.0.jar -Djava.awt.headless=true -D$java.rmi.server.hostname=127.0.0.1 -Xmx8
g -Dkotlin.environment.keepalive -ea org.jetbrains.kotlin.daemon.KotlinCompileDaemon --daemon-runFilesPath /root/.local/share/kotlin/daemon --daemon-autoshutdownIdleSeconds=7200 --daemon-compilerClasspath /root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-compiler-embeddable/1.7.10/909803167c986
06fcf22b4c848647c68e351d48d/kotlin-compiler-embeddable-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-reflect/1.7.10/165e600dfea6185cf5efa700756294cc4904dbeb/kotlin-reflect-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/1.7.10/d2abf9e77736ac
c4450dc4a3f707fa2c10f5099d/kotlin-stdlib-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-script-runtime/1.7.10/c99c87a6988d8fd8d5142e9ed5c9f34a7cf561ee/kotlin-script-runtime-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-daemon-embeddable/1.7.10/3a9
f7aef7080d3ae63126cbba4f827ed664f32fa/kotlin-daemon-embeddable-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.intellij.deps/trove4j/1.0.20200330/3afb14d5f9ceb459d724e907a21145e8ff394f02/trove4j-1.0.20200330.jar:/root/.gradle/caches/modules-2/files-2.1/net.java.dev.jna/jna/5.6.0/330f2244e9030119
ab3030fc3fededc86713d9cc/jna-5.6.0.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib-common/1.7.10/bac80c520d0a9e3f3673bc2658c6ed02ef45a76a/kotlin-stdlib-common-1.7.10.jar:/root/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9
/annotations-13.0.jar
root 411 241 1 20:17 ? 00:00:19 /opt/hostedtoolcache/Java_Zulu_jdk/11.0.18-10/x64/bin/java -Dfile.encoding=UTF-8 -Duser.country -Duser.language=en -Duser.variant -cp /root/.gradle/caches/modules-2/files-2.1/com.google.devsite/dackka-fat/10.10.12/5e0c3f42dd2a1b638dcbda274bcad90dcc3d11a5/dackka-
fat-10.10.12.jar org.jetbrains.dokka.MainKt /tmp/dackkaArgs2855163529207012510.json -loggingLevel DEBUG
Extended Thread dumps (Internal links for gpaste):
Extended Thread dumps (External links for gist):
Description
I have reported this a few days ago and a google staff who apparently didn't even bother to read past the first line closed the issue asking me to post a question of "why won't this code work" or "how do I resolve this specific error" in stack exchange! (by the way thank you for education on how to use issue tracker!)
From this sentence "Try posting on a Stack Exchange site." I can assume they haven't been working in google for very long. I'm reporting a bug not asking about an issue with my code!
Since this is an issue NOT FROM MY CODE BUT GOOGLE'S CODE, I'm posting it again
I have configured Open Id using following step by step tutorial and my code works as expected, when I'm sending referer header but when I don't send this header, I get 403 error.
However it seems API is using HTTP Referer to identify client calling the API. which then if it is not provided or doesn't match the website url, API will returns 403.
There are a few major issues with this approach.
1- Not all applications are web browser and thus they do not send referer (e.g. my windows (and Linux) desktop application which uses google open ID to identify and login users. Currently I'm sending one which matches my website, and it is meaningless since I'm not calling your API from that website.
2- Some of my users are using browser Referer extension (for privacy of course) which then masks inter-website referer header if the the two websites are not same (in this case my website and google). This also causes the following API endpoint return 403 too.
3- If this referer is implemented as a security measure, it is a horrible one, since I can even change it in any web browser with again an extension and even write a code to pretend I'm google itself (having the only other required client key)!
I Assume API also returns 403 error if browser user-agent header is not recognized by google.
This is easily reproducible with "Smart Referer" extension on firefox browser
or Referer Control extension on Chrome browser
In both cases no configuration needed, install the extension and activate it and following script will always fail (screenshots)
Here is my code that works when HTTP referer is sent and doesn't work when HTTP referer is not sent
HTML Page content
When referer extension is active (running on localhost)
Request Header (identifiers redacted)
Response Header (identifiers redacted)
With same page when referer extension is not active
Request Header (identifiers redacted)
Response Header (identifiers redacted)
Again I need to re-iterate that using HTTP referer or user-agent as a security measure is very very wrong since any user can easily modify it even with a browsers widely available in market. use of an encrypted value in a custom header, request GET or POST content instead, is more secure and preferred.
There are many alternative solutions such as implementing a key for clients to generate an encrypted token that can only be decrypted by google to make sure, request is made by the actual client.