Newer Version Available
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.
- Get the EMP Connector project from GitHub. See Download and Build the Project.
-
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} -
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.
-
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.