mirror of
https://github.com/TheShadowEevee/Sharpii-NetCore.git
synced 2025-01-11 14:58:51 -06:00
Added support for NUS downloading
This commit is contained in:
parent
9ca1f39600
commit
bb29106150
3 changed files with 232 additions and 1 deletions
223
Sharpii/NUSD.cs
Normal file
223
Sharpii/NUSD.cs
Normal file
|
@ -0,0 +1,223 @@
|
||||||
|
/* This file is part of Sharpii.
|
||||||
|
* Copyright (C) 2011 Person66
|
||||||
|
*
|
||||||
|
* Sharpii is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Sharpii is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Sharpii. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using libWiiSharp;
|
||||||
|
|
||||||
|
namespace Sharpii
|
||||||
|
{
|
||||||
|
partial class NUS_Stuff
|
||||||
|
{
|
||||||
|
public static void NUS(string[] args)
|
||||||
|
{
|
||||||
|
if (args.Length < 2)
|
||||||
|
{
|
||||||
|
NUS_help();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].ToUpper() == "-H" || args[1].ToUpper() == "-HELP")
|
||||||
|
{
|
||||||
|
NUS_help();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Set up variables
|
||||||
|
string id = "";
|
||||||
|
int version = -1;
|
||||||
|
string output = "";
|
||||||
|
bool local = false;
|
||||||
|
List<StoreType> store = new List<StoreType>();
|
||||||
|
bool entered = false;
|
||||||
|
|
||||||
|
//Get arguments
|
||||||
|
for (int i = 1; i < args.Length; i++)
|
||||||
|
{
|
||||||
|
switch (args[i].ToUpper())
|
||||||
|
{
|
||||||
|
case "-ALL":
|
||||||
|
store.Add(StoreType.All);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-WAD":
|
||||||
|
store.Add(StoreType.WAD);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-ENCRYPT":
|
||||||
|
store.Add(StoreType.EncryptedContent);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-ENCRYPTED":
|
||||||
|
store.Add(StoreType.EncryptedContent);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-DECRYPT":
|
||||||
|
store.Add(StoreType.DecryptedContent);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-DECRYPTED":
|
||||||
|
store.Add(StoreType.DecryptedContent);
|
||||||
|
entered = true;
|
||||||
|
break;
|
||||||
|
case "-LOCAL":
|
||||||
|
local = true;
|
||||||
|
break;
|
||||||
|
case "-V":
|
||||||
|
if (i + 1 >= args.Length)
|
||||||
|
{
|
||||||
|
Console.WriteLine("ERROR: No version set");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!int.TryParse(args[i + 1], out version))
|
||||||
|
{
|
||||||
|
Console.WriteLine("Invalid version {0}...", args[i + 1]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (version < 0 || version > 65535)
|
||||||
|
{
|
||||||
|
Console.WriteLine("Invalid version {0}...", version);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "-VERSION":
|
||||||
|
if (i + 1 >= args.Length)
|
||||||
|
{
|
||||||
|
Console.WriteLine("ERROR: No version set");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!int.TryParse(args[i + 1], out version))
|
||||||
|
{
|
||||||
|
Console.WriteLine("Invalid version {0}...", args[i + 1]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (version < 0 || version > 65535)
|
||||||
|
{
|
||||||
|
Console.WriteLine("Invalid version {0}...", version);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "-O":
|
||||||
|
if (i + 1 >= args.Length)
|
||||||
|
{
|
||||||
|
Console.WriteLine("ERROR: No output set");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
output = args[i + 1];
|
||||||
|
break;
|
||||||
|
case "-ID":
|
||||||
|
if (i + 1 >= args.Length)
|
||||||
|
{
|
||||||
|
Console.WriteLine("ERROR: No ID specified");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
id = args[i + 1];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Error checking
|
||||||
|
if (id == "")
|
||||||
|
{
|
||||||
|
System.Console.WriteLine("ERROR: No ID specified");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (version == -1)
|
||||||
|
{
|
||||||
|
System.Console.WriteLine("ERROR: No version specified");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (output == "")
|
||||||
|
{
|
||||||
|
output = id + "v" + version;
|
||||||
|
if (Quiet.quiet > 2)
|
||||||
|
System.Console.WriteLine("No output specified, using {0}", output);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (entered == false) //Will only be false if no store type argument was given
|
||||||
|
{
|
||||||
|
store.Add(StoreType.All);
|
||||||
|
if (Quiet.quiet > 2)
|
||||||
|
System.Console.WriteLine("No store type specified, using all");
|
||||||
|
}
|
||||||
|
|
||||||
|
//Main part, catches random/unexpected exceptions
|
||||||
|
try
|
||||||
|
{
|
||||||
|
NusClient nus = new NusClient();
|
||||||
|
|
||||||
|
if (local == true)
|
||||||
|
{
|
||||||
|
if (Quiet.quiet > 2)
|
||||||
|
System.Console.WriteLine("Using local files if present...");
|
||||||
|
nus.UseLocalFiles = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Quiet.quiet > 1)
|
||||||
|
System.Console.Write("Downloading title...");
|
||||||
|
|
||||||
|
nus.DownloadTitle(id, version.ToString(), output, store.ToArray());
|
||||||
|
|
||||||
|
if (Quiet.quiet > 1)
|
||||||
|
System.Console.Write("Done!\n");
|
||||||
|
|
||||||
|
if (Quiet.quiet > 1)
|
||||||
|
System.Console.WriteLine("Operation completed succesfully!");
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
System.Console.WriteLine("An unknown error occured, please try again");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine("ERROR DETAILS: {0}", ex.Message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void NUS_help()
|
||||||
|
{
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine("Sharpii {0} - NUSD - A tool by person66, using libWiiSharp.dll by leathl", Version.version);
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine(" Usage:");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine(" Sharpii.exe NUSD [-id titleID] [-v version] [-o otput] [-all] [-wad]");
|
||||||
|
System.Console.WriteLine(" [-decrypt] [-encrypt] [-local]");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine(" Arguments:");
|
||||||
|
System.Console.WriteLine("");
|
||||||
|
System.Console.WriteLine(" -id titleID [required] The Title ID of the file you wish to download");
|
||||||
|
System.Console.WriteLine(" -v version [required] The version of the file you wish to download");
|
||||||
|
System.Console.WriteLine(" -o output Folder to output the files to");
|
||||||
|
System.Console.WriteLine(" -local Use local files if present");
|
||||||
|
System.Console.WriteLine(" -all Create and keep encrypted, decrypted, and WAD versions");
|
||||||
|
System.Console.WriteLine(" of the file you wish to download");
|
||||||
|
System.Console.WriteLine(" -wad Keep only the WAD version of the file you wish to");
|
||||||
|
System.Console.WriteLine(" download");
|
||||||
|
System.Console.WriteLine(" -decrypt Keep only the Decrypted contents of the file you wish to");
|
||||||
|
System.Console.WriteLine(" download");
|
||||||
|
System.Console.WriteLine(" -encrypt Keep only the Encrypted contents of the file you wish to");
|
||||||
|
System.Console.WriteLine(" download");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -85,6 +85,12 @@ namespace Sharpii
|
||||||
Environment.Exit(0);
|
Environment.Exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Function.ToUpper() == "NUS" || Function.ToUpper() == "NUSD")
|
||||||
|
{
|
||||||
|
NUS_Stuff.NUS(args);
|
||||||
|
Environment.Exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
if (Function.ToUpper() == "SENDDOL" || Function.ToUpper() == "SENDOL")
|
if (Function.ToUpper() == "SENDDOL" || Function.ToUpper() == "SENDOL")
|
||||||
{
|
{
|
||||||
HBC_Stuff.SendDol(args);
|
HBC_Stuff.SendDol(args);
|
||||||
|
@ -117,6 +123,7 @@ namespace Sharpii
|
||||||
System.Console.WriteLine(" TPL Convert a image to a tpl, or vice versa");
|
System.Console.WriteLine(" TPL Convert a image to a tpl, or vice versa");
|
||||||
System.Console.WriteLine(" U8 Pack/Unpack a U8 archive");
|
System.Console.WriteLine(" U8 Pack/Unpack a U8 archive");
|
||||||
System.Console.WriteLine(" IOS Apply various patches to an IOS");
|
System.Console.WriteLine(" IOS Apply various patches to an IOS");
|
||||||
|
System.Console.WriteLine(" NUSD Download files from NUS");
|
||||||
System.Console.WriteLine(" SendDol Send a dol to the HBC over wifi");
|
System.Console.WriteLine(" SendDol Send a dol to the HBC over wifi");
|
||||||
System.Console.WriteLine("");
|
System.Console.WriteLine("");
|
||||||
System.Console.WriteLine(" NOTE: Too see more detailed descriptions of any of the above,");
|
System.Console.WriteLine(" NOTE: Too see more detailed descriptions of any of the above,");
|
||||||
|
@ -142,5 +149,5 @@ namespace Sharpii
|
||||||
}
|
}
|
||||||
public class Version
|
public class Version
|
||||||
{
|
{
|
||||||
public static string version = "1.0";
|
public static string version = "1.1";
|
||||||
}
|
}
|
|
@ -60,6 +60,7 @@
|
||||||
<Reference Include="System.Drawing" />
|
<Reference Include="System.Drawing" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Compile Include="NUSD.cs" />
|
||||||
<Compile Include="HBC.cs" />
|
<Compile Include="HBC.cs" />
|
||||||
<Compile Include="IOS.cs" />
|
<Compile Include="IOS.cs" />
|
||||||
<Compile Include="U8.cs" />
|
<Compile Include="U8.cs" />
|
||||||
|
|
Loading…
Reference in a new issue