mirror of
https://github.com/amnezia-vpn/amnezia-client.git
synced 2026-06-22 02:01:08 +07:00
847bb6923b
* refactor: move business logic from servers model * refactor: move containersModel initialization * refactor: added protocol ui controller and removed settings class from protocols model * refactor: moved cli management to separate controller * refactor: moved app split to separate controller * refactor: moved site split to separate controller * refactor: moved allowed dns to separate controller * refactor: moved language logic to separate ui controller * refactor: removed Settings from devices model * refactor: moved configs and services api logit to separate core controller * refactor: added a layer with a repository between the storage and controllers * refactor: use child parent system instead of smart pointers for controllers and models initialization * refactor: moved install functions from server controller to install controller * refactor: install controller refactoring * chore: renamed exportController to exportUiController * refactor: separate export controller * refactor: removed VpnConfigurationsController * chore: renamed ServerController to SshSession * refactor: replaced ServerController to SshSession * chore: moved qml controllers to separate folder * chore: include fixes * chore: moved utils from core root to core/utils * chore: include fixes * chore: rename core/utils files to camelCase foramt * chore: include fixes * chore: moved some utils to api and selfhosted folders * chore: include fixes * chore: remove unused file * chore: moved serialization folder to core/utils * chore: include fixes * chore: moved some files from client root to core/utils * chore: include fixes * chore: moved ui utils to ui/utils folder * chore: include fixes * chore: move utils from root to ui/utils * chore: include fixes * chore: moved configurators to core/configurators * chore: include fixes * refactor: moved iap logic from ui controller to core * refactor: moved remaining core logic from ApiConfigsController to SubscriptionController * chore: rename apiNewsController to apiNewsUiController * refactor: moved core logic from news ui controller to core * chore: renamed apiConfigsController to subscriptionUiController * chore: include fixes * refactor: merge ApiSettingsController with SubscriptionUiController * chore: moved ui selfhosted controllers to separate folder * chore: include fixes * chore: rename connectionController to connectiomUiController * refactor: moved core logic from connectionUiController * chore: rename settingsController to settingsUiController * refactor: move core logic from settingsUiController * refactor: moved core controller signal/slot connections to separate class * fix: newsController fixes after refactoring * chore: rename model to camelCase * chore: include fixes * chore: remove unused code * chore: move selfhosted core to separate folder * chore: include fixes * chore: rename importController to importUiController * refactor: move core logic from importUiController * chore: minor fixes * chore: remove prem v1 migration * refactor: remove openvpn over cloak and openvpn over shadowsocks * refactor: removed protocolsForContainer function * refactor: add core models * refactor: replace json with c++ structs for server config * refactor: move getDnsPair to ServerConfigUtils * feat: add admin selfhosted config export test * feat: add multi import test * refactor: use coreController for tests * feat: add few simple tests * chore: qrepos in all core controllers * feat: add test for settings * refactor: remove repo dependency from configurators * chore: moved protocols to core folder * chore: include fixes * refactor: moved containersDefs, defs, apiDefs, protocolsDefs to different places * chore: include fixes * chore: build fixes * chore: build fixes * refactor: remove q repo and interface repo * feat: add test for ui servers model and controller * chore: renamed to camelCase * chore: include fixes * refactor: moved core logic from sites ui controller * fix: fixed api config processing * fix: fixed processed server index processing * refactor: protocol models now use c++ structs instead of json configs * refactor: servers model now use c++ struct instead of json config * fix: fixed default server index processing * fix: fix logs init * fix: fix secure settings load keys * chore: build fixes * fix: fixed clear settings * fix: fixed restore backup * fix: sshSession usage * fix: fixed export functions signatures * fix: return missing part from buildContainerWorker * fix: fixed server description on page home * refactor: add container config helpers functions * refactor: c++ structs instead of json * chore: add dns protocol config struct * refactor: move config utils functions to config structs * feat: add test for selfhosted server setup * refactor: separate resources.qrc * fix: fixed server rename * chore: return nameOverriddenByUser * fix: build fixes * fix: fixed models init * refactor: cleanup models usage * fix: fixed models init * chore: cleanup connections and functions signatures * chore: cleanup updateModel calls * feat: added cache to servers repo * chore: cleanup unused functions * chore: ssxray processing * chore: remove transportProtoWithDefault and portWithDefault functions * chore: removed proto types any and l2tp * refactor: moved some constants * fix: fixed native configs export * refactor: remove json from processConfigWith functions * fix: fixed processed server index usage * fix: qml warning fixes * chore: merge fixes * chore: update tests * fix: fixed xray config processing * fix: fixed split tunneling processing * chore: rename sites controllers and model * chore: rename fixes * chore: minor fixes * chore: remove ability to load backup from "file with connection settings" button * fix: fixed api device revoke * fix: remove full model update when renaming a user * fix: fixed premium/free server rename * fix: fixed selfhosted new server install * fix: fixed updateContainer function * fix: fixed revoke for external premium configs * feat: add native configs qr processing * chore: codestyle fixes * fix: fixed admin config create * chore: again remove ability to load backup from "file with connection settings" button * chore: minor fixes * fix: fixed variables initialization * fix: fixed qml imports * fix: minor fixes * fix: fix vpnConnection function calls * feat: add buckup error handling * fix: fixed admin config revok * fix: fixed selfhosted awg installation * fix: ad visability * feat: add empty check for primary dns * chore: minor fixes
453 lines
14 KiB
QML
453 lines
14 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
import PageEnum 1.0
|
|
import ProtocolEnum 1.0
|
|
import Style 1.0
|
|
|
|
import "./"
|
|
import "../Controls2"
|
|
import "../Controls2/TextTypes"
|
|
import "../Config"
|
|
import "../Components"
|
|
|
|
PageType {
|
|
id: root
|
|
|
|
BackButtonType {
|
|
id: backButton
|
|
|
|
anchors.top: parent.top
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.topMargin: 20 + PageController.safeAreaTopMargin
|
|
|
|
onActiveFocusChanged: {
|
|
if(backButton.enabled && backButton.activeFocus) {
|
|
listView.positionViewAtBeginning()
|
|
}
|
|
}
|
|
}
|
|
|
|
ListViewType {
|
|
id: listView
|
|
|
|
anchors.top: backButton.bottom
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
anchors.left: parent.left
|
|
|
|
enabled: ServersUiController.isProcessedServerHasWriteAccess()
|
|
|
|
header: ColumnLayout {
|
|
width: listView.width
|
|
|
|
BaseHeaderType {
|
|
id: header
|
|
|
|
Layout.fillWidth: true
|
|
Layout.rightMargin: 16
|
|
Layout.leftMargin: 16
|
|
|
|
headerText: qsTr("OpenVPN Settings")
|
|
}
|
|
}
|
|
|
|
model: OpenVpnConfigModel
|
|
|
|
delegate: ColumnLayout {
|
|
width: listView.width
|
|
|
|
spacing: 0
|
|
|
|
TextFieldWithHeaderType {
|
|
id: vpnAddressSubnetTextField
|
|
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 32
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
enabled: listView.enabled
|
|
|
|
headerText: qsTr("VPN address subnet")
|
|
textField.text: subnetAddress
|
|
|
|
textField.onEditingFinished: {
|
|
if (textField.text !== subnetAddress) {
|
|
subnetAddress = textField.text
|
|
}
|
|
}
|
|
|
|
checkEmptyText: true
|
|
}
|
|
|
|
ParagraphTextType {
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 32
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
text: qsTr("Network protocol")
|
|
}
|
|
|
|
TransportProtoSelector {
|
|
id: transportProtoSelector
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 16
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
rootWidth: root.width
|
|
|
|
enabled: isTransportProtoEditable
|
|
|
|
currentIndex: {
|
|
return transportProto === "tcp" ? 1 : 0
|
|
}
|
|
|
|
onCurrentIndexChanged: {
|
|
if (transportProto === "tcp" && currentIndex === 0) {
|
|
transportProto = "udp"
|
|
} else if (transportProto === "udp" && currentIndex === 1) {
|
|
transportProto = "tcp"
|
|
}
|
|
}
|
|
}
|
|
|
|
TextFieldWithHeaderType {
|
|
id: portTextField
|
|
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 40
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
enabled: listView.enabled
|
|
|
|
headerText: qsTr("Port")
|
|
textField.text: port
|
|
textField.maximumLength: 5
|
|
textField.validator: IntValidator { bottom: 1; top: 65535 }
|
|
|
|
textField.onEditingFinished: {
|
|
if (textField.text !== port) {
|
|
port = textField.text
|
|
}
|
|
}
|
|
|
|
checkEmptyText: true
|
|
}
|
|
|
|
SwitcherType {
|
|
id: autoNegotiateEncryprionSwitcher
|
|
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 24
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
text: qsTr("Auto-negotiate encryption")
|
|
checked: autoNegotiateEncryprion
|
|
|
|
onToggled: function() {
|
|
if (checked !== autoNegotiateEncryprion) {
|
|
autoNegotiateEncryprion = checked
|
|
}
|
|
}
|
|
}
|
|
|
|
DropDownType {
|
|
id: hashDropDown
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 20
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
enabled: !autoNegotiateEncryprionSwitcher.checked
|
|
|
|
descriptionText: qsTr("Hash")
|
|
headerText: qsTr("Hash")
|
|
|
|
drawerParent: root
|
|
|
|
listView: ListViewWithRadioButtonType {
|
|
id: hashListView
|
|
|
|
rootWidth: root.width
|
|
|
|
model: ListModel {
|
|
ListElement { name : qsTr("SHA512") }
|
|
ListElement { name : qsTr("SHA384") }
|
|
ListElement { name : qsTr("SHA256") }
|
|
ListElement { name : qsTr("SHA3-512") }
|
|
ListElement { name : qsTr("SHA3-384") }
|
|
ListElement { name : qsTr("SHA3-256") }
|
|
ListElement { name : qsTr("whirlpool") }
|
|
ListElement { name : qsTr("BLAKE2b512") }
|
|
ListElement { name : qsTr("BLAKE2s256") }
|
|
ListElement { name : qsTr("SHA1") }
|
|
}
|
|
|
|
function updateSelectedIndex() {
|
|
hashDropDown.text = hash
|
|
for (var i = 0; i < hashListView.model.count; i++) {
|
|
if (hashListView.model.get(i).name === hash) {
|
|
selectedIndex = i
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
clickedFunction: function() {
|
|
hashDropDown.text = selectedText
|
|
hash = hashDropDown.text
|
|
hashDropDown.closeTriggered()
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
updateSelectedIndex()
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: listView.model
|
|
function onDataChanged() {
|
|
hashListView.updateSelectedIndex()
|
|
}
|
|
}
|
|
}
|
|
|
|
DropDownType {
|
|
id: cipherDropDown
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 16
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
enabled: !autoNegotiateEncryprionSwitcher.checked
|
|
|
|
descriptionText: qsTr("Cipher")
|
|
headerText: qsTr("Cipher")
|
|
|
|
drawerParent: root
|
|
|
|
listView: ListViewWithRadioButtonType {
|
|
id: cipherListView
|
|
|
|
rootWidth: root.width
|
|
|
|
model: ListModel {
|
|
ListElement { name : qsTr("AES-256-GCM") }
|
|
ListElement { name : qsTr("AES-192-GCM") }
|
|
ListElement { name : qsTr("AES-128-GCM") }
|
|
ListElement { name : qsTr("AES-256-CBC") }
|
|
ListElement { name : qsTr("AES-192-CBC") }
|
|
ListElement { name : qsTr("AES-128-CBC") }
|
|
ListElement { name : qsTr("ChaCha20-Poly1305") }
|
|
ListElement { name : qsTr("ARIA-256-CBC") }
|
|
ListElement { name : qsTr("CAMELLIA-256-CBC") }
|
|
ListElement { name : qsTr("none") }
|
|
}
|
|
|
|
function updateSelectedIndex() {
|
|
cipherDropDown.text = cipher
|
|
for (var i = 0; i < cipherListView.model.count; i++) {
|
|
if (cipherListView.model.get(i).name === cipher) {
|
|
selectedIndex = i
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
clickedFunction: function() {
|
|
cipherDropDown.text = selectedText
|
|
cipher = cipherDropDown.text
|
|
cipherDropDown.closeTriggered()
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
updateSelectedIndex()
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: listView.model
|
|
function onDataChanged() {
|
|
cipherListView.updateSelectedIndex()
|
|
}
|
|
}
|
|
}
|
|
|
|
Rectangle {
|
|
id: contentRect
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 32
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
Layout.preferredHeight: checkboxLayout.implicitHeight
|
|
color: AmneziaStyle.color.onyxBlack
|
|
radius: 16
|
|
|
|
ColumnLayout {
|
|
id: checkboxLayout
|
|
|
|
anchors.fill: parent
|
|
|
|
CheckBoxType {
|
|
id: tlsAuthCheckBox
|
|
Layout.fillWidth: true
|
|
|
|
text: qsTr("TLS auth")
|
|
checked: tlsAuth
|
|
|
|
onCheckedChanged: {
|
|
if (checked !== tlsAuth) {
|
|
console.log("tlsAuth changed to: " + checked)
|
|
tlsAuth = checked
|
|
}
|
|
}
|
|
}
|
|
|
|
DividerType {}
|
|
|
|
CheckBoxType {
|
|
id: blockDnsCheckBox
|
|
Layout.fillWidth: true
|
|
|
|
text: qsTr("Block DNS requests outside of VPN")
|
|
checked: blockDns
|
|
|
|
onCheckedChanged: {
|
|
if (checked !== blockDns) {
|
|
blockDns = checked
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
SwitcherType {
|
|
id: additionalClientCommandsSwitcher
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 32
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
checked: additionalClientCommands !== ""
|
|
|
|
text: qsTr("Additional client configuration commands")
|
|
|
|
onToggled: function() {
|
|
if (!checked) {
|
|
additionalClientCommands = ""
|
|
}
|
|
}
|
|
}
|
|
|
|
TextAreaType {
|
|
id: additionalClientCommandsTextArea
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 16
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
visible: additionalClientCommandsSwitcher.checked
|
|
|
|
textAreaText: additionalClientCommands
|
|
placeholderText: qsTr("Commands:")
|
|
|
|
textArea.onEditingFinished: {
|
|
if (additionalClientCommands !== textAreaText) {
|
|
additionalClientCommands = textAreaText
|
|
}
|
|
}
|
|
}
|
|
|
|
SwitcherType {
|
|
id: additionalServerCommandsSwitcher
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 16
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
checked: additionalServerCommands !== ""
|
|
|
|
text: qsTr("Additional server configuration commands")
|
|
|
|
onToggled: function() {
|
|
if (!checked) {
|
|
additionalServerCommands = ""
|
|
}
|
|
}
|
|
}
|
|
|
|
TextAreaType {
|
|
id: additionalServerCommandsTextArea
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 16
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
visible: additionalServerCommandsSwitcher.checked
|
|
|
|
textAreaText: additionalServerCommands
|
|
placeholderText: qsTr("Commands:")
|
|
|
|
textArea.onEditingFinished: {
|
|
if (additionalServerCommands !== textAreaText) {
|
|
additionalServerCommands = textAreaText
|
|
}
|
|
}
|
|
}
|
|
|
|
BasicButtonType {
|
|
id: saveButton
|
|
|
|
Layout.fillWidth: true
|
|
Layout.topMargin: 24
|
|
Layout.bottomMargin: 24
|
|
Layout.leftMargin: 16
|
|
Layout.rightMargin: 16
|
|
|
|
enabled: vpnAddressSubnetTextField.errorText === "" &&
|
|
portTextField.errorText === ""
|
|
|
|
text: qsTr("Save")
|
|
|
|
onClicked: function() {
|
|
forceActiveFocus()
|
|
|
|
var headerText = qsTr("Save settings?")
|
|
var descriptionText = qsTr("All users with whom you shared a connection with will no longer be able to connect to it.")
|
|
var yesButtonText = qsTr("Continue")
|
|
var noButtonText = qsTr("Cancel")
|
|
|
|
var yesButtonFunction = function() {
|
|
if (ConnectionController.isConnected && ServersModel.getDefaultServerData("defaultContainer") === ServersUiController.processedContainerIndex) {
|
|
PageController.showNotificationMessage(qsTr("Unable change settings while there is an active connection"))
|
|
return
|
|
}
|
|
|
|
PageController.goToPage(PageEnum.PageSetupWizardInstalling);
|
|
InstallController.updateContainer(ServersUiController.processedIndex, ServersUiController.processedContainerIndex, ProtocolEnum.OpenVpn)
|
|
}
|
|
var noButtonFunction = function() {
|
|
if (!GC.isMobile()) {
|
|
saveButton.forceActiveFocus()
|
|
}
|
|
}
|
|
showQuestionDrawer(headerText, descriptionText, yesButtonText, noButtonText, yesButtonFunction, noButtonFunction)
|
|
}
|
|
|
|
Keys.onEnterPressed: saveButton.clicked()
|
|
Keys.onReturnPressed: saveButton.clicked()
|
|
}
|
|
}
|
|
}
|
|
}
|