.. _buildinitclient: Build and initialize the workspace client ========================================= This documentation describes how to build and initialize the workspace clients. It assumes the build occurs on Ubuntu 18.04LTS. It assumes that the ``workspace_deluxe`` repo has been cloned (see :ref:`getcode`). Python client ------------- The Python client checked into ``libs/biokbase/workspace/client.py`` does not require a build, but does require the `requests `_ library. Change the working directory to the lib directory:: bareubuntu@bu:~/ws$ cd workspace_deluxe/lib/ bareubuntu@bu:~/ws/workspace_deluxe/lib$ Alternatively, add this directory to the ``PYTHONPATH``. Here we use the iPython interpreter to demonstrate initializing the client, but the standard python interpreter will also work:: bareubuntu@bu:~/ws/workspace_deluxe/lib$ ipython .. code-block:: python In [1]: from biokbase.workspace.client import Workspace In [2]: ws = Workspace('https://kbase.us/services/ws', token=[redacted]) In [3]: ws.ver() Out[3]: u'0.14.2' Developer tokens are available from the Account page of the KBase Narrative for approved developers or can be created in the testmode API of the `KBase authentication server `_ if running a local workspace and auth server. Java client ----------- The easiest way to use the client is with a build tool like Gradle or Maven, fetching the client via https://jitpack.io/#kbase/workspace_deluxe. If you want to build the client manually read on. The Java client build requires Java JDK 11+. Build the client:: bareubuntu@bu:~/ws/workspace_deluxe$ ./gradlew jar The client jar is created in ``client/build/libs/client.jar``. For simplicity, copy the required jars into a single directory. You will also need the following jars, which can be downloaded from a maven repository or https://jitpack.io: * The `Jackson `_ annotations, core, and databind jars (maven) * The javax annotation api jar (maven) * The `KBase auth client jar `_ * The `KBase java_common jar `_ :: bareubuntu@bu:~/ws$ mkdir tryjavaclient bareubuntu@bu:~/ws$ cd tryjavaclient/ bareubuntu@bu:~/ws/tryjavaclient$ ls auth2_client_java-0.5.0.jar java_common-0.3.0.jar jackson-annotations-2.9.9.jar javax.annotation-api-1.3.2.jar jackson-core-2.9.9.jar client.jar jackson-databind-2.9.9.jar This simple program initializes and calls a method on the WSS client:: bareubuntu@bu:~/ws/tryjavaclient$ cat TryWorkspaceClient.java .. code-block:: java import java.net.URI; import java.net.URL; import us.kbase.auth.AuthToken; import us.kbase.auth.client.AuthClient; import us.kbase.workspace.WorkspaceClient; public class TryWorkspaceClient { public static void main(String[] args) throws Exception { final String authUrl = "https://appdev.kbase.us/services/auth/"; final AuthClient authcli = AuthClient.from(new URI(authUrl)); final String tokenString = args[0]; final AuthToken token = authcli.validateToken(tokenString); final WorkspaceClient client = new WorkspaceClient( new URL("https://appdev.kbase.us/services/ws/"), token); System.out.println(client.ver()); } } Compile and run:: bareubuntu@bu:~/ws/tryjavaclient$ javac -cp "./*" TryWorkspaceClient.java bareubuntu@bu:~/ws/tryjavaclient$ java -cp "./:./*" TryWorkspaceClient $KBASE_TOKEN 0.14.2 For more client initialization and configuration options, see :ref:`apidocs`. Javascript client ----------------- .. todo:: Build (probably not needed) and initialization instructions for the Javascript client.