Skip to content
This repository has been archived by the owner on Jul 30, 2024. It is now read-only.
/ NuGet.Jobs Public archive

Commit

Permalink
Merge pull request #685 from NuGet/chenriks-legacy
Browse files Browse the repository at this point in the history
Convert CollectCdnLogs jobs to JsonConfig
  • Loading branch information
chenriksson authored Nov 29, 2018
2 parents c1801e1 + ea1dca0 commit 9537d56
Show file tree
Hide file tree
Showing 23 changed files with 411 additions and 192 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,9 @@ public class AzureStatsLogDestination : ILogDestination
private CloudBlobClient _cloudBlobClient;
private CloudBlobContainer _cloudBlobContainer;

public AzureStatsLogDestination(string connectionString, string containerName)
public AzureStatsLogDestination(CloudStorageAccount storageAccount, string containerName)
{
_azureAccount = CloudStorageAccount.Parse(connectionString);
_azureAccount = storageAccount;
_cloudBlobClient = _azureAccount.CreateCloudBlobClient();
_cloudBlobContainer = _cloudBlobClient.GetContainerReference(containerName);
_cloudBlobContainer.CreateIfNotExists();
Expand Down
4 changes: 2 additions & 2 deletions src/Stats.AzureCdnLogs.Common/Collect/AzureStatsLogSource.cs
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,9 @@ public class AzureStatsLogSource : ILogSource
/// </summary>
/// <param name="connectionString">The connection string for the Azure account.</param>
/// <param name="containerName">The container name.</param>
public AzureStatsLogSource(string connectionString, string containerName, int azureServerTimeoutInSeconds)
public AzureStatsLogSource(CloudStorageAccount storageAccount, string containerName, int azureServerTimeoutInSeconds)
{
_azureAccount = CloudStorageAccount.Parse(connectionString);
_azureAccount = storageAccount;
_blobClient = _azureAccount.CreateCloudBlobClient();
_container = _blobClient.GetContainerReference(containerName);
_blobRequestOptions = new BlobRequestOptions();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.

namespace Stats.CollectAzureCdnLogs
{
public class CollectAzureCdnLogsConfiguration
{
public string AzureCdnAccountNumber { get; set; }

public string AzureCdnCloudStorageAccount { get; set; }

public string AzureCdnCloudStorageContainerName { get; set; }

public string AzureCdnPlatform { get; set; }

public string FtpSourceUri { get; set; }

public string FtpSourceUsername { get; set; }

public string FtpSourcePassword { get; set; }
}
}
70 changes: 50 additions & 20 deletions src/Stats.CollectAzureCdnLogs/Job.cs
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,13 @@
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using Autofac;
using ICSharpCode.SharpZipLib;
using ICSharpCode.SharpZipLib.GZip;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using Microsoft.WindowsAzure.Storage;
using NuGet.Jobs;
using Stats.AzureCdnLogs.Common;
Expand All @@ -20,31 +24,48 @@

namespace Stats.CollectAzureCdnLogs
{
public class Job
: JobBase
public class Job : JsonConfigurationJob
{
private static readonly DateTime _unixTimestamp = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
private Uri _ftpServerUri;
private string _ftpUsername;
private string _ftpPassword;
private string _azureCdnAccountNumber;
private AzureCdnPlatform _azureCdnPlatform;
private CloudStorageAccount _cloudStorageAccount;
private string _cloudStorageContainerName;

private CollectAzureCdnLogsConfiguration _configuration;

public override void Init(IServiceContainer serviceContainer, IDictionary<string, string> jobArgsDictionary)
{
var ftpLogFolder = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.FtpSourceUri);
var azureCdnPlatform = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.AzureCdnPlatform);
var cloudStorageAccount = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.AzureCdnCloudStorageAccount);
_cloudStorageContainerName = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.AzureCdnCloudStorageContainerName);
_azureCdnAccountNumber = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.AzureCdnAccountNumber);
_ftpUsername = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.FtpSourceUsername);
_ftpPassword = JobConfigurationManager.GetArgument(jobArgsDictionary, JobArgumentNames.FtpSourcePassword);

_ftpServerUri = ValidateFtpUri(ftpLogFolder);
_azureCdnPlatform = ValidateAzureCdnPlatform(azureCdnPlatform);
_cloudStorageAccount = ValidateAzureCloudStorageAccount(cloudStorageAccount);
base.Init(serviceContainer, jobArgsDictionary);

InitializeJobConfiguration(_serviceProvider);
}

public void InitializeJobConfiguration(IServiceProvider serviceProvider)
{
_configuration = serviceProvider.GetRequiredService<IOptionsSnapshot<CollectAzureCdnLogsConfiguration>>().Value;

if (string.IsNullOrEmpty(_configuration.AzureCdnAccountNumber))
{
throw new ArgumentException("Configuration 'AzureCdnAccountNumber' is required", nameof(_configuration));
}

if (string.IsNullOrEmpty(_configuration.AzureCdnCloudStorageContainerName))
{
throw new ArgumentException("Configuration 'AzureCdnCloudStorageContainerName' is required", nameof(_configuration));
}

if (string.IsNullOrEmpty(_configuration.FtpSourceUsername)) {
throw new ArgumentException("Configuration 'FtpSourceUsername' is required", nameof(_configuration));
}

if (string.IsNullOrEmpty(_configuration.FtpSourcePassword))
{
throw new ArgumentException("Configuration 'FtpSourcePassword' is required", nameof(_configuration));
}

_cloudStorageAccount = ValidateAzureCloudStorageAccount(_configuration.AzureCdnCloudStorageAccount);
_azureCdnPlatform = ValidateAzureCdnPlatform(_configuration.AzureCdnPlatform);
_ftpServerUri = ValidateFtpUri(_configuration.FtpSourceUri);
}

private static CloudStorageAccount ValidateAzureCloudStorageAccount(string cloudStorageAccount)
Expand Down Expand Up @@ -110,14 +131,14 @@ private static Uri ValidateFtpUri(string serverUrl)

public override async Task Run()
{
var ftpClient = new FtpRawLogClient(LoggerFactory, _ftpUsername, _ftpPassword);
var ftpClient = new FtpRawLogClient(LoggerFactory, _configuration.FtpSourceUsername, _configuration.FtpSourcePassword);
var azureClient = new CloudBlobRawLogClient(LoggerFactory, _cloudStorageAccount);

// Collect directory listing.
var rawLogFileUris = await ftpClient.GetRawLogFileUris(_ftpServerUri);

// Prepare cloud storage blob container.
var cloudBlobContainer = await azureClient.CreateContainerIfNotExistsAsync(_cloudStorageContainerName);
var cloudBlobContainer = await azureClient.CreateContainerIfNotExistsAsync(_configuration.AzureCdnCloudStorageContainerName);

foreach (var rawLogFileUri in rawLogFileUris)
{
Expand All @@ -126,7 +147,7 @@ public override async Task Run()
var rawLogFile = new RawLogFileInfo(rawLogFileUri);

if (_azureCdnPlatform != rawLogFile.AzureCdnPlatform
|| !_azureCdnAccountNumber.Equals(rawLogFile.AzureCdnAccountNumber, StringComparison.InvariantCultureIgnoreCase))
|| !_configuration.AzureCdnAccountNumber.Equals(rawLogFile.AzureCdnAccountNumber, StringComparison.InvariantCultureIgnoreCase))
{
// Only process the raw log files matching the target CDN platform and account number.
continue;
Expand Down Expand Up @@ -367,5 +388,14 @@ private static string ToUnixTimeStamp(DateTime dateTime)
var secondsPastEpoch = (dateTime - _unixTimestamp).TotalSeconds;
return secondsPastEpoch.ToString(CultureInfo.InvariantCulture);
}

protected override void ConfigureAutofacServices(ContainerBuilder containerBuilder)
{
}

protected override void ConfigureJobServices(IServiceCollection services, IConfigurationRoot configurationRoot)
{
ConfigureInitializationSection<CollectAzureCdnLogsConfiguration>(services, configurationRoot);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,16 @@
cd bin

:Top
echo "Starting job - #{Jobs.stats.collectazurecdnlogs.Title}"
echo "Starting job - #{Jobs.stats.collectazurecdnlogs.Title}"

title #{Jobs.stats.collectazurecdnlogs.Title}
title #{Jobs.stats.collectazurecdnlogs.Title}

start /w stats.collectazurecdnlogs.exe -VaultName "#{Deployment.Azure.KeyVault.VaultName}" -ClientId "#{Deployment.Azure.KeyVault.ClientId}" -CertificateThumbprint "#{Deployment.Azure.KeyVault.CertificateThumbprint}" -FtpSourceUri "#{Jobs.stats.collectazurecdnlogs.FtpSource.Uri}" -FtpSourceUsername "#{Jobs.stats.collectazurecdnlogs.FtpSource.Username}" -FtpSourcePassword "#{Jobs.stats.collectazurecdnlogs.FtpSource.Password}" -AzureCdnAccountNumber "#{Jobs.stats.collectazurecdnlogs.AzureCdn.AccountNumber}" -AzureCdnPlatform "#{Jobs.stats.collectazurecdnlogs.AzureCdn.Platform}" -AzureCdnCloudStorageAccount "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageAccount}" -AzureCdnCloudStorageContainerName "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageContainerName}" -InstrumentationKey "#{Jobs.stats.collectazurecdnlogs.InstrumentationKey}" -verbose true -Interval #{Jobs.stats.collectazurecdnlogs.Interval}
start /w stats.collectazurecdnlogs.exe ^
-Configuration "#{Jobs.stats.collectazurecdnlogs.Configuration}" ^
-InstrumentationKey "#{Jobs.stats.collectazurecdnlogs.InstrumentationKey}" ^
-verbose true ^
-Interval #{Jobs.stats.collectazurecdnlogs.Interval}

echo "Finished #{Jobs.stats.collectazurecdnlogs.Title}"
echo "Finished #{Jobs.stats.collectazurecdnlogs.Title}"

goto Top
goto Top
18 changes: 18 additions & 0 deletions src/Stats.CollectAzureCdnLogs/Settings/dev.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"Initialization": {
"FtpSourceUri": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Uri}",
"FtpSourceUsername": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Username}",
"FtpSourcePassword": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Password}",
"AzureCdnAccountNumber": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.AccountNumber}",
"AzureCdnPlatform": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.Platform}",
"AzureCdnCloudStorageAccount": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageAccount}",
"AzureCdnCloudStorageContainerName": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageContainerName}"
},

"KeyVault_VaultName": "#{Deployment.Azure.KeyVault.VaultName}",
"KeyVault_ClientId": "#{Deployment.Azure.KeyVault.ClientId}",
"KeyVault_CertificateThumbprint": "#{Deployment.Azure.KeyVault.CertificateThumbprint}",
"KeyVault_ValidateCertificate": true,
"KeyVault_StoreName": "My",
"KeyVault_StoreLocation": "LocalMachine"
}
18 changes: 18 additions & 0 deletions src/Stats.CollectAzureCdnLogs/Settings/int.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"Initialization": {
"FtpSourceUri": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Uri}",
"FtpSourceUsername": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Username}",
"FtpSourcePassword": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Password}",
"AzureCdnAccountNumber": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.AccountNumber}",
"AzureCdnPlatform": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.Platform}",
"AzureCdnCloudStorageAccount": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageAccount}",
"AzureCdnCloudStorageContainerName": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageContainerName}"
},

"KeyVault_VaultName": "#{Deployment.Azure.KeyVault.VaultName}",
"KeyVault_ClientId": "#{Deployment.Azure.KeyVault.ClientId}",
"KeyVault_CertificateThumbprint": "#{Deployment.Azure.KeyVault.CertificateThumbprint}",
"KeyVault_ValidateCertificate": true,
"KeyVault_StoreName": "My",
"KeyVault_StoreLocation": "LocalMachine"
}
18 changes: 18 additions & 0 deletions src/Stats.CollectAzureCdnLogs/Settings/prod.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
{
"Initialization": {
"FtpSourceUri": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Uri}",
"FtpSourceUsername": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Username}",
"FtpSourcePassword": "#{Jobs.stats.collectazurecdnlogs.FtpSource.Password}",
"AzureCdnAccountNumber": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.AccountNumber}",
"AzureCdnPlatform": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.Platform}",
"AzureCdnCloudStorageAccount": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageAccount}",
"AzureCdnCloudStorageContainerName": "#{Jobs.stats.collectazurecdnlogs.AzureCdn.CloudStorageContainerName}"
},

"KeyVault_VaultName": "#{Deployment.Azure.KeyVault.VaultName}",
"KeyVault_ClientId": "#{Deployment.Azure.KeyVault.ClientId}",
"KeyVault_CertificateThumbprint": "#{Deployment.Azure.KeyVault.CertificateThumbprint}",
"KeyVault_ValidateCertificate": true,
"KeyVault_StoreName": "My",
"KeyVault_StoreLocation": "LocalMachine"
}
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@
</ItemGroup>
<ItemGroup>
<Compile Include="Blob\CloudBlobRawLogClient.cs" />
<Compile Include="Configuration\CollectAzureCdnLogsConfiguration.cs" />
<Compile Include="FileExtensions.cs" />
<Compile Include="Ftp\FtpDownloadStream.cs" />
<Compile Include="Ftp\FtpRawLogClient.cs" />
Expand All @@ -70,6 +71,9 @@
<SubType>Designer</SubType>
</None>
<None Include="Scripts\*" />
<None Include="Settings\dev.json" />
<None Include="Settings\int.json" />
<None Include="Settings\prod.json" />
<None Include="Stats.CollectAzureCdnLogs.nuspec" />
</ItemGroup>
<ItemGroup>
Expand Down Expand Up @@ -110,6 +114,7 @@
<Version>7.1.2</Version>
</PackageReference>
</ItemGroup>
<ItemGroup />
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
<PropertyGroup>
<SignPath>..\..\build</SignPath>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,7 @@
<file src="Scripts\PreDeploy.ps1" />
<file src="Scripts\PostDeploy.ps1" />
<file src="Scripts\nssm.exe" />

<file src="Settings\*.json" target="bin" />
</files>
</package>
16 changes: 0 additions & 16 deletions src/Stats.CollectAzureChinaCDNLogs/ArgumentNames.cs

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.

namespace Stats.CollectAzureChinaCDNLogs
{
public class CollectAzureChinaCdnLogsConfiguration
{
public string AzureAccountConnectionStringSource { get; set; }

public string AzureAccountConnectionStringDestination { get; set; }

public string AzureContainerNameSource { get; set; }

public string AzureContainerNameDestination { get; set; }

public string DestinationFilePrefix { get; set; }

public int? ExecutionTimeoutInSeconds { get; set; }
}
}
Loading

0 comments on commit 9537d56

Please sign in to comment.