AI-generated Key Takeaways
- 
          This interface is deprecated and MessagesClientshould be used instead.
- 
          The API allows publishing and subscribing to simple messages from nearby devices unauthenticated. 
- 
          Using the API requires enabling the Nearby Messages API and creating an API key in the Google Developers Console. 
- 
          Publish and subscribe operations should ideally be managed within the onStart()andonStop()lifecycle methods of a foreground Activity.
This interface is deprecated.
      Use MessagesClient.
API which allows your app to publish simple messages and subscribe to receive those messages from nearby devices.
The API performs its operations in an unauthenticated manner, so it does not require a Google account. However, it requires that the developer has a project in the Google Developers Console with the following prerequisites:
- Nearby Messages API turned on.
 Follow these instructions to enable the "Nearby Messages API".
- An API key for the Android application using its package name and SHA1 fingerprint.
 Follow these instructions to create the "Public API access" API key specific for your app.
- Add the API key generated above to your application's manifest:
          <manifest ...> <application ...> <meta-data android:name="com.google.android.nearby.messages.API_KEY" android:value="SPECIFY_APPLICATION_API_KEY_HERE" /> <activity> ... </activity> </application> </manifest>
The Messages API should be accessed from the Nearby entry point.
      For example:
 @Override
 protected void onCreate(Bundle savedInstanceState) {
   mGoogleApiClient = new GoogleApiClient.Builder(context)
       .addApi(Nearby.MESSAGES_API)
       .addConnectionCallbacks(this)
       .build();
 }
 @Override
 protected void onStart() {
   mGoogleApiClient.connect();
 }
 @Override
 public void onConnected(Bundle connectionHint) {
   PendingResult<Status> pendingResult = Nearby.Messages.publish(mGoogleApiClient,
       new Message(bytes));
 }
 All of the Messages APIs should be used from a foreground Activity, with the exception of
      the variants of subscribe that take a PendingIntent
      parameter. Your Activity should 
      publish(GoogleApiClient, Message) or 
      subscribe(GoogleApiClient, MessageListener) either in Activity.onStart()
      or in response to a user action in a visible Activity, and you should always symmetrically
      
      unpublish(GoogleApiClient, Message) or 
      unsubscribe(GoogleApiClient, MessageListener) in Activity.onStop().
Public Method Summary
| abstract PendingResult<Status> | 
                  
                  getPermissionStatus(GoogleApiClient
                  client)
                   
                    This method is deprecated. This call will always succeed now that
                    permission status is handled at connection time.
                   | 
| abstract void | 
                  
                  handleIntent(Intent
                  intent, MessageListener
                  messageListener)
                   
                    Extracts information from an Intent sent as a subscription callback, and calls
                    the corresponding methods on the given MessageListener.
                   | 
| abstract PendingResult<Status> | 
                  
                  publish(GoogleApiClient
                  client, Message
                  message)
                   
                    Publishes a message so that it is visible to nearby devices, using the default
                    options from  
                    PublishOptions.DEFAULT. | 
| abstract PendingResult<Status> | 
                  
                  publish(GoogleApiClient
                  client, Message
                  message, PublishOptions
                  options)
                   
                    Publishes a message so that it is visible to nearby devices.
                   | 
| abstract PendingResult<Status> | 
                  
                  registerStatusCallback(GoogleApiClient
                  client, StatusCallback
                  statusCallback)
                   
                    Registers a status callback, which will be notified when significant events
                    occur that affect Nearby for your app.
                   | 
| abstract PendingResult<Status> | 
                  
                  subscribe(GoogleApiClient
                  client, PendingIntent
                  pendingIntent, 
                  SubscribeOptions options)
                   
                    Note: Currently, this method only finds messages attached to BLE beacons.
                   | 
| abstract PendingResult<Status> | 
                  
                  subscribe(GoogleApiClient
                  client, MessageListener
                  listener, 
                  SubscribeOptions options)
                   
                    Subscribes for published messages from nearby devices.
                   | 
| abstract PendingResult<Status> | 
                  
                  subscribe(GoogleApiClient
                  client, MessageListener
                  listener)
                   
                    Subscribes for published messages from nearby devices, using the default
                    options in  
                    SubscribeOptions.DEFAULT. | 
| abstract PendingResult<Status> | 
                  
                  subscribe(GoogleApiClient
                  client, PendingIntent
                  pendingIntent)
                   
                    Note: Currently, this method only finds messages attached to BLE beacons.
                   | 
| abstract PendingResult<Status> | |
| abstract PendingResult<Status> | 
                  
                  unregisterStatusCallback(GoogleApiClient
                  client, StatusCallback
                  statusCallback)
                   
                    Unregisters a status callback previously registered with  
                    registerStatusCallback(GoogleApiClient, StatusCallback). | 
| abstract PendingResult<Status> | |
| abstract PendingResult<Status> | 
Public Methods
public abstract PendingResult<Status> getPermissionStatus (GoogleApiClient client)
This method is deprecated.
          This call will always succeed now that permission status is handled at connection
          time.
Checks if the user has granted this app permission to publish and subscribe.
In particular, the status returned can be
- NearbyMessagesStatusCodes.APP_NOT_OPTED_IN- If the app asked for permission and was denied by user.
- CommonStatusCodes.SUCCESS- If the app has permission to publish and subscribe.
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|
Returns
- The PendingResultwhich can be used to determine if the app has all the required permissions to publish/subscribe.
public abstract void handleIntent (Intent intent, MessageListener messageListener)
Extracts information from an Intent sent as a subscription callback, and calls the corresponding methods on the given MessageListener.
Note: Only 
            MessageListener.onFound(Message) and 
            MessageListener.onLost(Message) are supported.
For example:
 PendingIntent pendingIntent = PendingIntent.getService(context, 0,
     new Intent(context, MyService.class), PendingIntent.FLAG_UPDATE_CURRENT);
 Nearby.Messages.subscribe(googleApiClient, pendingIntent, ...);
 public class MyService extends IntentService {
   protected void onHandleIntent(Intent intent) {
     Nearby.Messages.handleIntent(intent, new MessageListener() {
       @Override
       public void onFound(Message message) {...}
     }
   });
 }
 Parameters
| intent | An intent that was sent as a result of 
                subscribe(GoogleApiClient, PendingIntent, SubscribeOptions) | 
|---|---|
| messageListener | This will be called immediately with information present in the Intent | 
public abstract PendingResult<Status> publish (GoogleApiClient client, Message message)
Publishes a message so that it is visible to nearby devices, using the default
            options from 
            PublishOptions.DEFAULT.
public abstract PendingResult<Status> publish (GoogleApiClient client, Message message, PublishOptions options)
Publishes a message so that it is visible to nearby devices.
The message is only delivered to apps that share the same project id in the Developer Console and have an active subscription. Create project identifiers and turn on the Nearby API in the Google Developers Console.
Allowed Contexts GoogleApiClient
            can be bound to:
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| message | A Messageto publish for nearby devices to see | 
| options | A PublishOptionsobject for this operation | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> registerStatusCallback (GoogleApiClient client, StatusCallback statusCallback)
Registers a status callback, which will be notified when significant events occur that affect Nearby for your app.
When your app first calls this API, it may be immediately called back with current status.
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API. | 
|---|---|
| statusCallback | A callback to notify when events occur. | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> subscribe (GoogleApiClient client, PendingIntent pendingIntent, SubscribeOptions options)
Note: Currently, this method only finds messages attached to BLE beacons. See Beacons.
Subscribes for published messages from nearby devices in a persistent and low-power manner. This uses less battery, but will have higher latency and lower reliability. Notably, updates may only be delivered when the device's screen turns on (or when Bluetooth turns on). The subscription will be retained after the client disconnects.
Call 
            handleIntent(Intent, MessageListener) to handle the Intents received from
            Nearby while subscribed. Call 
            unsubscribe(GoogleApiClient, PendingIntent) to cancel the subscription.
Each application can pass up to 5 PendingIntents.
            When the limit is reached, this returns 
            NearbyMessagesStatusCodes.TOO_MANY_PENDING_INTENTS, and the subscription is
            not created.
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| pendingIntent | A PendingIntentto get callbacks about nearby messages | 
| options | A SubscribeOptionsobject for this operation | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> subscribe (GoogleApiClient client, MessageListener listener, SubscribeOptions options)
Subscribes for published messages from nearby devices.
Only messages published by apps sharing the same project id in the Developer Console will be delivered.
Allowed Contexts GoogleApiClient
            can be bound to:
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| listener | A MessageListenerimplementation to get callbacks of received messages | 
| options | A SubscribeOptionsobject for this operation | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> subscribe (GoogleApiClient client, MessageListener listener)
Subscribes for published messages from nearby devices, using the default options in
            
            SubscribeOptions.DEFAULT.
public abstract PendingResult<Status> subscribe (GoogleApiClient client, PendingIntent pendingIntent)
Note: Currently, this method only finds messages attached to BLE beacons. See Beacons.
Subscribes for published messages from nearby devices in a persistent and low-power
            manner, using the default options in 
            SubscribeOptions.DEFAULT.
public abstract PendingResult<Status> unpublish (GoogleApiClient client, Message message)
Cancels an existing published message.
If this method is called and the message is not currently published, it will return
            a Status of
            CommonStatusCodes.SUCCESS.
Allowed Contexts GoogleApiClient
            can be bound to:
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| message | A Messagethat is currently published | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> unregisterStatusCallback (GoogleApiClient client, StatusCallback statusCallback)
Unregisters a status callback previously registered with 
            registerStatusCallback(GoogleApiClient, StatusCallback).
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API. | 
|---|---|
| statusCallback | A callback previously registered with 
                registerStatusCallback(GoogleApiClient, StatusCallback). | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> unsubscribe (GoogleApiClient client, PendingIntent pendingIntent)
Cancels an existing subscription.
If this method is called and the pendingIntent is not currently
            subscribed, it will return a Status of
            CommonStatusCodes.SUCCESS.
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| pendingIntent | A PendingIntentthat is currently subscribed | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.
public abstract PendingResult<Status> unsubscribe (GoogleApiClient client, MessageListener listener)
Cancels an existing subscription.
If this method is called and the listener is not currently subscribed,
            it will return a Status of
            CommonStatusCodes.SUCCESS.
Allowed Contexts GoogleApiClient
            can be bound to:
Parameters
| client | A connected GoogleApiClientforNearby.MESSAGES_API | 
|---|---|
| listener | A MessageListenerimplementation that is currently subscribed | 
Returns
- The PendingResultwhich can be used to determine if the call succeeded.