2020-10-21 17:33:58 +03:00
|
|
|
using System;
|
|
|
|
using System.IO;
|
|
|
|
using System.Text.RegularExpressions;
|
|
|
|
using MalwareMultiScan.Backends.Backends.Abstracts;
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
|
|
|
namespace MalwareMultiScan.Backends.Backends.Implementations
|
|
|
|
{
|
|
|
|
public class DrWebScanBackend : AbstractLocalProcessScanBackend
|
|
|
|
{
|
|
|
|
public DrWebScanBackend(ILogger logger) : base(logger)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
public override string Id { get; } = "drweb";
|
|
|
|
|
|
|
|
public override DateTime DatabaseLastUpdate =>
|
|
|
|
File.GetLastWriteTime("/var/opt/drweb.com/version/version.ini");
|
|
|
|
|
|
|
|
protected override string BackendPath { get; } = "/usr/bin/drweb-ctl";
|
|
|
|
|
|
|
|
protected override Regex MatchRegex { get; } =
|
|
|
|
new Regex(@".* - infected with (?<threat>[\S ]+)", RegexOptions.Compiled | RegexOptions.Multiline);
|
2020-10-22 14:15:27 +03:00
|
|
|
|
2020-10-21 17:33:58 +03:00
|
|
|
protected override string GetBackendArguments(string path)
|
|
|
|
{
|
|
|
|
return $"scan {path}";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|