/*
* Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import {Callback} from "./basic";
import radio from "./@ohos.telephony.radio";
import data from "./@ohos.telephony.data";
import call from "./@ohos.telephony.call";
import sim from "./@ohos.telephony.sim";
/**
* Monitors telephony state updates of a device, including updates of the network state,
* signal strength, call state, the data link connection state and others.
*
* @since 6
* @syscap SystemCapability.Telephony.StateRegistry
*/
declare namespace observer {
type NetworkState = radio.NetworkState;
type SignalInformation = radio.SignalInformation;
type CellInformation = radio.CellInformation;
type DataConnectState = data.DataConnectState;
type RatType = radio.RadioTechnology;
type DataFlowType = data.DataFlowType;
type CallState = call.CallState;
type CardType = sim.CardType;
type SimState = sim.SimState;
/**
* Called when the network state corresponding to a monitored {@code slotId} updates.
*
*
Applications must have the {@code ohos.permission.GET_NETWORK_INFO} permission
* to register this event.
*
* @param type networkStateChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including an instance of the {@code NetworkState} class.
* @permission ohos.permission.GET_NETWORK_INFO
*/
function on(type: 'networkStateChange', callback: Callback): void;
function on(type: 'networkStateChange', options: { slotId: number }, callback: Callback): void;
function off(type: 'networkStateChange', callback?: Callback): void;
/**
* Called when the signal strength corresponding to a monitored {@code slotId} updates.
*
* @param type signalInfoChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including an array of instances of the classes derived from {@link SignalInformation}.
*/
function on(type: 'signalInfoChange', callback: Callback>): void;
function on(type: 'signalInfoChange', options: { slotId: number },
callback: Callback>): void;
function off(type: 'signalInfoChange', callback?: Callback>): void;
/**
* Called back when the cell information corresponding to a monitored {@code slotId} updates.
*
* Applications must have the {@code ohos.permission.LOCATION} permission
* to register this event.
*
* @param type cellInfoChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including an array of instances of the classes derived from {@link CellInformation}.
* @permission ohos.permission.LOCATION
* @systemapi Hide this for inner system use.
* @since 8
*/
function on(type: 'cellInfoChange', callback: Callback>): void;
function on(type: 'cellInfoChange', options: { slotId: number },
callback: Callback>): void;
/**
* @systemapi Hide this for inner system use.
* @since 8
*/
function off(type: 'cellInfoChange', callback?: Callback>): void;
/**
* Called when the cellular data link connection state updates.
*
* @param type cellularDataConnectionStateChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including state Indicates the cellular data link connection state,
* and networkType Indicates the radio access technology for cellular data services.
* @since 7
*/
function on(type: 'cellularDataConnectionStateChange',
callback: Callback<{ state: DataConnectState, network: RatType }>): void;
function on(type: 'cellularDataConnectionStateChange', options: { slotId: number },
callback: Callback<{ state: DataConnectState, network: RatType }>): void;
function off(type: 'cellularDataConnectionStateChange',
callback?: Callback<{ state: DataConnectState, network: RatType }>): void;
/**
* Called when the uplink and downlink data flow state of cellular data services updates.
*
* @param type cellularDataFlowChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including the cellular data flow state.
* @since 7
*/
function on(type: 'cellularDataFlowChange', callback: Callback): void;
function on(type: 'cellularDataFlowChange', options: { slotId: number },
callback: Callback): void;
function off(type: 'cellularDataFlowChange', callback?: Callback): void;
/**
* Receives a call state change. This callback is invoked when the call state of a specified card updates
* and the observer is added to monitor the updates.
*
* @param type callStateChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including state Indicates the call state, and number Indicates the called number.
* The value of number is an empty string if the application does not have
* the {@code ohos.permission#READ_CALL_LOG READ_CALL_LOG} permission.
*/
function on(type: 'callStateChange', callback: Callback<{ state: CallState, number: string }>): void;
function on(type: 'callStateChange', options: { slotId: number },
callback: Callback<{ state: CallState, number: string }>): void;
function off(type: 'callStateChange', callback?: Callback<{ state: CallState, number: string }>): void;
/**
* Receives a sim state change. This callback is invoked when the sim state of a specified card updates
* and the observer is added to monitor the updates.
*
* @param type simStateChange
* @param options including slotId Indicates the ID of the target card slot.
* The value {@code 0} indicates card 1, and the value {@code 1} indicates card 2.
* @param callback including state Indicates the sim state, and reason Indicates the cause of the change.
* The value of reason is an empty string if the application does not have
* @since 7
*/
function on(type: 'simStateChange', callback: Callback): void;
function on(type: 'simStateChange', options: { slotId: number }, callback: Callback): void;
function off(type: 'simStateChange', callback?: Callback): void;
/**
* @since 7
*/
export interface SimStateData {
type: CardType,
state: SimState,
/**
* @since 8
*/
reason: LockReason
}
/**
* @since 8
*/
export enum LockReason {
SIM_NONE,
SIM_PIN,
SIM_PUK,
SIM_PN_PIN, //Network Personalization (refer 3GPP TS 22.022 [33])
SIM_PN_PUK,
SIM_PU_PIN, //network sUbset Personalization (refer 3GPP TS 22.022 [33])
SIM_PU_PUK,
SIM_PP_PIN, //service Provider Personalization (refer 3GPP TS 22.022 [33])
SIM_PP_PUK,
SIM_PC_PIN, //Corporate Personalization (refer 3GPP TS 22.022 [33])
SIM_PC_PUK,
SIM_SIM_PIN, //SIM/USIM personalisation (refer 3GPP TS 22.022 [33])
SIM_SIM_PUK,
}
}
export default observer;