mirror of
https://github.com/TheShadowEevee/libWiiSharp.git
synced 2025-01-11 15:38:51 -06:00
Add IDE Annotaions to NusClient.cs
This commit is contained in:
parent
f2183837bd
commit
a147e64b79
1 changed files with 101 additions and 15 deletions
114
NusClient.cs
114
NusClient.cs
|
@ -63,10 +63,7 @@ namespace libWiiSharp
|
||||||
set => continueWithoutTicket = value;
|
set => continueWithoutTicket = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public event EventHandler<ProgressChangedEventArgs> Progress;
|
#region IDisposable Members
|
||||||
|
|
||||||
public event EventHandler<MessageEventArgs> Debug;
|
|
||||||
|
|
||||||
~NusClient() => Dispose(false);
|
~NusClient() => Dispose(false);
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
|
@ -84,7 +81,17 @@ namespace libWiiSharp
|
||||||
|
|
||||||
isDisposed = true;
|
isDisposed = true;
|
||||||
}
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Public Functions
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a title from NUS, you can define several store types.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="outputDir"></param>
|
||||||
|
/// <param name="storeTypes"></param>
|
||||||
public void DownloadTitle(string titleId, string titleVersion, string outputDir, params StoreType[] storeTypes)
|
public void DownloadTitle(string titleId, string titleVersion, string outputDir, params StoreType[] storeTypes)
|
||||||
{
|
{
|
||||||
if (titleId.Length != 16)
|
if (titleId.Length != 16)
|
||||||
|
@ -96,6 +103,16 @@ namespace libWiiSharp
|
||||||
PrivDownloadTitle(titleId, titleVersion, outputDir, storeTypes);
|
PrivDownloadTitle(titleId, titleVersion, outputDir, storeTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a title from NUS, you can define several store types.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/"
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="outputDir"></param>
|
||||||
|
/// <param name="nusUrl"></param>
|
||||||
|
/// <param name="storeTypes"></param>
|
||||||
public void DownloadTitle(string titleId, string titleVersion, string outputDir, string nusUrl, params StoreType[] storeTypes)
|
public void DownloadTitle(string titleId, string titleVersion, string outputDir, string nusUrl, params StoreType[] storeTypes)
|
||||||
{
|
{
|
||||||
if (titleId.Length != 16)
|
if (titleId.Length != 16)
|
||||||
|
@ -107,30 +124,66 @@ namespace libWiiSharp
|
||||||
PrivDownloadTitle(titleId, titleVersion, outputDir, nusUrl, storeTypes);
|
PrivDownloadTitle(titleId, titleVersion, outputDir, nusUrl, storeTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a TMD from NUS.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public TMD DownloadTMD(string titleId, string titleVersion)
|
public TMD DownloadTMD(string titleId, string titleVersion)
|
||||||
{
|
{
|
||||||
if (isStopRequired) return null;
|
if (isStopRequired) return null;
|
||||||
return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion) : throw new Exception("Title ID must be 16 characters long!");
|
return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion) : throw new Exception("Title ID must be 16 characters long!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a TMD from NUS.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/"
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="nusUrl"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public TMD DownloadTMD(string titleId, string titleVersion, string nusUrl)
|
public TMD DownloadTMD(string titleId, string titleVersion, string nusUrl)
|
||||||
{
|
{
|
||||||
if (isStopRequired) return null;
|
if (isStopRequired) return null;
|
||||||
return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion, nusUrl) : throw new Exception("Title ID must be 16 characters long!");
|
return titleId.Length == 16 ? PrivDownloadTmd(titleId, titleVersion, nusUrl) : throw new Exception("Title ID must be 16 characters long!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a Ticket from NUS.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public Ticket DownloadTicket(string titleId)
|
public Ticket DownloadTicket(string titleId)
|
||||||
{
|
{
|
||||||
if (isStopRequired) return null;
|
if (isStopRequired) return null;
|
||||||
return titleId.Length == 16 ? PrivDownloadTicket(titleId) : throw new Exception("Title ID must be 16 characters long!");
|
return titleId.Length == 16 ? PrivDownloadTicket(titleId) : throw new Exception("Title ID must be 16 characters long!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a Ticket from NUS.
|
||||||
|
/// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/"
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="nusUrl"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public Ticket DownloadTicket(string titleId, string nusUrl)
|
public Ticket DownloadTicket(string titleId, string nusUrl)
|
||||||
{
|
{
|
||||||
if (isStopRequired) return null;
|
if (isStopRequired) return null;
|
||||||
return titleId.Length == 16 ? PrivDownloadTicket(titleId, nusUrl) : throw new Exception("Title ID must be 16 characters long!");
|
return titleId.Length == 16 ? PrivDownloadTicket(titleId, nusUrl) : throw new Exception("Title ID must be 16 characters long!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a single content file and decrypts it.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="contentId"></param>
|
||||||
|
/// <returns></returns>
|
||||||
public byte[] DownloadSingleContent(string titleId, string titleVersion, string contentId)
|
public byte[] DownloadSingleContent(string titleId, string titleVersion, string contentId)
|
||||||
{
|
{
|
||||||
if (isStopRequired) return null;
|
if (isStopRequired) return null;
|
||||||
|
@ -142,6 +195,14 @@ namespace libWiiSharp
|
||||||
return PrivDownloadSingleContent(titleId, titleVersion, contentId);
|
return PrivDownloadSingleContent(titleId, titleVersion, contentId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a single content file and decrypts it.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="contentId"></param>
|
||||||
|
/// <param name="savePath"></param>
|
||||||
public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath)
|
public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath)
|
||||||
{
|
{
|
||||||
if (titleId.Length != 16)
|
if (titleId.Length != 16)
|
||||||
|
@ -163,6 +224,16 @@ namespace libWiiSharp
|
||||||
File.WriteAllBytes(savePath, bytes);
|
File.WriteAllBytes(savePath, bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Grabs a single content file and decrypts it.
|
||||||
|
/// Leave the title version empty for the latest.
|
||||||
|
/// nusUrl should be formatted as "http://x.y.z.host.com/ccs/download/"
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="titleId"></param>
|
||||||
|
/// <param name="titleVersion"></param>
|
||||||
|
/// <param name="contentId"></param>
|
||||||
|
/// <param name="savePath"></param>
|
||||||
|
/// <param name="nusUrl"></param>
|
||||||
public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath, string nusUrl)
|
public void DownloadSingleContent(string titleId, string titleVersion, string contentId, string savePath, string nusUrl)
|
||||||
{
|
{
|
||||||
if (titleId.Length != 16)
|
if (titleId.Length != 16)
|
||||||
|
@ -183,7 +254,9 @@ namespace libWiiSharp
|
||||||
byte[] bytes = PrivDownloadSingleContent(titleId, titleVersion, contentId, nusUrl);
|
byte[] bytes = PrivDownloadSingleContent(titleId, titleVersion, contentId, nusUrl);
|
||||||
File.WriteAllBytes(savePath, bytes);
|
File.WriteAllBytes(savePath, bytes);
|
||||||
}
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Private Functions
|
||||||
private byte[] PrivDownloadSingleContent(string titleId, string titleVersion, string contentId)
|
private byte[] PrivDownloadSingleContent(string titleId, string titleVersion, string contentId)
|
||||||
{
|
{
|
||||||
uint num = uint.Parse(contentId, NumberStyles.HexNumber);
|
uint num = uint.Parse(contentId, NumberStyles.HexNumber);
|
||||||
|
@ -952,6 +1025,28 @@ namespace libWiiSharp
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Events
|
||||||
|
/// <summary>
|
||||||
|
/// Fires the Progress of various operations
|
||||||
|
/// </summary>
|
||||||
|
public event EventHandler<ProgressChangedEventArgs> Progress;
|
||||||
|
/// <summary>
|
||||||
|
/// Fires debugging messages. You may write them into a log file or log textbox.
|
||||||
|
/// </summary>
|
||||||
|
public event EventHandler<MessageEventArgs> Debug;
|
||||||
|
|
||||||
|
private void FireProgress(int progressPercentage)
|
||||||
|
{
|
||||||
|
EventHandler<ProgressChangedEventArgs> progress = Progress;
|
||||||
|
if (progress == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
progress(new object(), new ProgressChangedEventArgs(progressPercentage, string.Empty));
|
||||||
|
}
|
||||||
|
|
||||||
private void FireDebug(string debugMessage, params object[] args)
|
private void FireDebug(string debugMessage, params object[] args)
|
||||||
{
|
{
|
||||||
|
@ -964,15 +1059,6 @@ namespace libWiiSharp
|
||||||
debug(new object(), new MessageEventArgs(string.Format(debugMessage, args)));
|
debug(new object(), new MessageEventArgs(string.Format(debugMessage, args)));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FireProgress(int progressPercentage)
|
#endregion
|
||||||
{
|
|
||||||
EventHandler<ProgressChangedEventArgs> progress = Progress;
|
|
||||||
if (progress == null)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
progress(new object(), new ProgressChangedEventArgs(progressPercentage, string.Empty));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue