|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
using System;
using System.Diagnostics;
namespace Microsoft.DotNet.SignTool
{
internal readonly struct SignInfo
{
/// <summary>
/// Used to flag that the signing for the file is not necessary.
/// </summary>
public static readonly SignInfo Ignore = new SignInfo(ignoreThisFile: true, alreadySigned: false, isAlreadyStrongNamed: false);
/// <summary>
/// Used to flag that the file is already signed.
/// </summary>
public static readonly SignInfo AlreadySigned = new SignInfo(ignoreThisFile: false, alreadySigned: true, isAlreadyStrongNamed: false);
/// <summary>
/// The authenticode certificate which should be used to sign the binary. This can be null
/// in cases where we have a zip container where the contents are signed but not the actual
/// container itself. This is the case when dealing with nupkg files.
/// </summary>
internal string Certificate { get; }
/// <summary>
/// This will be null in the case a strong name signing is not required.
/// </summary>
internal string StrongName { get; }
internal string Notarization { get; }
internal bool ShouldIgnore { get; }
internal bool IsAlreadyStrongNamed { get; }
internal bool IsAlreadySigned { get; }
/// <summary>
/// This is used to decide what SignInfos to use in the case of a collision. In case of a collision
/// we'll use the lower value since it would map a lower node in the graph and has precedence
/// over the rest
/// </summary>
internal string CollisionPriorityId { get; }
public bool ShouldLocallyStrongNameSign => ShouldStrongName && StrongName.EndsWith(".snk", StringComparison.OrdinalIgnoreCase);
public bool ShouldSign => !IsAlreadySigned && !ShouldIgnore;
public bool ShouldStrongName => !IsAlreadyStrongNamed && !string.IsNullOrEmpty(StrongName);
public bool ShouldNotarize => !string.IsNullOrEmpty(Notarization) && !ShouldIgnore;
public SignInfo(string certificate, string strongName, string notarization, string collisionPriorityId, bool shouldIgnore, bool isAlreadySigned, bool isAlreadyStrongNamed)
{
ShouldIgnore = shouldIgnore;
IsAlreadySigned = isAlreadySigned;
Certificate = certificate;
StrongName = strongName;
CollisionPriorityId = collisionPriorityId;
IsAlreadyStrongNamed = isAlreadyStrongNamed;
Notarization = notarization;
}
private SignInfo(bool ignoreThisFile, bool alreadySigned, bool isAlreadyStrongNamed)
: this(certificate: null, strongName: null, notarization: null, collisionPriorityId: null, ignoreThisFile, alreadySigned, isAlreadyStrongNamed)
{
}
internal SignInfo(string certificate, string strongName = null, string notarization = null, string collisionPriorityId = null)
: this(certificate, strongName, notarization, collisionPriorityId, shouldIgnore: false, isAlreadySigned: false, isAlreadyStrongNamed: false)
{
}
internal SignInfo WithCertificateName(string value, string collisionPriorityId)
=> new SignInfo(value, StrongName, Notarization, collisionPriorityId, ShouldIgnore, IsAlreadySigned, IsAlreadyStrongNamed);
internal SignInfo WithNotarization(string value, string collisionPriorityId)
=> new SignInfo(Certificate, StrongName, value, collisionPriorityId, ShouldIgnore, IsAlreadySigned, IsAlreadyStrongNamed);
internal SignInfo WithCollisionPriorityId(string collisionPriorityId)
=> new SignInfo(Certificate, StrongName, Notarization, collisionPriorityId, ShouldIgnore, IsAlreadySigned, IsAlreadyStrongNamed);
internal SignInfo WithIsAlreadySigned(bool value = false)
=> Certificate != null ?
new SignInfo(Certificate, StrongName, Notarization, CollisionPriorityId, value, value, IsAlreadyStrongNamed) :
new SignInfo(Certificate, StrongName, Notarization, CollisionPriorityId, true, value, IsAlreadyStrongNamed);
internal SignInfo WithIsAlreadyStrongNamed(bool value = false) =>
new SignInfo(Certificate, StrongName, Notarization, CollisionPriorityId, ShouldIgnore, IsAlreadySigned, value);
}
}
|