mirror of
https://github.com/PepperDash/Essentials.git
synced 2026-01-31 05:14:51 +00:00
132 lines
4.2 KiB
C#
132 lines
4.2 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using Crestron.SimplSharp;
|
|
|
|
using PepperDash.Core;
|
|
using PepperDash.Essentials.Core;
|
|
using PepperDash.Essentials.Core.Config;
|
|
using PepperDash.Essentials.Devices.Common.Codec;
|
|
using Serilog.Events;
|
|
|
|
namespace PepperDash.Essentials.Devices.Common.AudioCodec
|
|
{
|
|
public class MockAC : AudioCodecBase
|
|
{
|
|
public MockAC(string key, string name, MockAcPropertiesConfig props)
|
|
: base(key, name)
|
|
{
|
|
CodecInfo = new MockAudioCodecInfo();
|
|
|
|
CodecInfo.PhoneNumber = props.PhoneNumber;
|
|
}
|
|
|
|
public override void Dial(string number)
|
|
{
|
|
if (!IsInCall)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "Dial: {0}", number);
|
|
var call = new CodecActiveCallItem()
|
|
{
|
|
Name = "Mock Outgoing Call",
|
|
Number = number,
|
|
Type = eCodecCallType.Audio,
|
|
Status = eCodecCallStatus.Connected,
|
|
Direction = eCodecCallDirection.Outgoing,
|
|
Id = "mockAudioCall-1"
|
|
};
|
|
|
|
ActiveCalls.Add(call);
|
|
|
|
OnCallStatusChange(call);
|
|
}
|
|
else
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "Already in call. Cannot dial new call.");
|
|
}
|
|
}
|
|
|
|
public override void EndCall(CodecActiveCallItem call)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "EndCall");
|
|
ActiveCalls.Remove(call);
|
|
SetNewCallStatusAndFireCallStatusChange(eCodecCallStatus.Disconnected, call);
|
|
}
|
|
|
|
public override void EndAllCalls()
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "EndAllCalls");
|
|
for (int i = ActiveCalls.Count - 1; i >= 0; i--)
|
|
{
|
|
var call = ActiveCalls[i];
|
|
ActiveCalls.Remove(call);
|
|
SetNewCallStatusAndFireCallStatusChange(eCodecCallStatus.Disconnected, call);
|
|
}
|
|
}
|
|
|
|
public override void AcceptCall(CodecActiveCallItem call)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "AcceptCall");
|
|
SetNewCallStatusAndFireCallStatusChange(eCodecCallStatus.Connecting, call);
|
|
}
|
|
|
|
public override void RejectCall(CodecActiveCallItem call)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "RejectCall");
|
|
ActiveCalls.Remove(call);
|
|
SetNewCallStatusAndFireCallStatusChange(eCodecCallStatus.Disconnected, call);
|
|
}
|
|
|
|
public override void SendDtmf(string s)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "BEEP BOOP SendDTMF: {0}", s);
|
|
}
|
|
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <param name="url"></param>
|
|
public void TestIncomingAudioCall(string number)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, this, "TestIncomingAudioCall from {0}", number);
|
|
var call = new CodecActiveCallItem() { Name = number, Id = number, Number = number, Type = eCodecCallType.Audio, Direction = eCodecCallDirection.Incoming };
|
|
ActiveCalls.Add(call);
|
|
SetNewCallStatusAndFireCallStatusChange(eCodecCallStatus.Ringing, call);
|
|
}
|
|
|
|
}
|
|
|
|
public class MockAudioCodecInfo : AudioCodecInfo
|
|
{
|
|
string _phoneNumber;
|
|
|
|
public override string PhoneNumber
|
|
{
|
|
get
|
|
{
|
|
return _phoneNumber;
|
|
}
|
|
set
|
|
{
|
|
_phoneNumber = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
public class MockACFactory : EssentialsDeviceFactory<MockAC>
|
|
{
|
|
public MockACFactory()
|
|
{
|
|
TypeNames = new List<string>() { "mockac" };
|
|
}
|
|
|
|
public override EssentialsDevice BuildDevice(DeviceConfig dc)
|
|
{
|
|
Debug.LogMessage(LogEventLevel.Debug, "Factory Attempting to create new MockAc Device");
|
|
var props = Newtonsoft.Json.JsonConvert.DeserializeObject<AudioCodec.MockAcPropertiesConfig>(dc.Properties.ToString());
|
|
return new AudioCodec.MockAC(dc.Key, dc.Name, props);
|
|
}
|
|
}
|
|
|
|
} |