/* Copyright (C) 2016-2017 Carsten Pfeiffer This file is part of Gadgetbridge. Gadgetbridge is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Gadgetbridge is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package nodomain.freeyourgadget.gadgetbridge.service.btle.profiles; import android.bluetooth.BluetoothGattCharacteristic; import android.content.Context; import android.content.Intent; import android.support.v4.content.LocalBroadcastManager; import java.io.IOException; import java.util.UUID; import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice; import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEDeviceSupport; import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractGattCallback; import nodomain.freeyourgadget.gadgetbridge.service.btle.BtLEQueue; import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder; /** * Base class for all BLE profiles, with things that all impplementations are * expected to use. * * Instances are used in the context of a concrete AbstractBTLEDeviceSupport instance, * i.e. a concrete device. * * @see nodomain.freeyourgadget.gadgetbridge.service.btle.GattService * @see nodomain.freeyourgadget.gadgetbridge.service.btle.GattCharacteristic * @see https://www.bluetooth.com/specifications/assigned-numbers */ public abstract class AbstractBleProfile<T extends AbstractBTLEDeviceSupport> extends AbstractGattCallback { private final T mSupport; public AbstractBleProfile(T support) { this.mSupport = support; } /** * All notifications should be sent through this methods to make them testable. * @param intent the intent to broadcast */ protected void notify(Intent intent) { LocalBroadcastManager.getInstance(getContext()).sendBroadcast(intent); } /** * Delegates to the DeviceSupport instance and additionally sets this instance as the Gatt * callback for the transaction. * * @param taskName * @return * @throws IOException */ public TransactionBuilder performInitialized(String taskName) throws IOException { TransactionBuilder builder = mSupport.performInitialized(taskName); builder.setGattCallback(this); return builder; } public Context getContext() { return mSupport.getContext(); } protected GBDevice getDevice() { return mSupport.getDevice(); } protected BluetoothGattCharacteristic getCharacteristic(UUID uuid) { return mSupport.getCharacteristic(uuid); } protected BtLEQueue getQueue() { return mSupport.getQueue(); } }