NekoX/TMessagesProj/jni/voip/tgcalls/InstanceImpl.cpp

200 lines
5.5 KiB
C++
Raw Normal View History

2020-08-14 18:58:22 +02:00
#include "InstanceImpl.h"
#include "LogSinkImpl.h"
#include "Manager.h"
#include "MediaManager.h"
#include "VideoCaptureInterfaceImpl.h"
#include "VideoCapturerInterface.h"
namespace tgcalls {
namespace {
rtc::Thread *makeManagerThread() {
static std::unique_ptr<rtc::Thread> value = rtc::Thread::Create();
value->SetName("WebRTC-Manager", nullptr);
value->Start();
return value.get();
}
rtc::Thread *getManagerThread() {
static rtc::Thread *value = makeManagerThread();
return value;
}
} // namespace
InstanceImpl::InstanceImpl(Descriptor &&descriptor)
2020-12-23 08:48:30 +01:00
: _logSink(std::make_unique<LogSinkImpl>(descriptor.config.logPath)) {
2020-08-14 18:58:22 +02:00
rtc::LogMessage::LogToDebug(rtc::LS_INFO);
rtc::LogMessage::SetLogToStderr(false);
rtc::LogMessage::AddLogToStream(_logSink.get(), rtc::LS_INFO);
2020-12-23 08:48:30 +01:00
2020-08-15 23:06:36 +02:00
auto networkType = descriptor.initialNetworkType;
2020-08-14 18:58:22 +02:00
_manager.reset(new ThreadLocalObject<Manager>(getManagerThread(), [descriptor = std::move(descriptor)]() mutable {
return new Manager(getManagerThread(), std::move(descriptor));
}));
_manager->perform(RTC_FROM_HERE, [](Manager *manager) {
manager->start();
});
2020-12-23 08:48:30 +01:00
2020-08-15 23:06:36 +02:00
setNetworkType(networkType);
2020-08-14 18:58:22 +02:00
}
InstanceImpl::~InstanceImpl() {
rtc::LogMessage::RemoveLogToStream(_logSink.get());
}
void InstanceImpl::receiveSignalingData(const std::vector<uint8_t> &data) {
_manager->perform(RTC_FROM_HERE, [data](Manager *manager) {
manager->receiveSignalingData(data);
});
};
void InstanceImpl::setVideoCapture(std::shared_ptr<VideoCaptureInterface> videoCapture) {
_manager->perform(RTC_FROM_HERE, [videoCapture](Manager *manager) {
manager->setVideoCapture(videoCapture);
});
}
2021-08-31 21:06:39 +02:00
void InstanceImpl::sendVideoDeviceUpdated() {
_manager->perform(RTC_FROM_HERE, [](Manager *manager) {
manager->sendVideoDeviceUpdated();
});
}
2020-10-01 03:59:32 +02:00
void InstanceImpl::setRequestedVideoAspect(float aspect) {
_manager->perform(RTC_FROM_HERE, [aspect](Manager *manager) {
manager->setRequestedVideoAspect(aspect);
});
}
2020-08-14 18:58:22 +02:00
void InstanceImpl::setNetworkType(NetworkType networkType) {
2020-08-15 23:06:36 +02:00
bool isLowCostNetwork = false;
switch (networkType) {
case NetworkType::WiFi:
case NetworkType::Ethernet:
isLowCostNetwork = true;
break;
default:
break;
}
2020-12-23 08:48:30 +01:00
2020-08-15 23:06:36 +02:00
_manager->perform(RTC_FROM_HERE, [isLowCostNetwork](Manager *manager) {
manager->setIsLocalNetworkLowCost(isLowCostNetwork);
});
2020-08-14 18:58:22 +02:00
}
void InstanceImpl::setMuteMicrophone(bool muteMicrophone) {
_manager->perform(RTC_FROM_HERE, [muteMicrophone](Manager *manager) {
manager->setMuteOutgoingAudio(muteMicrophone);
});
}
void InstanceImpl::setIncomingVideoOutput(std::shared_ptr<rtc::VideoSinkInterface<webrtc::VideoFrame>> sink) {
_manager->perform(RTC_FROM_HERE, [sink](Manager *manager) {
manager->setIncomingVideoOutput(sink);
});
}
void InstanceImpl::setAudioOutputGainControlEnabled(bool enabled) {
}
void InstanceImpl::setEchoCancellationStrength(int strength) {
}
void InstanceImpl::setAudioInputDevice(std::string id) {
2020-10-01 03:59:32 +02:00
_manager->perform(RTC_FROM_HERE, [id](Manager *manager) {
manager->setAudioInputDevice(id);
});
2020-08-14 18:58:22 +02:00
}
void InstanceImpl::setAudioOutputDevice(std::string id) {
2020-10-01 03:59:32 +02:00
_manager->perform(RTC_FROM_HERE, [id](Manager *manager) {
manager->setAudioOutputDevice(id);
});
2020-08-14 18:58:22 +02:00
}
void InstanceImpl::setInputVolume(float level) {
2020-10-01 03:59:32 +02:00
_manager->perform(RTC_FROM_HERE, [level](Manager *manager) {
manager->setInputVolume(level);
});
2020-08-14 18:58:22 +02:00
}
void InstanceImpl::setOutputVolume(float level) {
2020-10-01 03:59:32 +02:00
_manager->perform(RTC_FROM_HERE, [level](Manager *manager) {
manager->setOutputVolume(level);
});
2020-08-14 18:58:22 +02:00
}
void InstanceImpl::setAudioOutputDuckingEnabled(bool enabled) {
// TODO: not implemented
}
2021-07-30 16:49:55 +02:00
void InstanceImpl::addExternalAudioSamples(std::vector<uint8_t> &&samples) {
_manager->perform(RTC_FROM_HERE, [samples = std::move(samples)](Manager *manager) mutable {
manager->addExternalAudioSamples(std::move(samples));
});
}
2020-08-14 18:58:22 +02:00
void InstanceImpl::setIsLowBatteryLevel(bool isLowBatteryLevel) {
_manager->perform(RTC_FROM_HERE, [isLowBatteryLevel](Manager *manager) {
manager->setIsLowBatteryLevel(isLowBatteryLevel);
});
}
std::string InstanceImpl::getLastError() {
return ""; // TODO: not implemented
}
std::string InstanceImpl::getDebugInfo() {
return ""; // TODO: not implemented
}
int64_t InstanceImpl::getPreferredRelayId() {
return 0; // we don't have endpoint ids
}
TrafficStats InstanceImpl::getTrafficStats() {
return TrafficStats{}; // TODO: not implemented
}
PersistentState InstanceImpl::getPersistentState() {
return PersistentState{}; // we dont't have such information
}
2020-08-15 23:06:36 +02:00
void InstanceImpl::stop(std::function<void(FinalState)> completion) {
std::string debugLog = _logSink->result();
2020-12-23 08:48:30 +01:00
2020-08-15 23:06:36 +02:00
_manager->perform(RTC_FROM_HERE, [completion, debugLog = std::move(debugLog)](Manager *manager) {
2020-10-01 03:59:32 +02:00
manager->getNetworkStats([completion, debugLog = std::move(debugLog)](TrafficStats stats, CallStats callStats) {
2020-08-15 23:06:36 +02:00
FinalState finalState;
finalState.debugLog = debugLog;
finalState.isRatingSuggested = false;
finalState.trafficStats = stats;
2020-10-01 03:59:32 +02:00
finalState.callStats = callStats;
2020-12-23 08:48:30 +01:00
2020-08-15 23:06:36 +02:00
completion(finalState);
});
});
2020-08-14 18:58:22 +02:00
}
int InstanceImpl::GetConnectionMaxLayer() {
2021-06-25 02:43:10 +02:00
return 92;
2020-08-14 18:58:22 +02:00
}
2020-08-15 23:06:36 +02:00
std::vector<std::string> InstanceImpl::GetVersions() {
std::vector<std::string> result;
result.push_back("2.7.7");
result.push_back("3.0.0");
return result;
2020-08-14 18:58:22 +02:00
}
template <>
bool Register<InstanceImpl>() {
return Meta::RegisterOne<InstanceImpl>();
}
} // namespace tgcalls