Using Buildforge 7x to RTC 3x build definition get API: Access denied
com.ibm.team.build.common.TeamBuildException: Error sending request "Create build for project af530bd50c621000ca2dd3c675547554" to Build Forge server at "172.172.172.172:3966" for build engine id "BF": API: Access denied.
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection.createTeamBuildException(BuildForgeConnection.java:132)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection.runAsRetryable(BuildForgeConnection.java:99)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection.createBuild(BuildForgeConnection.java:430)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeBuildLoopRunnable.startBuildForgeProject(BuildForgeBuildLoopRunnable.java:245)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeBuildLoopRunnable.run(BuildForgeBuildLoopRunnable.java:193)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeBuildLoopScheduledTask.runTask(BuildForgeBuildLoopScheduledTask.java:71)
at com.ibm.team.repository.service.async.AbstractAutoScheduledTask.executeTask(AbstractAutoScheduledTask.java:88)
at sun.reflect.GeneratedMethodAccessor129.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
at java.lang.reflect.Method.invoke(Method.java:611)
at org.eclipse.soda.sat.core.internal.record.ExportProxyServiceRecord.invoke(ExportProxyServiceRecord.java:361)
at org.eclipse.soda.sat.core.internal.record.ExportProxyServiceRecord.access$0(ExportProxyServiceRecord.java:347)
at org.eclipse.soda.sat.core.internal.record.ExportProxyServiceRecord$ExportedServiceInvocationHandler.invoke(ExportProxyServiceRecord.java:56)
at $Proxy487.executeTask(Unknown Source)
at com.ibm.team.repository.service.internal.scheduler.AsynchronousTaskRunner.runTask(AsynchronousTaskRunner.java:158)
at com.ibm.team.repository.service.internal.scheduler.AsynchronousTaskRunner.run(AsynchronousTaskRunner.java:119)
at java.lang.Thread.run(Thread.java:738)
Caused by: com.buildforge.services.common.api.APIException: Message[uuid=null, timestamp=1373498694, userUuid=, processId=0, severity=ERROR, type=, componentUuid=null, messageKey=APIAccessDenied, indirectionMask=0, args={}]
at com.buildforge.services.client.api.APIClientConnection.call(APIClientConnection.java:607)
at com.buildforge.services.client.dbo.Build.create(Build.java:569)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection$4.run(BuildForgeConnection.java:437)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection$4.run(BuildForgeConnection.java:1)
at com.ibm.rational.buildforge.team.internal.service.BuildForgeConnection.runAsRetryable(BuildForgeConnection.java:95)
... 15 more
2013-07-10 16:09:48 [Jazz build engine] Searching for buildResultUUID=_woYl4Om1EeKyK_0LrHLRhA
2013-07-10 16:09:48 [Jazz build engine] The -noComplete argument was specified. The build result will not be completed by JBE.
2013-07-10 16:09:48 [Jazz build engine] Building only the specified participants: "[com.ibm.team.build.jazzscm]"
2013-07-10 16:09:48 [Jazz build engine] Not using a proxy to reach https://ourrepo-address.org:9443/ccm
2013-07-10 16:09:51 [Jazz build engine] CRRTC3526W: Warning: The build engine is either not in the repository, or it cannot be accessed by the following user: "O386600". The UUID of the build engine is "_uUlzwOm0EeK3_LMAcS2E1w". For more details, open the help system and search for CRRTC3526W.
2013-07-10 16:09:51 [Jazz build engine] No requests found.
2013-07-10 16:09:51 [Jazz build engine] Exiting JBE after completing single build request, RC=1.
CRRTC3529W: The execution of Jazz Build Engine completed with a non-zero return code (RC=1). For more details, open the help system and search for CRRTC3529W.
ENDBFBomPlaceholder425838192bomp2
Accepted answer
~Spencer
Comments
Thanks, Spencer! I included the information about the repository information because it's actually somehow opposite as one would expect. The build does start and on the build agent it creates an appropriate folder under the build root directory. The BF Agent log provides some information that looks like it's authenticating with something (I'm not sure what).
Hmm, I take that back. I tried to replicate the error I got before the APIAccessDenied serverruntime error and was unable to so maybe something else is going on.
So as far as the second error, the engineUUID SHOULD be valid since BF sets that value before the build. So look at the build log in Build Forge and verify that the engineUUID environment variable exists and is set to something that looks like a UUID. I'm going to assume that the user O386600 has access to the Build Forge engine on RTC.
1 vote
Two of our freshly upgraded to 4.0.3 RTC repositories are reporting this on a frequent basis. Funny thing is that on one repository two of the now failing builds SUCCEEDED once before failures started. I've been so involved with RTC of late I've forgotten almost all the Build Forge I knew. In addition to an exception with strong similarity to OP, there is a complaint about missing metadata
1 vote
You might try creating a new BF user and setting the RTC BF engine creds to that brand new user. That way you can ensure that no one else is doing anything with that user and make sure that there isn't some kind of mix up with different creds trying to connect to BF from RTC.
1 vote
@Spencer: regarding a new BF user. I'm not sure if I can (within the logistics of our support group) but I'll try. Here's something else I noticed about this problem: I recreated it but setting up a brand new build definition, new BF project, new workspace, etc. It worked the first time (as far as connecting to BF, getting logs, etc) but again get the API Denied error on subsequent attempts - exactly like my original problem. The BF admin asked if I was using lscm because he was not seeing a logout so I wonder if somehow the adapter doesn't break the RTC connection so it works once - an only once.
@Spencer: regarding the engineUUID - I only get that on the very first attempt. The subsequent attempts where I'm getting the APIDenied error, there are no BF logs whatsoever.
@Spencer
After our session yesterday ( we did NOT try to update build defs with new ID) the builds could begin but RTC wasn't updating likely because the build definition was using different BF id and could not update the in-flight build started by another ID.
We suggested users reset password on the RTC BE with 4.0.3 client. No help. A new build engine was defined and attached to build which is executing properly.
Ultimately, the problem was that the build definition was locking the Build Forge account. Our communication between the users (us) and the Build Forge administrators is not that fluid so it took a while to figure that out. Still a mystery why it would always work that first time but fail subsequently. Also discovered at this time, as well, that any BF connection will somehow do a "keep alive" ping since this account was being locked regardless of whether any builds were being requested.
My observation(s) of late: We have several RTC projects (different repos) trying to use our build forge server. MANY builds are getting this API: Access denied even though the Build Engine Test works fine. Observing the BF_USERS table only 1 ID is changing with respect to the BF_FAILCOUNT -- root. But no build engines are using root ID (might have used to force an update on the Build Engine). RTC server A is reporting API: Access denied frequently, while RTC server B IS ALSO IMPACTED.
The BF_FAILCOUNT increases when rtc server logs a message also containing "API: Access denied" Blocking ALL API access based on one failing ID, apparently.
3 other answers
After a long test runs I ultimately got success in the issue. Actually I had more then one build engine each with different build userid. After Access Denied lets say I did expire the password for user, reset via RBF web console and again triggered the build as soon as I am using the same build engine it worked fine. The moment I trigger the different build engine the first one start getting the API access denied.
Simple resolution is to have only one user for all the build engine. Also if you have less user license then make the user used for build as priority user. That allow the build user to access the buld forge even all licenses occupied. Also if build user logged in , it will not be logged out by someone else.
- Make user as priority
- Use only one user for all build engine.
I am getting the issue in RTC4.0.3 with all users. my build forge is 7.1.3.3. And I all working till day before. Suddenly the issue appears. I used some builduser account got issue. Then I used my account I got success in first time and thats it it fails from next onward. I check my login and manual trigger as well. Its working fine.
Not I used root users but same happening with root user as well. If there is access issue why the root user also getting the issue.
There's a fix in 5.0.1 in item 317575.