Compare commits

...

8 Commits

Author SHA1 Message Date
nerdunit
a8181b7052 Update bug_report.md 2020-11-12 07:39:54 -08:00
nerdunit
b9af1909d4 Update bug_report.md 2020-11-12 07:25:32 -08:00
nerdunit
f2fdc7f5f4 Create feature_request.md 2020-11-12 07:20:48 -08:00
nerdunit
ce38e1374e Create bug_report.md 2020-11-12 07:18:36 -08:00
nerdunit
5db29e0215 v1.16 2020-11-12 03:35:51 -08:00
nerdunit
8b0d724253 Update version 2020-11-12 03:35:48 -08:00
nerdunit
9ca02c9e4f Add files via upload 2020-11-06 08:44:19 -08:00
nerdunit
9bc80c73b4 Update version 2020-11-06 08:41:08 -08:00
24 changed files with 507 additions and 280 deletions

30
.github/ISSUE_TEMPLATE/bug_report.md vendored Normal file
View File

@@ -0,0 +1,30 @@
---
name: Bug report 🐞
about: Create a report to help us improve
title: ''
labels: bug
---
**Describe the bug**
A clear and concise description of what the bug is.
**To Reproduce**
Steps to reproduce the behavior:
1. Go to '...'
2. Click on '....'
3. Scroll down to '....'
4. See error
**Expected behavior**
A clear and concise description of what you expected to happen.
**Screenshots**
If applicable, add screenshots to help explain your problem.
**Environment (please complete the following information):**
- Debuglog.txt file from the sideloader folder
- adb.log file from %USERNAME%\AppData\Local\Temp
- log.txt from the sideloader\rclone
- OS [e.g. Windows 10 build 1833]
- Version [e.g. 1.15]
**Additional context**
Add any other context about the problem here.

View File

@@ -0,0 +1,11 @@
---
name: Feature Request 💡
about: Suggest a new idea for the project.
labels: enhancement
---
## Summary
Brief explanation of the feature.
### Basic example
If the proposal involves a new or changed API, include a basic code example. Omit this section if it's not applicable.
### Motivation
Why are we doing this? What use cases does it support? What is the expected outcome?

19
ADB.cs
View File

@@ -1,22 +1,6 @@
using System;
using System.Diagnostics;
using System.Windows.Forms;
using System.IO;
using System.Threading;
using System.Collections.Generic;
using System.Drawing;
using System.Management;
using System.ComponentModel;
using System.Text;
using System.Threading.Tasks;
using System.Net.Http;
using System.Windows.Threading;
using System.Net;
using SergeUtils;
using JR.Utils.GUI.Forms;
using Newtonsoft.Json;
using System.Globalization;
using System.Linq;
namespace AndroidSideloader
{
@@ -33,7 +17,6 @@ namespace AndroidSideloader
if (DeviceID.Length > 1)
command = $" -s {DeviceID} {command}";
Logger.Log($"Running command {command}");
adb.StartInfo.FileName = Environment.CurrentDirectory + "\\adb\\adb.exe";
adb.StartInfo.Arguments = command;
@@ -57,7 +40,7 @@ namespace AndroidSideloader
adb.WaitForExit();
IsRunningCommand = false;
Logger.Log($"Output {output}");
Logger.Log(output);
return output;
}

View File

@@ -195,6 +195,7 @@
<Compile Include="SettingsForm.Designer.cs">
<DependentUpon>SettingsForm.cs</DependentUpon>
</Compile>
<Compile Include="Sideloader.cs" />
<Compile Include="spoofer.cs" />
<Compile Include="SpoofForm.cs">
<SubType>Form</SubType>
@@ -202,6 +203,10 @@
<Compile Include="SpoofForm.Designer.cs">
<DependentUpon>SpoofForm.cs</DependentUpon>
</Compile>
<Compile Include="ThemeForm.cs" />
<Compile Include="ThemeForm.Designer.cs">
<DependentUpon>ThemeForm.cs</DependentUpon>
</Compile>
<Compile Include="UsernameForm.cs">
<SubType>Form</SubType>
</Compile>
@@ -241,12 +246,18 @@
<EmbeddedResource Include="SpoofForm.resx">
<DependentUpon>SpoofForm.cs</DependentUpon>
</EmbeddedResource>
<EmbeddedResource Include="ThemeForm.resx">
<DependentUpon>ThemeForm.cs</DependentUpon>
</EmbeddedResource>
<EmbeddedResource Include="UsernameForm.resx">
<DependentUpon>UsernameForm.cs</DependentUpon>
<SubType>Designer</SubType>
</EmbeddedResource>
<None Include=".editorconfig" />
<None Include="AndroidSideloader_TemporaryKey.pfx" />
<None Include="keypair.snk">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="packages.config" />
<None Include="Properties\Settings.settings">
<Generator>SettingsSingleFileGenerator</Generator>
@@ -257,6 +268,9 @@
<DependentUpon>Settings.settings</DependentUpon>
<DesignTimeSharedInput>True</DesignTimeSharedInput>
</Compile>
<None Include="public.snk">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
</ItemGroup>
<ItemGroup>
<None Include="App.config" />
@@ -288,4 +302,12 @@
<Error Condition="!Exists('packages\Fody.6.0.0\build\Fody.targets')" Text="$([System.String]::Format('$(ErrorText)', 'packages\Fody.6.0.0\build\Fody.targets'))" />
<Error Condition="!Exists('packages\Costura.Fody.4.1.0\build\Costura.Fody.props')" Text="$([System.String]::Format('$(ErrorText)', 'packages\Costura.Fody.4.1.0\build\Costura.Fody.props'))" />
</Target>
<PropertyGroup>
<PreBuildEvent>
</PreBuildEvent>
</PropertyGroup>
<PropertyGroup>
<PostBuildEvent>
</PostBuildEvent>
</PropertyGroup>
</Project>

View File

@@ -2,6 +2,7 @@
<configuration>
<configSections>
<sectionGroup name="userSettings" type="System.Configuration.UserSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
<section name="AndroidSideloader.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
<section name="AndroidADB.Sideloader.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
</sectionGroup>
</configSections>
@@ -9,6 +10,65 @@
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
</startup>
<userSettings>
<AndroidSideloader.Properties.Settings>
<setting name="checkForUpdates" serializeAs="String">
<value>True</value>
</setting>
<setting name="enableMessageBoxes" serializeAs="String">
<value>True</value>
</setting>
<setting name="logRclone" serializeAs="String">
<value>False</value>
</setting>
<setting name="firstRun" serializeAs="String">
<value>True</value>
</setting>
<setting name="deleteAllAfterInstall" serializeAs="String">
<value>True</value>
</setting>
<setting name="autoUpdateConfig" serializeAs="String">
<value>True</value>
</setting>
<setting name="userJsonOnGameInstall" serializeAs="String">
<value>True</value>
</setting>
<setting name="CallUpgrade" serializeAs="String">
<value>True</value>
</setting>
<setting name="BackColor" serializeAs="String">
<value>45, 45, 45</value>
</setting>
<setting name="PanelColor" serializeAs="String">
<value>ActiveCaptionText</value>
</setting>
<setting name="ButtonColor" serializeAs="String">
<value>ActiveCaptionText</value>
</setting>
<setting name="SubButtonColor" serializeAs="String">
<value>64, 64, 64</value>
</setting>
<setting name="TextBoxColor" serializeAs="String">
<value>45, 45, 45</value>
</setting>
<setting name="ComboBoxColor" serializeAs="String">
<value>45, 45, 45</value>
</setting>
<setting name="FontColor" serializeAs="String">
<value>White</value>
</setting>
<setting name="FontStyle" serializeAs="String">
<value>Microsoft Sans Serif, 11.25pt</value>
</setting>
<setting name="BackPicturePath" serializeAs="String">
<value />
</setting>
<setting name="SpoofGames" serializeAs="String">
<value>False</value>
</setting>
<setting name="BandwithLimit" serializeAs="String">
<value />
</setting>
</AndroidSideloader.Properties.Settings>
<AndroidADB.Sideloader.Properties.Settings>
<setting name="checkForUpdates" serializeAs="String">
<value>True</value>

47
Form1.Designer.cs generated
View File

@@ -46,6 +46,7 @@
this.aboutBtn = new System.Windows.Forms.Button();
this.settingsButton = new System.Windows.Forms.Button();
this.otherContainer = new System.Windows.Forms.Panel();
this.SpoofFormButton = new System.Windows.Forms.Button();
this.QuestOptionsButton = new System.Windows.Forms.Button();
this.killRcloneButton = new System.Windows.Forms.Button();
this.movieStreamButton = new System.Windows.Forms.Button();
@@ -64,7 +65,6 @@
this.freeDisclaimer = new System.Windows.Forms.Label();
this.devicesComboBox = new System.Windows.Forms.ComboBox();
this.remotesList = new System.Windows.Forms.ComboBox();
this.SpoofFormButton = new System.Windows.Forms.Button();
this.panel1.SuspendLayout();
this.otherContainer.SuspendLayout();
this.backupContainer.SuspendLayout();
@@ -395,6 +395,27 @@
this.otherContainer.Size = new System.Drawing.Size(218, 148);
this.otherContainer.TabIndex = 80;
//
// SpoofFormButton
//
this.SpoofFormButton.BackColor = global::AndroidSideloader.Properties.Settings.Default.SubButtonColor;
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("BackColor", global::AndroidSideloader.Properties.Settings.Default, "SubButtonColor", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("Font", global::AndroidSideloader.Properties.Settings.Default, "FontStyle", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("ForeColor", global::AndroidSideloader.Properties.Settings.Default, "FontColor", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.Dock = System.Windows.Forms.DockStyle.Top;
this.SpoofFormButton.FlatAppearance.BorderSize = 0;
this.SpoofFormButton.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
this.SpoofFormButton.Font = global::AndroidSideloader.Properties.Settings.Default.FontStyle;
this.SpoofFormButton.ForeColor = global::AndroidSideloader.Properties.Settings.Default.FontColor;
this.SpoofFormButton.Location = new System.Drawing.Point(0, 112);
this.SpoofFormButton.Name = "SpoofFormButton";
this.SpoofFormButton.Padding = new System.Windows.Forms.Padding(23, 0, 0, 0);
this.SpoofFormButton.Size = new System.Drawing.Size(218, 28);
this.SpoofFormButton.TabIndex = 17;
this.SpoofFormButton.Text = "SPOOF";
this.SpoofFormButton.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
this.SpoofFormButton.UseVisualStyleBackColor = false;
this.SpoofFormButton.Click += new System.EventHandler(this.SpoofFormButton_Click);
//
// QuestOptionsButton
//
this.QuestOptionsButton.BackColor = global::AndroidSideloader.Properties.Settings.Default.SubButtonColor;
@@ -414,7 +435,7 @@
this.QuestOptionsButton.Text = "QUEST OPTIONS";
this.QuestOptionsButton.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
this.QuestOptionsButton.UseVisualStyleBackColor = false;
this.QuestOptionsButton.Click += new System.EventHandler(this.QuestOptionsButton_Click_1);
this.QuestOptionsButton.Click += new System.EventHandler(this.QuestOptionsButton_Click);
//
// killRcloneButton
//
@@ -608,7 +629,6 @@
this.pictureBox1.SizeMode = System.Windows.Forms.PictureBoxSizeMode.StretchImage;
this.pictureBox1.TabIndex = 74;
this.pictureBox1.TabStop = false;
this.pictureBox1.Click += new System.EventHandler(this.pictureBox1_Click);
//
// etaLabel
//
@@ -696,27 +716,6 @@
this.remotesList.Text = "Select a mirror";
this.remotesList.SelectedIndexChanged += new System.EventHandler(this.remotesList_SelectedIndexChanged);
//
// SpoofFormButton
//
this.SpoofFormButton.BackColor = global::AndroidSideloader.Properties.Settings.Default.SubButtonColor;
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("BackColor", global::AndroidSideloader.Properties.Settings.Default, "SubButtonColor", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("Font", global::AndroidSideloader.Properties.Settings.Default, "FontStyle", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.DataBindings.Add(new System.Windows.Forms.Binding("ForeColor", global::AndroidSideloader.Properties.Settings.Default, "FontColor", true, System.Windows.Forms.DataSourceUpdateMode.OnPropertyChanged));
this.SpoofFormButton.Dock = System.Windows.Forms.DockStyle.Top;
this.SpoofFormButton.FlatAppearance.BorderSize = 0;
this.SpoofFormButton.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
this.SpoofFormButton.Font = global::AndroidSideloader.Properties.Settings.Default.FontStyle;
this.SpoofFormButton.ForeColor = global::AndroidSideloader.Properties.Settings.Default.FontColor;
this.SpoofFormButton.Location = new System.Drawing.Point(0, 112);
this.SpoofFormButton.Name = "SpoofFormButton";
this.SpoofFormButton.Padding = new System.Windows.Forms.Padding(23, 0, 0, 0);
this.SpoofFormButton.Size = new System.Drawing.Size(218, 28);
this.SpoofFormButton.TabIndex = 17;
this.SpoofFormButton.Text = "SPOOF";
this.SpoofFormButton.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
this.SpoofFormButton.UseVisualStyleBackColor = false;
this.SpoofFormButton.Click += new System.EventHandler(this.SpoofFormButton_Click);
//
// Form1
//
this.AllowDrop = true;

243
Form1.cs
View File

@@ -4,19 +4,13 @@ using System.Windows.Forms;
using System.IO;
using System.Threading;
using System.Collections.Generic;
using System.Drawing;
using System.Management;
using System.ComponentModel;
using System.Text;
using System.Threading.Tasks;
using System.Net.Http;
using System.Windows.Threading;
using System.Net;
using SergeUtils;
using JR.Utils.GUI.Forms;
using Newtonsoft.Json;
using System.Globalization;
using System.Linq;
using Spoofer;
namespace AndroidSideloader
@@ -29,14 +23,9 @@ namespace AndroidSideloader
#else
public static bool debugMode = false;
#endif
string path;
string allText;
bool is1April = false;
string rclonepw = "";
public Form1()
{
InitializeComponent();
@@ -62,8 +51,6 @@ namespace AndroidSideloader
}
}
List<string> listBoxItems = new List<string>();
void AprilPrank()
{
if (is1April)
@@ -77,6 +64,8 @@ namespace AndroidSideloader
private async void startsideloadbutton_Click(object sender, EventArgs e)
{
string output = string.Empty;
string path = string.Empty;
using (OpenFileDialog openFileDialog = new OpenFileDialog())
{
openFileDialog.Filter = "Android apps (*.apk)|*.apk";
@@ -92,7 +81,7 @@ namespace AndroidSideloader
ADB.DeviceID = GetDeviceID();
Thread t1 = new Thread(() =>
{
ADB.Sideload(path);
output += ADB.Sideload(path);
});
t1.IsBackground = true;
t1.Start();
@@ -101,9 +90,6 @@ namespace AndroidSideloader
await Task.Delay(100);
showAvailableSpace();
if (!is1April)
notify(allText);
}
List<string> Devices = new List<string>();
async Task<int> CheckForDevice()
@@ -164,6 +150,7 @@ namespace AndroidSideloader
private async void obbcopybutton_Click(object sender, EventArgs e)
{
string output = string.Empty;
var dialog = new FolderSelectDialog
{
Title = "Select your obb folder"
@@ -174,7 +161,7 @@ namespace AndroidSideloader
Thread t1 = new Thread(() =>
{
ADB.CopyOBB(dialog.FileName);
output += ADB.CopyOBB(dialog.FileName);
});
t1.IsBackground = true;
t1.Start();
@@ -186,12 +173,12 @@ namespace AndroidSideloader
}
else return;
notify(allText);
notify(output);
}
private async void ChangeTitlebarToDevice()
private void ChangeTitlebarToDevice()
{
if (Devices.Count > 1 && !Devices.Contains("unauthorized"))
if (!Devices.Contains("unauthorized"))
{
if (Devices[0].Length > 1 && Devices[0].Contains("unauthorized"))
this.Invoke(() => { this.Text = "Rookie's Sideloader | Device Not Authorized"; });
@@ -295,6 +282,13 @@ namespace AndroidSideloader
private async void Form1_Load(object sender, EventArgs e)
{
//Delete the Debug file if it is more than 5MB
if (File.Exists(Logger.logfile))
{
long length = new System.IO.FileInfo(Logger.logfile).Length;
if (length > 5000000) File.Delete(Logger.logfile);
}
ChangeTitle("Loading...");
try { Spoofer.spoofer.Init(); } catch { }
progressBar.Style = ProgressBarStyle.Marquee;
@@ -308,14 +302,13 @@ namespace AndroidSideloader
this.CenterToScreen();
try { downloadFiles(); } catch { notify("You must have internet access for initial downloads, you can try:\n1. Disabling the firewall and antivirus\n2. Delete every file from the sideloader besides the .exe\n3. Try a vpn\n"); }
etaLabel.Text = "";
speedLabel.Text = "";
diskLabel.Text = "";
this.Activate();
downloadFiles(); await Task.Delay(100);
//this.Activate();
await CheckForDevice();
@@ -323,16 +316,14 @@ namespace AndroidSideloader
Thread t1 = new Thread(() =>
{
Environment.SetEnvironmentVariable("RCLONE_CRYPT_REMOTE", rclonepw);
Environment.SetEnvironmentVariable("RCLONE_CONFIG_PASS", rclonepw);
if (!debugMode && Properties.Settings.Default.checkForUpdates)
{
Updater.AppName = "AndroidSideloader";
Updater.RawGitHubUrl = "https://raw.githubusercontent.com/nerdunit/androidsideloader";
Updater.Update();
}
initMirrors();
initGames();
listappsBtn();
});
t1.SetApartmentState(ApartmentState.STA);
@@ -433,7 +424,9 @@ namespace AndroidSideloader
return ADB.RunAdbCommandToString("shell pm list packages");
}
#pragma warning disable CS1998 // Async method lacks 'await' operators and will run synchronously
public async Task<string[]> getGames()
#pragma warning restore CS1998 // Async method lacks 'await' operators and will run synchronously
{
string command = $"cat \"{currentRemote}:Quest Games/APK_packagenames.txt\" --config .\\a";
Process cmd = new Process();
@@ -454,10 +447,8 @@ namespace AndroidSideloader
return games;
}
private async void listappsBtn()
private void listappsBtn()
{
games = getGames().Result;
allText = "";
m_combo.Invoke(() => { m_combo.Items.Clear(); });
var line = listapps().Split('\n');
@@ -611,7 +602,7 @@ namespace AndroidSideloader
RemoveFolder("/sdcard/Android/obb/" + packageName);
RemoveFolder("/sdcard/Android/obb/" + packageName + "/");
uninstallText += allText;
// uninstallText += allText;
dialogResult = FlexibleMessageBox.Show("Do you want to remove savedata for " + packageName + ", this CANNOT be undone!", "WARNING!", MessageBoxButtons.YesNo);
if (dialogResult == DialogResult.Yes)
@@ -662,7 +653,7 @@ namespace AndroidSideloader
notify("Done bulk sideloading");
}
private async void recursiveSideload(string location)
private void recursiveSideload(string location)
{
ADB.DeviceID = GetDeviceID();
string[] files = Directory.GetFiles(location);
@@ -711,7 +702,7 @@ namespace AndroidSideloader
FlexibleMessageBox.Show("Done");
}
async void recursiveCopy(string location)
void recursiveCopy(string location)
{
string[] files = Directory.GetFiles(location);
string[] childDirectories = Directory.GetDirectories(location);
@@ -749,6 +740,7 @@ namespace AndroidSideloader
string[] files = (string[])e.Data.GetData(DataFormats.FileDrop);
foreach (string file in files)
{
string extension = Path.GetExtension(file);
if (extension == ".apk")
{
@@ -770,6 +762,10 @@ namespace AndroidSideloader
}
else if (Directory.Exists(file))
{
if (File.Exists("install.txt"))
{
try { Sideloader.RunCommandsFromFile($"{file}\\install.txt", file); } catch { }
}
ok = true;
string[] foldersindirectory = Directory.GetDirectories(file);
foreach (string curr in foldersindirectory)
@@ -820,6 +816,7 @@ namespace AndroidSideloader
string[] games;
private async void Form1_Shown(object sender, EventArgs e)
{
DateTime today = DateTime.Today;
@@ -831,8 +828,6 @@ namespace AndroidSideloader
Thread t1 = new Thread(() =>
{
ADB.DeviceID = GetDeviceID();
initMirrors();
initGames();
});
t1.IsBackground = true;
t1.Start();
@@ -844,8 +839,8 @@ namespace AndroidSideloader
void initMirrors()
{
remotesList.Invoke(() => { remotesList.Items.Clear(); });
var mirrors = runRcloneCommand("--config .\\a listremotes").Split('\n');
mirrors = runRcloneCommand("--config .\\a listremotes").Split('\n');
var mirrors = RCLONE.runRcloneCommand("--config .\\a listremotes").Split('\n');
mirrors = RCLONE.runRcloneCommand("--config .\\a listremotes").Split('\n');
Logger.Log("Loaded following mirrors: ");
foreach (string mirror in mirrors)
@@ -877,43 +872,9 @@ namespace AndroidSideloader
{
downloadInstallGameButton.Enabled = true;
}
string processError = string.Empty;
Process rclone = new Process();
string runRcloneCommand(string command, bool log = true)
{
wait = true;
rclone.StartInfo.StandardOutputEncoding = Encoding.UTF8;
if (rclonepw.Length > 0)
command += " --ask-password=false";
if (log && Properties.Settings.Default.logRclone)
command += " --log-file=log.txt --log-level DEBUG";
rclone.StartInfo.FileName = Environment.CurrentDirectory + "\\rclone\\rclone.exe";
rclone.StartInfo.Arguments = command;
rclone.StartInfo.RedirectStandardInput = true;
rclone.StartInfo.RedirectStandardError = true;
rclone.StartInfo.RedirectStandardOutput = true;
rclone.StartInfo.WorkingDirectory = Environment.CurrentDirectory + "\\rclone";
rclone.StartInfo.CreateNoWindow = true;
if (debugMode == true)
rclone.StartInfo.CreateNoWindow = false;
rclone.StartInfo.UseShellExecute = false;
rclone.Start();
rclone.StandardInput.WriteLine(command);
rclone.StandardInput.Flush();
rclone.StandardInput.Close();
public static string processError = string.Empty;
var output = rclone.StandardOutput.ReadToEnd();
string rcloneError = rclone.StandardError.ReadToEnd();
rclone.WaitForExit();
wait = false;
Debug.WriteLine($"Rclone error: {rcloneError} {rcloneError.Length}");
if (rcloneError.Length > 77)
processError = rcloneError;
return output;
}
string currentRemote = string.Empty;
void initGames()
{
@@ -921,7 +882,7 @@ namespace AndroidSideloader
gamesComboBox.Invoke(() => { gamesComboBox.Items.Clear(); });
var currGames = runRcloneCommand($"lsf --config .\\a --dirs-only \"{currentRemote}:Quest Games\" --drive-acknowledge-abuse").Split('\n');
var currGames = RCLONE.runRcloneCommand($"lsf --config .\\a --dirs-only \"{currentRemote}:Quest Games\" --drive-acknowledge-abuse").Split('\n');
Debug.WriteLine("Loaded following games: ");
foreach (string game in currGames)
@@ -956,11 +917,11 @@ namespace AndroidSideloader
string about = $@"Finally {Updater.LocalVersion}, with new version comming Soon™
- Software orignally coded by rookie.wtf
- Thanks to pmow for all of his work, including rclone, wonka and other projects
- Thanks to flow for being friendly and helping every one
- Thanks to succ for creating and maintaining the server
- Thanks to badcoder5000 for redesigning the UI
- Thanks to the data team, they know who they are ;)
- Thanks to flow for being friendly and helping every one, also congrats on being the discord server owner now! :D
- Thanks to badcoder5000 for helping me redesign the ui
- Thanks to gotard for the theme changer
- Thanks to Verb8em#0423 for drawing the new icon
- Thanks to Verb8em for drawing the new icon
- Thanks to 7zip team for 7zip :)
- Thanks to rclone team for rclone :D
- Thanks to https://stackoverflow.com/users/57611/erike for the folder browser dialog code
@@ -971,8 +932,6 @@ namespace AndroidSideloader
FlexibleMessageBox.Show(about);
}
bool wait;
private void userjsonButton_Click(object sender, EventArgs e)
{
UsernameForm form = new UsernameForm();
@@ -1015,34 +974,15 @@ namespace AndroidSideloader
private static readonly HttpClient client = new HttpClient();
bool updatedConfig = false;
async Task updateConfig()
{
updatedConfig = true;
string localHash = "";
try { localHash = File.ReadAllText(Environment.CurrentDirectory + "\\rclone\\hash.txt"); } catch { } //file may not exist
string hash = runRcloneCommand($"md5sum --config .\\a \"{currentRemote}:Quest Homebrew/Sideloading Methods/1. Rookie Sideloader - VRP Edition/a\"");
try { hash = hash.Substring(0, hash.LastIndexOf(" ")); } catch { return; } //remove stuff after hash
Debug.WriteLine("The local file hash is " + localHash + " and the current a file hash is " + hash);
if (!string.Equals(localHash, hash))
{
ChangeTitle("Rookie's Sideloader | Updating rclone config");
runRcloneCommand(string.Format($"copy \"{currentRemote}:Quest Homebrew/Sideloading Methods/1. Rookie Sideloader - VRP Edition/a\" \"{Environment.CurrentDirectory}\" --config .\\a"));
killRclone();
File.Copy(Environment.CurrentDirectory + "\\a", Environment.CurrentDirectory + "\\rclone\\a", true);
File.WriteAllText(Environment.CurrentDirectory + "\\rclone\\hash.txt", hash);
}
}
bool gamesAreDownloading = false;
List<string> gamesQueueList = new List<string>();
#pragma warning disable CS1998 // Async method lacks 'await' operators and will run synchronously
async Task<bool> showGameSizeDialog(string gameName)
#pragma warning restore CS1998 // Async method lacks 'await' operators and will run synchronously
{
dynamic results = JsonConvert.DeserializeObject<dynamic>(runRcloneCommand($"size \"{currentRemote}:Quest Games/{gameName}\" --config .\\a --json"));
dynamic results = JsonConvert.DeserializeObject<dynamic>(RCLONE.runRcloneCommand($"size \"{currentRemote}:Quest Games/{gameName}\" --config .\\a --json"));
long gameSize = results.bytes.ToObject<long>();
Debug.WriteLine($"Remote: {currentRemote}, GameSize: {gameSize}, GameName: {gameName}");
DialogResult dialogResult = FlexibleMessageBox.Show($"Are you sure you want to download {gameName}? it has a size of {String.Format("{0:0.00}", (double)gameSize / 1000000)} MB", "Are you sure?", MessageBoxButtons.YesNo);
@@ -1050,6 +990,7 @@ namespace AndroidSideloader
return false;
return true;
}
int quotaTries = 0;
private async void downloadInstallGameButton_Click(object sender, EventArgs e)
{
@@ -1061,8 +1002,9 @@ namespace AndroidSideloader
if (updatedConfig == false && Properties.Settings.Default.autoUpdateConfig == true) //check for config only once per program open and if setting enabled
{
ChangeTitle("Rookie's Sideloader | Checking if config is updated");
await Task.Run(() => updateConfig());
updatedConfig = true;
ChangeTitle("Rookie's Sideloader | Checking if config is updated and updating config");
await Task.Run(() => Sideloader.updateConfig(currentRemote));
}
if (await showGameSizeDialog(gamesComboBox.SelectedItem.ToString())==false)
@@ -1077,41 +1019,38 @@ namespace AndroidSideloader
gamesAreDownloading = true;
Thread userJsonThread = new Thread(() =>
if (Properties.Settings.Default.userJsonOnGameInstall)
{
doUserJson();
});
userJsonThread.IsBackground = true;
userJsonThread.Start();
Thread userJsonThread = new Thread(() => { ChangeTitle("Rookie's Sideloader | Pushing user.json"); Sideloader.PushUserJsons(); });
userJsonThread.IsBackground = true;
userJsonThread.Start();
}
string output = "";
while (gamesQueueList.Count>0)
{
string gameName = gamesQueueList.ToArray()[0];
Debug.WriteLine(runRcloneCommand($"size \"{currentRemote}:Quest Games/{gameName}\" --config .\\a --json"));
Debug.WriteLine(RCLONE.runRcloneCommand($"size \"{currentRemote}:Quest Games/{gameName}\" --config .\\a --json"));
int apkNumber = 0;
int obbNumber = 0;
Directory.CreateDirectory(Environment.CurrentDirectory + "\\" + gameName);
string[] games;
string gameDirectory = Environment.CurrentDirectory + "\\" + gameName;
Directory.CreateDirectory(gameDirectory);
Thread t1 = new Thread(() =>
{
games = runRcloneCommand($"copy --config .\\a \"{currentRemote}:Quest Games/" + gameName + "\" \"" + Environment.CurrentDirectory + "\\" + gameName + "\" --progress --drive-acknowledge-abuse --rc").Split('\n');
foreach (string line in games)
Debug.WriteLine(line);
games = RCLONE.runRcloneCommand($"copy --config .\\a \"{currentRemote}:Quest Games/{gameName}\" \"{Environment.CurrentDirectory}\\{gameName}\" --progress --drive-acknowledge-abuse --rc", true, Properties.Settings.Default.BandwithLimit).Split('\n');
if (File.Exists("install.txt"))
{
try { Sideloader.RunCommandsFromFile($"{gameDirectory}\\install.txt", gameDirectory); } catch { }
}
});
t1.IsBackground = true;
t1.Start();
ChangeTitle("Rookie's Sideloader | Pushing user.json");
ChangeTitle("Rookie's Sideloader | Downloading game " + gameName);
int i = 0;
@@ -1169,9 +1108,9 @@ namespace AndroidSideloader
//Quota Errors
bool quotaError = false;
if (processError.Length!=0)
if (RCLONE.rcloneError.Length!=0)
{
if (processError.Contains("downloadQuotaExceeded"))
if (RCLONE.rcloneError.Contains("downloadQuotaExceeded"))
{
quotaTries++;
quotaError = true;
@@ -1191,13 +1130,11 @@ namespace AndroidSideloader
remotesList.SelectedIndex=0;
gamesQueueList.RemoveAt(0);
//gamesQueueList.Add(gameName);
gamesQueListBox.DataSource = null;
gamesQueListBox.DataSource = gamesQueueList;
}
else FlexibleMessageBox.Show(processError);
else FlexibleMessageBox.Show(RCLONE.rcloneError);
}
processError = string.Empty;
if (quotaError==false)
{
@@ -1232,18 +1169,16 @@ namespace AndroidSideloader
Console.WriteLine(spoofer.spoofedApkPath);
Spoofer.spoofer.SpoofApk(file, $"com.{Utilities.randomString(rand.Next(3, 8))}.{Utilities.randomString(rand.Next(3, 8))}");
ADB.Sideload(spoofer.spoofedApkPath);
output += ADB.Sideload(spoofer.spoofedApkPath);
}
else
ADB.Sideload(file);
output += ADB.Sideload(file);
});
apkThread.IsBackground = true;
apkThread.Start();
while (apkThread.IsAlive)
await Task.Delay(100);
output += allText;
}
}
@@ -1276,15 +1211,13 @@ namespace AndroidSideloader
{
if (Properties.Settings.Default.SpoofGames)
Spoofer.spoofer.RenameObb(folder, spoofer.newPackageName, spoofer.originalPackageName);
ADB.CopyOBB(folder);
output += ADB.CopyOBB(folder);
});
obbThread.IsBackground = true;
obbThread.Start();
while (obbThread.IsAlive)
await Task.Delay(100);
output += allText;
}
}
@@ -1313,29 +1246,9 @@ namespace AndroidSideloader
notify($"Apk installation output: {output}\n");
}
private void doUserJson()
{
if (!Properties.Settings.Default.userJsonOnGameInstall)
return;
foreach (var userJson in UsernameForm.userJsons)
{
UsernameForm.createUserJsonByName(randomString(16), userJson);
ADB.RunAdbCommandToString("push \"" + Environment.CurrentDirectory + $"\\{userJson}\" " + " /sdcard/");
File.Delete(userJson);
}
}
void killRclone()
{
foreach (var process in Process.GetProcessesByName("rclone"))
{
process.Kill();
}
}
private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
killRclone();
RCLONE.killRclone();
}
private void movieStreamButton_Click(object sender, EventArgs e)
@@ -1344,7 +1257,7 @@ namespace AndroidSideloader
{
Thread t1 = new Thread(() =>
{
runRcloneCommand($"--config .\\a serve dlna {currentRemote}-movies:");
RCLONE.runRcloneCommand($"--config .\\a serve dlna {currentRemote}-movies:");
});
t1.IsBackground = true;
t1.Start();
@@ -1354,7 +1267,7 @@ namespace AndroidSideloader
}
else
{
try { rclone.Kill(); } catch { }
try { RCLONE.killRclone(); } catch { }
ChangeTitle("Stopped Movie Stream!");
movieStreamButton.Text = "START MOVIE STREAM";
}
@@ -1363,7 +1276,7 @@ namespace AndroidSideloader
private async void killRcloneButton_Click(object sender, EventArgs e)
{
killRclone();
RCLONE.killRclone();
movieStreamButton.Text = "START MOVIE STREAM";
ChangeTitle("Killed Rclone");
await Task.Delay(TimeSpan.FromSeconds(5));
@@ -1396,18 +1309,8 @@ namespace AndroidSideloader
remotesList.Invoke(() => { currentRemote = remotesList.SelectedItem.ToString(); });
}
private void QuestOptionsButton_Click(object sender, EventArgs e)
{
QuestForm form = new QuestForm();
form.Show();
}
private void pictureBox1_Click(object sender, EventArgs e)
{
}
private void QuestOptionsButton_Click_1(object sender, EventArgs e)
{
QuestForm Form = new QuestForm();
Form.Show();

11
ImageForm.Designer.cs generated
View File

@@ -34,24 +34,25 @@
//
// pictureBox1
//
this.pictureBox1.Location = new System.Drawing.Point(13, 13);
this.pictureBox1.Location = new System.Drawing.Point(10, 11);
this.pictureBox1.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2);
this.pictureBox1.Name = "pictureBox1";
this.pictureBox1.Size = new System.Drawing.Size(775, 425);
this.pictureBox1.Size = new System.Drawing.Size(581, 345);
this.pictureBox1.TabIndex = 0;
this.pictureBox1.TabStop = false;
//
// ImageForm
//
this.AutoScaleDimensions = new System.Drawing.SizeF(8F, 16F);
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(800, 450);
this.ClientSize = new System.Drawing.Size(600, 366);
this.Controls.Add(this.pictureBox1);
this.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2);
this.Name = "ImageForm";
this.ShowIcon = false;
this.Text = "ImageForm";
this.TopMost = true;
this.FormClosing += new System.Windows.Forms.FormClosingEventHandler(this.ImageForm_FormClosing);
this.Load += new System.EventHandler(this.ImageForm_Load);
this.Shown += new System.EventHandler(this.ImageForm_Shown);
((System.ComponentModel.ISupportInitialize)(this.pictureBox1)).EndInit();
this.ResumeLayout(false);

View File

@@ -1,11 +1,5 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace AndroidSideloader
@@ -31,11 +25,6 @@ namespace AndroidSideloader
}
private void ImageForm_Load(object sender, EventArgs e)
{
}
private void ImageForm_FormClosing(object sender, FormClosingEventArgs e)
{
Form1 obj = (Form1)Application.OpenForms["Form1"];

View File

@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace AndroidSideloader

View File

@@ -5,10 +5,11 @@ using System.Runtime.InteropServices;
// General Information about an assembly is controlled through the following
// set of attributes. Change these attribute values to modify the information
// associated with an assembly.
//[assembly: AssemblyKeyFileAttribute("keypair.snk")]
[assembly: AssemblyTitle("AndroidSideloader")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyDescription("Rookie's Sideloader")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
[assembly: AssemblyCompany("Rookie.WTF")]
[assembly: AssemblyProduct("AndroidSideloader")]
[assembly: AssemblyCopyright("Copyright © 2020")]
[assembly: AssemblyTrademark("")]

View File

@@ -238,5 +238,17 @@ namespace AndroidSideloader.Properties {
this["SpoofGames"] = value;
}
}
[global::System.Configuration.UserScopedSettingAttribute()]
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
[global::System.Configuration.DefaultSettingValueAttribute("")]
public string BandwithLimit {
get {
return ((string)(this["BandwithLimit"]));
}
set {
this["BandwithLimit"] = value;
}
}
}
}

View File

@@ -56,5 +56,8 @@
<Setting Name="SpoofGames" Type="System.Boolean" Scope="User">
<Value Profile="(Default)">False</Value>
</Setting>
<Setting Name="BandwithLimit" Type="System.String" Scope="User">
<Value Profile="(Default)" />
</Setting>
</Settings>
</SettingsFile>

View File

@@ -1,11 +1,4 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace AndroidSideloader

View File

@@ -1,12 +1,66 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Diagnostics;
using System.Text;
using System.Threading.Tasks;
namespace AndroidSideloader
{
class RCLONE
{
public static void killRclone()
{
foreach (var process in Process.GetProcessesByName("rclone"))
process.Kill();
}
public static string rclonepw = "0aE0$D61#avO";
private static Process rclone = new Process();
public static string rcloneError = "";
public static string runRcloneCommand(string command, bool log = true, string bandwithLimit = "")
{
Environment.SetEnvironmentVariable("RCLONE_CRYPT_REMOTE", rclonepw);
Environment.SetEnvironmentVariable("RCLONE_CONFIG_PASS", rclonepw);
rclone.StartInfo.StandardOutputEncoding = Encoding.UTF8;
if (bandwithLimit.Length>0)
{
command += $" --bwlimit={bandwithLimit}";
}
if (rclonepw.Length > 0)
command += " --ask-password=false";
if (log && Properties.Settings.Default.logRclone)
command += " --log-file=log.txt --log-level DEBUG";
Logger.Log($"Running Rclone command: {command}");
rclone.StartInfo.FileName = Environment.CurrentDirectory + "\\rclone\\rclone.exe";
rclone.StartInfo.Arguments = command;
rclone.StartInfo.RedirectStandardInput = true;
rclone.StartInfo.RedirectStandardError = true;
rclone.StartInfo.RedirectStandardOutput = true;
rclone.StartInfo.WorkingDirectory = Environment.CurrentDirectory + "\\rclone";
rclone.StartInfo.CreateNoWindow = true;
if (Form1.debugMode == true)
rclone.StartInfo.CreateNoWindow = false;
rclone.StartInfo.UseShellExecute = false;
rclone.Start();
rclone.StandardInput.WriteLine(command);
rclone.StandardInput.Flush();
rclone.StandardInput.Close();
var output = rclone.StandardOutput.ReadToEnd();
string error = rclone.StandardError.ReadToEnd();
rclone.WaitForExit();
Logger.Log($"Rclone error: {error} {error.Length}\nRclone Output: {output}");
if (error.Length > 77)
Form1.processError = rcloneError;
return output;
}
}
}

View File

@@ -37,6 +37,9 @@
this.debugRcloneCheckBox = new System.Windows.Forms.CheckBox();
this.userJsonOnGameInstall = new System.Windows.Forms.CheckBox();
this.spoofGamesCheckbox = new System.Windows.Forms.CheckBox();
this.BandwithTextbox = new System.Windows.Forms.TextBox();
this.label1 = new System.Windows.Forms.Label();
this.BandwithComboBox = new System.Windows.Forms.ComboBox();
this.SuspendLayout();
//
// checkForUpdatesCheckBox
@@ -54,7 +57,7 @@
//
this.applyButton.BackColor = System.Drawing.Color.White;
this.applyButton.ForeColor = System.Drawing.Color.Black;
this.applyButton.Location = new System.Drawing.Point(357, 183);
this.applyButton.Location = new System.Drawing.Point(357, 266);
this.applyButton.Name = "applyButton";
this.applyButton.Size = new System.Drawing.Size(75, 23);
this.applyButton.TabIndex = 5;
@@ -77,7 +80,7 @@
//
this.resetSettingsButton.BackColor = System.Drawing.Color.White;
this.resetSettingsButton.ForeColor = System.Drawing.Color.Black;
this.resetSettingsButton.Location = new System.Drawing.Point(256, 183);
this.resetSettingsButton.Location = new System.Drawing.Point(256, 266);
this.resetSettingsButton.Name = "resetSettingsButton";
this.resetSettingsButton.Size = new System.Drawing.Size(95, 23);
this.resetSettingsButton.TabIndex = 4;
@@ -140,12 +143,44 @@
this.spoofGamesCheckbox.UseVisualStyleBackColor = true;
this.spoofGamesCheckbox.CheckedChanged += new System.EventHandler(this.spoofGamesCheckbox_CheckedChanged);
//
// BandwithTextbox
//
this.BandwithTextbox.Location = new System.Drawing.Point(183, 176);
this.BandwithTextbox.Name = "BandwithTextbox";
this.BandwithTextbox.Size = new System.Drawing.Size(177, 20);
this.BandwithTextbox.TabIndex = 11;
//
// label1
//
this.label1.AutoSize = true;
this.label1.Location = new System.Drawing.Point(10, 179);
this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(167, 13);
this.label1.TabIndex = 12;
this.label1.Text = "Rclone bandwith limit, 0 to disable";
//
// BandwithComboBox
//
this.BandwithComboBox.FormattingEnabled = true;
this.BandwithComboBox.Items.AddRange(new object[] {
"B",
"K",
"M",
"G"});
this.BandwithComboBox.Location = new System.Drawing.Point(366, 176);
this.BandwithComboBox.Name = "BandwithComboBox";
this.BandwithComboBox.Size = new System.Drawing.Size(55, 21);
this.BandwithComboBox.TabIndex = 13;
//
// SettingsForm
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.BackColor = global::AndroidSideloader.Properties.Settings.Default.BackColor;
this.ClientSize = new System.Drawing.Size(444, 218);
this.ClientSize = new System.Drawing.Size(444, 301);
this.Controls.Add(this.BandwithComboBox);
this.Controls.Add(this.label1);
this.Controls.Add(this.BandwithTextbox);
this.Controls.Add(this.spoofGamesCheckbox);
this.Controls.Add(this.userJsonOnGameInstall);
this.Controls.Add(this.debugRcloneCheckBox);
@@ -178,5 +213,8 @@
private System.Windows.Forms.CheckBox debugRcloneCheckBox;
private System.Windows.Forms.CheckBox userJsonOnGameInstall;
private System.Windows.Forms.CheckBox spoofGamesCheckbox;
private System.Windows.Forms.TextBox BandwithTextbox;
private System.Windows.Forms.Label label1;
private System.Windows.Forms.ComboBox BandwithComboBox;
}
}

View File

@@ -1,11 +1,5 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using JR.Utils.GUI.Forms;
using System;
using System.Windows.Forms;
namespace AndroidSideloader
@@ -35,6 +29,12 @@ namespace AndroidSideloader
debugRcloneCheckBox.Checked = Properties.Settings.Default.logRclone;
userJsonOnGameInstall.Checked = Properties.Settings.Default.userJsonOnGameInstall;
spoofGamesCheckbox.Checked = Properties.Settings.Default.SpoofGames;
if (Properties.Settings.Default.BandwithLimit.Length>1)
{
BandwithTextbox.Text = Properties.Settings.Default.BandwithLimit.Remove(Properties.Settings.Default.BandwithLimit.Length - 1);
BandwithComboBox.Text = Properties.Settings.Default.BandwithLimit[Properties.Settings.Default.BandwithLimit.Length-1].ToString();
}
}
void intToolTips()
@@ -49,6 +49,16 @@ namespace AndroidSideloader
private void applyButton_Click(object sender, EventArgs e)
{
if (BandwithTextbox.Text.Length > 0 && BandwithTextbox.Text != "0")
if (BandwithComboBox.SelectedIndex == -1)
{
FlexibleMessageBox.Show("You need to select something from the combobox");
return;
}
else
Properties.Settings.Default.BandwithLimit = $"{BandwithTextbox.Text.Replace(" ", "")}{BandwithComboBox.Text}";
else
Properties.Settings.Default.BandwithLimit = "";
Properties.Settings.Default.Save();
}

53
Sideloader.cs Normal file
View File

@@ -0,0 +1,53 @@
using System;
using System.Diagnostics;
using System.IO;
using System.Threading.Tasks;
using Spoofer;
namespace AndroidSideloader
{
class Sideloader
{
public static void PushUserJsons()
{
foreach (var userJson in UsernameForm.userJsons)
{
UsernameForm.createUserJsonByName(Utilities.randomString(16), userJson);
ADB.RunAdbCommandToString("push \"" + Environment.CurrentDirectory + $"\\{userJson}\" " + " /sdcard/");
File.Delete(userJson);
}
}
#pragma warning disable CS1998 // Async method lacks 'await' operators and will run synchronously
public static async Task updateConfig(string remote)
#pragma warning restore CS1998 // Async method lacks 'await' operators and will run synchronously
{
string localHash = "";
try { localHash = File.ReadAllText(Environment.CurrentDirectory + "\\rclone\\hash.txt"); } catch { } //file may not exist
string hash = RCLONE.runRcloneCommand($"md5sum --config .\\a \"{remote}:Quest Homebrew/Sideloading Methods/1. Rookie Sideloader - VRP Edition/a\"");
try { hash = hash.Substring(0, hash.LastIndexOf(" ")); } catch { return; } //remove stuff after hash
Debug.WriteLine("The local file hash is " + localHash + " and the current a file hash is " + hash);
if (!string.Equals(localHash, hash))
{
RCLONE.runRcloneCommand(string.Format($"copy \"{remote}:Quest Homebrew/Sideloading Methods/1. Rookie Sideloader - VRP Edition/a\" \"{Environment.CurrentDirectory}\" --config .\\a"));
RCLONE.killRclone();
File.Copy(Environment.CurrentDirectory + "\\a", Environment.CurrentDirectory + "\\rclone\\a", true);
File.WriteAllText(Environment.CurrentDirectory + "\\rclone\\hash.txt", hash);
}
}
public static string RunCommandsFromFile(string path, string RunFromPath)
{
string output = string.Empty;
var commands = File.ReadAllLines(path);
foreach (string command in commands)
output+=Utilities.startProcess("cmd.exe",RunFromPath,command);
return output;
}
}
}

View File

@@ -1,14 +1,7 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Collections;
using System.Collections.Specialized;
namespace AndroidSideloader

View File

@@ -1,5 +1,4 @@
using System;
using System.Diagnostics;
using System.Windows.Forms;
using System.IO;
using System.Collections.Generic;

View File

@@ -6,13 +6,12 @@ using System.Net;
using System.Windows.Forms;
using System.Net.Http;
using System.IO;
using AndroidSideloader;
namespace Spoofer
{
class Utilities
{
private static Random rand = new Random();
public static string RandomPackageName()
{
return $"com.{Utilities.randomString(rand.Next(3, 8))}.{Utilities.randomString(rand.Next(3, 8))}";
@@ -55,23 +54,24 @@ namespace Spoofer
FileName = "cmd.exe"
});
}
static Random rand = new Random();
public static string randomString(int length)
{
string valid = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
StringBuilder res = new StringBuilder();
Random rnd = new Random();
int randomInteger = rnd.Next(0, valid.Length);
int randomInteger = rand.Next(0, valid.Length);
while (0 < length--)
{
res.Append(valid[randomInteger]);
randomInteger = rnd.Next(0, valid.Length);
randomInteger = rand.Next(0, valid.Length);
}
return res.ToString();
}
public static string processError = string.Empty;
public static string startProcess(string process, string path, string command)
{
Logger.Log($"Ran process {process} with command {command} in path {path}");
Process cmd = new Process();
cmd.StartInfo.FileName = "cmd.exe";
cmd.StartInfo.RedirectStandardInput = true;
@@ -88,8 +88,10 @@ namespace Spoofer
string error = cmd.StandardError.ReadToEnd();
if (error.Length > 1)
processError = error;
return cmd.StandardOutput.ReadToEnd();
var output = cmd.StandardOutput.ReadToEnd();
Logger.Log($"Output: {output}");
Logger.Log($"Error: {error}");
return output;
}
}
@@ -101,8 +103,8 @@ namespace Spoofer
if (!File.Exists(Environment.CurrentDirectory + "\\7z.exe"))
{
WebClient client = new WebClient();
client.DownloadFile("https://github.com/nerdunit/androidADB.Sideloader/raw/master/7z.exe", "7z.exe");
client.DownloadFile("https://github.com/nerdunit/androidADB.Sideloader/raw/master/7z.dll", "7z.dll");
client.DownloadFile("https://github.com/nerdunit/androidsideloader/raw/master/7z.exe", "7z.exe");
client.DownloadFile("https://github.com/nerdunit/androidsideloader/raw/master/7z.dll", "7z.dll");
}
ProcessStartInfo pro = new ProcessStartInfo();
pro.WindowStyle = ProcessWindowStyle.Hidden;
@@ -118,7 +120,7 @@ namespace Spoofer
public static string AppName { get; set; }
public static string RawGitHubUrl { get; set; } //https://raw.githubusercontent.com/nerdunit/androidADB.Sideloader
static readonly public string LocalVersion = "1.15";
static readonly public string LocalVersion = "1.16";
public static string currentVersion = string.Empty;
public static string changelog = string.Empty;

View File

@@ -1,6 +1,82 @@
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA256
v1.16
Changes
+ Speed Limiter for rclone
= Random packagenames more random now
= Bugfixes
Date 11/12/2020
VT: https://bit.ly/2K4Y5Lv
MD5 Checksum: 29978E435BF02865CE61EF6279FB42ED
SHA-1 Checksum: 2E47CFDE7549D088A102F021657E9CD6859EAC47
SHA-256 Checksum: 50057AC0DA315C492C9C45B5801AE99E65B812F5BC18E23622CCAF5FBC48760A
SHA-512 Checksum: E485ADB6088C1F7DC34B65B57A9077E876D3D576D48CCED1FCA691A113CA5F6D0F8A0D31C6C848B6719FF18B7D4C5F829B9DAA8789EA6087F8B1D41005F87A48
You can always get my public key from rookie.wtf/pgp.txt
You can verify the signed message using kleopatra for windows or dark.fail/pgp
-----BEGIN PGP SIGNATURE-----
iQIzBAEBCAAdFiEEG9eYw4mQVDjvGf4lvrtJUNxETxMFAl+tHY0ACgkQvrtJUNxE
TxOpjRAAmjaIfvIP+HvfTMGKOEGoVRDIBqEyi8tzq8hn5Z3OadBVLkWT23WblQBw
Ur6BN1fuhH5B8ToGoqX/C1lrgXsvHNDB8frGUWnO1G1KJAQEGwKPRdKyK7YPlrYm
kK74CYuM8w7qjkhX3f50ECZ4Kj1WsE92mIHjfB1xLSGzN0o7Tr1EvFFDnuXrJ0I0
vEbeto0Qo19ORcoP7KFPgGuYmMYJQ2MuwYmWDWAdm4iL1Y9vEKZ4TsHG+KmYPdo8
19YoZj8PsgYxCBy9B+UZfkJnfF7gYKmiAsgnQviDc4BvZccfAVjmWcKkzJueDkvr
GgFmbaFE48svC2NU8Qd2gq6gIX0JrnKACZqopqgorl1817Z7Rsdh2iVwTMOvxbe7
a4kAtDN90KwuRlnwoxeCBdESDSrANbiNi1yaDZc5hr/xOxUsa1JKhk7/8mcdHj78
QoCRoji60Cq8XYeRNDXI32TkZd7ql9c64AjGH1uSySIPXfehOa+m5S53Jo2dRh5p
iI1LGHjTk7EDekIVRh/cPC+hohfUAKYbUcXp15cx0HndW5+galYIH/RAjF0L+Q1U
THz36HpKvLSsgkVkeVjPNJn9Ow6xgyByLTkHrS9D7Kj78FrKiAKr08+aI3+WCpdq
1G9HcH5VzDeZ7/jfVQPhsAn3dPxlTt6ReYzbeFkrO1UHFcTdl58=
=KyH4
-----END PGP SIGNATURE-----
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA256
v1.15HF1
Changes
= Bugfixes
Date 11/06/2020
VT: https://bit.ly/2GDYWRU
MD5 Checksum: F0D51FEC94F8D266390E61E89E6A2EE0
SHA-1 Checksum: 4FB43CFA6021B8360A23858169FAF15468B68EDF
SHA-256 Checksum: CBE414D9A283871099057EE5D8E56AF408996AE9C996C31F92C4DAE16D48B024
SHA-512 Checksum: F16A6B29ECABBB16D25B7F7FC52CB15AE4930B2B17ABAC791BF1F331270F40B047094FDEAF1EF834E72E26AA3A6762AF8BE13EBCB735EB1C1009F884E338D9DE
You can always get my public key from rookie.wtf/pgp.txt
You can verify the signed message using kleopatra for windows or dark.fail/pgp
-----BEGIN PGP SIGNATURE-----
iQIzBAEBCAAdFiEEG9eYw4mQVDjvGf4lvrtJUNxETxMFAl+lfEkACgkQvrtJUNxE
TxMDDxAAg+90vrCn0PllPEezzX3AJpy7NFWhFjUlDOLzNFMPa/QdAfF6H5vhEGay
bhX2BDHKSIV86bLkyGPkGHuf3etpXvZsNAmPuDoZpZ4owd1O09DOvAHIJx8F1Eia
Jc9Zovz6lKLAeIbK9ZdChKwTG3hYLIkx3rMgtvnJkZfzUKbhdU9MP0rVEzDPkSfe
ay2CGA9xLBUhPcItUTxhANzrDpRXMGHqbi+Wrscp+KmvnjHzN3Haq2A9rsasXM5Z
RSG8ccLZiI496tJQquTvPXYcnWQQudzcf3yiicztein0xcISEat0FFIVao7TtnS4
cgitvGNtfXXauAxyzjZ7PdgrVuoAE/v4m25pzaTRy7TOfW1uTz2/6lr6tZa38+p9
Bs36KcoK64FcPWjfR7zvvmCUWT/aHlRC9FwMvBHB81WRRk6xGaKl8G2QxfKY/ATl
DNlgYXfXLzipam74XfPHiyK4Sc55WLDQxZfZfD6tqTo4u8qoDESvcEz+pbGe4Wp8
awY4FVeSP1jVQzHgWf+oMTiHm5Gb3qMLUhZ/AHidUWFLhzXmAA4YXxIHKidRjCYT
42Kzs1sjT2A5ll2V7jz4pqoRlsvRAxNZ5KgAZ2R01zo7gS1nGqjyoGq3tLWHbfJk
/kD4QlOwcv06Jvp8aHcPxpccB7KHZGoRT2PB6IQE9Gt72pmAU9c=
=f7yh
-----END PGP SIGNATURE-----
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA256
v1.15
Changes

View File

@@ -1,8 +1,7 @@
using System;
using System.IO;
using System.Diagnostics;
using System.Text;
using System.Collections.Generic;
using AndroidSideloader;
namespace Spoofer
{
@@ -67,12 +66,11 @@ namespace Spoofer
folderPath = apkPath.Replace(Path.GetFileName(apkPath), "");
File.Move(apkPath, $"{folderPath}spoofme.apk");
apkPath = $"{folderPath}spoofme.apk";
var rand = new Random();
decompiledPath = apkPath.Replace(".apk","");
//newPackageName = $"com.{Utilities.randomString(rand.Next(3, 8))}.{Utilities.randomString(rand.Next(3, 8))}";
originalPackageName = PackageName(apkPath);
Console.WriteLine($"Your app will be spoofed as {newPackageName}");
Console.WriteLine($"Folderpath: {folderPath} decompiledPaht: {decompiledPath} ");
Logger.Log($"Your app will be spoofed as {newPackageName}");
Logger.Log($"Folderpath: {folderPath} decompiledPaht: {decompiledPath} ");
if (obbPath.Length > 1)
{
RenameObb(obbPath,newPackageName,originalPackageName);
@@ -110,7 +108,7 @@ namespace Spoofer
spoofedApkPath = $"{Path.GetFileName(apkPath).Replace(".apk", "")}_Spoofed as {newPackageName}.apk";
string output = Utilities.startProcess("cmd.exe", folderPath, $"apktool b \"{Path.GetFileName(apkPath).Replace(".apk", "")}\" -o \"{spoofedApkPath}\"");
File.AppendAllText("debug.txt", $"apktool b \"{Path.GetFileName(apkPath).Replace(".apk", "")}\" -o \"{spoofedApkPath}\": {output}");
Logger.Log($"apktool b \"{Path.GetFileName(apkPath).Replace(".apk", "")}\" -o \"{spoofedApkPath}\": {output}");
Console.WriteLine("APK Rebuilt");
//Sign the new apk

View File

@@ -1 +1 @@
1.15
1.16