Remotely/Shared/Utilities/RewritableStream.cs
Jared Goodwin 3f8d63c2c0
Azure Pipelines, Docker, and embedded server data. (#543)
* Add Azure Pipelines yml.

* Remove Server Installer.

* Update Release Build.yml for Azure Pipelines

* Update Release Build.yml

* Update Release Build.yml for Azure Pipelines

* Update Release Build.yml for Azure Pipelines

* Update Release Build.yml for Azure Pipelines

* Update Release Build.yml for Azure Pipelines

* Update signtool.exe

* Update Release Build.yml

* Update Publish.ps1

* Update pipeline and Dockerfile.

* Move docker files.

* Update Dockerfile

* Update Dockerfile

* Update Dockerfile

* Update Dockerfile

* Move files.

* Update Dockerfile

* Update Dockerfile

* Create RewritableStream.

* Finish implementation of rewritable stream and embedded data searcher.

* Remove RelayCode.

* Get branding from default org if orgId is missing.

* Update README.md

* Remove AppConstants.ServerUrl.  Fix main module file path.

* Update submodule.

* Extract embedded data in Program.cs.

* Add logging.  Update submodule.

* Remove size block.  BinaryWriter prefixes size.

* Remove unused async

* Update Immense.RemoteControl

* Update Release Build.yml for Azure Pipelines

* Update Release Build.yml for Azure Pipelines

* Use UpgradeService for determining out of date clients.
2022-12-31 19:10:40 -08:00

114 lines
3.0 KiB
C#

using System;
using System.Buffers;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Remotely.Shared.Utilities
{
public class RewritableStream : Stream
{
private readonly Stream _underlyingStream;
private readonly Dictionary<long, byte> _rewriteMap;
public RewritableStream(Stream underlyingStream, Dictionary<long, byte> rewriteMap)
{
_underlyingStream = underlyingStream;
_rewriteMap = rewriteMap;
}
public override bool CanRead => _underlyingStream.CanRead;
public override bool CanSeek => _underlyingStream.CanSeek;
public override bool CanTimeout => _underlyingStream.CanTimeout;
public override bool CanWrite => _underlyingStream.CanWrite;
public override long Length => _underlyingStream.Length;
public override long Position
{
get => _underlyingStream.Position;
set => _underlyingStream.Position = value;
}
public override int ReadTimeout
{
get => _underlyingStream.ReadTimeout;
set => _underlyingStream.ReadTimeout = value;
}
public override int WriteTimeout
{
get => _underlyingStream.WriteTimeout;
set => _underlyingStream.WriteTimeout = value;
}
public override void Close()
{
_underlyingStream.Close();
base.Close();
}
public override ValueTask DisposeAsync()
{
GC.SuppressFinalize(this);
return _underlyingStream.DisposeAsync();
}
public override void Flush()
{
_underlyingStream.Flush();
}
public override int Read(byte[] buffer, int offset, int count)
{
var i = 0;
for (; i < count; i++)
{
if (_rewriteMap.TryGetValue(Position, out var newValue))
{
buffer[offset + i] = newValue;
Seek(1, SeekOrigin.Current);
}
else
{
var current = _underlyingStream.ReadByte();
if (current == -1)
{
break;
}
buffer[offset + i] = current == -1 ? (byte)0 : (byte)current;
}
}
return i;
}
public override long Seek(long offset, SeekOrigin origin)
{
return _underlyingStream.Seek(offset, origin);
}
public override void SetLength(long value)
{
_underlyingStream.SetLength(value);
}
public override void Write(byte[] buffer, int offset, int count)
{
_underlyingStream.Write(buffer, offset, count);
}
protected override void Dispose(bool disposing)
{
_underlyingStream.Dispose();
base.Dispose(disposing);
}
}
}