How to authorize a Java Batch job so it can run from a startup bean in WebSphere Liberty?

643 views Asked by At

I am trying to submit a basic batch job from within my startup bean, which is giving me an error message of "User UNAUTHENTICATED is not authorized to start batch jobs."

This is my startup bean:

@Singleton
@Startup
public class ControllerBean {
    @PersistenceContext(unitName = "item-persister")
    EntityManager entityManager; 

    @PostConstruct
    public void initialize() { 
        JobOperator jobOperator = BatchRuntime.getJobOperator();
        long execID = jobOperator.start("testjob", null);
    }
}

In my server.xml, I have configured a username and password:

<basicRegistry id="basic" realm="ibm/api">
    <user name="bob" password="bobpwd"/>
</basicRegistry>

<authorization-roles id="com.ibm.ws.batch">
    <security-role name="batchAdmin">
        <user name="bob"/>
    </security-role>
</authorization-roles>

How do I authenticate properly so that my job can be run by a startup bean?

1

There are 1 answers

0
Scott Kurz On BEST ANSWER

An easy way is to:

Configure a RunAs identity

You need to align the @RunAs annotation value with the server configuration.

In the server config (server.xml):

<application name="MyApp" ... >
    <application-bnd>
        <security-role name="JOBSTARTER">
            <user name="bob" />
            <run-as userid="bob" password="bobpwd"/>
        </security-role>
    </application-bnd>
</application>

In your Java code calling JobOperator:

@Singleton
@Startup
@RunAs("JOBSTARTER")
public class ControllerBean {

    @PostConstruct
    public void initialize() { 
        JobOperator jobOperator = BatchRuntime.getJobOperator();
        long execID = jobOperator.start("testjob", null);
    }
}

In your snippet you had the basic registry and the user mapped to the batch authorization role. You just needed to establish this user on the thread via the @RunAs.