Newer Version Available

This content describes an older version of this product. View Latest

Run a Java Client with Username and Password Login

Run a Java client that uses EMP Connector to subscribe to the channel with username and password authentication.
  1. Get the EMP Connector project from GitHub. See Download and Build the Project.
  2. In the /src/main/java/com/salesforce/emp/connector/example folder, open the LoginExample.java source file.
    1/* 
    2 * Copyright (c) 2016, salesforce.com, inc.
    3 * All rights reserved.
    4 * Licensed under the BSD 3-Clause license. 
    5 * For full license text, see LICENSE.TXT file in the repo root  or https://opensource.org/licenses/BSD-3-Clause
    6 */
    7package com.salesforce.emp.connector.example;
    8
    9import static com.salesforce.emp.connector.LoginHelper.login;
    10
    11import java.net.URL;
    12import java.util.Map;
    13import java.util.concurrent.TimeUnit;
    14import java.util.function.Consumer;
    15
    16import com.salesforce.emp.connector.BayeuxParameters;
    17import com.salesforce.emp.connector.EmpConnector;
    18import com.salesforce.emp.connector.LoginHelper;
    19import com.salesforce.emp.connector.TopicSubscription;
    20
    21/**
    22 * An example of using the EMP connector using login credentials
    23 */
    24public class LoginExample {
    25    public static void main(String[] argv) throws Exception {
    26        if (argv.length < 3 || argv.length > 4) {
    27            System.err.println(
    28                "Usage: LoginExample username password channel [replayFrom]");
    29            System.exit(1);
    30        }
    31        long replayFrom = EmpConnector.REPLAY_FROM_EARLIEST;
    32        if (argv.length == 4) {
    33            replayFrom = Long.parseLong(argv[3]);
    34        }
    35
    36        BearerTokenProvider tokenProvider = new BearerTokenProvider(() -> {
    37            try {
    38                return login(argv[0], argv[1]);
    39            } catch (Exception e) {
    40                e.printStackTrace(System.err);
    41                System.exit(1);
    42                throw new RuntimeException(e);
    43            }
    44        });
    45
    46        BayeuxParameters params = tokenProvider.login();
    47
    48        Consumer<Map<String, Object>> consumer = event -> 
    49            System.out.println(String.format("Received:\n%s", event));
    50
    51        EmpConnector connector = new EmpConnector(params);
    52
    53        connector.setBearerTokenProvider(tokenProvider);
    54
    55        connector.start().get(5, TimeUnit.SECONDS);
    56
    57        TopicSubscription subscription = connector.subscribe(
    58            argv[2], replayFrom, consumer).get(5, TimeUnit.SECONDS);
    59
    60        System.out.println(String.format("Subscribed: %s", subscription));
    61    }
    62}
  3. Run the LoginExample class and provide arguments.
    Argument Value
    username Username of the logged-in user.
    password Password for the username (or logged-in user).
    channel /u/notifications/ExampleUserChannel
    The sample fetches the earliest saved events within the past 24 hours. Optionally, to receive different events, you can include a replay ID as the last argument. Valid values are:
    • –1—Get all new events sent after subscription.
    • –2—Get all new events sent after subscription and all past events within the past 24 hours.
    • Specific number—Get all events that occurred after the event with the specified replay ID.
  4. When you run this client app and generate notifications using the REST resource, the output will look something like:
    1Subscribed: Subscription [/u/notifications/ExampleUserChannel:-2]
    2Received:
    3{payload=Broadcast message to all subscribers, event={createdDate=2016-12-13T00:57:36.020Z, replayId=1}}
    4Received:
    5{payload=Another message, event={createdDate=2016-12-13T00:58:16.591Z, replayId=2}}
Generally, do not handle usernames and passwords of others when running code in production. In a production environment, delegate the login to OAuth. The next step connects to Streaming API with OAuth.