1
0
Fork 0
mirror of https://github.com/proxysu/ProxySU.git synced 2025-04-19 09:00:57 +00:00

Compare commits

..

No commits in common. "master" and "v4.1.11" have entirely different histories.

20 changed files with 53 additions and 359 deletions

View file

@ -1,4 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<Weavers>
<Costura />
</Weavers>

View file

@ -9,11 +9,6 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ProxySuper.WPF", "ProxySupe
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ProxySuper.Core", "ProxySuper.Core\ProxySuper.Core.csproj", "{15779EE6-D8CA-44BF-BFE2-941E155EEF3F}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ProxySuper.Core", "ProxySuper.Core\ProxySuper.Core.csproj", "{15779EE6-D8CA-44BF-BFE2-941E155EEF3F}"
EndProject EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "解决方案项", "解决方案项", "{327FE75A-7D23-4F0E-80E2-7D10C7603969}"
ProjectSection(SolutionItems) = preProject
FodyWeavers.xml = FodyWeavers.xml
EndProjectSection
EndProject
Global Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU Debug|Any CPU = Debug|Any CPU

View file

@ -1,7 +1,5 @@
using System; using System;
using System.Globalization; using System.Globalization;
using System.Linq;
using System.Windows;
using System.Windows.Data; using System.Windows.Data;
namespace ProxySuper.Core.Converters namespace ProxySuper.Core.Converters
@ -28,19 +26,4 @@ namespace ProxySuper.Core.Converters
return parameter; return parameter;
} }
} }
public class BooleanOrConverter : IMultiValueConverter
{
public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
{
return values.OfType<bool>().Any(v => v);
}
public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
{
throw new NotImplementedException();
}
}
} }

View file

@ -9,47 +9,22 @@ namespace ProxySuper.Core.Converters
{ {
public object Convert(object value, Type targetType, object parameter, CultureInfo culture) public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{ {
bool isMatch = (value != null && value.Equals(parameter)); return value.Equals(true) ? Visibility.Visible : Visibility.Collapsed;
// 如果匹配则显示否则隐藏Collapsed
return isMatch ? Visibility.Visible : Visibility.Hidden;//Collapsed;
//return value.Equals(true) ? Visibility.Visible : Visibility.Hidden;//Collapsed;
} }
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{ {
throw new NotImplementedException(); if (value == null)
//if (value == null) {
//{ return false;
// return false;
//}
//if (value.Equals(Visibility.Visible))
//{
// return true;
//}
//return false;
}
} }
public class BooleanOrToVisibilityConverter : IMultiValueConverter if (value.Equals(Visibility.Visible))
{ {
public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture) return true;
{
// 如果任一条件为 true则返回 Visible否则返回 Hidden/Collapsed
foreach (var value in values)
{
if (value is bool boolVal && boolVal)
{
return Visibility.Visible;
}
}
return Visibility.Hidden;//Collapsed
} }
public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture) return false;
{
throw new NotImplementedException();
} }
} }
} }

View file

@ -20,12 +20,12 @@ namespace ProxySuper.Core.Models.Hosts
public string Address { get; set; } public string Address { get; set; }
public int Port { get; set; } = 22;
public string UserName { get; set; } public string UserName { get; set; }
public string Password { get; set; } public string Password { get; set; }
public int Port { get; set; } = 22;
public string PrivateKeyPath { get; set; } public string PrivateKeyPath { get; set; }
public string PrivateKeyPassPhrase { get; set; } public string PrivateKeyPassPhrase { get; set; }
@ -34,47 +34,24 @@ namespace ProxySuper.Core.Models.Hosts
public LoginSecretType SecretType { get; set; } public LoginSecretType SecretType { get; set; }
//public IMvxCommand UploadPrivateKeyCommand => new MvxCommand(UploadPrivateKey); public IMvxCommand UploadPrivateKeyCommand => new MvxCommand(UploadPrivateKey);
private readonly IMvxCommand _uploadPrivateKeyCommand;
public IMvxCommand UploadPrivateKeyCommand => _uploadPrivateKeyCommand ?? new MvxCommand(UploadPrivateKey);
private void UploadPrivateKey() private void UploadPrivateKey()
{ {
var fileDialog = new OpenFileDialog() var fileDialog = new OpenFileDialog();
{
Filter = "Private Key (*.pem;*.key)|*.pem;*.key|All File (*.*)|*.*",
Title = "Select the private key file"
};
fileDialog.FileOk += OnFileOk; fileDialog.FileOk += OnFileOk;
fileDialog.ShowDialog(); fileDialog.ShowDialog();
} }
private async void OnFileOk(object sender, CancelEventArgs e) private void OnFileOk(object sender, CancelEventArgs e)
{ {
var file = sender as OpenFileDialog; var file = sender as OpenFileDialog;
if (file != null)
{
PrivateKeyPath = file.FileName; PrivateKeyPath = file.FileName;
//Task.Delay(300).ContinueWith((t) => Task.Delay(300).ContinueWith((t) =>
//{
// MessageBox.Show("OK:" + PrivateKeyPath, "Tips");
//});
await Task.Delay(300);
MessageBox.Show("OK:" + PrivateKeyPath, "Tips");
}
else
{ {
//Task.Delay(300).ContinueWith((t) => MessageBox.Show("上传成功", "提示");
//{ });
// MessageBox.Show("Error:Unable to get file!", "Tips");
//});
await Task.Delay(300);
MessageBox.Show("Error:Unable to get file!", "Tips");
}
} }
} }
} }

View file

@ -829,8 +829,7 @@ namespace ProxySuper.Core.Services
proxyType: _host.Proxy.Type, proxyType: _host.Proxy.Type,
proxyHost: _host.Proxy.Address, proxyHost: _host.Proxy.Address,
proxyPort: _host.Proxy.Port, proxyPort: _host.Proxy.Port,
proxyUsername: _host.Proxy.UserName, proxyUsername: _host.Proxy.UserName, proxyPassword: _host.Proxy.Password,
proxyPassword: _host.Proxy.Password,
authenticationMethods: authMethods.ToArray()); authenticationMethods: authMethods.ToArray());
} }
catch (Exception ex) catch (Exception ex)

View file

@ -79,8 +79,7 @@ namespace ProxySuper.Core.Services
} }
var domain = parameters.MaskDomain var domain = parameters.MaskDomain
.TrimStart("http://".ToCharArray()) .TrimStart("http://".ToCharArray())
.TrimStart("https://".ToCharArray()) .TrimStart("https://".ToCharArray());
.TrimEnd('/');
caddyStr = caddyStr.Replace("##reverse_proxy##", $"reverse_proxy {prefix}{domain} {{ \n header_up Host {domain} \n }}"); caddyStr = caddyStr.Replace("##reverse_proxy##", $"reverse_proxy {prefix}{domain} {{ \n header_up Host {domain} \n }}");
} }
@ -104,7 +103,7 @@ namespace ProxySuper.Core.Services
} }
else else
{ {
flow = "xtls-rprx-vision";//兼容普通tls与xtls flow = "xtls-rprx-vision,none";//兼容普通tls与xtls
obj = new { id = id, flow = flow }; obj = new { id = id, flow = flow };
} }

View file

@ -13,10 +13,6 @@
<UserControl.Resources> <UserControl.Resources>
<convert:LoginSecretTypeConverter x:Key="SecretTypeConverter" /> <convert:LoginSecretTypeConverter x:Key="SecretTypeConverter" />
<convert:ProxyTypeConverter x:Key="ProxyTypeConverter" /> <convert:ProxyTypeConverter x:Key="ProxyTypeConverter" />
<convert:BooleanOrConverter x:Key="BooleanOrConverter" />
<convert:BooleanOrToVisibilityConverter x:Key="BooleanOrToVisibilityConverter" />
<convert:VisibleConverter x:Key="VisibleConverter" />
</UserControl.Resources> </UserControl.Resources>
<Grid> <Grid>
@ -99,13 +95,7 @@
}" /> }" />
</StackPanel> </StackPanel>
<Label Content="{DynamicResource HostUploadSecretKey}" <Label Content="{DynamicResource HostUploadSecretKey}" Grid.Row="6" Grid.Column="0" />
Grid.Row="6" Grid.Column="0"
Visibility="{
Binding Host.SecretType,
Converter={StaticResource VisibleConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}"/>
<Button Height="24" <Button Height="24"
Width="100" Width="100"
HorizontalAlignment="Left" HorizontalAlignment="Left"
@ -116,20 +106,9 @@
Converter={StaticResource SecretTypeConverter}, Converter={StaticResource SecretTypeConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey} ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}" }"
Visibility="{
Binding Host.SecretType,
Converter={StaticResource VisibleConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}"
Content="{DynamicResource HostUploadSecretKey}" /> Content="{DynamicResource HostUploadSecretKey}" />
<Label Content="{DynamicResource HostSertTypePrivateKeyPassPhrase}" <Label Content="{DynamicResource HostSertTypePrivateKeyPassPhrase}" Grid.Row="7" Grid.Column="0" />
Grid.Row="7" Grid.Column="0"
Visibility="{
Binding Host.SecretType,
Converter={StaticResource VisibleConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}"/>
<TextBox Grid.Row="7" Grid.Column="1" <TextBox Grid.Row="7" Grid.Column="1"
Width="170" Width="170"
Text="{Binding Host.PrivateKeyPassPhrase}" Text="{Binding Host.PrivateKeyPassPhrase}"
@ -138,32 +117,7 @@
Converter={StaticResource SecretTypeConverter}, Converter={StaticResource SecretTypeConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey} ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}" }"
Visibility="{ VerticalContentAlignment="Center" />
Binding Host.SecretType,
Converter={StaticResource VisibleConverter},
ConverterParameter={x:Static host:LoginSecretType.PrivateKey}
}"
VerticalContentAlignment="Center" Height="26" >
<TextBox.Resources>
<VisualBrush x:Key="HelpBrush" TileMode="None" Opacity="0.3" Stretch="None" AlignmentX="Left">
<VisualBrush.Visual>
<TextBlock FontStyle="Italic" Text="{DynamicResource TextBoxContentTipsNoneBlank}"/>
</VisualBrush.Visual>
</VisualBrush>
</TextBox.Resources>
<TextBox.Style>
<Style TargetType="TextBox">
<Style.Triggers>
<Trigger Property="Text" Value="{x:Null}">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
<Trigger Property="Text" Value="">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
</Style.Triggers>
</Style>
</TextBox.Style>
</TextBox>
</Grid> </Grid>
</GroupBox> </GroupBox>
@ -190,13 +144,6 @@
Converter={StaticResource ProxyTypeConverter}, Converter={StaticResource ProxyTypeConverter},
ConverterParameter={x:Static ssh:ProxyTypes.None} ConverterParameter={x:Static ssh:ProxyTypes.None}
}"/> }"/>
<RadioButton Content="{DynamicResource ProxyTypeSocks5}"
Margin="5,0"
IsChecked="{
Binding Host.Proxy.Type,
Converter={StaticResource ProxyTypeConverter},
ConverterParameter={x:Static ssh:ProxyTypes.Socks5}
}"/>
<RadioButton Content="{DynamicResource ProxyTypeHttp}" <RadioButton Content="{DynamicResource ProxyTypeHttp}"
Margin="5,0" Margin="5,0"
IsChecked="{ IsChecked="{
@ -204,168 +151,26 @@
Converter={StaticResource ProxyTypeConverter}, Converter={StaticResource ProxyTypeConverter},
ConverterParameter={x:Static ssh:ProxyTypes.Http} ConverterParameter={x:Static ssh:ProxyTypes.Http}
}"/> }"/>
</StackPanel> <RadioButton Content="{DynamicResource ProxyTypeSocks5}"
Margin="5,0"
<Label Content="{DynamicResource ProxyAddress}" Grid.Row="1" Grid.Column="0" > IsChecked="{
<Label.Visibility>
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</Label.Visibility>
</Label>
<TextBox Text="{Binding Host.Proxy.Address}"
Grid.Row="1"
Grid.Column="1" >
<!-- IsEnabled="{
Binding Host.Proxy.Type, Binding Host.Proxy.Type,
Converter={StaticResource ProxyTypeConverter}, Converter={StaticResource ProxyTypeConverter},
ConverterParameter={x:Static ssh:ProxyTypes.Socks5} ConverterParameter={x:Static ssh:ProxyTypes.Socks5}
}" --> }"/>
<TextBox.IsEnabled> </StackPanel>
<MultiBinding Converter="{StaticResource BooleanOrConverter}">
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</TextBox.IsEnabled>
<TextBox.Visibility>
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</TextBox.Visibility>
</TextBox>
<Label Content="{DynamicResource HostPort}" Grid.Row="2" Grid.Column="0" > <Label Content="{DynamicResource ProxyAddress}" Grid.Row="1" Grid.Column="0" />
<Label.Visibility> <TextBox Text="{Binding Host.Proxy.Address}" Grid.Row="1" Grid.Column="1" />
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</Label.Visibility>
</Label>
<TextBox Text="{Binding Host.Proxy.Port}" Grid.Row="2" Grid.Column="1" >
<TextBox.IsEnabled>
<MultiBinding Converter="{StaticResource BooleanOrConverter}">
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</TextBox.IsEnabled>
<TextBox.Visibility>
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Http}" />
</MultiBinding>
</TextBox.Visibility>
</TextBox>
<Label Content="{DynamicResource ProxyUserName}" Grid.Row="3" Grid.Column="0" > <Label Content="{DynamicResource ProxyUserName}" Grid.Row="2" Grid.Column="0" />
<Label.Visibility> <TextBox Text="{Binding Host.Proxy.UserName}" Grid.Row="2" Grid.Column="1" />
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</Label.Visibility>
</Label>
<TextBox Text="{Binding Host.Proxy.UserName}" Grid.Row="3" Grid.Column="1" Height="26" >
<TextBox.IsEnabled>
<MultiBinding Converter="{StaticResource BooleanOrConverter}">
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</TextBox.IsEnabled>
<TextBox.Visibility>
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</TextBox.Visibility>
<TextBox.Resources>
<VisualBrush x:Key="HelpBrush" TileMode="None" Opacity="0.3" Stretch="None" AlignmentX="Left">
<VisualBrush.Visual>
<TextBlock FontStyle="Italic" Text="{DynamicResource TextBoxContentTipsNoneBlank}"/>
</VisualBrush.Visual>
</VisualBrush>
</TextBox.Resources>
<TextBox.Style>
<Style TargetType="TextBox">
<Style.Triggers>
<Trigger Property="Text" Value="{x:Null}">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
<Trigger Property="Text" Value="">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
</Style.Triggers>
</Style>
</TextBox.Style>
</TextBox>
<Label Content="{DynamicResource ProxyPassword}" Grid.Row="4" Grid.Column="0" > <Label Content="{DynamicResource HostPort}" Grid.Row="3" Grid.Column="0" />
<Label.Visibility> <TextBox Text="{Binding Host.Proxy.Port}" Grid.Row="3" Grid.Column="1" />
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type" <Label Content="{DynamicResource ProxyPassword}" Grid.Row="4" Grid.Column="0" />
Converter="{StaticResource ProxyTypeConverter}" <TextBox Text="{Binding Host.Proxy.Password}" Grid.Row="4" Grid.Column="1" />
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</Label.Visibility>
</Label>
<TextBox Text="{Binding Host.Proxy.Password}" Grid.Row="4" Grid.Column="1" Height="26" >
<TextBox.IsEnabled>
<MultiBinding Converter="{StaticResource BooleanOrConverter}">
<Binding Path="Host.Proxy.Type" Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</TextBox.IsEnabled>
<TextBox.Visibility>
<MultiBinding Converter="{StaticResource BooleanOrToVisibilityConverter}">
<Binding Path="Host.Proxy.Type"
Converter="{StaticResource ProxyTypeConverter}"
ConverterParameter="{x:Static ssh:ProxyTypes.Socks5}" />
</MultiBinding>
</TextBox.Visibility>
<TextBox.Resources>
<VisualBrush x:Key="HelpBrush" TileMode="None" Opacity="0.3" Stretch="None" AlignmentX="Left">
<VisualBrush.Visual>
<TextBlock Height="auto" FontStyle="Italic" Text="{DynamicResource TextBoxContentTipsNoneBlank}"/>
</VisualBrush.Visual>
</VisualBrush>
</TextBox.Resources>
<TextBox.Style>
<Style TargetType="TextBox">
<Style.Triggers>
<Trigger Property="Text" Value="{x:Null}">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
<Trigger Property="Text" Value="">
<Setter Property="Background" Value="{StaticResource HelpBrush}"/>
</Trigger>
</Style.Triggers>
</Style>
</TextBox.Style>
</TextBox>
</Grid> </Grid>
</GroupBox> </GroupBox>

View file

@ -17,13 +17,6 @@
<StackPanel Orientation="Horizontal"> <StackPanel Orientation="Horizontal">
<!--#region VLESS --> <!--#region VLESS -->
<WrapPanel Orientation="Vertical"> <WrapPanel Orientation="Vertical">
<!--XTLS+Reality-->
<CheckBox Width="150"
VerticalContentAlignment="Center"
IsChecked="{Binding Path=Checked_VLESS_TCP_XTLS}">
<Label Content="{DynamicResource VlessXtlsRealityDesc}" FontSize="12" Foreground="LimeGreen" />
</CheckBox>
<!--XTLS--> <!--XTLS-->
<CheckBox Width="150" <CheckBox Width="150"
VerticalContentAlignment="Center" VerticalContentAlignment="Center"

View file

@ -8,7 +8,7 @@
mc:Ignorable="d" mc:Ignorable="d"
WindowStartupLocation="CenterScreen" WindowStartupLocation="CenterScreen"
Icon="/Resources/ProxySU.ico" Icon="/Resources/ProxySU.ico"
Title="ProxySU v4.2.0" Height="600" Width="1000"> Title="ProxySU v4.1.10" Height="600" Width="1000">
<Grid> <Grid>
</Grid> </Grid>

View file

@ -49,5 +49,5 @@ using System.Windows;
//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 //可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值
//通过使用 "*",如下所示: //通过使用 "*",如下所示:
// [assembly: AssemblyVersion("1.0.*")] // [assembly: AssemblyVersion("1.0.*")]
[assembly: AssemblyVersion("4.2.0.0")] [assembly: AssemblyVersion("4.1.10.0")]
[assembly: AssemblyFileVersion("4.2.0.0")] [assembly: AssemblyFileVersion("4.1.10.0")]

View file

@ -1,6 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Import Project="..\packages\Costura.Fody.6.0.0\build\Costura.Fody.props" Condition="Exists('..\packages\Costura.Fody.6.0.0\build\Costura.Fody.props')" />
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" /> <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
<PropertyGroup> <PropertyGroup>
  <AllowedReferenceRelatedFileExtensions>   <AllowedReferenceRelatedFileExtensions>
@ -19,7 +18,7 @@
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
<PlatformTarget>AnyCPU</PlatformTarget> <PlatformTarget>AnyCPU</PlatformTarget>
<DebugType>none</DebugType> <DebugType>pdbonly</DebugType>
<Optimize>true</Optimize> <Optimize>true</Optimize>
<OutputPath>bin\Release\</OutputPath> <OutputPath>bin\Release\</OutputPath>
<DefineConstants>TRACE</DefineConstants> <DefineConstants>TRACE</DefineConstants>
@ -33,9 +32,6 @@
<StartupObject>ProxySuper.WPF.App</StartupObject> <StartupObject>ProxySuper.WPF.App</StartupObject>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<Reference Include="Costura, Version=6.0.0.0, Culture=neutral, PublicKeyToken=9919ef960d84173d, processorArchitecture=MSIL">
<HintPath>..\packages\Costura.Fody.6.0.0\lib\netstandard2.0\Costura.dll</HintPath>
</Reference>
<Reference Include="Microsoft.Extensions.Logging.Abstractions, Version=7.0.0.0, Culture=neutral, PublicKeyToken=adb9793829ddae60, processorArchitecture=MSIL"> <Reference Include="Microsoft.Extensions.Logging.Abstractions, Version=7.0.0.0, Culture=neutral, PublicKeyToken=adb9793829ddae60, processorArchitecture=MSIL">
<HintPath>..\packages\Microsoft.Extensions.Logging.Abstractions.7.0.0\lib\net462\Microsoft.Extensions.Logging.Abstractions.dll</HintPath> <HintPath>..\packages\Microsoft.Extensions.Logging.Abstractions.7.0.0\lib\net462\Microsoft.Extensions.Logging.Abstractions.dll</HintPath>
</Reference> </Reference>
@ -716,10 +712,5 @@
<ErrorText>这台计算机上缺少此项目引用的 NuGet 程序包。使用“NuGet 程序包还原”可下载这些程序包。有关更多信息,请参见 http://go.microsoft.com/fwlink/?LinkID=322105。缺少的文件是 {0}。</ErrorText> <ErrorText>这台计算机上缺少此项目引用的 NuGet 程序包。使用“NuGet 程序包还原”可下载这些程序包。有关更多信息,请参见 http://go.microsoft.com/fwlink/?LinkID=322105。缺少的文件是 {0}。</ErrorText>
</PropertyGroup> </PropertyGroup>
<Error Condition="!Exists('..\packages\System.Runtime.WindowsRuntime.4.7.0\build\net461\System.Runtime.WindowsRuntime.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\System.Runtime.WindowsRuntime.4.7.0\build\net461\System.Runtime.WindowsRuntime.targets'))" /> <Error Condition="!Exists('..\packages\System.Runtime.WindowsRuntime.4.7.0\build\net461\System.Runtime.WindowsRuntime.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\System.Runtime.WindowsRuntime.4.7.0\build\net461\System.Runtime.WindowsRuntime.targets'))" />
<Error Condition="!Exists('..\packages\Fody.6.8.2\build\Fody.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\Fody.6.8.2\build\Fody.targets'))" />
<Error Condition="!Exists('..\packages\Costura.Fody.6.0.0\build\Costura.Fody.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\Costura.Fody.6.0.0\build\Costura.Fody.props'))" />
<Error Condition="!Exists('..\packages\Costura.Fody.6.0.0\build\Costura.Fody.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\Costura.Fody.6.0.0\build\Costura.Fody.targets'))" />
</Target> </Target>
<Import Project="..\packages\Fody.6.8.2\build\Fody.targets" Condition="Exists('..\packages\Fody.6.8.2\build\Fody.targets')" />
<Import Project="..\packages\Costura.Fody.6.0.0\build\Costura.Fody.targets" Condition="Exists('..\packages\Costura.Fody.6.0.0\build\Costura.Fody.targets')" />
</Project> </Project>

View file

@ -29,7 +29,6 @@
<sys:String x:Key="MainMenuHelperUseRoot">UseRoot</sys:String> <sys:String x:Key="MainMenuHelperUseRoot">UseRoot</sys:String>
<sys:String x:Key="MainMenuHelperCertQuestion">CertQuestion</sys:String> <sys:String x:Key="MainMenuHelperCertQuestion">CertQuestion</sys:String>
<sys:String x:Key="MainMenuHelperPrivateKey">PrivateKey</sys:String> <sys:String x:Key="MainMenuHelperPrivateKey">PrivateKey</sys:String>
<sys:String x:Key="MainMenuHelperResourcesAndTutorials">Related Resources and Tutorials</sys:String>
<!--Main DataGrid--> <!--Main DataGrid-->
<sys:String x:Key="MainDataGridColumnTag">Tag</sys:String> <sys:String x:Key="MainDataGridColumnTag">Tag</sys:String>
@ -52,12 +51,11 @@
<sys:String x:Key="HostPassword">Password</sys:String> <sys:String x:Key="HostPassword">Password</sys:String>
<sys:String x:Key="HostPort">Port</sys:String> <sys:String x:Key="HostPort">Port</sys:String>
<sys:String x:Key="HostSecretType">SecretType</sys:String> <sys:String x:Key="HostSecretType">SecretType</sys:String>
<sys:String x:Key="HostUploadSecretKey">LoadingKey</sys:String> <sys:String x:Key="HostUploadSecretKey">UploadKey</sys:String>
<sys:String x:Key="HostSertTypePassword">Password</sys:String> <sys:String x:Key="HostSertTypePassword">Password</sys:String>
<sys:String x:Key="HostSertTypePrivateKey">PrivateKey</sys:String> <sys:String x:Key="HostSertTypePrivateKey">PrivateKey</sys:String>
<sys:String x:Key="HostSertTypePrivateKeyPassPhrase">PKPassword</sys:String> <sys:String x:Key="HostSertTypePrivateKeyPassPhrase">PKPassword</sys:String>
<sys:String x:Key="TextBoxContentTipsNoneBlank">None,Blank</sys:String>
<sys:String x:Key="ProxyGroupName">Proxy</sys:String> <sys:String x:Key="ProxyGroupName">Proxy</sys:String>
<sys:String x:Key="ProxyAddress">Address</sys:String> <sys:String x:Key="ProxyAddress">Address</sys:String>
@ -74,7 +72,6 @@
<sys:String x:Key="EditorProxyParams" xml:space="preserve">Params</sys:String> <sys:String x:Key="EditorProxyParams" xml:space="preserve">Params</sys:String>
<!--Xray--> <!--Xray-->
<sys:String x:Key="VlessXtlsRealityDesc" xml:space="preserve">VLESS XTLS REALITY</sys:String>
<sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String> <sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String>
<sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String> <sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String>
<sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String> <sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String>

View file

@ -29,7 +29,6 @@
<sys:String x:Key="MainMenuHelperUseRoot">اکانت روت را فعال کنید</sys:String> <sys:String x:Key="MainMenuHelperUseRoot">اکانت روت را فعال کنید</sys:String>
<sys:String x:Key="MainMenuHelperCertQuestion">در مورد گواهینامه</sys:String> <sys:String x:Key="MainMenuHelperCertQuestion">در مورد گواهینامه</sys:String>
<sys:String x:Key="MainMenuHelperPrivateKey">در مورد سوال</sys:String> <sys:String x:Key="MainMenuHelperPrivateKey">در مورد سوال</sys:String>
<sys:String x:Key="MainMenuHelperResourcesAndTutorials">منابع و آموزش های مرتبط</sys:String>
<!--Main DataGrid--> <!--Main DataGrid-->
<sys:String x:Key="MainDataGridColumnTag">برچسب</sys:String> <sys:String x:Key="MainDataGridColumnTag">برچسب</sys:String>
@ -52,12 +51,11 @@
<sys:String x:Key="HostPassword">رمز عبور</sys:String> <sys:String x:Key="HostPassword">رمز عبور</sys:String>
<sys:String x:Key="HostPort">پورت</sys:String> <sys:String x:Key="HostPort">پورت</sys:String>
<sys:String x:Key="HostSecretType">نوع تأیید ورود</sys:String> <sys:String x:Key="HostSecretType">نوع تأیید ورود</sys:String>
<sys:String x:Key="HostUploadSecretKey">بارگیری کلید خصوصی</sys:String> <sys:String x:Key="HostUploadSecretKey">کلید آپلود</sys:String>
<sys:String x:Key="HostSertTypePassword">رمز عبور</sys:String> <sys:String x:Key="HostSertTypePassword">رمز عبور</sys:String>
<sys:String x:Key="HostSertTypePrivateKey">کلید خصوصی</sys:String> <sys:String x:Key="HostSertTypePrivateKey">کلید خصوصی</sys:String>
<sys:String x:Key="HostSertTypePrivateKeyPassPhrase">رمز عبور PK</sys:String> <sys:String x:Key="HostSertTypePrivateKeyPassPhrase">رمز عبور PK</sys:String>
<sys:String x:Key="TextBoxContentTipsNoneBlank">اگر هیچ کدام، آن را خالی بگذارید</sys:String>
<sys:String x:Key="ProxyGroupName">پروکسی</sys:String> <sys:String x:Key="ProxyGroupName">پروکسی</sys:String>
<sys:String x:Key="ProxyAddress">آدرس</sys:String> <sys:String x:Key="ProxyAddress">آدرس</sys:String>
@ -67,14 +65,13 @@
<sys:String x:Key="ProxyType">نوع</sys:String> <sys:String x:Key="ProxyType">نوع</sys:String>
<sys:String x:Key="ProxyTypeNone">None</sys:String> <sys:String x:Key="ProxyTypeNone">None</sys:String>
<sys:String x:Key="ProxyTypeHttp">Http</sys:String> <sys:String x:Key="ProxyTypeHttp">Http</sys:String>
<sys:String x:Key="ProxyTypeSocks5">Socks5</sys:String> <sys:String x:Key="ProxyTypeSocks5">ساکس5</sys:String>
<!--editor--> <!--editor-->
<sys:String x:Key="EditorProxyType" xml:space="preserve">نوع پروکسی</sys:String> <sys:String x:Key="EditorProxyType" xml:space="preserve">نوع پروکسی</sys:String>
<sys:String x:Key="EditorProxyParams" xml:space="preserve">Params</sys:String> <sys:String x:Key="EditorProxyParams" xml:space="preserve">Params</sys:String>
<!--Xray--> <!--Xray-->
<sys:String x:Key="VlessXtlsRealityDesc" xml:space="preserve">VLESS TCP XTLS REALITY</sys:String>
<sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String> <sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String>
<sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String> <sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String>
<sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String> <sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String>

View file

@ -29,7 +29,7 @@
<sys:String x:Key="MainMenuHelperUseRoot">啓用Root賬戶</sys:String> <sys:String x:Key="MainMenuHelperUseRoot">啓用Root賬戶</sys:String>
<sys:String x:Key="MainMenuHelperCertQuestion">證書問題</sys:String> <sys:String x:Key="MainMenuHelperCertQuestion">證書問題</sys:String>
<sys:String x:Key="MainMenuHelperPrivateKey">私鑰問題</sys:String> <sys:String x:Key="MainMenuHelperPrivateKey">私鑰問題</sys:String>
<sys:String x:Key="MainMenuHelperResourcesAndTutorials">相關資源與教程</sys:String>
<!--Main DataGrid--> <!--Main DataGrid-->
<sys:String x:Key="MainDataGridColumnTag">名稱</sys:String> <sys:String x:Key="MainDataGridColumnTag">名稱</sys:String>
@ -52,13 +52,11 @@
<sys:String x:Key="HostPassword">密碼</sys:String> <sys:String x:Key="HostPassword">密碼</sys:String>
<sys:String x:Key="HostPort">端口</sys:String> <sys:String x:Key="HostPort">端口</sys:String>
<sys:String x:Key="HostSecretType">登録驗證</sys:String> <sys:String x:Key="HostSecretType">登録驗證</sys:String>
<sys:String x:Key="HostUploadSecretKey">載入私鑰</sys:String> <sys:String x:Key="HostUploadSecretKey">上傳Key</sys:String>
<sys:String x:Key="HostSertTypePassword">密碼</sys:String> <sys:String x:Key="HostSertTypePassword">密碼</sys:String>
<sys:String x:Key="HostSertTypePrivateKey">私鑰</sys:String> <sys:String x:Key="HostSertTypePrivateKey">私鑰</sys:String>
<sys:String x:Key="HostSertTypePrivateKeyPassPhrase">私鑰密碼</sys:String> <sys:String x:Key="HostSertTypePrivateKeyPassPhrase">私鑰密碼</sys:String>
<sys:String x:Key="TextBoxContentTipsNoneBlank">若無,則留空</sys:String>
<sys:String x:Key="ProxyGroupName">代理</sys:String> <sys:String x:Key="ProxyGroupName">代理</sys:String>
<sys:String x:Key="ProxyAddress">IP/地址</sys:String> <sys:String x:Key="ProxyAddress">IP/地址</sys:String>
<sys:String x:Key="ProxyPort">端口</sys:String> <sys:String x:Key="ProxyPort">端口</sys:String>
@ -74,8 +72,7 @@
<sys:String x:Key="EditorProxyParams" xml:space="preserve">節點參數</sys:String> <sys:String x:Key="EditorProxyParams" xml:space="preserve">節點參數</sys:String>
<!--Xray--> <!--Xray-->
<sys:String x:Key="VlessXtlsRealityDesc" xml:space="preserve">VLESS XTLS REALITY</sys:String> <sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS TCP XTLS</sys:String>
<sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String>
<sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String> <sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String>
<sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String> <sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String>
<sys:String x:Key="VlessRpcDesc" xml:space="preserve">VLESS gRPC</sys:String> <sys:String x:Key="VlessRpcDesc" xml:space="preserve">VLESS gRPC</sys:String>

View file

@ -29,7 +29,7 @@
<sys:String x:Key="MainMenuHelperUseRoot">启用Root账户</sys:String> <sys:String x:Key="MainMenuHelperUseRoot">启用Root账户</sys:String>
<sys:String x:Key="MainMenuHelperCertQuestion">证书问题</sys:String> <sys:String x:Key="MainMenuHelperCertQuestion">证书问题</sys:String>
<sys:String x:Key="MainMenuHelperPrivateKey">私钥问题</sys:String> <sys:String x:Key="MainMenuHelperPrivateKey">私钥问题</sys:String>
<sys:String x:Key="MainMenuHelperResourcesAndTutorials">相关资源与教程</sys:String>
<!--Main DataGrid--> <!--Main DataGrid-->
<sys:String x:Key="MainDataGridColumnTag">名称</sys:String> <sys:String x:Key="MainDataGridColumnTag">名称</sys:String>
@ -53,13 +53,11 @@
<sys:String x:Key="HostPassword">密码</sys:String> <sys:String x:Key="HostPassword">密码</sys:String>
<sys:String x:Key="HostPort">端口</sys:String> <sys:String x:Key="HostPort">端口</sys:String>
<sys:String x:Key="HostSecretType">登陆验证</sys:String> <sys:String x:Key="HostSecretType">登陆验证</sys:String>
<sys:String x:Key="HostUploadSecretKey">载入私钥</sys:String> <sys:String x:Key="HostUploadSecretKey">上传Key</sys:String>
<sys:String x:Key="HostSertTypePassword">密码</sys:String> <sys:String x:Key="HostSertTypePassword">密码</sys:String>
<sys:String x:Key="HostSertTypePrivateKey">私钥</sys:String> <sys:String x:Key="HostSertTypePrivateKey">私钥</sys:String>
<sys:String x:Key="HostSertTypePrivateKeyPassPhrase">私钥密码</sys:String> <sys:String x:Key="HostSertTypePrivateKeyPassPhrase">私钥密码</sys:String>
<sys:String x:Key="TextBoxContentTipsNoneBlank">若无,则留空</sys:String>
<sys:String x:Key="ProxyGroupName">代理</sys:String> <sys:String x:Key="ProxyGroupName">代理</sys:String>
<sys:String x:Key="ProxyAddress">IP/地址</sys:String> <sys:String x:Key="ProxyAddress">IP/地址</sys:String>
<sys:String x:Key="ProxyPort">端口</sys:String> <sys:String x:Key="ProxyPort">端口</sys:String>
@ -75,8 +73,7 @@
<sys:String x:Key="EditorProxyParams" xml:space="preserve">节点参数</sys:String> <sys:String x:Key="EditorProxyParams" xml:space="preserve">节点参数</sys:String>
<!--Xray--> <!--Xray-->
<sys:String x:Key="VlessXtlsRealityDesc" xml:space="preserve">VLESS XTLS REALITY</sys:String> <sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS TCP XTLS</sys:String>
<sys:String x:Key="VlessXtlsDesc" xml:space="preserve">VLESS XTLS</sys:String>
<sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String> <sys:String x:Key="VlessTcpDesc" xml:space="preserve">VLESS TCP</sys:String>
<sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String> <sys:String x:Key="VlessWsDesc" xml:space="preserve">VLESS WS</sys:String>
<sys:String x:Key="VlessRpcDesc" xml:space="preserve">VLESS gRPC</sys:String> <sys:String x:Key="VlessRpcDesc" xml:space="preserve">VLESS gRPC</sys:String>

View file

@ -5,7 +5,7 @@
"clients": [ "clients": [
{ {
"id": "", "id": "",
"flow": "xtls-rprx-vision" "flow": "xtls-rprx-vision,none"
} }
], ],
"decryption": "none", "decryption": "none",

View file

@ -41,7 +41,6 @@
<MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperUseRoot}" Click="LaunchUseRootSite"></MenuItem> <MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperUseRoot}" Click="LaunchUseRootSite"></MenuItem>
<MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperCertQuestion}" Click="LaunchCertQuestion"></MenuItem> <MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperCertQuestion}" Click="LaunchCertQuestion"></MenuItem>
<MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperPrivateKey}" Click="LaunchPrivateKeyQuestion"></MenuItem> <MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperPrivateKey}" Click="LaunchPrivateKeyQuestion"></MenuItem>
<MenuItem Padding="0,5" Header="{DynamicResource MainMenuHelperResourcesAndTutorials}" Click="LaunchResourcesAndTutorials"></MenuItem>
</MenuItem> </MenuItem>
</Menu> </Menu>

View file

@ -62,10 +62,6 @@ namespace ProxySuper.WPF.Views
System.Diagnostics.Process.Start("explorer.exe", "https://github.com/proxysu/ProxySU/wiki/PrivateKey%E8%BD%AC%E6%8D%A2"); System.Diagnostics.Process.Start("explorer.exe", "https://github.com/proxysu/ProxySU/wiki/PrivateKey%E8%BD%AC%E6%8D%A2");
} }
private void LaunchResourcesAndTutorials(object sender, RoutedEventArgs e)
{
System.Diagnostics.Process.Start("explorer.exe", "https://github.com/proxysu/ProxySU/wiki/%E7%9B%B8%E5%85%B3%E8%B5%84%E6%BA%90%E4%B8%8E%E6%95%99%E7%A8%8B");
}
ResourceDictionary resource = new ResourceDictionary(); ResourceDictionary resource = new ResourceDictionary();
private void SetSimpleChinese(object sender, RoutedEventArgs e) private void SetSimpleChinese(object sender, RoutedEventArgs e)

View file

@ -1,7 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<packages> <packages>
<package id="Costura.Fody" version="6.0.0" targetFramework="net472" developmentDependency="true" />
<package id="Fody" version="6.8.2" targetFramework="net472" developmentDependency="true" />
<package id="Microsoft.Extensions.Logging.Abstractions" version="7.0.0" targetFramework="net472" /> <package id="Microsoft.Extensions.Logging.Abstractions" version="7.0.0" targetFramework="net472" />
<package id="MvvmCross" version="8.0.2" targetFramework="net472" /> <package id="MvvmCross" version="8.0.2" targetFramework="net472" />
<package id="MvvmCross.Platforms.Wpf" version="8.0.2" targetFramework="net472" /> <package id="MvvmCross.Platforms.Wpf" version="8.0.2" targetFramework="net472" />