#nullable disable
namespace StardewModdingAPI.Web.Framework
{
/// Generic metadata about a mod.
internal class ModInfoModel
{
/*********
** Accessors
*********/
/// The mod name.
public string Name { get; set; }
/// The mod's latest version.
public ISemanticVersion Version { get; set; }
/// The mod's latest optional or prerelease version, if newer than .
public ISemanticVersion PreviewVersion { get; set; }
/// The mod's web URL.
public string Url { get; set; }
/// The mod availability status on the remote site.
public RemoteModStatus Status { get; set; } = RemoteModStatus.Ok;
/// The error message indicating why the mod is invalid (if applicable).
public string Error { get; set; }
/*********
** Public methods
*********/
/// Construct an empty instance.
public ModInfoModel() { }
/// Construct an instance.
/// The mod name.
/// The semantic version for the mod's latest release.
/// The semantic version for the mod's latest preview release, if available and different from .
/// The mod's web URL.
public ModInfoModel(string name, ISemanticVersion version, string url, ISemanticVersion previewVersion = null)
{
this
.SetBasicInfo(name, url)
.SetVersions(version, previewVersion);
}
/// Set the basic mod info.
/// The mod name.
/// The mod's web URL.
public ModInfoModel SetBasicInfo(string name, string url)
{
this.Name = name;
this.Url = url;
return this;
}
/// Set the mod version info.
/// The semantic version for the mod's latest release.
/// The semantic version for the mod's latest preview release, if available and different from .
public ModInfoModel SetVersions(ISemanticVersion version, ISemanticVersion previewVersion = null)
{
this.Version = version;
this.PreviewVersion = previewVersion;
return this;
}
/// Set a mod error.
/// The mod availability status on the remote site.
/// The error message indicating why the mod is invalid (if applicable).
public ModInfoModel SetError(RemoteModStatus status, string error)
{
this.Status = status;
this.Error = error;
return this;
}
}
}