-rw-r--r-- | noncore/settings/networksettings/ppp/TODO | 6 | ||||
-rw-r--r-- | noncore/settings/networksettings/ppp/accounts.cpp | 42 | ||||
-rw-r--r-- | noncore/settings/networksettings/ppp/pppconfig.cpp | 8 | ||||
-rw-r--r-- | noncore/settings/networksettings/ppp/pppdata.cpp | 54 | ||||
-rw-r--r-- | noncore/settings/networksettings/ppp/pppdata.h | 23 | ||||
-rw-r--r-- | noncore/settings/networksettings/ppp/pppmodule.cpp | 23 |
6 files changed, 78 insertions, 78 deletions
diff --git a/noncore/settings/networksettings/ppp/TODO b/noncore/settings/networksettings/ppp/TODO new file mode 100644 index 0000000..2410880 --- a/dev/null +++ b/noncore/settings/networksettings/ppp/TODO | |||
@@ -0,0 +1,6 @@ | |||
1 | - impl. PPPData::copyaccount & PPPData::deleteAccount | ||
2 | - update modem attribute inputs when modem has changed | ||
3 | - fix layout of edit account | ||
4 | - save pppd arguments in edit account | ||
5 | - popup configure modem with the correct account prselected | ||
6 | not quite shure why it does not work... IMHO it should work | ||
diff --git a/noncore/settings/networksettings/ppp/accounts.cpp b/noncore/settings/networksettings/ppp/accounts.cpp index 19db9ef..11d4739 100644 --- a/noncore/settings/networksettings/ppp/accounts.cpp +++ b/noncore/settings/networksettings/ppp/accounts.cpp | |||
@@ -1,271 +1,245 @@ | |||
1 | /* | 1 | /* |
2 | * kPPP: A pppd front end for the KDE project | 2 | * kPPP: A pppd front end for the KDE project |
3 | * | 3 | * |
4 | * $Id$ | 4 | * $Id$ |
5 | * | 5 | * |
6 | * Copyright (C) 1997 Bernd Johannes Wuebben | 6 | * Copyright (C) 1997 Bernd Johannes Wuebben |
7 | * wuebben@math.cornell.edu | 7 | * wuebben@math.cornell.edu |
8 | * | 8 | * |
9 | * based on EzPPP: | 9 | * based on EzPPP: |
10 | * Copyright (C) 1997 Jay Painter | 10 | * Copyright (C) 1997 Jay Painter |
11 | * | 11 | * |
12 | * This program is free software; you can redistribute it and/or | 12 | * This program is free software; you can redistribute it and/or |
13 | * modify it under the terms of the GNU Library General Public | 13 | * modify it under the terms of the GNU Library General Public |
14 | * License as published by the Free Software Foundation; either | 14 | * License as published by the Free Software Foundation; either |
15 | * version 2 of the License, or (at your option) any later version. | 15 | * version 2 of the License, or (at your option) any later version. |
16 | * | 16 | * |
17 | * This program is distributed in the hope that it will be useful, | 17 | * This program is distributed in the hope that it will be useful, |
18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
20 | * Library General Public License for more details. | 20 | * Library General Public License for more details. |
21 | * | 21 | * |
22 | * You should have received a copy of the GNU Library General Public | 22 | * You should have received a copy of the GNU Library General Public |
23 | * License along with this program; if not, write to the Free | 23 | * License along with this program; if not, write to the Free |
24 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 24 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
25 | */ | 25 | */ |
26 | 26 | ||
27 | #include <qdir.h> | 27 | #include <qdir.h> |
28 | #include <stdlib.h> | 28 | #include <stdlib.h> |
29 | #include <qlayout.h> | 29 | #include <qlayout.h> |
30 | #include <qtabwidget.h> | 30 | #include <qtabwidget.h> |
31 | #include <qtabdialog.h> | 31 | #include <qtabdialog.h> |
32 | #include <qwhatsthis.h> | 32 | #include <qwhatsthis.h> |
33 | #include <qmessagebox.h> | 33 | #include <qmessagebox.h> |
34 | 34 | ||
35 | #include <qapplication.h> | 35 | #include <qapplication.h> |
36 | #include <qbuttongroup.h> | 36 | #include <qbuttongroup.h> |
37 | #include <qmessagebox.h> | 37 | #include <qmessagebox.h> |
38 | //#include <klocale.h> | 38 | //#include <klocale.h> |
39 | #define i18n QObject::tr | 39 | #define i18n QObject::tr |
40 | //#include <kglobal.h> | 40 | //#include <kglobal.h> |
41 | //#include <kwin.h> | 41 | //#include <kwin.h> |
42 | //#include <kdialogbase.h> | 42 | //#include <kdialogbase.h> |
43 | #include <qvgroupbox.h> | 43 | #include <qvgroupbox.h> |
44 | 44 | ||
45 | #include "pppdata.h" | 45 | #include "pppdata.h" |
46 | #include "accounts.h" | 46 | #include "accounts.h" |
47 | //#include "accounting.h" | 47 | //#include "accounting.h" |
48 | //#include "providerdb.h" | 48 | //#include "providerdb.h" |
49 | #include "edit.h" | 49 | #include "edit.h" |
50 | 50 | ||
51 | void parseargs(char* buf, char** args); | 51 | void parseargs(char* buf, char** args); |
52 | 52 | ||
53 | AccountWidget::AccountWidget( QWidget *parent, const char *name ) | 53 | AccountWidget::AccountWidget( QWidget *parent, const char *name ) |
54 | : QWidget( parent, name ) | 54 | : QWidget( parent, name ) |
55 | { | 55 | { |
56 | // int min = 0; | ||
57 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); | 56 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); |
58 | |||
59 | // add a hbox | ||
60 | // QHBoxLayout *l11 = new QHBoxLayout; | ||
61 | // l1->addLayout(l11); | ||
62 | |||
63 | accountlist_l = new QListBox(this); | 57 | accountlist_l = new QListBox(this); |
64 | // accountlist_l->setMinimumSize(160, 128); | 58 | |
65 | connect(accountlist_l, SIGNAL(highlighted(int)), | 59 | connect(accountlist_l, SIGNAL(highlighted(int)), |
66 | this, SLOT(slotListBoxSelect(int))); | 60 | this, SLOT(slotListBoxSelect(int))); |
67 | connect(accountlist_l, SIGNAL(selected(int)), | 61 | connect(accountlist_l, SIGNAL(selected(int)), |
68 | this, SLOT(editaccount())); | 62 | this, SLOT(editaccount())); |
69 | l1->addWidget(accountlist_l, 10); | 63 | l1->addWidget(accountlist_l, 10); |
70 | 64 | ||
71 | // QVBoxLayout *l111 = new QVBoxLayout(this); | ||
72 | // l11->addLayout(l111, 1); | ||
73 | edit_b = new QPushButton(i18n("&Edit..."), this); | 65 | edit_b = new QPushButton(i18n("&Edit..."), this); |
74 | connect(edit_b, SIGNAL(clicked()), SLOT(editaccount())); | 66 | connect(edit_b, SIGNAL(clicked()), SLOT(editaccount())); |
75 | QWhatsThis::add(edit_b, i18n("Allows you to modify the selected account")); | 67 | QWhatsThis::add(edit_b, i18n("Allows you to modify the selected account")); |
76 | |||
77 | // min = edit_b->sizeHint().width(); | ||
78 | // min = QMAX(70,min); | ||
79 | // edit_b->setMinimumWidth(min); | ||
80 | |||
81 | l1->addWidget(edit_b); | 68 | l1->addWidget(edit_b); |
82 | 69 | ||
83 | new_b = new QPushButton(i18n("&New..."), this); | 70 | new_b = new QPushButton(i18n("&New..."), this); |
84 | connect(new_b, SIGNAL(clicked()), SLOT(newaccount())); | 71 | connect(new_b, SIGNAL(clicked()), SLOT(newaccount())); |
85 | l1->addWidget(new_b); | 72 | l1->addWidget(new_b); |
86 | QWhatsThis::add(new_b, i18n("Create a new dialup connection\n" | 73 | QWhatsThis::add(new_b, i18n("Create a new dialup connection\n" |
87 | "to the Internet")); | 74 | "to the Internet")); |
88 | 75 | ||
89 | copy_b = new QPushButton(i18n("Co&py"), this); | 76 | copy_b = new QPushButton(i18n("Co&py"), this); |
90 | connect(copy_b, SIGNAL(clicked()), SLOT(copyaccount())); | 77 | connect(copy_b, SIGNAL(clicked()), SLOT(copyaccount())); |
91 | l1->addWidget(copy_b); | 78 | l1->addWidget(copy_b); |
92 | QWhatsThis::add(copy_b, | 79 | QWhatsThis::add(copy_b, |
93 | i18n("Makes a copy of the selected account. All\n" | 80 | i18n("Makes a copy of the selected account. All\n" |
94 | "settings of the selected account are copied\n" | 81 | "settings of the selected account are copied\n" |
95 | "to a new account, that you can modify to fit your\n" | 82 | "to a new account, that you can modify to fit your\n" |
96 | "needs")); | 83 | "needs")); |
97 | 84 | ||
98 | delete_b = new QPushButton(i18n("De&lete"), this); | 85 | delete_b = new QPushButton(i18n("De&lete"), this); |
99 | connect(delete_b, SIGNAL(clicked()), SLOT(deleteaccount())); | 86 | connect(delete_b, SIGNAL(clicked()), SLOT(deleteaccount())); |
100 | l1->addWidget(delete_b); | 87 | l1->addWidget(delete_b); |
101 | QWhatsThis::add(delete_b, | 88 | QWhatsThis::add(delete_b, |
102 | i18n("<p>Deletes the selected account\n\n" | 89 | i18n("<p>Deletes the selected account\n\n" |
103 | "<font color=\"red\"><b>Use with care!</b></font>")); | 90 | "<font color=\"red\"><b>Use with care!</b></font>")); |
104 | 91 | ||
105 | QHBoxLayout *l12 = new QHBoxLayout; | 92 | QHBoxLayout *l12 = new QHBoxLayout; |
106 | l1->addStretch(1); | 93 | l1->addStretch(1); |
107 | l1->addLayout(l12); | 94 | l1->addLayout(l12); |
108 | 95 | ||
109 | // QVBoxLayout *l121 = new QVBoxLayout; | 96 | // QVBoxLayout *l121 = new QVBoxLayout; |
110 | // l12->addLayout(l121); | 97 | // l12->addLayout(l121); |
111 | // l121->addStretch(1); | 98 | // l121->addStretch(1); |
112 | // costlabel = new QLabel(i18n("Phone costs:"), parent); | 99 | // costlabel = new QLabel(i18n("Phone costs:"), parent); |
113 | // costlabel->setEnabled(FALSE); | 100 | // costlabel->setEnabled(FALSE); |
114 | // l121->addWidget(costlabel); | 101 | // l121->addWidget(costlabel); |
115 | 102 | ||
116 | // costedit = new QLineEdit(parent); | 103 | // costedit = new QLineEdit(parent); |
117 | // costedit->setFocusPolicy(QWidget::NoFocus); | 104 | // costedit->setFocusPolicy(QWidget::NoFocus); |
118 | // costedit->setFixedHeight(costedit->sizeHint().height()); | 105 | // costedit->setFixedHeight(costedit->sizeHint().height()); |
119 | // costedit->setEnabled(FALSE); | 106 | // costedit->setEnabled(FALSE); |
120 | // l121->addWidget(costedit); | 107 | // l121->addWidget(costedit); |
121 | // l121->addStretch(1); | 108 | // l121->addStretch(1); |
122 | // QString tmp = i18n("<p>This shows the accumulated phone costs\n" | 109 | // QString tmp = i18n("<p>This shows the accumulated phone costs\n" |
123 | // "for the selected account.\n" | 110 | // "for the selected account.\n" |
124 | // "\n" | 111 | // "\n" |
125 | // "<b>Important</b>: If you have more than one \n" | 112 | // "<b>Important</b>: If you have more than one \n" |
126 | // "account - beware, this is <b>NOT</b> the sum \n" | 113 | // "account - beware, this is <b>NOT</b> the sum \n" |
127 | // "of the phone costs of all your accounts!"); | 114 | // "of the phone costs of all your accounts!"); |
128 | // QWhatsThis::add(costlabel, tmp); | 115 | // QWhatsThis::add(costlabel, tmp); |
129 | // QWhatsThis::add(costedit, tmp); | 116 | // QWhatsThis::add(costedit, tmp); |
130 | 117 | ||
131 | // vollabel = new QLabel(i18n("Volume:"), parent); | 118 | // vollabel = new QLabel(i18n("Volume:"), parent); |
132 | // vollabel->setEnabled(FALSE); | 119 | // vollabel->setEnabled(FALSE); |
133 | // l121->addWidget(vollabel); | 120 | // l121->addWidget(vollabel); |
134 | 121 | ||
135 | // voledit = new QLineEdit(parent,"voledit"); | 122 | // voledit = new QLineEdit(parent,"voledit"); |
136 | // voledit->setFocusPolicy(QWidget::NoFocus); | 123 | // voledit->setFocusPolicy(QWidget::NoFocus); |
137 | // voledit->setFixedHeight(voledit->sizeHint().height()); | 124 | // voledit->setFixedHeight(voledit->sizeHint().height()); |
138 | // voledit->setEnabled(FALSE); | 125 | // voledit->setEnabled(FALSE); |
139 | // l121->addWidget(voledit); | 126 | // l121->addWidget(voledit); |
140 | // tmp = i18n("<p>This shows the number of bytes transferred\n" | 127 | // tmp = i18n("<p>This shows the number of bytes transferred\n" |
141 | // "for the selected account (not for all of your\n" | 128 | // "for the selected account (not for all of your\n" |
142 | // "accounts. You can select what to display in\n" | 129 | // "accounts. You can select what to display in\n" |
143 | // "the accounting dialog.\n" | 130 | // "the accounting dialog.\n" |
144 | // "\n" | 131 | // "\n" |
145 | // "<a href=\"#volaccounting\">More on volume accounting</a>"); | 132 | // "<a href=\"#volaccounting\">More on volume accounting</a>"); |
146 | 133 | ||
147 | // QWhatsThis::add(vollabel,tmp); | 134 | // QWhatsThis::add(vollabel,tmp); |
148 | // QWhatsThis::add(voledit, tmp); | 135 | // QWhatsThis::add(voledit, tmp); |
149 | 136 | ||
150 | // QVBoxLayout *l122 = new QVBoxLayout; | 137 | // QVBoxLayout *l122 = new QVBoxLayout; |
151 | // l12->addStretch(1); | 138 | // l12->addStretch(1); |
152 | // l12->addLayout(l122); | 139 | // l12->addLayout(l122); |
153 | 140 | ||
154 | // l122->addStretch(1); | 141 | // l122->addStretch(1); |
155 | // reset = new QPushButton(i18n("&Reset..."), parent); | 142 | // reset = new QPushButton(i18n("&Reset..."), parent); |
156 | // reset->setEnabled(FALSE); | 143 | // reset->setEnabled(FALSE); |
157 | // connect(reset, SIGNAL(clicked()), | 144 | // connect(reset, SIGNAL(clicked()), |
158 | // this, SLOT(resetClicked())); | 145 | // this, SLOT(resetClicked())); |
159 | // l122->addWidget(reset); | 146 | // l122->addWidget(reset); |
160 | 147 | ||
161 | // log = new QPushButton(i18n("&View Logs"), this); | 148 | // log = new QPushButton(i18n("&View Logs"), this); |
162 | // connect(log, SIGNAL(clicked()), | 149 | // connect(log, SIGNAL(clicked()), |
163 | // this, SLOT(viewLogClicked())); | 150 | // this, SLOT(viewLogClicked())); |
164 | // l122->addWidget(log); | 151 | // l122->addWidget(log); |
165 | // l122->addStretch(1); | 152 | // l122->addStretch(1); |
166 | 153 | ||
167 | //load up account list from gppdata to the list box | 154 | //load up account list from gppdata to the list box |
168 | if(PPPData::data()->count() > 0) { | 155 | if(PPPData::data()->count() > 0) { |
169 | for(int i=0; i <= PPPData::data()->count()-1; i++) { | 156 | for(int i=0; i <= PPPData::data()->count()-1; i++) { |
170 | PPPData::data()->setAccountbyIndex(i); | 157 | PPPData::data()->setAccountbyIndex(i); |
171 | accountlist_l->insertItem(PPPData::data()->accname()); | 158 | accountlist_l->insertItem(PPPData::data()->accname()); |
172 | } | 159 | } |
173 | } | 160 | } |
174 | 161 | ||
175 | slotListBoxSelect(accountlist_l->currentItem()); | 162 | // slotListBoxSelect(accountlist_l->currentItem()); |
163 | qDebug("setting listview index to %i",PPPData::data()->currentAccountID() ); | ||
164 | accountlist_l->setCurrentItem( PPPData::data()->currentAccountID() ); | ||
165 | // slotListBoxSelect( PPPData::data()->currentAccountID()); | ||
176 | 166 | ||
177 | l1->activate(); | 167 | l1->activate(); |
178 | } | 168 | } |
179 | 169 | ||
180 | 170 | ||
181 | 171 | ||
182 | void AccountWidget::slotListBoxSelect(int idx) { | 172 | void AccountWidget::slotListBoxSelect(int idx) { |
183 | delete_b->setEnabled((bool)(idx != -1)); | 173 | delete_b->setEnabled((bool)(idx != -1)); |
184 | edit_b->setEnabled((bool)(idx != -1)); | 174 | edit_b->setEnabled((bool)(idx != -1)); |
185 | copy_b->setEnabled((bool)(idx != -1)); | 175 | copy_b->setEnabled((bool)(idx != -1)); |
186 | if(idx!=-1) { | 176 | if(idx!=-1) { |
177 | qDebug("setting account to %i", idx); | ||
187 | QString account = PPPData::data()->accname(); | 178 | QString account = PPPData::data()->accname(); |
188 | PPPData::data()->setAccountbyIndex(accountlist_l->currentItem()); | 179 | PPPData::data()->setAccountbyIndex(accountlist_l->currentItem()); |
189 | // reset->setEnabled(TRUE); | 180 | // PPPData::data()->setAccount(account); |
190 | // costlabel->setEnabled(TRUE); | 181 | } |
191 | // costedit->setEnabled(TRUE); | ||
192 | // costedit->setText(AccountingBase::getCosts(accountlist_l->text(accountlist_l->currentItem()))); | ||
193 | |||
194 | // vollabel->setEnabled(TRUE); | ||
195 | // voledit->setEnabled(TRUE); | ||
196 | // int bytes = PPPData::data()->totalBytes(); | ||
197 | // voledit->setText(prettyPrintVolume(bytes)); | ||
198 | PPPData::data()->setAccount(account); | ||
199 | } else{ | ||
200 | // reset->setEnabled(FALSE); | ||
201 | // costlabel->setEnabled(FALSE); | ||
202 | // costedit->setText(""); | ||
203 | // costedit->setEnabled(FALSE); | ||
204 | // vollabel->setEnabled(FALSE); | ||
205 | // voledit->setText(""); | ||
206 | // voledit->setEnabled(FALSE); | ||
207 | } | ||
208 | } | 182 | } |
209 | 183 | ||
210 | 184 | ||
211 | // void AccountWidget::viewLogClicked(){ | 185 | // void AccountWidget::viewLogClicked(){ |
212 | 186 | ||
213 | // QApplication::flushX(); | 187 | // QApplication::flushX(); |
214 | // if(fork() == 0) { | 188 | // if(fork() == 0) { |
215 | // setgid(getgid()); | 189 | // setgid(getgid()); |
216 | // setuid(getuid()); | 190 | // setuid(getuid()); |
217 | // system("kppplogview -kppp"); | 191 | // system("kppplogview -kppp"); |
218 | // _exit(0); | 192 | // _exit(0); |
219 | // } | 193 | // } |
220 | // } | 194 | // } |
221 | 195 | ||
222 | 196 | ||
223 | // void AccountWidget::resetClicked(){ | 197 | // void AccountWidget::resetClicked(){ |
224 | // if(accountlist_l->currentItem() == -1) | 198 | // if(accountlist_l->currentItem() == -1) |
225 | // return; | 199 | // return; |
226 | 200 | ||
227 | // // QueryReset dlg(this); | 201 | // // QueryReset dlg(this); |
228 | // // int what = dlg.exec(); | 202 | // // int what = dlg.exec(); |
229 | 203 | ||
230 | // // if(what && QueryReset::COSTS) { | 204 | // // if(what && QueryReset::COSTS) { |
231 | // // emit resetCosts(accountlist_l->text(accountlist_l->currentItem())); | 205 | // // emit resetCosts(accountlist_l->text(accountlist_l->currentItem())); |
232 | // // costedit->setText("0"); | 206 | // // costedit->setText("0"); |
233 | // // } | 207 | // // } |
234 | 208 | ||
235 | // // if(what && QueryReset::VOLUME) { | 209 | // // if(what && QueryReset::VOLUME) { |
236 | // // emit resetVolume(accountlist_l->text(accountlist_l->currentItem())); | 210 | // // emit resetVolume(accountlist_l->text(accountlist_l->currentItem())); |
237 | // // voledit->setText(prettyPrintVolume(0)); | 211 | // // voledit->setText(prettyPrintVolume(0)); |
238 | // // } | 212 | // // } |
239 | // } | 213 | // } |
240 | 214 | ||
241 | 215 | ||
242 | void AccountWidget::editaccount() { | 216 | void AccountWidget::editaccount() { |
243 | PPPData::data()->setAccount(accountlist_l->text(accountlist_l->currentItem())); | 217 | PPPData::data()->setAccount(accountlist_l->text(accountlist_l->currentItem())); |
244 | 218 | ||
245 | int result = doTab(); | 219 | int result = doTab(); |
246 | 220 | ||
247 | if(result == QDialog::Accepted) { | 221 | if(result == QDialog::Accepted) { |
248 | accountlist_l->changeItem(PPPData::data()->accname(),accountlist_l->currentItem()); | 222 | accountlist_l->changeItem(PPPData::data()->accname(),accountlist_l->currentItem()); |
249 | // emit resetaccounts(); | 223 | // emit resetaccounts(); |
250 | PPPData::data()->save(); | 224 | PPPData::data()->save(); |
251 | } | 225 | } |
252 | } | 226 | } |
253 | 227 | ||
254 | 228 | ||
255 | void AccountWidget::newaccount() { | 229 | void AccountWidget::newaccount() { |
256 | if(accountlist_l->count() == MAX_ACCOUNTS) { | 230 | if(accountlist_l->count() == MAX_ACCOUNTS) { |
257 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); | 231 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); |
258 | return; | 232 | return; |
259 | } | 233 | } |
260 | 234 | ||
261 | int result; | 235 | int result; |
262 | // int query = QMessageBox::information(this, | 236 | // int query = QMessageBox::information(this, |
263 | // i18n("Do you want to use the wizard to create the new account or the " | 237 | // i18n("Do you want to use the wizard to create the new account or the " |
264 | // "standard, dialog-based setup?\n" | 238 | // "standard, dialog-based setup?\n" |
265 | // "The wizard is easier and sufficient in most cases. If you need " | 239 | // "The wizard is easier and sufficient in most cases. If you need " |
266 | // "very special settings, you might want to try the standard, " | 240 | // "very special settings, you might want to try the standard, " |
267 | // "dialog-based setup."), | 241 | // "dialog-based setup."), |
268 | // i18n("Create New Account"), | 242 | // i18n("Create New Account"), |
269 | // i18n("Wizard"), i18n("Dialog Setup"), i18n("Cancel")); | 243 | // i18n("Wizard"), i18n("Dialog Setup"), i18n("Cancel")); |
270 | 244 | ||
271 | // switch(query) { | 245 | // switch(query) { |
diff --git a/noncore/settings/networksettings/ppp/pppconfig.cpp b/noncore/settings/networksettings/ppp/pppconfig.cpp index e2521a6..4c5f7aa 100644 --- a/noncore/settings/networksettings/ppp/pppconfig.cpp +++ b/noncore/settings/networksettings/ppp/pppconfig.cpp | |||
@@ -1,69 +1,77 @@ | |||
1 | 1 | ||
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qmessagebox.h> | 3 | #include <qmessagebox.h> |
4 | #include <qtabwidget.h> | 4 | #include <qtabwidget.h> |
5 | 5 | ||
6 | #include "accounts.h" | 6 | #include "accounts.h" |
7 | #include "general.h" | 7 | #include "general.h" |
8 | #include "interface.h" | 8 | #include "interface.h" |
9 | #include "modem.h" | 9 | #include "modem.h" |
10 | #include "pppconfig.h" | 10 | #include "pppconfig.h" |
11 | #include "pppdata.h" | 11 | #include "pppdata.h" |
12 | #include "runtests.h" | 12 | #include "runtests.h" |
13 | 13 | ||
14 | PPPConfigWidget::PPPConfigWidget( Interface* iface, QWidget *parent, | 14 | PPPConfigWidget::PPPConfigWidget( Interface* iface, QWidget *parent, |
15 | const char *name, | 15 | const char *name, |
16 | bool modal, WFlags fl ) | 16 | bool modal, WFlags fl ) |
17 | : QDialog(parent, name, modal, fl) | 17 | : QDialog(parent, name, modal, fl) |
18 | { | 18 | { |
19 | setCaption(tr("Configure Modem")); | 19 | setCaption(tr("Configure Modem")); |
20 | int result = runTests(); | 20 | int result = runTests(); |
21 | if(result == TEST_CRITICAL){ | 21 | if(result == TEST_CRITICAL){ |
22 | QMessageBox::critical(0, tr("Modem failure"), tr("A critical failure appeard while testing the modem") ); | 22 | QMessageBox::critical(0, tr("Modem failure"), tr("A critical failure appeard while testing the modem") ); |
23 | return; | 23 | return; |
24 | } | 24 | } |
25 | 25 | ||
26 | interface = iface; | 26 | interface = iface; |
27 | if (!PPPData::data()->setModemDevice( interface->getInterfaceName() )) | 27 | if (!PPPData::data()->setModemDevice( interface->getInterfaceName() )) |
28 | PPPData::data()->setModemDevice("/dev/modem"); | 28 | PPPData::data()->setModemDevice("/dev/modem"); |
29 | qDebug("PPPConfigWidget::PPPConfigWidget"); | ||
30 | qDebug(" interface->getHardwareName >%s<", interface->getHardwareName().latin1()); | ||
29 | if (!PPPData::data()->setAccount( interface->getHardwareName() )) | 31 | if (!PPPData::data()->setAccount( interface->getHardwareName() )) |
30 | PPPData::data()->setAccount( 0 ); | 32 | PPPData::data()->setAccount( 0 ); |
33 | |||
34 | qDebug(" PPPData::data()->accname >%s<",PPPData::data()->accname().latin1()); | ||
35 | qDebug(" PPPData::data()->currentAccountID() >%i<",PPPData::data()->currentAccountID()); | ||
31 | (void)new Modem; | 36 | (void)new Modem; |
32 | 37 | ||
33 | QVBoxLayout *layout = new QVBoxLayout( this ); | 38 | QVBoxLayout *layout = new QVBoxLayout( this ); |
34 | layout->setSpacing( 0 ); | 39 | layout->setSpacing( 0 ); |
35 | layout->setMargin( 1 ); | 40 | layout->setMargin( 1 ); |
36 | tabWindow = new QTabWidget( this, "tabWidget" ); | 41 | tabWindow = new QTabWidget( this, "tabWidget" ); |
37 | layout->addWidget( tabWindow ); | 42 | layout->addWidget( tabWindow ); |
38 | 43 | ||
39 | accounts = new AccountWidget( tabWindow, "accounts" ); | 44 | accounts = new AccountWidget( tabWindow, "accounts" ); |
40 | tabWindow->addTab( accounts, tr("&Accounts") ); | 45 | tabWindow->addTab( accounts, tr("&Accounts") ); |
41 | modem1 = new ModemWidget( tabWindow, "modem1" ); | 46 | modem1 = new ModemWidget( tabWindow, "modem1" ); |
42 | tabWindow->addTab( modem1, tr("&Device") ); | 47 | tabWindow->addTab( modem1, tr("&Device") ); |
43 | modem2 = new ModemWidget2( tabWindow, "modem2" ); | 48 | modem2 = new ModemWidget2( tabWindow, "modem2" ); |
44 | tabWindow->addTab( modem2, tr("&Modem") ); | 49 | tabWindow->addTab( modem2, tr("&Modem") ); |
45 | // graph = new GraphSetup( tabWindow->addPage( tr("&Graph"), tr("Throughput Graph" ) ) ); | 50 | // graph = new GraphSetup( tabWindow->addPage( tr("&Graph"), tr("Throughput Graph" ) ) ); |
46 | // general = new GeneralWidget( tabWindow->addPage( tr("M&isc"), tr("Miscellaneous Settings") ) ); | 51 | // general = new GeneralWidget( tabWindow->addPage( tr("M&isc"), tr("Miscellaneous Settings") ) ); |
47 | 52 | ||
48 | } | 53 | } |
49 | 54 | ||
50 | 55 | ||
51 | PPPConfigWidget::~PPPConfigWidget() | 56 | PPPConfigWidget::~PPPConfigWidget() |
52 | { | 57 | { |
53 | 58 | ||
54 | } | 59 | } |
55 | 60 | ||
56 | void PPPConfigWidget::accept() | 61 | void PPPConfigWidget::accept() |
57 | { | 62 | { |
63 | qDebug("PPPConfigWidget::accept"); | ||
64 | qDebug(" PPPData::data()->accname >%s<",PPPData::data()->accname().latin1()); | ||
65 | qDebug(" interface->getHardwareName >%s<", interface->getHardwareName().latin1()); | ||
58 | interface->setInterfaceName( PPPData::data()->modemDevice() ); | 66 | interface->setInterfaceName( PPPData::data()->modemDevice() ); |
59 | interface->setHardwareName( PPPData::data()->accname() ); | 67 | interface->setHardwareName( PPPData::data()->accname() ); |
60 | PPPData::data()->save(); | 68 | PPPData::data()->save(); |
61 | QDialog::accept(); | 69 | QDialog::accept(); |
62 | } | 70 | } |
63 | 71 | ||
64 | 72 | ||
65 | void PPPConfigWidget::reject() | 73 | void PPPConfigWidget::reject() |
66 | { | 74 | { |
67 | PPPData::data()->cancel(); | 75 | PPPData::data()->cancel(); |
68 | QDialog::reject(); | 76 | QDialog::reject(); |
69 | } | 77 | } |
diff --git a/noncore/settings/networksettings/ppp/pppdata.cpp b/noncore/settings/networksettings/ppp/pppdata.cpp index 109e3b7..3f1675c 100644 --- a/noncore/settings/networksettings/ppp/pppdata.cpp +++ b/noncore/settings/networksettings/ppp/pppdata.cpp | |||
@@ -1,128 +1,127 @@ | |||
1 | /* | 1 | /* |
2 | * kPPP: A pppd front end for the KDE project | 2 | * kPPP: A pppd front end for the KDE project |
3 | * | 3 | * |
4 | * $Id$ | 4 | * $Id$ |
5 | * | 5 | * |
6 | * Copyright (C) 1997 Bernd Johannes Wuebben | 6 | * Copyright (C) 1997 Bernd Johannes Wuebben |
7 | * wuebben@math.cornell.edu | 7 | * wuebben@math.cornell.edu |
8 | * | 8 | * |
9 | * based on EzPPP: | 9 | * based on EzPPP: |
10 | * Copyright (C) 1997 Jay Painter | 10 | * Copyright (C) 1997 Jay Painter |
11 | * | 11 | * |
12 | * This program is free software; you can redistribute it and/or | 12 | * This program is free software; you can redistribute it and/or |
13 | * modify it under the terms of the GNU Library General Public | 13 | * modify it under the terms of the GNU Library General Public |
14 | * License as published by the Free Software Foundation; either | 14 | * License as published by the Free Software Foundation; either |
15 | * version 2 of the License, or (at your option) any later version. | 15 | * version 2 of the License, or (at your option) any later version. |
16 | * | 16 | * |
17 | * This program is distributed in the hope that it will be useful, | 17 | * This program is distributed in the hope that it will be useful, |
18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
20 | * Library General Public License for more details. | 20 | * Library General Public License for more details. |
21 | * | 21 | * |
22 | * You should have received a copy of the GNU Library General Public | 22 | * You should have received a copy of the GNU Library General Public |
23 | * License along with this program; if not, write to the Free | 23 | * License along with this program; if not, write to the Free |
24 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 24 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
25 | */ | 25 | */ |
26 | 26 | ||
27 | #include "pppdata.h" | 27 | #include "pppdata.h" |
28 | #include "runtests.h" | 28 | #include "runtests.h" |
29 | #include "devices.h" | 29 | #include "devices.h" |
30 | //#include <klocale.h> | 30 | //#include <klocale.h> |
31 | #define i18n QObject::tr | 31 | #define i18n QObject::tr |
32 | #include <qpe/config.h> | 32 | #include <qpe/config.h> |
33 | #include <qmessagebox.h> | 33 | #include <qmessagebox.h> |
34 | #include <qapplication.h> | 34 | #include <qapplication.h> |
35 | // #include <klocale.h> | 35 | // #include <klocale.h> |
36 | // #include <kconfig.h> | 36 | // #include <kconfig.h> |
37 | // #include <kmessagebox.h> | 37 | // #include <kmessagebox.h> |
38 | // #include <kapplication.h> | 38 | // #include <kapplication.h> |
39 | #include <assert.h> | 39 | #include <assert.h> |
40 | 40 | ||
41 | PPPData *PPPData::_data = 0; | 41 | PPPData *PPPData::_data = 0; |
42 | Config *PPPData::config = 0; | 42 | Config *PPPData::config = 0; |
43 | 43 | ||
44 | PPPData* PPPData::data() | 44 | PPPData* PPPData::data() |
45 | { | 45 | { |
46 | if (!_data){ | 46 | if (!_data){ |
47 | qDebug("PPPData::data() creates new Instance"); | 47 | qDebug("PPPData::data() creates new Instance"); |
48 | _data = new PPPData(); | 48 | _data = new PPPData(); |
49 | } | 49 | } |
50 | if (!_data->config){ | 50 | if (!_data->config){ |
51 | qDebug("PPPData::data() opens conffile"); | 51 | qDebug("PPPData::data() opens conffile"); |
52 | _data->open(); | 52 | _data->open(); |
53 | } | 53 | } |
54 | return _data; | 54 | return _data; |
55 | } | 55 | } |
56 | 56 | ||
57 | PPPData::PPPData() | 57 | PPPData::PPPData() |
58 | : //config(0L), | 58 | : modemDeviceGroup(-1), |
59 | highcount(-1), // start out with no entries | 59 | highcount(-1), // start out with no entries |
60 | caccount(-1), // set the current account index also | 60 | caccount(-1), // set the current account index also |
61 | suidprocessid(-1), // process ID of setuid child | 61 | suidprocessid(-1), // process ID of setuid child |
62 | pppdisrunning(false), | 62 | pppdisrunning(false), |
63 | pppderror(0), | 63 | pppderror(0) |
64 | modemDeviceGroup(-1) | ||
65 | { | 64 | { |
66 | } | 65 | } |
67 | 66 | ||
68 | 67 | ||
69 | // | 68 | // |
70 | // open configuration file | 69 | // open configuration file |
71 | // | 70 | // |
72 | bool PPPData::open() { | 71 | bool PPPData::open() { |
73 | qDebug("opening configfile NetworkSetupPPP"); | 72 | qDebug("opening configfile NetworkSetupPPP"); |
74 | if (config) return true; | 73 | if (config) return true; |
75 | config = new Config("NetworkSetupPPP"); | 74 | config = new Config("NetworkSetupPPP"); |
76 | 75 | ||
77 | highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1; | 76 | highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1; |
78 | 77 | ||
79 | if (highcount > MAX_ACCOUNTS) | 78 | if (highcount > MAX_ACCOUNTS) |
80 | highcount = MAX_ACCOUNTS; | 79 | highcount = MAX_ACCOUNTS; |
81 | 80 | ||
82 | if(highcount >= 0 && defaultAccount().isEmpty()) { | 81 | if(highcount >= 0 && defaultAccount().isEmpty()) { |
83 | setAccountbyIndex(0); | 82 | setAccountbyIndex(0); |
84 | setDefaultAccount(accname()); | 83 | setDefaultAccount(accname()); |
85 | } else if(!setAccount(defaultAccount())) | 84 | } else if(!setAccount(defaultAccount())) |
86 | setDefaultAccount(accname()); | 85 | setDefaultAccount(accname()); |
87 | 86 | ||
88 | // start out with internal debugging disabled | 87 | // start out with internal debugging disabled |
89 | // the user is still free to specify `debug' on his own | 88 | // the user is still free to specify `debug' on his own |
90 | setPPPDebug(false); | 89 | setPPPDebug(false); |
91 | 90 | ||
92 | ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch); | 91 | ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch); |
93 | 92 | ||
94 | return true; | 93 | return true; |
95 | } | 94 | } |
96 | 95 | ||
97 | 96 | ||
98 | // | 97 | // |
99 | // save configuration | 98 | // save configuration |
100 | // | 99 | // |
101 | void PPPData::save() { | 100 | void PPPData::save() { |
102 | 101 | ||
103 | if (config) { | 102 | if (config) { |
104 | writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count()); | 103 | writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count()); |
105 | delete config; | 104 | delete config; |
106 | config = 0; | 105 | config = 0; |
107 | qDebug("worte confi NetworkSetupPPP"); | 106 | qDebug("worte confi NetworkSetupPPP"); |
108 | } | 107 | } |
109 | if (_data){ | 108 | if (_data){ |
110 | delete _data; | 109 | delete _data; |
111 | _data = 0; | 110 | _data = 0; |
112 | } | 111 | } |
113 | 112 | ||
114 | } | 113 | } |
115 | 114 | ||
116 | 115 | ||
117 | // | 116 | // |
118 | // cancel changes | 117 | // cancel changes |
119 | // | 118 | // |
120 | void PPPData::cancel() { | 119 | void PPPData::cancel() { |
121 | 120 | ||
122 | // if (config) { | 121 | // if (config) { |
123 | // config->rollback(); | 122 | // config->rollback(); |
124 | // config->reparseConfiguration(); | 123 | // config->reparseConfiguration(); |
125 | // } | 124 | // } |
126 | 125 | ||
127 | } | 126 | } |
128 | 127 | ||
@@ -268,129 +267,128 @@ bool PPPData::get_show_log_window() { | |||
268 | 267 | ||
269 | 268 | ||
270 | void PPPData::set_show_log_window(bool set) { | 269 | void PPPData::set_show_log_window(bool set) { |
271 | writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set); | 270 | writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set); |
272 | } | 271 | } |
273 | 272 | ||
274 | 273 | ||
275 | bool PPPData::automatic_redial() { | 274 | bool PPPData::automatic_redial() { |
276 | return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE); | 275 | return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE); |
277 | } | 276 | } |
278 | 277 | ||
279 | 278 | ||
280 | void PPPData::set_automatic_redial(bool set) { | 279 | void PPPData::set_automatic_redial(bool set) { |
281 | writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set); | 280 | writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set); |
282 | } | 281 | } |
283 | 282 | ||
284 | 283 | ||
285 | bool PPPData::get_iconify_on_connect() { | 284 | bool PPPData::get_iconify_on_connect() { |
286 | return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE); | 285 | return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE); |
287 | } | 286 | } |
288 | 287 | ||
289 | 288 | ||
290 | void PPPData::set_iconify_on_connect(bool set) { | 289 | void PPPData::set_iconify_on_connect(bool set) { |
291 | writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set); | 290 | writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set); |
292 | } | 291 | } |
293 | 292 | ||
294 | 293 | ||
295 | bool PPPData::get_dock_into_panel() { | 294 | bool PPPData::get_dock_into_panel() { |
296 | return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false); | 295 | return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false); |
297 | } | 296 | } |
298 | 297 | ||
299 | 298 | ||
300 | void PPPData::set_dock_into_panel(bool set) { | 299 | void PPPData::set_dock_into_panel(bool set) { |
301 | writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set); | 300 | writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set); |
302 | } | 301 | } |
303 | 302 | ||
304 | 303 | ||
305 | QString PPPData::pppdVersion() { | 304 | QString PPPData::pppdVersion() { |
306 | return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch); | 305 | return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch); |
307 | } | 306 | } |
308 | 307 | ||
309 | bool PPPData::pppdVersionMin(int ver, int mod, int patch) { | 308 | bool PPPData::pppdVersionMin(int ver, int mod, int patch) { |
310 | // check if pppd version fulfills minimum requirement | 309 | // check if pppd version fulfills minimum requirement |
311 | return (pppdVer > ver | 310 | return (pppdVer > ver |
312 | || (pppdVer == ver && pppdMod > mod) | 311 | || (pppdVer == ver && pppdMod > mod) |
313 | || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch)); | 312 | || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch)); |
314 | } | 313 | } |
315 | 314 | ||
316 | int PPPData::pppdTimeout() { | 315 | int PPPData::pppdTimeout() { |
317 | return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT); | 316 | return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT); |
318 | } | 317 | } |
319 | 318 | ||
320 | 319 | ||
321 | void PPPData::setpppdTimeout(int n) { | 320 | void PPPData::setpppdTimeout(int n) { |
322 | writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n); | 321 | writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n); |
323 | } | 322 | } |
324 | 323 | ||
325 | 324 | ||
326 | const QString PPPData::modemDevice() { | 325 | const QString PPPData::modemDevice() { |
327 | return readConfig (modemGroup(), MODEMDEV_KEY, devices[DEV_DEFAULT]); | 326 | return readConfig (modemGroup(), MODEMDEV_KEY, devices[DEV_DEFAULT]); |
328 | } | 327 | } |
329 | 328 | ||
330 | 329 | ||
331 | bool PPPData::setModemDevice(const QString &n) { | 330 | bool PPPData::setModemDevice(const QString &n) { |
332 | //FIXME: change modem group | ||
333 | bool ret = false; | 331 | bool ret = false; |
334 | for (int i = 0; devices[i]; i++) | 332 | for (int i = 0; devices[i]; i++) |
335 | if (devices[i] == n){ | 333 | if (devices[i] == n){ |
336 | modemDeviceGroup = i; | 334 | modemDeviceGroup = i; |
337 | writeConfig(modemGroup(), MODEMDEV_KEY, n); | 335 | writeConfig(modemGroup(), MODEMDEV_KEY, n); |
338 | ret = true; | 336 | ret = true; |
339 | } | 337 | } |
340 | return ret; | 338 | return ret; |
341 | } | 339 | } |
342 | 340 | ||
343 | 341 | ||
344 | const QString PPPData::flowcontrol() { | 342 | const QString PPPData::flowcontrol() { |
345 | return readConfig(modemGroup(), FLOWCONTROL_KEY, "CRTSCTS"); | 343 | return readConfig(modemGroup(), FLOWCONTROL_KEY, "CRTSCTS"); |
346 | } | 344 | } |
347 | 345 | ||
348 | 346 | ||
349 | void PPPData::setFlowcontrol(const QString &n) { | 347 | void PPPData::setFlowcontrol(const QString &n) { |
350 | writeConfig(modemGroup(), FLOWCONTROL_KEY, n); | 348 | writeConfig(modemGroup(), FLOWCONTROL_KEY, n); |
351 | } | 349 | } |
352 | 350 | ||
353 | 351 | ||
354 | const QString PPPData::speed() { | 352 | const QString PPPData::speed() { |
355 | QString s = readConfig(modemGroup(), SPEED_KEY, "57600"); | 353 | QString s = readConfig(modemGroup(), SPEED_KEY, "57600"); |
356 | // undo the damage of a bug in former versions. It left an empty Speed= | 354 | // undo the damage of a bug in former versions. It left an empty Speed= |
357 | // entry in kppprc. kppp did set the serial port to 57600 as default but | 355 | // entry in kppprc. kppp did set the serial port to 57600 as default but |
358 | // pppd wouldn't receive the speed via the command line. | 356 | // pppd wouldn't receive the speed via the command line. |
359 | if(s.toUInt() == 0) | 357 | if(s.toUInt() == 0) |
360 | s = "57600"; | 358 | s = "57600"; |
361 | return s; | 359 | return s; |
362 | } | 360 | } |
363 | 361 | ||
364 | 362 | ||
365 | void PPPData::setSpeed(const QString &n) { | 363 | void PPPData::setSpeed(const QString &n) { |
366 | writeConfig(modemGroup(), SPEED_KEY, n); | 364 | writeConfig(modemGroup(), SPEED_KEY, n); |
367 | } | 365 | } |
368 | 366 | ||
369 | 367 | ||
370 | #if 0 | 368 | #if 0 |
371 | void PPPData::setUseCDLine(const int n) { | 369 | void PPPData::setUseCDLine(const int n) { |
372 | writeConfig(modemGroup(),USECDLINE_KEY,n); | 370 | writeConfig(modemGroup(),USECDLINE_KEY,n); |
373 | } | 371 | } |
374 | 372 | ||
375 | 373 | ||
376 | int PPPData::UseCDLine() { | 374 | int PPPData::UseCDLine() { |
377 | return readNumConfig(modemGroup(),USECDLINE_KEY,0); | 375 | return readNumConfig(modemGroup(),USECDLINE_KEY,0); |
378 | } | 376 | } |
379 | #endif | 377 | #endif |
380 | 378 | ||
381 | const QString PPPData::modemEscapeStr() { | 379 | const QString PPPData::modemEscapeStr() { |
382 | return readConfig(modemGroup(),ESCAPESTR_KEY,"+++"); | 380 | return readConfig(modemGroup(),ESCAPESTR_KEY,"+++"); |
383 | } | 381 | } |
384 | 382 | ||
385 | 383 | ||
386 | void PPPData::setModemEscapeStr(const QString &n) { | 384 | void PPPData::setModemEscapeStr(const QString &n) { |
387 | writeConfig(modemGroup(),ESCAPESTR_KEY,n); | 385 | writeConfig(modemGroup(),ESCAPESTR_KEY,n); |
388 | } | 386 | } |
389 | 387 | ||
390 | 388 | ||
391 | const QString PPPData::modemEscapeResp() { | 389 | const QString PPPData::modemEscapeResp() { |
392 | return readConfig(modemGroup(),ESCAPERESP_KEY,"OK"); | 390 | return readConfig(modemGroup(),ESCAPERESP_KEY,"OK"); |
393 | } | 391 | } |
394 | 392 | ||
395 | 393 | ||
396 | void PPPData::setModemEscapeResp(const QString &n) { | 394 | void PPPData::setModemEscapeResp(const QString &n) { |
@@ -743,129 +741,129 @@ bool PPPData::deleteAccount() { | |||
743 | // it = map.begin(); | 741 | // it = map.begin(); |
744 | // while (it != map.end()) { | 742 | // while (it != map.end()) { |
745 | // config->writeEntry(it.key(), ""); | 743 | // config->writeEntry(it.key(), ""); |
746 | // it++; | 744 | // it++; |
747 | // } | 745 | // } |
748 | 746 | ||
749 | // // shift the succeeding accounts | 747 | // // shift the succeeding accounts |
750 | // for(int i = caccount+1; i <= highcount; i++) { | 748 | // for(int i = caccount+1; i <= highcount; i++) { |
751 | // setAccountbyIndex(i); | 749 | // setAccountbyIndex(i); |
752 | // map = config->entryMap(cgroup); | 750 | // map = config->entryMap(cgroup); |
753 | // it = map.begin(); | 751 | // it = map.begin(); |
754 | // setAccountbyIndex(i-1); | 752 | // setAccountbyIndex(i-1); |
755 | // config->setGroup(cgroup); | 753 | // config->setGroup(cgroup); |
756 | // while (it != map.end()) { | 754 | // while (it != map.end()) { |
757 | // config->writeEntry(it.key(), *it); | 755 | // config->writeEntry(it.key(), *it); |
758 | // it++; | 756 | // it++; |
759 | // } | 757 | // } |
760 | // } | 758 | // } |
761 | 759 | ||
762 | // // make sure the top account is cleared | 760 | // // make sure the top account is cleared |
763 | // setAccountbyIndex(highcount); | 761 | // setAccountbyIndex(highcount); |
764 | // map = config->entryMap(cgroup); | 762 | // map = config->entryMap(cgroup); |
765 | // it = map.begin(); | 763 | // it = map.begin(); |
766 | // config->setGroup(cgroup); | 764 | // config->setGroup(cgroup); |
767 | // while (it.key() != QString::null) { | 765 | // while (it.key() != QString::null) { |
768 | // config->writeEntry(it.key(), ""); | 766 | // config->writeEntry(it.key(), ""); |
769 | // it++; | 767 | // it++; |
770 | // } | 768 | // } |
771 | 769 | ||
772 | // highcount--; | 770 | // highcount--; |
773 | // if(caccount > highcount) | 771 | // if(caccount > highcount) |
774 | // caccount = highcount; | 772 | // caccount = highcount; |
775 | 773 | ||
776 | // setAccountbyIndex(caccount); | 774 | // setAccountbyIndex(caccount); |
777 | 775 | ||
778 | // return true; | 776 | // return true; |
779 | } | 777 | } |
780 | 778 | ||
781 | 779 | ||
782 | bool PPPData::deleteAccount(const QString &aname) { | 780 | bool PPPData::deleteAccount(const QString &aname) { |
783 | if(!setAccount(aname)) | 781 | if(!setAccount(aname)) |
784 | return false; | 782 | return false; |
785 | 783 | ||
786 | deleteAccount(); | 784 | deleteAccount(); |
787 | 785 | ||
788 | return true; | 786 | return true; |
789 | } | 787 | } |
790 | 788 | ||
791 | 789 | ||
792 | int PPPData::newaccount() { | 790 | int PPPData::newaccount() { |
793 | 791 | ||
794 | qDebug("PPPData::newaccount highcount %i/%i",highcount,MAX_ACCOUNTS); | 792 | qDebug("PPPData::newaccount highcount %i/%i",highcount,MAX_ACCOUNTS); |
795 | if(!config) open(); | 793 | if(!config) open(); |
796 | if (highcount >= MAX_ACCOUNTS) return -1; | 794 | if (highcount >= MAX_ACCOUNTS) return -1; |
797 | 795 | ||
798 | highcount++; | 796 | highcount++; |
799 | setAccountbyIndex(highcount); | 797 | setAccountbyIndex(highcount); |
800 | 798 | ||
801 | setpppdArgumentDefaults(); | 799 | setpppdArgumentDefaults(); |
802 | qDebug("PPPData::newaccount -> %i",caccount); | 800 | qDebug("PPPData::newaccount -> %i",caccount); |
803 | return caccount; | 801 | return caccount; |
804 | } | 802 | } |
805 | 803 | ||
806 | int PPPData::copyaccount(int i) { | 804 | int PPPData::copyaccount(int i) { |
807 | 805 | // FIXME | |
808 | // if(highcount >= MAX_ACCOUNTS) | 806 | // if(highcount >= MAX_ACCOUNTS) |
809 | return -1; | 807 | return -1; |
810 | 808 | ||
811 | // setAccountbyIndex(i); | 809 | // setAccountbyIndex(i); |
812 | 810 | ||
813 | // QMap <QString, QString> map = config->entryMap(cgroup); | 811 | // QMap <QString, QString> map = config->entryMap(cgroup); |
814 | // QMap <QString, QString>::ConstIterator it = map.begin(); | 812 | // QMap <QString, QString>::ConstIterator it = map.begin(); |
815 | 813 | ||
816 | // QString newname = i18n("%1_copy").arg(accname()); | 814 | // QString newname = i18n("%1_copy").arg(accname()); |
817 | 815 | ||
818 | // newaccount(); | 816 | // newaccount(); |
819 | 817 | ||
820 | // while (it != map.end()) { | 818 | // while (it != map.end()) { |
821 | // config->writeEntry(it.key(), *it); | 819 | // config->writeEntry(it.key(), *it); |
822 | // it++; | 820 | // it++; |
823 | // } | 821 | // } |
824 | 822 | ||
825 | // setAccname(newname); | 823 | // setAccname(newname); |
826 | 824 | ||
827 | // return caccount; | 825 | // return caccount; |
828 | } | 826 | } |
829 | 827 | ||
830 | 828 | ||
831 | const QString PPPData::accname() { | 829 | const QString PPPData::accname() { |
832 | return readConfig(cgroup, NAME_KEY); | 830 | return readConfig(cgroup, NAME_KEY); |
833 | } | 831 | } |
834 | 832 | ||
835 | void PPPData::setAccname(const QString &n) { | 833 | void PPPData::setAccname(const QString &n) { |
836 | if(!cgroup.isNull()) { | 834 | if(!cgroup.isNull()) { |
837 | // are we manipulating the default account's name ? then change it, too. | 835 | // are we manipulating the default account's name ? then change it, too. |
838 | bool def = accname() == defaultAccount(); | 836 | bool def = accname() == defaultAccount(); |
839 | writeConfig(cgroup, NAME_KEY, n); | 837 | writeConfig(cgroup, NAME_KEY, n); |
840 | if (def) | 838 | if (def) |
841 | setDefaultAccount(n); | 839 | setDefaultAccount(n); |
842 | } | 840 | } |
843 | } | 841 | } |
844 | 842 | ||
845 | 843 | ||
846 | #define SEPARATOR_CHAR '&' | 844 | #define SEPARATOR_CHAR '&' |
847 | QStringList &PPPData::phonenumbers() { | 845 | QStringList &PPPData::phonenumbers() { |
848 | 846 | ||
849 | readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR); | 847 | readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR); |
850 | return phonelist; | 848 | return phonelist; |
851 | 849 | ||
852 | } | 850 | } |
853 | 851 | ||
854 | 852 | ||
855 | const QString PPPData::phonenumber() { | 853 | const QString PPPData::phonenumber() { |
856 | return readConfig(cgroup, PHONENUMBER_KEY); | 854 | return readConfig(cgroup, PHONENUMBER_KEY); |
857 | } | 855 | } |
858 | 856 | ||
859 | 857 | ||
860 | void PPPData::setPhonenumber(const QString &n) { | 858 | void PPPData::setPhonenumber(const QString &n) { |
861 | writeConfig(cgroup, PHONENUMBER_KEY, n); | 859 | writeConfig(cgroup, PHONENUMBER_KEY, n); |
862 | } | 860 | } |
863 | 861 | ||
864 | 862 | ||
865 | const QString PPPData::dialPrefix() { | 863 | const QString PPPData::dialPrefix() { |
866 | return readConfig(cgroup, DIAL_PREFIX_KEY, ""); | 864 | return readConfig(cgroup, DIAL_PREFIX_KEY, ""); |
867 | } | 865 | } |
868 | 866 | ||
869 | 867 | ||
870 | void PPPData::setDialPrefix(const QString &s) { | 868 | void PPPData::setDialPrefix(const QString &s) { |
871 | writeConfig(cgroup, DIAL_PREFIX_KEY, s); | 869 | writeConfig(cgroup, DIAL_PREFIX_KEY, s); |
@@ -1160,89 +1158,95 @@ void PPPData::setpppdArgumentDefaults() { | |||
1160 | // QColor in, | 1158 | // QColor in, |
1161 | // QColor out) | 1159 | // QColor out) |
1162 | // { | 1160 | // { |
1163 | // if(config) { | 1161 | // if(config) { |
1164 | // config->setGroup(GRAPH_GRP); | 1162 | // config->setGroup(GRAPH_GRP); |
1165 | // config->writeEntry(GENABLED, enable); | 1163 | // config->writeEntry(GENABLED, enable); |
1166 | // // config->writeEntry(GCOLOR_BG, bg); | 1164 | // // config->writeEntry(GCOLOR_BG, bg); |
1167 | // // config->writeEntry(GCOLOR_TEXT, text); | 1165 | // // config->writeEntry(GCOLOR_TEXT, text); |
1168 | // // config->writeEntry(GCOLOR_IN, in); | 1166 | // // config->writeEntry(GCOLOR_IN, in); |
1169 | // // config->writeEntry(GCOLOR_OUT, out); | 1167 | // // config->writeEntry(GCOLOR_OUT, out); |
1170 | // } | 1168 | // } |
1171 | // } | 1169 | // } |
1172 | 1170 | ||
1173 | // void PPPData::graphingOptions(bool &enable, | 1171 | // void PPPData::graphingOptions(bool &enable, |
1174 | // QColor &bg, | 1172 | // QColor &bg, |
1175 | // QColor &text, | 1173 | // QColor &text, |
1176 | // QColor &in, | 1174 | // QColor &in, |
1177 | // QColor &out) | 1175 | // QColor &out) |
1178 | // { | 1176 | // { |
1179 | // QColor c; | 1177 | // QColor c; |
1180 | 1178 | ||
1181 | // if(config) { | 1179 | // if(config) { |
1182 | // config->setGroup(GRAPH_GRP); | 1180 | // config->setGroup(GRAPH_GRP); |
1183 | // enable = config->readBoolEntry(GENABLED, true); | 1181 | // enable = config->readBoolEntry(GENABLED, true); |
1184 | // bg = Qt::white; | 1182 | // bg = Qt::white; |
1185 | // //bg = config->readColorEntry(GCOLOR_BG, &c); | 1183 | // //bg = config->readColorEntry(GCOLOR_BG, &c); |
1186 | // text = Qt::black; | 1184 | // text = Qt::black; |
1187 | // //text = config->readColorEntry(GCOLOR_TEXT, &c); | 1185 | // //text = config->readColorEntry(GCOLOR_TEXT, &c); |
1188 | // in = Qt::blue; | 1186 | // in = Qt::blue; |
1189 | // //in = config->readColorEntry(GCOLOR_IN, &c); | 1187 | // //in = config->readColorEntry(GCOLOR_IN, &c); |
1190 | // out = Qt::red; | 1188 | // out = Qt::red; |
1191 | // //out = config->readColorEntry(GCOLOR_OUT, &c); | 1189 | // //out = config->readColorEntry(GCOLOR_OUT, &c); |
1192 | // } | 1190 | // } |
1193 | // } | 1191 | // } |
1194 | 1192 | ||
1195 | 1193 | ||
1196 | // bool PPPData::graphingEnabled() { | 1194 | // bool PPPData::graphingEnabled() { |
1197 | // return (bool) readNumConfig(GRAPH_GRP, GENABLED, true); | 1195 | // return (bool) readNumConfig(GRAPH_GRP, GENABLED, true); |
1198 | // } | 1196 | // } |
1199 | 1197 | ||
1200 | 1198 | ||
1201 | 1199 | ||
1202 | // | 1200 | // |
1203 | //functions to change/set the child pppd process info | 1201 | //functions to change/set the child pppd process info |
1204 | // | 1202 | // |
1205 | bool PPPData::pppdRunning() const { | 1203 | bool PPPData::pppdRunning() const { |
1206 | return pppdisrunning; | 1204 | return pppdisrunning; |
1207 | } | 1205 | } |
1208 | 1206 | ||
1209 | void PPPData::setpppdRunning(bool set) { | 1207 | void PPPData::setpppdRunning(bool set) { |
1210 | pppdisrunning = set; | 1208 | pppdisrunning = set; |
1211 | } | 1209 | } |
1212 | 1210 | ||
1213 | int PPPData::pppdError() const { | 1211 | int PPPData::pppdError() const { |
1214 | return pppderror; | 1212 | return pppderror; |
1215 | } | 1213 | } |
1216 | 1214 | ||
1217 | void PPPData::setpppdError(int err) { | 1215 | void PPPData::setpppdError(int err) { |
1218 | pppderror = err; | 1216 | pppderror = err; |
1219 | } | 1217 | } |
1220 | 1218 | ||
1221 | QString PPPData::modemGroup() | 1219 | QString PPPData::modemGroup() |
1222 | { | 1220 | { |
1223 | if (modemDeviceGroup<0)qFatal("wrong modem %i",modemDeviceGroup); | 1221 | if (modemDeviceGroup<0)qFatal("wrong modem %i",modemDeviceGroup); |
1224 | return QString("MODEM_GRP_%1").arg(modemDeviceGroup); | 1222 | return QString("%1_%1").arg(MODEM_GRP).arg(modemDeviceGroup); |
1225 | } | 1223 | } |
1226 | 1224 | ||
1227 | // // | ||
1228 | // // window position | ||
1229 | // // | ||
1230 | // void PPPData::winPosConWin(int& p_x, int& p_y) { | ||
1231 | // p_x = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_X, QApplication::desktop()->width()/2-160); | ||
1232 | // p_y = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_Y, QApplication::desktop()->height()/2-55); | ||
1233 | // } | ||
1234 | 1225 | ||
1235 | // void PPPData::setWinPosConWin(int p_x, int p_y) { | 1226 | QMap<QString,QString> PPPData::getConfiguredInterfaces() |
1236 | // writeConfig(WINPOS_GRP, WINPOS_CONWIN_X, p_x); | 1227 | { |
1237 | // writeConfig(WINPOS_GRP, WINPOS_CONWIN_Y, p_y); | 1228 | QMap<QString,QString> ifaces; |
1238 | // } | 1229 | int count = readNumConfig( ACCLIST_GRP, ACCOUNTS_COUNT, -1 ); |
1230 | QString accGrp; | ||
1231 | for (int i = 0; i < count; i++){ | ||
1232 | accGrp = QString("%1_%1").arg(ACCLIST_GRP).arg(i); | ||
1233 | ifaces.insert( readConfig( accGrp, ACOUNTS_DEV, "error" ), | ||
1234 | readConfig( accGrp, ACOUNTS_ACC, "error" ) ); | ||
1235 | } | ||
1239 | 1236 | ||
1240 | // void PPPData::winPosStatWin(int& p_x, int& p_y) { | 1237 | return ifaces; |
1241 | // p_x = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_X, QApplication::desktop()->width()/2-160); | 1238 | } |
1242 | // p_y = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_Y, QApplication::desktop()->height()/2-55); | ||
1243 | // } | ||
1244 | 1239 | ||
1245 | // void PPPData::setWinPosStatWin(int p_x, int p_y) { | 1240 | void PPPData::setConfiguredInterfaces( QMap<QString,QString> ifaces ) |
1246 | // writeConfig(WINPOS_GRP, WINPOS_STATWIN_X, p_x); | 1241 | { |
1247 | // writeConfig(WINPOS_GRP, WINPOS_STATWIN_Y, p_y); | 1242 | QMap<QString,QString>::Iterator it; |
1248 | // } | 1243 | QString accGrp; |
1244 | int i = 0; | ||
1245 | for( it = ifaces.begin(); it != ifaces.end(); ++it, ++i ){ | ||
1246 | accGrp = QString("%1_%1").arg(ACCLIST_GRP).arg(i); | ||
1247 | writeConfig( accGrp, ACOUNTS_DEV, it.key() ); | ||
1248 | writeConfig( accGrp, ACOUNTS_ACC, it.data() ); | ||
1249 | } | ||
1250 | writeConfig( ACCLIST_GRP, ACCOUNTS_COUNT, i ); | ||
1251 | |||
1252 | } | ||
diff --git a/noncore/settings/networksettings/ppp/pppdata.h b/noncore/settings/networksettings/ppp/pppdata.h index 41dfbd8..c1c7e69 100644 --- a/noncore/settings/networksettings/ppp/pppdata.h +++ b/noncore/settings/networksettings/ppp/pppdata.h | |||
@@ -1,255 +1,252 @@ | |||
1 | /* -*- C++ -*- | 1 | /* -*- C++ -*- |
2 | * | 2 | * |
3 | * kPPP: A pppd front end for the KDE project | 3 | * kPPP: A pppd front end for the KDE project |
4 | * | 4 | * |
5 | * $Id$ | 5 | * $Id$ |
6 | * | 6 | * |
7 | * Copyright (C) 1997 Bernd Johannes Wuebben | 7 | * Copyright (C) 1997 Bernd Johannes Wuebben |
8 | * wuebben@math.cornell.edu | 8 | * wuebben@math.cornell.edu |
9 | * | 9 | * |
10 | * based on EzPPP: | 10 | * based on EzPPP: |
11 | * Copyright (C) 1997 Jay Painter | 11 | * Copyright (C) 1997 Jay Painter |
12 | * | 12 | * |
13 | * This program is free software; you can redistribute it and/or | 13 | * This program is free software; you can redistribute it and/or |
14 | * modify it under the terms of the GNU Library General Public | 14 | * modify it under the terms of the GNU Library General Public |
15 | * License as published by the Free Software Foundation; either | 15 | * License as published by the Free Software Foundation; either |
16 | * version 2 of the License, or (at your option) any later version. | 16 | * version 2 of the License, or (at your option) any later version. |
17 | * | 17 | * |
18 | * This program is distributed in the hope that it will be useful, | 18 | * This program is distributed in the hope that it will be useful, |
19 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 19 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
20 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 20 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
21 | * Library General Public License for more details. | 21 | * Library General Public License for more details. |
22 | * | 22 | * |
23 | * You should have received a copy of the GNU Library General Public | 23 | * You should have received a copy of the GNU Library General Public |
24 | * License along with this program; if not, write to the Free | 24 | * License along with this program; if not, write to the Free |
25 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 25 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #ifndef _PPPDATA_H_ | 28 | #ifndef _PPPDATA_H_ |
29 | #define _PPPDATA_H_ | 29 | #define _PPPDATA_H_ |
30 | 30 | ||
31 | #include <unistd.h> | 31 | #include <unistd.h> |
32 | #include <sys/types.h> | 32 | #include <sys/types.h> |
33 | 33 | ||
34 | #include <qcolor.h> | ||
35 | #include <qmap.h> | ||
34 | #include <qstring.h> | 36 | #include <qstring.h> |
35 | #include <qstringlist.h> | 37 | #include <qstringlist.h> |
36 | #include <qcolor.h> | ||
37 | 38 | ||
38 | #include "kpppconfig.h" | 39 | #include "kpppconfig.h" |
39 | 40 | ||
40 | class Config; | 41 | class Config; |
41 | 42 | ||
42 | // string lengths | 43 | // string lengths |
43 | 44 | ||
44 | #define PATH_SIZE 120 | 45 | #define PATH_SIZE 120 |
45 | #define MODEMSTR_SIZE 80 | 46 | #define MODEMSTR_SIZE 80 |
46 | #define ACCNAME_SIZE 50 | 47 | #define ACCNAME_SIZE 50 |
47 | #define PHONENUMBER_SIZE 60 | 48 | #define PHONENUMBER_SIZE 60 |
48 | #define COMMAND_SIZE 255 | 49 | #define COMMAND_SIZE 255 |
49 | #define IPADDR_SIZE 15 | 50 | #define IPADDR_SIZE 15 |
50 | #define DOMAIN_SIZE 50 | 51 | #define DOMAIN_SIZE 50 |
51 | #define TIMEOUT_SIZE 60 | 52 | #define TIMEOUT_SIZE 60 |
52 | 53 | ||
53 | // | 54 | // |
54 | // keys for config file | 55 | // keys for config file |
55 | // | 56 | // |
56 | 57 | ||
57 | // groups | 58 | // groups |
58 | #define GENERAL_GRP "PPP_General" | 59 | #define GENERAL_GRP "PPP_General" |
59 | #define MODEM_GRP "PPP_Modem" | 60 | #define MODEM_GRP "PPP_Modem" |
60 | #define ACCOUNT_GRP "PPP_Account" | 61 | #define ACCOUNT_GRP "PPP_Account" |
62 | #define ACCLIST_GRP "PPP_Accounts_List" | ||
61 | //#define GRAPH_GRP "Graph" | 63 | //#define GRAPH_GRP "Graph" |
62 | //#define WINPOS_GRP "WindowPosition" | 64 | //#define WINPOS_GRP "WindowPosition" |
63 | 65 | ||
64 | // general | 66 | // general |
65 | #define DEFAULTACCOUNT_KEY "DefaultAccount" | 67 | #define DEFAULTACCOUNT_KEY "DefaultAccount" |
66 | #define PPPDVERSION_KEY "pppdVersion" | 68 | #define PPPDVERSION_KEY "pppdVersion" |
67 | #define PPPDTIMEOUT_KEY "pppdTimeout" | 69 | #define PPPDTIMEOUT_KEY "pppdTimeout" |
68 | #define SHOWCLOCK_KEY "ShowClock" | 70 | #define SHOWCLOCK_KEY "ShowClock" |
69 | #define SHOWLOGWIN_KEY "ShowLogWindow" | 71 | #define SHOWLOGWIN_KEY "ShowLogWindow" |
70 | #define AUTOREDIAL_KEY "AutomaticRedial" | 72 | #define AUTOREDIAL_KEY "AutomaticRedial" |
71 | #define DISCONNECT_KEY "DisconnectOnXServerExit" | 73 | #define DISCONNECT_KEY "DisconnectOnXServerExit" |
72 | #define QUITONDISCONNECT_KEY "QuitOnDisconnect" | 74 | #define QUITONDISCONNECT_KEY "QuitOnDisconnect" |
73 | #define NUMACCOUNTS_KEY "NumberOfAccounts" | 75 | #define NUMACCOUNTS_KEY "NumberOfAccounts" |
74 | #define ID_KEY "ID" | 76 | #define ID_KEY "ID" |
75 | 77 | ||
76 | // modem | 78 | // modem |
77 | #define MODEMDEV_KEY "Device" | 79 | #define MODEMDEV_KEY "Device" |
78 | #define LOCKFILE_KEY "UseLockFile" | 80 | #define LOCKFILE_KEY "UseLockFile" |
79 | #define FLOWCONTROL_KEY "FlowControl" | 81 | #define FLOWCONTROL_KEY "FlowControl" |
80 | #define SPEED_KEY "Speed" | 82 | #define SPEED_KEY "Speed" |
81 | #define TIMEOUT_KEY "Timeout" | 83 | #define TIMEOUT_KEY "Timeout" |
82 | #define TONEDURATION_KEY "ToneDuration" | 84 | #define TONEDURATION_KEY "ToneDuration" |
83 | #define BUSYWAIT_KEY "BusyWait" | 85 | #define BUSYWAIT_KEY "BusyWait" |
84 | #define INITSTR_KEY "InitString" | 86 | #define INITSTR_KEY "InitString" |
85 | #define INITRESP_KEY "InitResponse" | 87 | #define INITRESP_KEY "InitResponse" |
86 | #define PREINITDELAY_KEY "PreInitDelay" | 88 | #define PREINITDELAY_KEY "PreInitDelay" |
87 | #define INITDELAY_KEY "InitDelay" | 89 | #define INITDELAY_KEY "InitDelay" |
88 | #define NODTDETECT_KEY "NoDialToneDetection" | 90 | #define NODTDETECT_KEY "NoDialToneDetection" |
89 | #define DIALTONEWAIT_KEY "WaitForDialTone" | 91 | #define DIALTONEWAIT_KEY "WaitForDialTone" |
90 | #define DIALSTR_KEY "DialString" | 92 | #define DIALSTR_KEY "DialString" |
91 | #define CONNECTRESP_KEY "ConnectResponse" | 93 | #define CONNECTRESP_KEY "ConnectResponse" |
92 | #define BUSYRESP_KEY "BusyResponse" | 94 | #define BUSYRESP_KEY "BusyResponse" |
93 | #define NOCARRIERRESP_KEY "NoCarrierResponse" | 95 | #define NOCARRIERRESP_KEY "NoCarrierResponse" |
94 | #define NODIALTONERESP_KEY "NoDialToneResp" | 96 | #define NODIALTONERESP_KEY "NoDialToneResp" |
95 | #define HANGUPSTR_KEY "HangupString" | 97 | #define HANGUPSTR_KEY "HangupString" |
96 | #define HANGUPRESP_KEY "HangUpResponse" | 98 | #define HANGUPRESP_KEY "HangUpResponse" |
97 | #define ANSWERSTR_KEY "AnswerString" | 99 | #define ANSWERSTR_KEY "AnswerString" |
98 | #define RINGRESP_KEY "RingResponse" | 100 | #define RINGRESP_KEY "RingResponse" |
99 | #define ANSWERRESP_KEY "AnswerResponse" | 101 | #define ANSWERRESP_KEY "AnswerResponse" |
100 | #define ENTER_KEY "Enter" | 102 | #define ENTER_KEY "Enter" |
101 | #define ESCAPESTR_KEY "EscapeString" | 103 | #define ESCAPESTR_KEY "EscapeString" |
102 | #define ESCAPERESP_KEY "EscapeResponse" | 104 | #define ESCAPERESP_KEY "EscapeResponse" |
103 | #define ESCAPEGUARDTIME_KEY "EscapeGuardTime" | 105 | #define ESCAPEGUARDTIME_KEY "EscapeGuardTime" |
104 | #define USECDLINE_KEY "UseCDLine" | 106 | #define USECDLINE_KEY "UseCDLine" |
105 | #define VOLUME_HIGH "VolumeHigh" | 107 | #define VOLUME_HIGH "VolumeHigh" |
106 | #define VOLUME_MEDIUM "VolumeMedium" | 108 | #define VOLUME_MEDIUM "VolumeMedium" |
107 | #define VOLUME_OFF "VolumeOff" | 109 | #define VOLUME_OFF "VolumeOff" |
108 | #define VOLUME_KEY "Volume" | 110 | #define VOLUME_KEY "Volume" |
109 | 111 | ||
110 | // account | 112 | // account |
111 | #define NAME_KEY "Name" | 113 | #define NAME_KEY "Name" |
112 | #define PHONENUMBER_KEY "Phonenumber" | 114 | #define PHONENUMBER_KEY "Phonenumber" |
113 | #define DIAL_PREFIX_KEY "DialPrefix" | 115 | #define DIAL_PREFIX_KEY "DialPrefix" |
114 | #define AUTH_KEY "Authentication" | 116 | #define AUTH_KEY "Authentication" |
115 | #define STORED_PASSWORD_KEY "Password" | 117 | #define STORED_PASSWORD_KEY "Password" |
116 | #define STORED_USERNAME_KEY "Username" | 118 | #define STORED_USERNAME_KEY "Username" |
117 | #define STORE_PASSWORD_KEY "StorePassword" | 119 | #define STORE_PASSWORD_KEY "StorePassword" |
118 | #define BEFORE_CONNECT_KEY "BeforeConnect" | 120 | #define BEFORE_CONNECT_KEY "BeforeConnect" |
119 | #define COMMAND_KEY "Command" | 121 | #define COMMAND_KEY "Command" |
120 | #define DISCONNECT_COMMAND_KEY "DisconnectCommand" | 122 | #define DISCONNECT_COMMAND_KEY "DisconnectCommand" |
121 | #define BEFORE_DISCONNECT_KEY "BeforeDisconnect" | 123 | #define BEFORE_DISCONNECT_KEY "BeforeDisconnect" |
122 | #define IPADDR_KEY "IPAddr" | 124 | #define IPADDR_KEY "IPAddr" |
123 | #define SUBNETMASK_KEY "SubnetMask" | 125 | #define SUBNETMASK_KEY "SubnetMask" |
124 | #define ACCTENABLED_KEY "AccountingEnabled" | 126 | #define ACCTENABLED_KEY "AccountingEnabled" |
125 | #define VOLACCTENABLED_KEY "VolumeAccountingEnabled" | 127 | #define VOLACCTENABLED_KEY "VolumeAccountingEnabled" |
126 | #define ACCTFILE_KEY "AccountingFile" | 128 | #define ACCTFILE_KEY "AccountingFile" |
127 | #define AUTONAME_KEY "AutoName" | 129 | #define AUTONAME_KEY "AutoName" |
128 | #define GATEWAY_KEY "Gateway" | 130 | #define GATEWAY_KEY "Gateway" |
129 | #define DEFAULTROUTE_KEY "DefaultRoute" | 131 | #define DEFAULTROUTE_KEY "DefaultRoute" |
130 | #define DOMAIN_KEY "Domain" | 132 | #define DOMAIN_KEY "Domain" |
131 | #define DNS_KEY "DNS" | 133 | #define DNS_KEY "DNS" |
132 | #define AUTODNS_KEY "AutoDNS" | 134 | #define AUTODNS_KEY "AutoDNS" |
133 | #define EXDNSDISABLED_KEY "ExDNSDisabled" | 135 | #define EXDNSDISABLED_KEY "ExDNSDisabled" |
134 | #define SCRIPTCOM_KEY "ScriptCommands" | 136 | #define SCRIPTCOM_KEY "ScriptCommands" |
135 | #define SCRIPTARG_KEY "ScriptArguments" | 137 | #define SCRIPTARG_KEY "ScriptArguments" |
136 | #define PPPDARG_KEY "pppdArguments" | 138 | #define PPPDARG_KEY "pppdArguments" |
137 | #define PPP_DEBUG_OPTION "PPPDebug" | 139 | #define PPP_DEBUG_OPTION "PPPDebug" |
138 | #define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect" | 140 | #define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect" |
139 | #define DOCKING_KEY "DockIntoPanel" | 141 | #define DOCKING_KEY "DockIntoPanel" |
140 | #define TOTALCOSTS_KEY "TotalCosts" | 142 | #define TOTALCOSTS_KEY "TotalCosts" |
141 | #define TOTALBYTES_KEY "TotalBytes" | 143 | #define TOTALBYTES_KEY "TotalBytes" |
142 | 144 | ||
143 | // graph colors | ||
144 | #define GENABLED "Enabled" | ||
145 | #define GCOLOR_BG "Background" | ||
146 | #define GCOLOR_TEXT "Text" | ||
147 | #define GCOLOR_IN "InBytes" | ||
148 | #define GCOLOR_OUT "OutBytes" | ||
149 | |||
150 | // pppd errors | 145 | // pppd errors |
151 | #define E_IF_TIMEOUT 1 | 146 | #define E_IF_TIMEOUT 1 |
152 | #define E_PPPD_DIED 2 | 147 | #define E_PPPD_DIED 2 |
153 | 148 | ||
154 | // window position | 149 | // account list |
155 | #define WINPOS_CONWIN_X "WindowPositionConWinX" | 150 | #define ACCOUNTS_COUNT "Accounts_Count" |
156 | #define WINPOS_CONWIN_Y "WindowPositionConWinY" | 151 | #define ACOUNTS_DEV "Accounts_Modem" |
157 | #define WINPOS_STATWIN_X "WindowPositionStatWinX" | 152 | #define ACOUNTS_ACC "Accounts_Account" |
158 | #define WINPOS_STATWIN_Y "WindowPositionStatWinY" | ||
159 | 153 | ||
160 | class PPPData { | 154 | class PPPData { |
161 | public: | 155 | public: |
162 | PPPData(); | 156 | PPPData(); |
163 | ~PPPData() {}; | 157 | ~PPPData() {}; |
164 | static PPPData* data(); | 158 | static PPPData* data(); |
165 | 159 | ||
166 | enum { NumInitStrings = 2 }; | 160 | enum { NumInitStrings = 2 }; |
167 | 161 | ||
168 | // general functions | 162 | // general functions |
169 | bool open(); | 163 | bool open(); |
170 | void save(); | 164 | void save(); |
171 | void cancel(); | 165 | void cancel(); |
172 | 166 | ||
167 | QMap<QString,QString> getConfiguredInterfaces(); | ||
168 | void setConfiguredInterfaces( QMap<QString,QString> ); | ||
173 | 169 | ||
174 | // function to read/write date to configuration file | 170 | // function to read/write date to configuration file |
175 | QString readConfig(const QString &, const QString &, const QString &); | 171 | QString readConfig(const QString &, const QString &, const QString &); |
176 | int readNumConfig(const QString &, const QString &, int); | 172 | int readNumConfig(const QString &, const QString &, int); |
177 | bool readListConfig(const QString &, const QString &, | 173 | bool readListConfig(const QString &, const QString &, |
178 | QStringList &, char sep = ','); | 174 | QStringList &, char sep = ','); |
179 | void writeConfig(const QString &, const QString &, const QString &); | 175 | void writeConfig(const QString &, const QString &, const QString &); |
180 | void writeConfig(const QString &, const QString &, int); | 176 | void writeConfig(const QString &, const QString &, int); |
181 | void writeListConfig(const QString &, const QString &, | 177 | void writeListConfig(const QString &, const QString &, |
182 | QStringList &, char sep = ','); | 178 | QStringList &, char sep = ','); |
183 | 179 | ||
184 | // return the current account group | 180 | // return the current account group |
185 | QString currentGroup() { return cgroup; } | 181 | QString currentGroup() { return cgroup; } |
186 | QString modemGroup(); | 182 | QString modemGroup(); |
187 | 183 | ||
188 | // functions to set/get general kppp info | 184 | // functions to set/get general kppp info |
189 | QString password() const; | 185 | QString password() const; |
190 | void setPassword(const QString &); | 186 | void setPassword(const QString &); |
191 | 187 | ||
188 | int currentAccountID() { return caccount; }; | ||
192 | const QString defaultAccount(); | 189 | const QString defaultAccount(); |
193 | void setDefaultAccount(const QString &); | 190 | void setDefaultAccount(const QString &); |
194 | 191 | ||
195 | void set_xserver_exit_disconnect(bool set); | 192 | void set_xserver_exit_disconnect(bool set); |
196 | bool get_xserver_exit_disconnect(); | 193 | bool get_xserver_exit_disconnect(); |
197 | 194 | ||
198 | void setPPPDebug(bool set); | 195 | void setPPPDebug(bool set); |
199 | bool getPPPDebug(); | 196 | bool getPPPDebug(); |
200 | 197 | ||
201 | void set_quit_on_disconnect(bool); | 198 | void set_quit_on_disconnect(bool); |
202 | bool quit_on_disconnect(); | 199 | bool quit_on_disconnect(); |
203 | 200 | ||
204 | void set_show_clock_on_caption(bool set); | 201 | void set_show_clock_on_caption(bool set); |
205 | bool get_show_clock_on_caption(); | 202 | bool get_show_clock_on_caption(); |
206 | 203 | ||
207 | void set_show_log_window(bool set); | 204 | void set_show_log_window(bool set); |
208 | bool get_show_log_window(); | 205 | bool get_show_log_window(); |
209 | 206 | ||
210 | void set_automatic_redial(bool set); | 207 | void set_automatic_redial(bool set); |
211 | bool automatic_redial(); | 208 | bool automatic_redial(); |
212 | 209 | ||
213 | void set_iconify_on_connect(bool set); | 210 | void set_iconify_on_connect(bool set); |
214 | bool get_iconify_on_connect(); | 211 | bool get_iconify_on_connect(); |
215 | 212 | ||
216 | void set_dock_into_panel(bool set); | 213 | void set_dock_into_panel(bool set); |
217 | bool get_dock_into_panel(); | 214 | bool get_dock_into_panel(); |
218 | 215 | ||
219 | const QString enter(); | 216 | const QString enter(); |
220 | void setEnter(const QString &); | 217 | void setEnter(const QString &); |
221 | 218 | ||
222 | QString pppdVersion(); | 219 | QString pppdVersion(); |
223 | bool pppdVersionMin(int ver, int mod, int patch); | 220 | bool pppdVersionMin(int ver, int mod, int patch); |
224 | 221 | ||
225 | int pppdTimeout(); | 222 | int pppdTimeout(); |
226 | void setpppdTimeout(int); | 223 | void setpppdTimeout(int); |
227 | 224 | ||
228 | int busyWait(); | 225 | int busyWait(); |
229 | void setbusyWait(int); | 226 | void setbusyWait(int); |
230 | 227 | ||
231 | bool modemLockFile(); | 228 | bool modemLockFile(); |
232 | void setModemLockFile(bool set); | 229 | void setModemLockFile(bool set); |
233 | 230 | ||
234 | int modemEscapeGuardTime(); | 231 | int modemEscapeGuardTime(); |
235 | void setModemEscapeGuardTime(int i); | 232 | void setModemEscapeGuardTime(int i); |
236 | 233 | ||
237 | void setModemEscapeStr(const QString &); | 234 | void setModemEscapeStr(const QString &); |
238 | const QString modemEscapeStr(); | 235 | const QString modemEscapeStr(); |
239 | 236 | ||
240 | void setModemEscapeResp(const QString &); | 237 | void setModemEscapeResp(const QString &); |
241 | const QString modemEscapeResp(); | 238 | const QString modemEscapeResp(); |
242 | 239 | ||
243 | const QString modemDevice(); | 240 | const QString modemDevice(); |
244 | bool setModemDevice(const QString &); | 241 | bool setModemDevice(const QString &); |
245 | 242 | ||
246 | const QString flowcontrol(); | 243 | const QString flowcontrol(); |
247 | void setFlowcontrol(const QString &); | 244 | void setFlowcontrol(const QString &); |
248 | 245 | ||
249 | int modemTimeout(); | 246 | int modemTimeout(); |
250 | void setModemTimeout(int); | 247 | void setModemTimeout(int); |
251 | 248 | ||
252 | int modemToneDuration(); | 249 | int modemToneDuration(); |
253 | void setModemToneDuration(int); | 250 | void setModemToneDuration(int); |
254 | 251 | ||
255 | QString volumeInitString(); | 252 | QString volumeInitString(); |
diff --git a/noncore/settings/networksettings/ppp/pppmodule.cpp b/noncore/settings/networksettings/ppp/pppmodule.cpp index 3a97535..7cbccc2 100644 --- a/noncore/settings/networksettings/ppp/pppmodule.cpp +++ b/noncore/settings/networksettings/ppp/pppmodule.cpp | |||
@@ -1,89 +1,100 @@ | |||
1 | #include "pppconfig.h" | 1 | #include "pppconfig.h" |
2 | #include "pppmodule.h" | 2 | #include "pppmodule.h" |
3 | #include "pppdata.h" | 3 | #include "pppdata.h" |
4 | #include "kpppwidget.h" | 4 | #include "kpppwidget.h" |
5 | #include "interfaceinformationimp.h" | 5 | #include "interfaceinformationimp.h" |
6 | //#include "devices.h" | 6 | //#include "devices.h" |
7 | 7 | ||
8 | /** | 8 | /** |
9 | * Constructor, find all of the possible interfaces | 9 | * Constructor, find all of the possible interfaces |
10 | */ | 10 | */ |
11 | PPPModule::PPPModule() : Module() | 11 | PPPModule::PPPModule() : Module() |
12 | { | 12 | { |
13 | QMap<QString,QString> ifaces = PPPData::data()->getConfiguredInterfaces(); | ||
14 | QMap<QString,QString>::Iterator it; | ||
13 | Interface *iface; | 15 | Interface *iface; |
14 | iface = new Interface( 0, "device" ); | 16 | qDebug("getting interfaces"); |
15 | iface->setHardwareName( "account" ); | 17 | for( it = ifaces.begin(); it != ifaces.end(); ++it ){ |
16 | list.append( iface ); | 18 | qDebug("ifaces %s", it.key().latin1()); |
19 | iface = new Interface( 0, it.key() ); | ||
20 | iface->setHardwareName( it.data() ); | ||
21 | list.append( iface ); | ||
22 | } | ||
17 | } | 23 | } |
18 | 24 | ||
19 | /** | 25 | /** |
20 | * Delete any interfaces that we own. | 26 | * Delete any interfaces that we own. |
21 | */ | 27 | */ |
22 | PPPModule::~PPPModule(){ | 28 | PPPModule::~PPPModule(){ |
23 | Interface *i; | 29 | QMap<QString,QString> ifaces; |
24 | for ( i=list.first(); i != 0; i=list.next() ) | 30 | Interface *i; |
25 | delete i; | 31 | for ( i=list.first(); i != 0; i=list.next() ){ |
32 | ifaces.insert( i->getInterfaceName(), i->getHardwareName() ); | ||
33 | delete i; | ||
34 | } | ||
35 | PPPData::data()->setConfiguredInterfaces( ifaces ); | ||
36 | PPPData::data()->save(); | ||
26 | } | 37 | } |
27 | 38 | ||
28 | /** | 39 | /** |
29 | * Change the current profile | 40 | * Change the current profile |
30 | */ | 41 | */ |
31 | void PPPModule::setProfile(const QString &newProfile){ | 42 | void PPPModule::setProfile(const QString &newProfile){ |
32 | profile = newProfile; | 43 | profile = newProfile; |
33 | } | 44 | } |
34 | 45 | ||
35 | /** | 46 | /** |
36 | * get the icon name for this device. | 47 | * get the icon name for this device. |
37 | * @param Interface* can be used in determining the icon. | 48 | * @param Interface* can be used in determining the icon. |
38 | * @return QString the icon name (minus .png, .gif etc) | 49 | * @return QString the icon name (minus .png, .gif etc) |
39 | */ | 50 | */ |
40 | QString PPPModule::getPixmapName(Interface* ){ | 51 | QString PPPModule::getPixmapName(Interface* ){ |
41 | return "ppp"; | 52 | return "ppp"; |
42 | } | 53 | } |
43 | 54 | ||
44 | /** | 55 | /** |
45 | * Check to see if the interface i is owned by this module. | 56 | * Check to see if the interface i is owned by this module. |
46 | * @param Interface* interface to check against | 57 | * @param Interface* interface to check against |
47 | * @return bool true if i is owned by this module, false otherwise. | 58 | * @return bool true if i is owned by this module, false otherwise. |
48 | */ | 59 | */ |
49 | bool PPPModule::isOwner(Interface *i){ | 60 | bool PPPModule::isOwner(Interface *i){ |
50 | return list.find( i ) != -1; | 61 | return list.find( i ) != -1; |
51 | } | 62 | } |
52 | 63 | ||
53 | /** | 64 | /** |
54 | * Create, and return the WLANConfigure Module | 65 | * Create, and return the WLANConfigure Module |
55 | * @return QWidget* pointer to this modules configure. | 66 | * @return QWidget* pointer to this modules configure. |
56 | */ | 67 | */ |
57 | QWidget *PPPModule::configure(Interface *i){ | 68 | QWidget *PPPModule::configure(Interface *i){ |
58 | qDebug("return ModemWidget"); | 69 | qDebug("return ModemWidget"); |
59 | PPPConfigWidget *pppconfig = new PPPConfigWidget( i, 0, "PPPConfig", | 70 | PPPConfigWidget *pppconfig = new PPPConfigWidget( i, 0, "PPPConfig", |
60 | false, | 71 | false, |
61 | Qt::WDestructiveClose ); | 72 | Qt::WDestructiveClose ); |
62 | return pppconfig; | 73 | return pppconfig; |
63 | } | 74 | } |
64 | 75 | ||
65 | /** | 76 | /** |
66 | * Create, and return the Information Module | 77 | * Create, and return the Information Module |
67 | * @return QWidget* pointer to this modules info. | 78 | * @return QWidget* pointer to this modules info. |
68 | */ | 79 | */ |
69 | QWidget *PPPModule::information(Interface *i){ | 80 | QWidget *PPPModule::information(Interface *i){ |
70 | // We don't have any advanced pppd information widget yet :-D | 81 | // We don't have any advanced pppd information widget yet :-D |
71 | // TODO ^ | 82 | // TODO ^ |
72 | qDebug("return PPPModule::information"); | 83 | qDebug("return PPPModule::information"); |
73 | InterfaceInformationImp *information = new InterfaceInformationImp( 0, "InterfaceSetupImp", i); | 84 | InterfaceInformationImp *information = new InterfaceInformationImp( 0, "InterfaceSetupImp", i); |
74 | return information; | 85 | return information; |
75 | } | 86 | } |
76 | 87 | ||
77 | /** | 88 | /** |
78 | * Get all active (up or down) interfaces | 89 | * Get all active (up or down) interfaces |
79 | * @return QList<Interface> A list of interfaces that exsist that havn't | 90 | * @return QList<Interface> A list of interfaces that exsist that havn't |
80 | * been called by isOwner() | 91 | * been called by isOwner() |
81 | */ | 92 | */ |
82 | QList<Interface> PPPModule::getInterfaces(){ | 93 | QList<Interface> PPPModule::getInterfaces(){ |
83 | // List all of the files in the peer directory | 94 | // List all of the files in the peer directory |
84 | qDebug("PPPModule::getInterfaces"); | 95 | qDebug("PPPModule::getInterfaces"); |
85 | return list; | 96 | return list; |
86 | } | 97 | } |
87 | 98 | ||
88 | /** | 99 | /** |
89 | * Attempt to add a new interface as defined by name | 100 | * Attempt to add a new interface as defined by name |