mirror of
https://github.com/openharmony/aafwk_standard.git
synced 2026-07-01 20:04:39 -04:00
2cb8ac18d5
Signed-off-by: jiangwensai <jiangwensai@huawei.com> Change-Id: Iffdccf0014fdbaac1a00b829e53b453c4dadc3b6
145 lines
4.1 KiB
C++
145 lines
4.1 KiB
C++
/*
|
|
* 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.
|
|
*/
|
|
|
|
#ifndef OHOS_AAFWK_CONNECTION_RECORD_H
|
|
#define OHOS_AAFWK_CONNECTION_RECORD_H
|
|
|
|
#include "ability_connect_callback_interface.h"
|
|
#include "ability_record.h"
|
|
#include "nocopyable.h"
|
|
|
|
namespace OHOS {
|
|
namespace AAFwk {
|
|
/**
|
|
* @enum ConnectionState
|
|
* ConnectionState defines the state of connect ability.
|
|
*/
|
|
enum class ConnectionState { INIT, CONNECTING, CONNECTED, DISCONNECTING, DISCONNECTED };
|
|
/**
|
|
* @class ConnectionRecord
|
|
* ConnectionRecord,This class is used to record information about a connection.
|
|
*/
|
|
class ConnectionRecord : public std::enable_shared_from_this<ConnectionRecord> {
|
|
public:
|
|
ConnectionRecord(const sptr<IRemoteObject> &callerToken, const std::shared_ptr<AbilityRecord> &targetService,
|
|
const sptr<IAbilityConnection> &connCallback);
|
|
virtual ~ConnectionRecord();
|
|
|
|
/**
|
|
* create a connection record by caller token , service ability and call back ipc object.
|
|
*
|
|
* @param callerToken, the token of caller ability.
|
|
* @param targetService, target service ability.
|
|
* @param callback, call back (ipc object).
|
|
* @return Return the connect record.
|
|
*/
|
|
static std::shared_ptr<ConnectionRecord> CreateConnectionRecord(const sptr<IRemoteObject> &callerToken,
|
|
const std::shared_ptr<AbilityRecord> &targetService, const sptr<IAbilityConnection> &connCallback);
|
|
|
|
/**
|
|
* set the connect state.
|
|
*
|
|
* @param state, target connection state.
|
|
*/
|
|
void SetConnectState(const ConnectionState &state);
|
|
|
|
/**
|
|
* get the connect state.
|
|
*
|
|
* @return state, target connection state.
|
|
*/
|
|
ConnectionState GetConnectState() const;
|
|
|
|
/**
|
|
* get the token of the ability.
|
|
*
|
|
* @return token.
|
|
*/
|
|
sptr<IRemoteObject> GetToken() const;
|
|
|
|
/**
|
|
* get the ability record from connection record.
|
|
*
|
|
* @return AbilityRecord.
|
|
*/
|
|
std::shared_ptr<AbilityRecord> GetAbilityRecord() const;
|
|
|
|
sptr<IAbilityConnection> GetAbilityConnectCallback() const;
|
|
|
|
/**
|
|
* disconnect the service ability.
|
|
*
|
|
* @return Returns ERR_OK on success, others on failure.
|
|
*/
|
|
int DisconnectAbility();
|
|
|
|
/**
|
|
* force to disconnect time out event.
|
|
*
|
|
*/
|
|
void DisconnectTimeout();
|
|
|
|
/**
|
|
* complete connect ability and invoke callback.
|
|
*
|
|
*/
|
|
void CompleteConnect(int resultCode);
|
|
|
|
/**
|
|
* complete disconnect ability and invoke callback.
|
|
*
|
|
*/
|
|
void CompleteDisconnect(int resultCode, bool isDied);
|
|
|
|
/**
|
|
* scheduler target service disconnect done.
|
|
*
|
|
*/
|
|
void ScheduleDisconnectAbilityDone();
|
|
|
|
/**
|
|
* scheduler target service Connect done.
|
|
*
|
|
*/
|
|
void ScheduleConnectAbilityDone();
|
|
|
|
/**
|
|
* get connection record id.
|
|
*
|
|
*/
|
|
inline int GetRecordId() const
|
|
{
|
|
return recordId_;
|
|
}
|
|
|
|
void ClearConnCallBack();
|
|
|
|
std::string ConvertConnectionState(const ConnectionState &state) const;
|
|
|
|
void Dump(std::vector<std::string> &info) const;
|
|
|
|
private:
|
|
static int64_t connectRecordId;
|
|
int recordId_; // record id
|
|
ConnectionState state_; // service connection state
|
|
sptr<IRemoteObject> callerToken_; // from:caller token
|
|
std::shared_ptr<AbilityRecord> targetService_; // target:service need to be connected
|
|
sptr<IAbilityConnection> connCallback_; // service connect callback
|
|
|
|
DISALLOW_COPY_AND_MOVE(ConnectionRecord);
|
|
};
|
|
} // namespace AAFwk
|
|
} // namespace OHOS
|
|
#endif // OHOS_AAFWK_CONNECTION_RECORD_H
|