mirror of
https://github.com/github/codeql.git
synced 2025-12-24 04:36:35 +01:00
74 lines
2.8 KiB
C#
74 lines
2.8 KiB
C#
using System;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using Semmle.Util;
|
|
using Semmle.Util.Logging;
|
|
|
|
namespace Semmle.Extraction.CSharp.DependencyFetching
|
|
{
|
|
internal class DependabotProxy
|
|
{
|
|
private readonly string? host;
|
|
private readonly string? port;
|
|
private readonly FileInfo? certFile;
|
|
|
|
/// <summary>
|
|
/// The full address of the Dependabot proxy, if available.
|
|
/// </summary>
|
|
internal readonly string? Address;
|
|
|
|
/// <summary>
|
|
/// Gets a value indicating whether a Dependabot proxy is configured.
|
|
/// </summary>
|
|
internal bool IsConfigured => !string.IsNullOrEmpty(this.Address);
|
|
|
|
internal DependabotProxy(ILogger logger, TemporaryDirectory tempWorkingDirectory)
|
|
{
|
|
// Obtain and store the address of the Dependabot proxy, if available.
|
|
this.host = Environment.GetEnvironmentVariable(EnvironmentVariableNames.ProxyHost);
|
|
this.port = Environment.GetEnvironmentVariable(EnvironmentVariableNames.ProxyPort);
|
|
|
|
if (string.IsNullOrWhiteSpace(host) || string.IsNullOrWhiteSpace(port))
|
|
{
|
|
logger.LogInfo("No Dependabot proxy credentials are configured.");
|
|
return;
|
|
}
|
|
|
|
this.Address = $"http://{this.host}:{this.port}";
|
|
logger.LogInfo($"Dependabot proxy configured at {this.Address}");
|
|
|
|
// Obtain and store the proxy's certificate, if available.
|
|
var cert = Environment.GetEnvironmentVariable(EnvironmentVariableNames.ProxyCertificate);
|
|
|
|
if (string.IsNullOrWhiteSpace(cert))
|
|
{
|
|
logger.LogInfo("No certificate configured for Dependabot proxy.");
|
|
return;
|
|
}
|
|
|
|
var certDirPath = new DirectoryInfo(Path.Join(tempWorkingDirectory.DirInfo.FullName, ".dependabot-proxy"));
|
|
Directory.CreateDirectory(certDirPath.FullName);
|
|
|
|
var certFilePath = Path.Join(certDirPath.FullName, "proxy.crt");
|
|
this.certFile = new FileInfo(certFilePath);
|
|
|
|
using var writer = this.certFile.CreateText();
|
|
writer.Write(cert);
|
|
|
|
logger.LogInfo($"Stored Dependabot proxy certificate at {certFilePath}");
|
|
}
|
|
|
|
internal void ApplyProxy(ILogger logger, ProcessStartInfo startInfo)
|
|
{
|
|
// If the proxy isn't configured, we have nothing to do.
|
|
if (!this.IsConfigured) return;
|
|
|
|
logger.LogInfo($"Setting up Dependabot proxy at {this.Address}");
|
|
|
|
startInfo.EnvironmentVariables.Add("HTTP_PROXY", this.Address);
|
|
startInfo.EnvironmentVariables.Add("HTTPS_PROXY", this.Address);
|
|
startInfo.EnvironmentVariables.Add("SSL_CERT_FILE", this.certFile?.FullName);
|
|
}
|
|
}
|
|
}
|