17 files changed, 615 insertions, 642 deletions
diff --git a/noncore/settings/networksettings/ppp/accounts.cpp b/noncore/settings/networksettings/ppp/accounts.cpp index d902517..19db9ef 100644 --- a/noncore/settings/networksettings/ppp/accounts.cpp +++ b/noncore/settings/networksettings/ppp/accounts.cpp | |||
@@ -1,491 +1,495 @@ | |||
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; | 56 | // int min = 0; |
57 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); | 57 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); |
58 | 58 | ||
59 | // add a hbox | 59 | // add a hbox |
60 | // QHBoxLayout *l11 = new QHBoxLayout; | 60 | // QHBoxLayout *l11 = new QHBoxLayout; |
61 | // l1->addLayout(l11); | 61 | // l1->addLayout(l11); |
62 | 62 | ||
63 | accountlist_l = new QListBox(this); | 63 | accountlist_l = new QListBox(this); |
64 | accountlist_l->setMinimumSize(160, 128); | 64 | // accountlist_l->setMinimumSize(160, 128); |
65 | connect(accountlist_l, SIGNAL(highlighted(int)), | 65 | connect(accountlist_l, SIGNAL(highlighted(int)), |
66 | this, SLOT(slotListBoxSelect(int))); | 66 | this, SLOT(slotListBoxSelect(int))); |
67 | connect(accountlist_l, SIGNAL(selected(int)), | 67 | connect(accountlist_l, SIGNAL(selected(int)), |
68 | this, SLOT(editaccount())); | 68 | this, SLOT(editaccount())); |
69 | l1->addWidget(accountlist_l, 10); | 69 | l1->addWidget(accountlist_l, 10); |
70 | 70 | ||
71 | // QVBoxLayout *l111 = new QVBoxLayout(this); | 71 | // QVBoxLayout *l111 = new QVBoxLayout(this); |
72 | // l11->addLayout(l111, 1); | 72 | // l11->addLayout(l111, 1); |
73 | edit_b = new QPushButton(i18n("&Edit..."), this); | 73 | edit_b = new QPushButton(i18n("&Edit..."), this); |
74 | connect(edit_b, SIGNAL(clicked()), SLOT(editaccount())); | 74 | connect(edit_b, SIGNAL(clicked()), SLOT(editaccount())); |
75 | QWhatsThis::add(edit_b, i18n("Allows you to modify the selected account")); | 75 | QWhatsThis::add(edit_b, i18n("Allows you to modify the selected account")); |
76 | 76 | ||
77 | min = edit_b->sizeHint().width(); | 77 | // min = edit_b->sizeHint().width(); |
78 | min = QMAX(70,min); | 78 | // min = QMAX(70,min); |
79 | edit_b->setMinimumWidth(min); | 79 | // edit_b->setMinimumWidth(min); |
80 | 80 | ||
81 | l1->addWidget(edit_b); | 81 | l1->addWidget(edit_b); |
82 | 82 | ||
83 | new_b = new QPushButton(i18n("&New..."), this); | 83 | new_b = new QPushButton(i18n("&New..."), this); |
84 | connect(new_b, SIGNAL(clicked()), SLOT(newaccount())); | 84 | connect(new_b, SIGNAL(clicked()), SLOT(newaccount())); |
85 | l1->addWidget(new_b); | 85 | l1->addWidget(new_b); |
86 | QWhatsThis::add(new_b, i18n("Create a new dialup connection\n" | 86 | QWhatsThis::add(new_b, i18n("Create a new dialup connection\n" |
87 | "to the Internet")); | 87 | "to the Internet")); |
88 | 88 | ||
89 | copy_b = new QPushButton(i18n("Co&py"), this); | 89 | copy_b = new QPushButton(i18n("Co&py"), this); |
90 | connect(copy_b, SIGNAL(clicked()), SLOT(copyaccount())); | 90 | connect(copy_b, SIGNAL(clicked()), SLOT(copyaccount())); |
91 | l1->addWidget(copy_b); | 91 | l1->addWidget(copy_b); |
92 | QWhatsThis::add(copy_b, | 92 | QWhatsThis::add(copy_b, |
93 | i18n("Makes a copy of the selected account. All\n" | 93 | i18n("Makes a copy of the selected account. All\n" |
94 | "settings of the selected account are copied\n" | 94 | "settings of the selected account are copied\n" |
95 | "to a new account, that you can modify to fit your\n" | 95 | "to a new account, that you can modify to fit your\n" |
96 | "needs")); | 96 | "needs")); |
97 | 97 | ||
98 | delete_b = new QPushButton(i18n("De&lete"), this); | 98 | delete_b = new QPushButton(i18n("De&lete"), this); |
99 | connect(delete_b, SIGNAL(clicked()), SLOT(deleteaccount())); | 99 | connect(delete_b, SIGNAL(clicked()), SLOT(deleteaccount())); |
100 | l1->addWidget(delete_b); | 100 | l1->addWidget(delete_b); |
101 | QWhatsThis::add(delete_b, | 101 | QWhatsThis::add(delete_b, |
102 | i18n("<p>Deletes the selected account\n\n" | 102 | i18n("<p>Deletes the selected account\n\n" |
103 | "<font color=\"red\"><b>Use with care!</b></font>")); | 103 | "<font color=\"red\"><b>Use with care!</b></font>")); |
104 | 104 | ||
105 | QHBoxLayout *l12 = new QHBoxLayout; | 105 | QHBoxLayout *l12 = new QHBoxLayout; |
106 | l1->addStretch(1); | 106 | l1->addStretch(1); |
107 | l1->addLayout(l12); | 107 | l1->addLayout(l12); |
108 | 108 | ||
109 | // QVBoxLayout *l121 = new QVBoxLayout; | 109 | // QVBoxLayout *l121 = new QVBoxLayout; |
110 | // l12->addLayout(l121); | 110 | // l12->addLayout(l121); |
111 | // l121->addStretch(1); | 111 | // l121->addStretch(1); |
112 | // costlabel = new QLabel(i18n("Phone costs:"), parent); | 112 | // costlabel = new QLabel(i18n("Phone costs:"), parent); |
113 | // costlabel->setEnabled(FALSE); | 113 | // costlabel->setEnabled(FALSE); |
114 | // l121->addWidget(costlabel); | 114 | // l121->addWidget(costlabel); |
115 | 115 | ||
116 | // costedit = new QLineEdit(parent); | 116 | // costedit = new QLineEdit(parent); |
117 | // costedit->setFocusPolicy(QWidget::NoFocus); | 117 | // costedit->setFocusPolicy(QWidget::NoFocus); |
118 | // costedit->setFixedHeight(costedit->sizeHint().height()); | 118 | // costedit->setFixedHeight(costedit->sizeHint().height()); |
119 | // costedit->setEnabled(FALSE); | 119 | // costedit->setEnabled(FALSE); |
120 | // l121->addWidget(costedit); | 120 | // l121->addWidget(costedit); |
121 | // l121->addStretch(1); | 121 | // l121->addStretch(1); |
122 | // QString tmp = i18n("<p>This shows the accumulated phone costs\n" | 122 | // QString tmp = i18n("<p>This shows the accumulated phone costs\n" |
123 | // "for the selected account.\n" | 123 | // "for the selected account.\n" |
124 | // "\n" | 124 | // "\n" |
125 | // "<b>Important</b>: If you have more than one \n" | 125 | // "<b>Important</b>: If you have more than one \n" |
126 | // "account - beware, this is <b>NOT</b> the sum \n" | 126 | // "account - beware, this is <b>NOT</b> the sum \n" |
127 | // "of the phone costs of all your accounts!"); | 127 | // "of the phone costs of all your accounts!"); |
128 | // QWhatsThis::add(costlabel, tmp); | 128 | // QWhatsThis::add(costlabel, tmp); |
129 | // QWhatsThis::add(costedit, tmp); | 129 | // QWhatsThis::add(costedit, tmp); |
130 | 130 | ||
131 | // vollabel = new QLabel(i18n("Volume:"), parent); | 131 | // vollabel = new QLabel(i18n("Volume:"), parent); |
132 | // vollabel->setEnabled(FALSE); | 132 | // vollabel->setEnabled(FALSE); |
133 | // l121->addWidget(vollabel); | 133 | // l121->addWidget(vollabel); |
134 | 134 | ||
135 | // voledit = new QLineEdit(parent,"voledit"); | 135 | // voledit = new QLineEdit(parent,"voledit"); |
136 | // voledit->setFocusPolicy(QWidget::NoFocus); | 136 | // voledit->setFocusPolicy(QWidget::NoFocus); |
137 | // voledit->setFixedHeight(voledit->sizeHint().height()); | 137 | // voledit->setFixedHeight(voledit->sizeHint().height()); |
138 | // voledit->setEnabled(FALSE); | 138 | // voledit->setEnabled(FALSE); |
139 | // l121->addWidget(voledit); | 139 | // l121->addWidget(voledit); |
140 | // tmp = i18n("<p>This shows the number of bytes transferred\n" | 140 | // tmp = i18n("<p>This shows the number of bytes transferred\n" |
141 | // "for the selected account (not for all of your\n" | 141 | // "for the selected account (not for all of your\n" |
142 | // "accounts. You can select what to display in\n" | 142 | // "accounts. You can select what to display in\n" |
143 | // "the accounting dialog.\n" | 143 | // "the accounting dialog.\n" |
144 | // "\n" | 144 | // "\n" |
145 | // "<a href=\"#volaccounting\">More on volume accounting</a>"); | 145 | // "<a href=\"#volaccounting\">More on volume accounting</a>"); |
146 | 146 | ||
147 | // QWhatsThis::add(vollabel,tmp); | 147 | // QWhatsThis::add(vollabel,tmp); |
148 | // QWhatsThis::add(voledit, tmp); | 148 | // QWhatsThis::add(voledit, tmp); |
149 | 149 | ||
150 | // QVBoxLayout *l122 = new QVBoxLayout; | 150 | // QVBoxLayout *l122 = new QVBoxLayout; |
151 | // l12->addStretch(1); | 151 | // l12->addStretch(1); |
152 | // l12->addLayout(l122); | 152 | // l12->addLayout(l122); |
153 | 153 | ||
154 | // l122->addStretch(1); | 154 | // l122->addStretch(1); |
155 | // reset = new QPushButton(i18n("&Reset..."), parent); | 155 | // reset = new QPushButton(i18n("&Reset..."), parent); |
156 | // reset->setEnabled(FALSE); | 156 | // reset->setEnabled(FALSE); |
157 | // connect(reset, SIGNAL(clicked()), | 157 | // connect(reset, SIGNAL(clicked()), |
158 | // this, SLOT(resetClicked())); | 158 | // this, SLOT(resetClicked())); |
159 | // l122->addWidget(reset); | 159 | // l122->addWidget(reset); |
160 | 160 | ||
161 | // log = new QPushButton(i18n("&View Logs"), this); | 161 | // log = new QPushButton(i18n("&View Logs"), this); |
162 | // connect(log, SIGNAL(clicked()), | 162 | // connect(log, SIGNAL(clicked()), |
163 | // this, SLOT(viewLogClicked())); | 163 | // this, SLOT(viewLogClicked())); |
164 | // l122->addWidget(log); | 164 | // l122->addWidget(log); |
165 | // l122->addStretch(1); | 165 | // l122->addStretch(1); |
166 | 166 | ||
167 | //load up account list from gppdata to the list box | 167 | //load up account list from gppdata to the list box |
168 | if(gpppdata.count() > 0) { | 168 | if(PPPData::data()->count() > 0) { |
169 | for(int i=0; i <= gpppdata.count()-1; i++) { | 169 | for(int i=0; i <= PPPData::data()->count()-1; i++) { |
170 | gpppdata.setAccountbyIndex(i); | 170 | PPPData::data()->setAccountbyIndex(i); |
171 | accountlist_l->insertItem(gpppdata.accname()); | 171 | accountlist_l->insertItem(PPPData::data()->accname()); |
172 | } | 172 | } |
173 | } | 173 | } |
174 | 174 | ||
175 | slotListBoxSelect(accountlist_l->currentItem()); | 175 | slotListBoxSelect(accountlist_l->currentItem()); |
176 | 176 | ||
177 | l1->activate(); | 177 | l1->activate(); |
178 | } | 178 | } |
179 | 179 | ||
180 | 180 | ||
181 | 181 | ||
182 | void AccountWidget::slotListBoxSelect(int idx) { | 182 | void AccountWidget::slotListBoxSelect(int idx) { |
183 | delete_b->setEnabled((bool)(idx != -1)); | 183 | delete_b->setEnabled((bool)(idx != -1)); |
184 | edit_b->setEnabled((bool)(idx != -1)); | 184 | edit_b->setEnabled((bool)(idx != -1)); |
185 | copy_b->setEnabled((bool)(idx != -1)); | 185 | copy_b->setEnabled((bool)(idx != -1)); |
186 | if(idx!=-1) { | 186 | if(idx!=-1) { |
187 | QString account = gpppdata.accname(); | 187 | QString account = PPPData::data()->accname(); |
188 | gpppdata.setAccountbyIndex(accountlist_l->currentItem()); | 188 | PPPData::data()->setAccountbyIndex(accountlist_l->currentItem()); |
189 | // reset->setEnabled(TRUE); | 189 | // reset->setEnabled(TRUE); |
190 | // costlabel->setEnabled(TRUE); | 190 | // costlabel->setEnabled(TRUE); |
191 | // costedit->setEnabled(TRUE); | 191 | // costedit->setEnabled(TRUE); |
192 | // costedit->setText(AccountingBase::getCosts(accountlist_l->text(accountlist_l->currentItem()))); | 192 | // costedit->setText(AccountingBase::getCosts(accountlist_l->text(accountlist_l->currentItem()))); |
193 | 193 | ||
194 | // vollabel->setEnabled(TRUE); | 194 | // vollabel->setEnabled(TRUE); |
195 | // voledit->setEnabled(TRUE); | 195 | // voledit->setEnabled(TRUE); |
196 | int bytes = gpppdata.totalBytes(); | 196 | // int bytes = PPPData::data()->totalBytes(); |
197 | // voledit->setText(prettyPrintVolume(bytes)); | 197 | // voledit->setText(prettyPrintVolume(bytes)); |
198 | gpppdata.setAccount(account); | 198 | PPPData::data()->setAccount(account); |
199 | } else{ | 199 | } else{ |
200 | // reset->setEnabled(FALSE); | 200 | // reset->setEnabled(FALSE); |
201 | // costlabel->setEnabled(FALSE); | 201 | // costlabel->setEnabled(FALSE); |
202 | // costedit->setText(""); | 202 | // costedit->setText(""); |
203 | // costedit->setEnabled(FALSE); | 203 | // costedit->setEnabled(FALSE); |
204 | // vollabel->setEnabled(FALSE); | 204 | // vollabel->setEnabled(FALSE); |
205 | // voledit->setText(""); | 205 | // voledit->setText(""); |
206 | // voledit->setEnabled(FALSE); | 206 | // voledit->setEnabled(FALSE); |
207 | } | 207 | } |
208 | } | 208 | } |
209 | 209 | ||
210 | 210 | ||
211 | // void AccountWidget::viewLogClicked(){ | 211 | // void AccountWidget::viewLogClicked(){ |
212 | 212 | ||
213 | // QApplication::flushX(); | 213 | // QApplication::flushX(); |
214 | // if(fork() == 0) { | 214 | // if(fork() == 0) { |
215 | // setgid(getgid()); | 215 | // setgid(getgid()); |
216 | // setuid(getuid()); | 216 | // setuid(getuid()); |
217 | // system("kppplogview -kppp"); | 217 | // system("kppplogview -kppp"); |
218 | // _exit(0); | 218 | // _exit(0); |
219 | // } | 219 | // } |
220 | // } | 220 | // } |
221 | 221 | ||
222 | 222 | ||
223 | // void AccountWidget::resetClicked(){ | 223 | // void AccountWidget::resetClicked(){ |
224 | // if(accountlist_l->currentItem() == -1) | 224 | // if(accountlist_l->currentItem() == -1) |
225 | // return; | 225 | // return; |
226 | 226 | ||
227 | // // QueryReset dlg(this); | 227 | // // QueryReset dlg(this); |
228 | // // int what = dlg.exec(); | 228 | // // int what = dlg.exec(); |
229 | 229 | ||
230 | // // if(what && QueryReset::COSTS) { | 230 | // // if(what && QueryReset::COSTS) { |
231 | // // emit resetCosts(accountlist_l->text(accountlist_l->currentItem())); | 231 | // // emit resetCosts(accountlist_l->text(accountlist_l->currentItem())); |
232 | // // costedit->setText("0"); | 232 | // // costedit->setText("0"); |
233 | // // } | 233 | // // } |
234 | 234 | ||
235 | // // if(what && QueryReset::VOLUME) { | 235 | // // if(what && QueryReset::VOLUME) { |
236 | // // emit resetVolume(accountlist_l->text(accountlist_l->currentItem())); | 236 | // // emit resetVolume(accountlist_l->text(accountlist_l->currentItem())); |
237 | // // voledit->setText(prettyPrintVolume(0)); | 237 | // // voledit->setText(prettyPrintVolume(0)); |
238 | // // } | 238 | // // } |
239 | // } | 239 | // } |
240 | 240 | ||
241 | 241 | ||
242 | void AccountWidget::editaccount() { | 242 | void AccountWidget::editaccount() { |
243 | gpppdata.setAccount(accountlist_l->text(accountlist_l->currentItem())); | 243 | PPPData::data()->setAccount(accountlist_l->text(accountlist_l->currentItem())); |
244 | 244 | ||
245 | int result = doTab(); | 245 | int result = doTab(); |
246 | 246 | ||
247 | if(result == QDialog::Accepted) { | 247 | if(result == QDialog::Accepted) { |
248 | accountlist_l->changeItem(gpppdata.accname(),accountlist_l->currentItem()); | 248 | accountlist_l->changeItem(PPPData::data()->accname(),accountlist_l->currentItem()); |
249 | // emit resetaccounts(); | 249 | // emit resetaccounts(); |
250 | gpppdata.save(); | 250 | PPPData::data()->save(); |
251 | } | 251 | } |
252 | } | 252 | } |
253 | 253 | ||
254 | 254 | ||
255 | void AccountWidget::newaccount() { | 255 | void AccountWidget::newaccount() { |
256 | if(accountlist_l->count() == MAX_ACCOUNTS) { | 256 | if(accountlist_l->count() == MAX_ACCOUNTS) { |
257 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); | 257 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); |
258 | return; | 258 | return; |
259 | } | 259 | } |
260 | 260 | ||
261 | int result; | 261 | int result; |
262 | // int query = QMessageBox::information(this, | 262 | // int query = QMessageBox::information(this, |
263 | // i18n("Do you want to use the wizard to create the new account or the " | 263 | // i18n("Do you want to use the wizard to create the new account or the " |
264 | // "standard, dialog-based setup?\n" | 264 | // "standard, dialog-based setup?\n" |
265 | // "The wizard is easier and sufficient in most cases. If you need " | 265 | // "The wizard is easier and sufficient in most cases. If you need " |
266 | // "very special settings, you might want to try the standard, " | 266 | // "very special settings, you might want to try the standard, " |
267 | // "dialog-based setup."), | 267 | // "dialog-based setup."), |
268 | // i18n("Create New Account"), | 268 | // i18n("Create New Account"), |
269 | // i18n("Wizard"), i18n("Dialog Setup"), i18n("Cancel")); | 269 | // i18n("Wizard"), i18n("Dialog Setup"), i18n("Cancel")); |
270 | 270 | ||
271 | // switch(query) { | 271 | // switch(query) { |
272 | // case QMessageBox::Yes: | 272 | // case QMessageBox::Yes: |
273 | // { | 273 | // { |
274 | // if (gpppdata.newaccount() == -1) | 274 | // if (PPPData::data()->newaccount() == -1) |
275 | // return; | 275 | // return; |
276 | // // ProviderDB pdb(this); | 276 | // // ProviderDB pdb(this); |
277 | // // result = pdb.exec(); | 277 | // // result = pdb.exec(); |
278 | // break; | 278 | // break; |
279 | // } | 279 | // } |
280 | // case QMessageBox::No: | 280 | // case QMessageBox::No: |
281 | if (gpppdata.newaccount() == -1){ | 281 | if (PPPData::data()->newaccount() == -1){ |
282 | qDebug("gpppdata.newaccount() == -1"); | 282 | qDebug("PPPData::data()->newaccount() == -1"); |
283 | return; | 283 | return; |
284 | } | 284 | } |
285 | result = doTab(); | 285 | result = doTab(); |
286 | // break; | 286 | // break; |
287 | // default: | 287 | // default: |
288 | // return; | 288 | // return; |
289 | // } | 289 | // } |
290 | 290 | ||
291 | if(result == QDialog::Accepted) { | 291 | if(result == QDialog::Accepted) { |
292 | accountlist_l->insertItem(gpppdata.accname()); | 292 | accountlist_l->insertItem(PPPData::data()->accname()); |
293 | accountlist_l->setSelected(accountlist_l->findItem(gpppdata.accname()), | 293 | accountlist_l->setSelected(accountlist_l->findItem(PPPData::data()->accname()), |
294 | true); | 294 | true); |
295 | // emit resetaccounts(); | 295 | // emit resetaccounts(); |
296 | gpppdata.save(); | 296 | PPPData::data()->save(); |
297 | } else | 297 | } else |
298 | gpppdata.deleteAccount(); | 298 | PPPData::data()->deleteAccount(); |
299 | } | 299 | } |
300 | 300 | ||
301 | 301 | ||
302 | void AccountWidget::copyaccount() { | 302 | void AccountWidget::copyaccount() { |
303 | if(accountlist_l->count() == MAX_ACCOUNTS) { | 303 | if(accountlist_l->count() == MAX_ACCOUNTS) { |
304 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); | 304 | QMessageBox::information(this, "sorry", i18n("Maximum number of accounts reached.")); |
305 | return; | 305 | return; |
306 | } | 306 | } |
307 | 307 | ||
308 | if(accountlist_l->currentItem()<0) { | 308 | if(accountlist_l->currentItem()<0) { |
309 | QMessageBox::information(this, "sorry", i18n("No account selected.")); | 309 | QMessageBox::information(this, "sorry", i18n("No account selected.")); |
310 | return; | 310 | return; |
311 | } | 311 | } |
312 | 312 | ||
313 | gpppdata.copyaccount(accountlist_l->currentItem()); | 313 | PPPData::data()->copyaccount(accountlist_l->currentItem()); |
314 | 314 | ||
315 | accountlist_l->insertItem(gpppdata.accname()); | 315 | accountlist_l->insertItem(PPPData::data()->accname()); |
316 | // emit resetaccounts(); | 316 | // emit resetaccounts(); |
317 | gpppdata.save(); | 317 | PPPData::data()->save(); |
318 | } | 318 | } |
319 | 319 | ||
320 | 320 | ||
321 | void AccountWidget::deleteaccount() { | 321 | void AccountWidget::deleteaccount() { |
322 | 322 | ||
323 | QString s = i18n("Are you sure you want to delete\nthe account \"%1\"?") | 323 | QString s = i18n("Are you sure you want to delete\nthe account \"%1\"?") |
324 | .arg(accountlist_l->text(accountlist_l->currentItem())); | 324 | .arg(accountlist_l->text(accountlist_l->currentItem())); |
325 | 325 | ||
326 | if(QMessageBox::warning(this, s, i18n("Confirm")) != QMessageBox::Yes) | 326 | if(QMessageBox::warning(this, s, i18n("Confirm")) != QMessageBox::Yes) |
327 | return; | 327 | return; |
328 | 328 | ||
329 | if(gpppdata.deleteAccount(accountlist_l->text(accountlist_l->currentItem()))) | 329 | if(PPPData::data()->deleteAccount(accountlist_l->text(accountlist_l->currentItem()))) |
330 | accountlist_l->removeItem(accountlist_l->currentItem()); | 330 | accountlist_l->removeItem(accountlist_l->currentItem()); |
331 | 331 | ||
332 | emit resetaccounts(); | 332 | emit resetaccounts(); |
333 | gpppdata.save(); | 333 | PPPData::data()->save(); |
334 | 334 | ||
335 | slotListBoxSelect(accountlist_l->currentItem()); | 335 | slotListBoxSelect(accountlist_l->currentItem()); |
336 | 336 | ||
337 | } | 337 | } |
338 | 338 | ||
339 | 339 | ||
340 | int AccountWidget::doTab(){ | 340 | int AccountWidget::doTab(){ |
341 | QDialog *dlg = new QDialog( this ); | 341 | QDialog *dlg = new QDialog( this, "newAccount", true ); |
342 | tabWindow = new QTabWidget( dlg ); | 342 | QVBoxLayout *layout = new QVBoxLayout( dlg ); |
343 | // tabWindow = new KDialogBase( KDialogBase::Tabbed, QString::null, | 343 | layout->setSpacing( 0 ); |
344 | // KDialogBase::Ok|KDialogBase::Cancel, KDialogBase::Ok, | 344 | layout->setMargin( 1 ); |
345 | // 0, 0, true); | 345 | |
346 | // KWin::setIcons(tabWindow->winId(), kapp->icon(), kapp->miniIcon()); | 346 | tabWindow = new QTabWidget( dlg, "tabWindow" ); |
347 | layout->addWidget( tabWindow ); | ||
348 | |||
347 | bool isnewaccount; | 349 | bool isnewaccount; |
348 | 350 | ||
349 | if(gpppdata.accname().isEmpty()) { | 351 | if(PPPData::data()->accname().isEmpty()) { |
350 | tabWindow->setCaption(i18n("New Account")); | 352 | dlg->setCaption(i18n("New Account")); |
351 | isnewaccount = true; | 353 | isnewaccount = true; |
352 | } else { | 354 | } else { |
353 | QString tit = i18n("Edit Account: "); | 355 | QString tit = i18n("Edit Account: "); |
354 | tit += gpppdata.accname(); | 356 | tit += PPPData::data()->accname(); |
355 | tabWindow->setCaption(tit); | 357 | dlg->setCaption(tit); |
356 | isnewaccount = false; | 358 | isnewaccount = false; |
357 | } | 359 | } |
358 | 360 | ||
359 | dial_w = new DialWidget( tabWindow ); | 361 | dial_w = new DialWidget( tabWindow, isnewaccount, "Dial Setup"); |
360 | tabWindow->addTab( dial_w, i18n("Dial") );//, i18n("Dial Setup")), isnewaccount); | 362 | tabWindow->addTab( dial_w, i18n("Dial") ); |
361 | ip_w = new IPWidget( tabWindow ); | 363 | ip_w = new IPWidget( tabWindow, isnewaccount, i18n("IP Setup")); |
362 | tabWindow->addTab( ip_w, i18n("IP") );//, i18n("IP Setup")), isnewaccount); | 364 | tabWindow->addTab( ip_w, i18n("IP") ); |
363 | gateway_w = new GatewayWidget( tabWindow ); | 365 | gateway_w = new GatewayWidget( tabWindow, isnewaccount, i18n("Gateway Setup")); |
364 | tabWindow->addTab( gateway_w, i18n("Gateway") );//, i18n("Gateway Setup")), isnewaccount); | 366 | tabWindow->addTab( gateway_w, i18n("Gateway") ); |
365 | dns_w = new DNSWidget( tabWindow ); | 367 | dns_w = new DNSWidget( tabWindow, isnewaccount, i18n("DNS Servers") ); |
366 | tabWindow->addTab( dns_w, i18n("DNS") );//, i18n("DNS Servers")), isnewaccount); | 368 | tabWindow->addTab( dns_w, i18n("DNS") ); |
367 | script_w = new ScriptWidget( tabWindow ); | 369 | script_w = new ScriptWidget( tabWindow, isnewaccount, i18n("Edit Login Script")); |
368 | tabWindow->addTab( script_w, i18n("Login Script") ); //, i18n("Edit Login Script")), isnewaccount); | 370 | tabWindow->addTab( script_w, i18n("Login Script") ); |
369 | ExecWidget *exec_w = new ExecWidget( tabWindow ); | 371 | ExecWidget *exec_w = new ExecWidget( tabWindow, isnewaccount, i18n("Execute Programs")); |
370 | tabWindow->addTab( exec_w, i18n("Execute") );//, i18n("Execute Programs")), isnewaccount); | 372 | tabWindow->addTab( exec_w, i18n("Execute") ); |
371 | // acct = new AccountingSelector( tabWindow, isnewaccount ); | 373 | // acct = new AccountingSelector( tabWindow, isnewaccount ); |
372 | // tabWindow->addTab( acct, i18n("Accounting")); | 374 | // tabWindow->addTab( acct, i18n("Accounting")); |
373 | 375 | ||
374 | int result = 0; | 376 | int result = 0; |
375 | bool ok = false; | 377 | bool ok = false; |
378 | qDebug("AccountWidget::doTab dlg->showMinimized"); | ||
379 | dlg->showMinimized(); | ||
376 | while (!ok){ | 380 | while (!ok){ |
377 | 381 | ||
378 | result = dlg->exec(); | 382 | result = dlg->exec(); |
379 | ok = true; | 383 | ok = true; |
380 | 384 | ||
381 | if(result == QDialog::Accepted) { | 385 | if(result == QDialog::Accepted) { |
382 | if (script_w->check()) { | 386 | if (script_w->check()) { |
383 | if(dial_w->save()) { | 387 | if(dial_w->save()) { |
384 | ip_w->save(); | 388 | ip_w->save(); |
385 | dns_w->save(); | 389 | dns_w->save(); |
386 | gateway_w->save(); | 390 | gateway_w->save(); |
387 | script_w->save(); | 391 | script_w->save(); |
388 | exec_w->save(); | 392 | exec_w->save(); |
389 | // acct->save(); | 393 | // acct->save(); |
390 | } else { | 394 | } else { |
391 | QMessageBox::critical(this, "error", i18n( "You must enter a unique\n" | 395 | QMessageBox::critical(this, "error", i18n( "You must enter a unique\n" |
392 | "account name")); | 396 | "account name")); |
393 | ok = false; | 397 | ok = false; |
394 | } | 398 | } |
395 | } else { | 399 | } else { |
396 | QMessageBox::critical(this, "error", i18n("Login script has unbalanced " | 400 | QMessageBox::critical(this, "error", i18n("Login script has unbalanced " |
397 | "loop Start/End")); | 401 | "loop Start/End")); |
398 | ok = false; | 402 | ok = false; |
399 | } | 403 | } |
400 | } | 404 | } |
401 | } | 405 | } |
402 | 406 | ||
403 | delete tabWindow; | 407 | delete tabWindow; |
404 | return result; | 408 | return result; |
405 | } | 409 | } |
406 | 410 | ||
407 | 411 | ||
408 | QString AccountWidget::prettyPrintVolume(unsigned int n) { | 412 | QString AccountWidget::prettyPrintVolume(unsigned int n) { |
409 | int idx = 0; | 413 | int idx = 0; |
410 | const QString quant[] = {i18n("Byte"), i18n("KB"), | 414 | const QString quant[] = {i18n("Byte"), i18n("KB"), |
411 | i18n("MB"), i18n("GB"), QString::null}; | 415 | i18n("MB"), i18n("GB"), QString::null}; |
412 | 416 | ||
413 | float n1 = n; | 417 | float n1 = n; |
414 | while(n >= 1024 && quant[idx] != QString::null) { | 418 | while(n >= 1024 && quant[idx] != QString::null) { |
415 | idx++; | 419 | idx++; |
416 | n /= 1024; | 420 | n /= 1024; |
417 | } | 421 | } |
418 | 422 | ||
419 | int i = idx; | 423 | int i = idx; |
420 | while(i--) | 424 | while(i--) |
421 | n1 = n1 / 1024.0; | 425 | n1 = n1 / 1024.0; |
422 | 426 | ||
423 | QString s = QString::number( n1, 'f', idx==0 ? 0 : 1 ); | 427 | QString s = QString::number( n1, 'f', idx==0 ? 0 : 1 ); |
424 | s += " " + quant[idx]; | 428 | s += " " + quant[idx]; |
425 | return s; | 429 | return s; |
426 | } | 430 | } |
427 | 431 | ||
428 | 432 | ||
429 | ///////////////////////////////////////////////////////////////////////////// | 433 | ///////////////////////////////////////////////////////////////////////////// |
430 | // | 434 | // |
431 | // Queries the user what to reset: costs, volume or both | 435 | // Queries the user what to reset: costs, volume or both |
432 | // | 436 | // |
433 | ///////////////////////////////////////////////////////////////////////////// | 437 | ///////////////////////////////////////////////////////////////////////////// |
434 | QueryReset::QueryReset(QWidget *parent) : QDialog(parent, 0, true) { | 438 | QueryReset::QueryReset(QWidget *parent) : QDialog(parent, 0, true) { |
435 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); | 439 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); |
436 | setCaption(i18n("Reset Accounting")); | 440 | setCaption(i18n("Reset Accounting")); |
437 | 441 | ||
438 | QVBoxLayout *tl = new QVBoxLayout(this, 10, 10); | 442 | QVBoxLayout *tl = new QVBoxLayout(this, 10, 10); |
439 | QVGroupBox *f = new QVGroupBox(i18n("What to Reset"), this); | 443 | QVGroupBox *f = new QVGroupBox(i18n("What to Reset"), this); |
440 | 444 | ||
441 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); | 445 | QVBoxLayout *l1 = new QVBoxLayout(this, 10, 10); |
442 | // costs = new QCheckBox(i18n("Reset the accumulated phone costs"), f); | 446 | // costs = new QCheckBox(i18n("Reset the accumulated phone costs"), f); |
443 | // costs->setChecked(true); | 447 | // costs->setChecked(true); |
444 | // l1->addWidget(costs); | 448 | // l1->addWidget(costs); |
445 | // QWhatsThis::add(costs, i18n("Check this to set the phone costs\n" | 449 | // QWhatsThis::add(costs, i18n("Check this to set the phone costs\n" |
446 | // "to zero. Typically you'll want to\n" | 450 | // "to zero. Typically you'll want to\n" |
447 | // "do this once a month.")); | 451 | // "do this once a month.")); |
448 | 452 | ||
449 | // volume = new QCheckBox(i18n("Reset volume accounting"), f); | 453 | // volume = new QCheckBox(i18n("Reset volume accounting"), f); |
450 | // volume->setChecked(true); | 454 | // volume->setChecked(true); |
451 | // l1->addWidget(volume); | 455 | // l1->addWidget(volume); |
452 | // QWhatsThis::add(volume, i18n("Check this to set the volume accounting\n" | 456 | // QWhatsThis::add(volume, i18n("Check this to set the volume accounting\n" |
453 | // "to zero. Typically you'll want to do this\n" | 457 | // "to zero. Typically you'll want to do this\n" |
454 | // "once a month.")); | 458 | // "once a month.")); |
455 | 459 | ||
456 | l1->activate(); | 460 | l1->activate(); |
457 | 461 | ||
458 | // this activates the f-layout and sets minimumSize() | 462 | // this activates the f-layout and sets minimumSize() |
459 | f->show(); | 463 | f->show(); |
460 | 464 | ||
461 | tl->addWidget(f); | 465 | tl->addWidget(f); |
462 | 466 | ||
463 | QButtonGroup *bbox = new QButtonGroup(this); | 467 | QButtonGroup *bbox = new QButtonGroup(this); |
464 | // bbox->addStretch(1); | 468 | // bbox->addStretch(1); |
465 | QPushButton *ok = new QPushButton( bbox, i18n("OK") ); | 469 | QPushButton *ok = new QPushButton( bbox, i18n("OK") ); |
466 | bbox->insert(ok); | 470 | bbox->insert(ok); |
467 | ok->setDefault(true); | 471 | ok->setDefault(true); |
468 | QPushButton *cancel = new QPushButton( bbox, i18n("Cancel") ); | 472 | QPushButton *cancel = new QPushButton( bbox, i18n("Cancel") ); |
469 | bbox->insert(cancel); | 473 | bbox->insert(cancel); |
470 | 474 | ||
471 | connect(ok, SIGNAL(clicked()), | 475 | connect(ok, SIGNAL(clicked()), |
472 | this, SLOT(accepted())); | 476 | this, SLOT(accepted())); |
473 | connect(cancel, SIGNAL(clicked()), | 477 | connect(cancel, SIGNAL(clicked()), |
474 | this, SLOT(reject())); | 478 | this, SLOT(reject())); |
475 | 479 | ||
476 | bbox->layout(); | 480 | bbox->layout(); |
477 | tl->addWidget(bbox); | 481 | tl->addWidget(bbox); |
478 | 482 | ||
479 | // TODO: activate if KGroupBox is fixed | 483 | // TODO: activate if KGroupBox is fixed |
480 | // setFixedSize(sizeHint()); | 484 | // setFixedSize(sizeHint()); |
481 | } | 485 | } |
482 | 486 | ||
483 | 487 | ||
484 | void QueryReset::accepted() { | 488 | void QueryReset::accepted() { |
485 | int result = costs->isChecked() ? COSTS : 0; | 489 | int result = costs->isChecked() ? COSTS : 0; |
486 | result += volume->isChecked() ? VOLUME : 0; | 490 | result += volume->isChecked() ? VOLUME : 0; |
487 | 491 | ||
488 | done(result); | 492 | done(result); |
489 | } | 493 | } |
490 | 494 | ||
491 | 495 | ||
diff --git a/noncore/settings/networksettings/ppp/connect.cpp b/noncore/settings/networksettings/ppp/connect.cpp index b7e229e..a3eda9d 100644 --- a/noncore/settings/networksettings/ppp/connect.cpp +++ b/noncore/settings/networksettings/ppp/connect.cpp | |||
@@ -1,1438 +1,1438 @@ | |||
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 | * | 4 | * |
5 | * Copyright (C) 1997 Bernd Johannes Wuebben | 5 | * Copyright (C) 1997 Bernd Johannes Wuebben |
6 | * wuebben@math.cornell.edu | 6 | * wuebben@math.cornell.edu |
7 | * Copyright (C) 1998-2001 Harri Porten <porten@kde.org> | 7 | * Copyright (C) 1998-2001 Harri Porten <porten@kde.org> |
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 <config.h> | 27 | //#include <config.h> |
28 | 28 | ||
29 | #include <qlayout.h> | 29 | #include <qlayout.h> |
30 | #include <qregexp.h> | 30 | #include <qregexp.h> |
31 | 31 | ||
32 | #include <qapplication.h> | 32 | #include <qapplication.h> |
33 | //#include <kdebug.h> | 33 | //#include <kdebug.h> |
34 | //#include <klocale.h> | 34 | //#include <klocale.h> |
35 | #define i18n QObject::tr | 35 | #define i18n QObject::tr |
36 | #include <qmessagebox.h> | 36 | #include <qmessagebox.h> |
37 | #include <qpushbutton.h> | 37 | #include <qpushbutton.h> |
38 | 38 | ||
39 | #include <unistd.h> | 39 | #include <unistd.h> |
40 | #include <stdlib.h> | 40 | #include <stdlib.h> |
41 | #include <string.h> | 41 | #include <string.h> |
42 | #include <fcntl.h> | 42 | #include <fcntl.h> |
43 | #include <netdb.h> | 43 | #include <netdb.h> |
44 | #include <sys/types.h> | 44 | #include <sys/types.h> |
45 | #include <sys/socket.h> | 45 | #include <sys/socket.h> |
46 | #include <arpa/inet.h> | 46 | #include <arpa/inet.h> |
47 | #include <netinet/in.h> | 47 | #include <netinet/in.h> |
48 | #include <sys/ioctl.h> | 48 | #include <sys/ioctl.h> |
49 | #include <assert.h> | 49 | #include <assert.h> |
50 | 50 | ||
51 | #ifdef _XPG4_2 | 51 | #ifdef _XPG4_2 |
52 | #define __xnet_connectconnect | 52 | #define __xnet_connectconnect |
53 | #endif | 53 | #endif |
54 | 54 | ||
55 | #include <errno.h> | 55 | #include <errno.h> |
56 | 56 | ||
57 | #ifdef HAVE_SYS_PARAM_H | 57 | #ifdef HAVE_SYS_PARAM_H |
58 | #include <sys/param.h> | 58 | #include <sys/param.h> |
59 | #endif | 59 | #endif |
60 | 60 | ||
61 | #ifdef __linux__ | 61 | #ifdef __linux__ |
62 | #include "runtests.h" | 62 | #include "runtests.h" |
63 | #endif | 63 | #endif |
64 | 64 | ||
65 | #include "auth.h" | 65 | #include "auth.h" |
66 | #include "connect.h" | 66 | #include "connect.h" |
67 | //#include "docking.h" | 67 | //#include "docking.h" |
68 | //#include "main.h" | 68 | //#include "main.h" |
69 | #include "modem.h" | 69 | #include "modem.h" |
70 | #include "kpppconfig.h" | 70 | #include "kpppconfig.h" |
71 | #include "pppdata.h" | 71 | #include "pppdata.h" |
72 | #include "kpppwidget.h" | 72 | #include "kpppwidget.h" |
73 | //#include "requester.h" | 73 | //#include "requester.h" |
74 | //#include "utils.h" | 74 | //#include "utils.h" |
75 | #define execute_command system | 75 | #define execute_command system |
76 | 76 | ||
77 | extern KPPPWidget *p_kppp; | 77 | extern KPPPWidget *p_kppp; |
78 | 78 | ||
79 | QString old_hostname; | 79 | QString old_hostname; |
80 | bool modified_hostname; | 80 | bool modified_hostname; |
81 | 81 | ||
82 | 82 | ||
83 | ConnectWidget::ConnectWidget(QWidget *parent, const char *name) | 83 | ConnectWidget::ConnectWidget(QWidget *parent, const char *name) |
84 | : QWidget(parent, name), | 84 | : QWidget(parent, name), |
85 | // initialize some important variables | 85 | // initialize some important variables |
86 | myreadbuffer(""), | 86 | myreadbuffer(""), |
87 | main_timer_ID(0), | 87 | main_timer_ID(0), |
88 | vmain(0), | 88 | vmain(0), |
89 | substate(-1), | 89 | substate(-1), |
90 | scriptindex(0), | 90 | scriptindex(0), |
91 | loopnest(0), | 91 | loopnest(0), |
92 | loopend(false), | 92 | loopend(false), |
93 | semaphore(false), | 93 | semaphore(false), |
94 | expecting(false), | 94 | expecting(false), |
95 | readbuffer(""), | 95 | readbuffer(""), |
96 | scanvar(""), | 96 | scanvar(""), |
97 | scanning(false), | 97 | scanning(false), |
98 | pausing(false), | 98 | pausing(false), |
99 | // termwindow(0), | 99 | // termwindow(0), |
100 | // stats(st), | 100 | // stats(st), |
101 | dialnumber(0) | 101 | dialnumber(0) |
102 | { | 102 | { |
103 | modified_hostname = false; | 103 | modified_hostname = false; |
104 | 104 | ||
105 | QVBoxLayout *tl = new QVBoxLayout(this, 8, 10); | 105 | QVBoxLayout *tl = new QVBoxLayout(this, 8, 10); |
106 | QString tit = i18n("Connecting to: "); | 106 | QString tit = i18n("Connecting to: "); |
107 | setCaption(tit); | 107 | setCaption(tit); |
108 | 108 | ||
109 | QHBoxLayout *l0 = new QHBoxLayout(10); | 109 | QHBoxLayout *l0 = new QHBoxLayout(10); |
110 | tl->addLayout(l0); | 110 | tl->addLayout(l0); |
111 | l0->addSpacing(10); | 111 | l0->addSpacing(10); |
112 | messg = new QLabel(this, "messg"); | 112 | messg = new QLabel(this, "messg"); |
113 | messg->setFrameStyle(QFrame::Panel|QFrame::Sunken); | 113 | messg->setFrameStyle(QFrame::Panel|QFrame::Sunken); |
114 | messg->setAlignment(AlignCenter); | 114 | messg->setAlignment(AlignCenter); |
115 | messg->setText(i18n("Unable to create modem lock file.")); | 115 | messg->setText(i18n("Unable to create modem lock file.")); |
116 | messg->setMinimumHeight(messg->sizeHint().height() + 5); | 116 | messg->setMinimumHeight(messg->sizeHint().height() + 5); |
117 | int messw = (messg->sizeHint().width() * 12) / 10; | 117 | int messw = (messg->sizeHint().width() * 12) / 10; |
118 | messw = QMAX(messw,280); | 118 | messw = QMAX(messw,280); |
119 | messg->setMinimumWidth(messw); | 119 | messg->setMinimumWidth(messw); |
120 | messg->setText(i18n("Looking for modem...")); | 120 | messg->setText(i18n("Looking for modem...")); |
121 | l0->addSpacing(10); | 121 | l0->addSpacing(10); |
122 | l0->addWidget(messg); | 122 | l0->addWidget(messg); |
123 | l0->addSpacing(10); | 123 | l0->addSpacing(10); |
124 | 124 | ||
125 | QHBoxLayout *l1 = new QHBoxLayout(10); | 125 | QHBoxLayout *l1 = new QHBoxLayout(10); |
126 | tl->addLayout(l1); | 126 | tl->addLayout(l1); |
127 | l1->addStretch(1); | 127 | l1->addStretch(1); |
128 | 128 | ||
129 | debug = new QPushButton(i18n("Log"), this); | 129 | debug = new QPushButton(i18n("Log"), this); |
130 | debug->setToggleButton(true); | 130 | debug->setToggleButton(true); |
131 | connect(debug, SIGNAL(clicked()), SIGNAL(toggleDebugWindow())); | 131 | connect(debug, SIGNAL(clicked()), SIGNAL(toggleDebugWindow())); |
132 | 132 | ||
133 | cancel = new QPushButton(i18n("Cancel"), this); | 133 | cancel = new QPushButton(i18n("Cancel"), this); |
134 | cancel->setFocus(); | 134 | cancel->setFocus(); |
135 | connect(cancel, SIGNAL(clicked()), SLOT(cancelbutton())); | 135 | connect(cancel, SIGNAL(clicked()), SLOT(cancelbutton())); |
136 | 136 | ||
137 | int maxw = QMAX(cancel->sizeHint().width(), | 137 | int maxw = QMAX(cancel->sizeHint().width(), |
138 | debug->sizeHint().width()); | 138 | debug->sizeHint().width()); |
139 | maxw = QMAX(maxw,65); | 139 | maxw = QMAX(maxw,65); |
140 | debug->setFixedWidth(maxw); | 140 | debug->setFixedWidth(maxw); |
141 | cancel->setFixedWidth(maxw); | 141 | cancel->setFixedWidth(maxw); |
142 | l1->addWidget(debug); | 142 | l1->addWidget(debug); |
143 | l1->addWidget(cancel); | 143 | l1->addWidget(cancel); |
144 | 144 | ||
145 | setFixedSize(sizeHint()); | 145 | setFixedSize(sizeHint()); |
146 | 146 | ||
147 | pausetimer = new QTimer(this); | 147 | pausetimer = new QTimer(this); |
148 | connect(pausetimer, SIGNAL(timeout()), SLOT(pause())); | 148 | connect(pausetimer, SIGNAL(timeout()), SLOT(pause())); |
149 | 149 | ||
150 | qApp->processEvents(); | 150 | qApp->processEvents(); |
151 | 151 | ||
152 | timeout_timer = new QTimer(this); | 152 | timeout_timer = new QTimer(this); |
153 | connect(timeout_timer, SIGNAL(timeout()), SLOT(script_timed_out())); | 153 | connect(timeout_timer, SIGNAL(timeout()), SLOT(script_timed_out())); |
154 | 154 | ||
155 | inittimer = new QTimer(this); | 155 | inittimer = new QTimer(this); |
156 | connect(inittimer, SIGNAL(timeout()), SLOT(init())); | 156 | connect(inittimer, SIGNAL(timeout()), SLOT(init())); |
157 | 157 | ||
158 | if_timeout_timer = new QTimer(this); | 158 | if_timeout_timer = new QTimer(this); |
159 | connect(if_timeout_timer, SIGNAL(timeout()), SLOT(if_waiting_timed_out())); | 159 | connect(if_timeout_timer, SIGNAL(timeout()), SLOT(if_waiting_timed_out())); |
160 | 160 | ||
161 | connect(this,SIGNAL(if_waiting_signal()),this,SLOT(if_waiting_slot())); | 161 | connect(this,SIGNAL(if_waiting_signal()),this,SLOT(if_waiting_slot())); |
162 | 162 | ||
163 | prompt = new PWEntry( this, "pw" ); | 163 | prompt = new PWEntry( this, "pw" ); |
164 | if_timer = new QTimer(this); | 164 | if_timer = new QTimer(this); |
165 | connect(if_timer,SIGNAL(timeout()), SLOT(if_waiting_slot())); | 165 | connect(if_timer,SIGNAL(timeout()), SLOT(if_waiting_slot())); |
166 | } | 166 | } |
167 | 167 | ||
168 | 168 | ||
169 | ConnectWidget::~ConnectWidget() { | 169 | ConnectWidget::~ConnectWidget() { |
170 | } | 170 | } |
171 | 171 | ||
172 | 172 | ||
173 | void ConnectWidget::preinit() { | 173 | void ConnectWidget::preinit() { |
174 | // this is all just to keep the GUI nice and snappy .... | 174 | // this is all just to keep the GUI nice and snappy .... |
175 | // you have to see to believe ... | 175 | // you have to see to believe ... |
176 | messg->setText(i18n("Looking for modem...")); | 176 | messg->setText(i18n("Looking for modem...")); |
177 | inittimer->start(100); | 177 | inittimer->start(100); |
178 | } | 178 | } |
179 | 179 | ||
180 | 180 | ||
181 | void ConnectWidget::init() { | 181 | void ConnectWidget::init() { |
182 | gpppdata.setpppdError(0); | 182 | PPPData::data()->setpppdError(0); |
183 | inittimer->stop(); | 183 | inittimer->stop(); |
184 | vmain = 0; | 184 | vmain = 0; |
185 | substate = -1; | 185 | substate = -1; |
186 | expecting = false; | 186 | expecting = false; |
187 | pausing = false; | 187 | pausing = false; |
188 | scriptindex = 0; | 188 | scriptindex = 0; |
189 | myreadbuffer = ""; | 189 | myreadbuffer = ""; |
190 | scanning = false; | 190 | scanning = false; |
191 | scanvar = ""; | 191 | scanvar = ""; |
192 | firstrunID = true; | 192 | firstrunID = true; |
193 | firstrunPW = true; | 193 | firstrunPW = true; |
194 | // stats->totalbytes = 0; | 194 | // stats->totalbytes = 0; |
195 | dialnumber = 0; | 195 | dialnumber = 0; |
196 | 196 | ||
197 | p_kppp->con_speed = ""; | 197 | p_kppp->con_speed = ""; |
198 | 198 | ||
199 | // p_kppp->setQuitOnDisconnect (p_kppp->quitOnDisconnect() || gpppdata.quit_on_disconnect()); | 199 | // p_kppp->setQuitOnDisconnect (p_kppp->quitOnDisconnect() || PPPData::data()->quit_on_disconnect()); |
200 | 200 | ||
201 | comlist = &gpppdata.scriptType(); | 201 | comlist = &PPPData::data()->scriptType(); |
202 | arglist = &gpppdata.script(); | 202 | arglist = &PPPData::data()->script(); |
203 | 203 | ||
204 | QString tit = i18n("Connecting to: %1").arg(gpppdata.accname()); | 204 | QString tit = i18n("Connecting to: %1").arg(PPPData::data()->accname()); |
205 | setCaption(tit); | 205 | setCaption(tit); |
206 | 206 | ||
207 | qApp->processEvents(); | 207 | qApp->processEvents(); |
208 | 208 | ||
209 | // run the "before-connect" command | 209 | // run the "before-connect" command |
210 | if (!gpppdata.command_before_connect().isEmpty()) { | 210 | if (!PPPData::data()->command_before_connect().isEmpty()) { |
211 | messg->setText(i18n("Running pre-startup command...")); | 211 | messg->setText(i18n("Running pre-startup command...")); |
212 | emit debugMessage(i18n("Running pre-startup command...")); | 212 | emit debugMessage(i18n("Running pre-startup command...")); |
213 | 213 | ||
214 | qApp->processEvents(); | 214 | qApp->processEvents(); |
215 | QApplication::flushX(); | 215 | QApplication::flushX(); |
216 | pid_t id = execute_command(gpppdata.command_before_connect()); | 216 | pid_t id = execute_command(PPPData::data()->command_before_connect()); |
217 | // int i, status; | 217 | // int i, status; |
218 | 218 | ||
219 | // do { | 219 | // do { |
220 | // qApp->processEvents(); | 220 | // qApp->processEvents(); |
221 | // i = waitpid(id, &status, WNOHANG); | 221 | // i = waitpid(id, &status, WNOHANG); |
222 | // usleep(100000); | 222 | // usleep(100000); |
223 | // } while (i == 0 && errno == 0); | 223 | // } while (i == 0 && errno == 0); |
224 | } | 224 | } |
225 | 225 | ||
226 | int lock = Modem::modem->lockdevice(); | 226 | int lock = Modem::modem->lockdevice(); |
227 | 227 | ||
228 | if (lock == 1) { | 228 | if (lock == 1) { |
229 | messg->setText(i18n("Modem device is locked.")); | 229 | messg->setText(i18n("Modem device is locked.")); |
230 | vmain = 20; // wait until cancel is pressed | 230 | vmain = 20; // wait until cancel is pressed |
231 | return; | 231 | return; |
232 | } | 232 | } |
233 | 233 | ||
234 | if (lock == -1) { | 234 | if (lock == -1) { |
235 | messg->setText(i18n("Unable to create modem lock file.")); | 235 | messg->setText(i18n("Unable to create modem lock file.")); |
236 | vmain = 20; // wait until cancel is pressed | 236 | vmain = 20; // wait until cancel is pressed |
237 | return; | 237 | return; |
238 | } | 238 | } |
239 | 239 | ||
240 | if(Modem::modem->opentty()) { | 240 | if(Modem::modem->opentty()) { |
241 | messg->setText(Modem::modem->modemMessage()); | 241 | messg->setText(Modem::modem->modemMessage()); |
242 | qApp->processEvents(); | 242 | qApp->processEvents(); |
243 | if(Modem::modem->hangup()) { | 243 | if(Modem::modem->hangup()) { |
244 | 244 | ||
245 | qApp->processEvents(); | 245 | qApp->processEvents(); |
246 | 246 | ||
247 | semaphore = false; | 247 | semaphore = false; |
248 | 248 | ||
249 | Modem::modem->stop(); | 249 | Modem::modem->stop(); |
250 | Modem::modem->notify(this, SLOT(readChar(unsigned char))); | 250 | Modem::modem->notify(this, SLOT(readChar(unsigned char))); |
251 | 251 | ||
252 | // if we are stuck anywhere we will time out | 252 | // if we are stuck anywhere we will time out |
253 | timeout_timer->start(gpppdata.modemTimeout()*1000); | 253 | timeout_timer->start(PPPData::data()->modemTimeout()*1000); |
254 | 254 | ||
255 | // this timer will run the script etc. | 255 | // this timer will run the script etc. |
256 | main_timer_ID = startTimer(10); | 256 | main_timer_ID = startTimer(10); |
257 | 257 | ||
258 | return; | 258 | return; |
259 | } | 259 | } |
260 | } | 260 | } |
261 | 261 | ||
262 | // initialization failed | 262 | // initialization failed |
263 | messg->setText(Modem::modem->modemMessage()); | 263 | messg->setText(Modem::modem->modemMessage()); |
264 | vmain = 20; // wait until cancel is pressed | 264 | vmain = 20; // wait until cancel is pressed |
265 | Modem::modem->unlockdevice(); | 265 | Modem::modem->unlockdevice(); |
266 | } | 266 | } |
267 | 267 | ||
268 | 268 | ||
269 | void ConnectWidget::timerEvent(QTimerEvent *) { | 269 | void ConnectWidget::timerEvent(QTimerEvent *) { |
270 | if (semaphore || pausing) | 270 | if (semaphore || pausing) |
271 | return; | 271 | return; |
272 | 272 | ||
273 | if(vmain == 0) { | 273 | if(vmain == 0) { |
274 | #ifdef DEBUG_WO_DIALING | 274 | #ifdef DEBUG_WO_DIALING |
275 | vmain = 10; | 275 | vmain = 10; |
276 | return; | 276 | return; |
277 | #endif | 277 | #endif |
278 | 278 | ||
279 | assert(PPPData::NumInitStrings > 0); | 279 | assert(PPPData::NumInitStrings > 0); |
280 | // first init string ? | 280 | // first init string ? |
281 | if(substate == -1) { | 281 | if(substate == -1) { |
282 | messg->setText(i18n("Initializing modem...")); | 282 | messg->setText(i18n("Initializing modem...")); |
283 | emit debugMessage(i18n("Initializing modem...")); | 283 | emit debugMessage(i18n("Initializing modem...")); |
284 | substate = 0; | 284 | substate = 0; |
285 | } | 285 | } |
286 | 286 | ||
287 | QString initStr = gpppdata.modemInitStr(substate); | 287 | QString initStr = PPPData::data()->modemInitStr(substate); |
288 | if (!initStr.isEmpty()) { | 288 | if (!initStr.isEmpty()) { |
289 | // send a carriage return and then wait a bit so that the modem will | 289 | // send a carriage return and then wait a bit so that the modem will |
290 | // let us issue commands. | 290 | // let us issue commands. |
291 | if(gpppdata.modemPreInitDelay() > 0) { | 291 | if(PPPData::data()->modemPreInitDelay() > 0) { |
292 | usleep(gpppdata.modemPreInitDelay() * 5000); | 292 | usleep(PPPData::data()->modemPreInitDelay() * 5000); |
293 | writeline(""); | 293 | writeline(""); |
294 | usleep(gpppdata.modemPreInitDelay() * 5000); | 294 | usleep(PPPData::data()->modemPreInitDelay() * 5000); |
295 | } | 295 | } |
296 | setExpect(gpppdata.modemInitResp()); | 296 | setExpect(PPPData::data()->modemInitResp()); |
297 | writeline(initStr); | 297 | writeline(initStr); |
298 | usleep(gpppdata.modemInitDelay() * 10000); // 0.01 - 3.0 sec | 298 | usleep(PPPData::data()->modemInitDelay() * 10000); // 0.01 - 3.0 sec |
299 | } | 299 | } |
300 | 300 | ||
301 | substate++; | 301 | substate++; |
302 | 302 | ||
303 | /* | 303 | /* |
304 | * FIXME after 3.0: Make it possible to disable ATS11 since it | 304 | * FIXME after 3.0: Make it possible to disable ATS11 since it |
305 | * seems to be incompatible with some ISDN adapters (e.g. DataBox | 305 | * seems to be incompatible with some ISDN adapters (e.g. DataBox |
306 | * Speed Dragon). Even better would be to detect this when doing | 306 | * Speed Dragon). Even better would be to detect this when doing |
307 | * a "Modem Query" | 307 | * a "Modem Query" |
308 | */ | 308 | */ |
309 | if (MODEM_TONEDURATION != gpppdata.modemToneDuration()) | 309 | if (MODEM_TONEDURATION != PPPData::data()->modemToneDuration()) |
310 | vmain = 5; | 310 | vmain = 5; |
311 | else | 311 | else |
312 | vmain = 3; | 312 | vmain = 3; |
313 | 313 | ||
314 | return; | 314 | return; |
315 | } | 315 | } |
316 | 316 | ||
317 | if (vmain == 5) { | 317 | if (vmain == 5) { |
318 | if(!expecting) { | 318 | if(!expecting) { |
319 | QString sToneDuration = "ATS11=" + QString::number(gpppdata.modemToneDuration()); | 319 | QString sToneDuration = "ATS11=" + QString::number(PPPData::data()->modemToneDuration()); |
320 | QString msg = i18n("Setting ") + sToneDuration; | 320 | QString msg = i18n("Setting ") + sToneDuration; |
321 | messg->setText(msg); | 321 | messg->setText(msg); |
322 | emit debugMessage(msg); | 322 | emit debugMessage(msg); |
323 | setExpect(gpppdata.modemInitResp()); | 323 | setExpect(PPPData::data()->modemInitResp()); |
324 | writeline(sToneDuration); | 324 | writeline(sToneDuration); |
325 | } | 325 | } |
326 | vmain = 3; | 326 | vmain = 3; |
327 | return; | 327 | return; |
328 | } | 328 | } |
329 | 329 | ||
330 | if(vmain == 3) { | 330 | if(vmain == 3) { |
331 | if(!expecting) { | 331 | if(!expecting) { |
332 | // done with all init strings ? | 332 | // done with all init strings ? |
333 | if(substate < PPPData::NumInitStrings) { | 333 | if(substate < PPPData::NumInitStrings) { |
334 | vmain = 0; | 334 | vmain = 0; |
335 | return; | 335 | return; |
336 | } | 336 | } |
337 | substate = -1; | 337 | substate = -1; |
338 | // skip setting the volume if command is empty | 338 | // skip setting the volume if command is empty |
339 | if(gpppdata.volumeInitString().isEmpty()) { | 339 | if(PPPData::data()->volumeInitString().isEmpty()) { |
340 | vmain = 4; | 340 | vmain = 4; |
341 | return; | 341 | return; |
342 | } | 342 | } |
343 | messg->setText(i18n("Setting speaker volume...")); | 343 | messg->setText(i18n("Setting speaker volume...")); |
344 | emit debugMessage(i18n("Setting speaker volume...")); | 344 | emit debugMessage(i18n("Setting speaker volume...")); |
345 | 345 | ||
346 | setExpect(gpppdata.modemInitResp()); | 346 | setExpect(PPPData::data()->modemInitResp()); |
347 | QString vol("AT"); | 347 | QString vol("AT"); |
348 | vol += gpppdata.volumeInitString(); | 348 | vol += PPPData::data()->volumeInitString(); |
349 | writeline(vol); | 349 | writeline(vol); |
350 | usleep(gpppdata.modemInitDelay() * 10000); // 0.01 - 3.0 sec | 350 | usleep(PPPData::data()->modemInitDelay() * 10000); // 0.01 - 3.0 sec |
351 | vmain = 4; | 351 | vmain = 4; |
352 | return; | 352 | return; |
353 | } | 353 | } |
354 | } | 354 | } |
355 | 355 | ||
356 | if(vmain == 4) { | 356 | if(vmain == 4) { |
357 | if(!expecting) { | 357 | if(!expecting) { |
358 | if(!gpppdata.waitForDialTone()) { | 358 | if(!PPPData::data()->waitForDialTone()) { |
359 | QString msg = i18n("Turning off dial tone waiting..."); | 359 | QString msg = i18n("Turning off dial tone waiting..."); |
360 | messg->setText(msg); | 360 | messg->setText(msg); |
361 | emit debugMessage(msg); | 361 | emit debugMessage(msg); |
362 | setExpect(gpppdata.modemInitResp()); | 362 | setExpect(PPPData::data()->modemInitResp()); |
363 | writeline(gpppdata.modemNoDialToneDetectionStr()); | 363 | writeline(PPPData::data()->modemNoDialToneDetectionStr()); |
364 | } | 364 | } |
365 | vmain = 1; | 365 | vmain = 1; |
366 | return; | 366 | return; |
367 | } | 367 | } |
368 | } | 368 | } |
369 | 369 | ||
370 | // dial the number and wait to connect | 370 | // dial the number and wait to connect |
371 | if(vmain == 1) { | 371 | if(vmain == 1) { |
372 | if(!expecting) { | 372 | if(!expecting) { |
373 | 373 | ||
374 | timeout_timer->stop(); | 374 | timeout_timer->stop(); |
375 | timeout_timer->start(gpppdata.modemTimeout()*1000); | 375 | timeout_timer->start(PPPData::data()->modemTimeout()*1000); |
376 | 376 | ||
377 | QStringList &plist = gpppdata.phonenumbers(); | 377 | QStringList &plist = PPPData::data()->phonenumbers(); |
378 | QString bmarg= gpppdata.dialPrefix(); | 378 | QString bmarg= PPPData::data()->dialPrefix(); |
379 | bmarg += *plist.at(dialnumber); | 379 | bmarg += *plist.at(dialnumber); |
380 | QString bm = i18n("Dialing %1").arg(bmarg); | 380 | QString bm = i18n("Dialing %1").arg(bmarg); |
381 | messg->setText(bm); | 381 | messg->setText(bm); |
382 | emit debugMessage(bm); | 382 | emit debugMessage(bm); |
383 | 383 | ||
384 | QString pn = gpppdata.modemDialStr(); | 384 | QString pn = PPPData::data()->modemDialStr(); |
385 | pn += gpppdata.dialPrefix(); | 385 | pn += PPPData::data()->dialPrefix(); |
386 | pn += *plist.at(dialnumber); | 386 | pn += *plist.at(dialnumber); |
387 | if(++dialnumber >= plist.count()) | 387 | if(++dialnumber >= plist.count()) |
388 | dialnumber = 0; | 388 | dialnumber = 0; |
389 | writeline(pn); | 389 | writeline(pn); |
390 | 390 | ||
391 | setExpect(gpppdata.modemConnectResp()); | 391 | setExpect(PPPData::data()->modemConnectResp()); |
392 | vmain = 100; | 392 | vmain = 100; |
393 | return; | 393 | return; |
394 | } | 394 | } |
395 | } | 395 | } |
396 | 396 | ||
397 | // wait for connect, but redial if BUSY or wait for user cancel | 397 | // wait for connect, but redial if BUSY or wait for user cancel |
398 | // if NO CARRIER or NO DIALTONE | 398 | // if NO CARRIER or NO DIALTONE |
399 | if(vmain == 100) { | 399 | if(vmain == 100) { |
400 | if(!expecting) { | 400 | if(!expecting) { |
401 | myreadbuffer = gpppdata.modemConnectResp(); | 401 | myreadbuffer = PPPData::data()->modemConnectResp(); |
402 | setExpect("\n"); | 402 | setExpect("\n"); |
403 | vmain = 101; | 403 | vmain = 101; |
404 | return; | 404 | return; |
405 | } | 405 | } |
406 | 406 | ||
407 | if(readbuffer.contains(gpppdata.modemBusyResp())) { | 407 | if(readbuffer.contains(PPPData::data()->modemBusyResp())) { |
408 | timeout_timer->stop(); | 408 | timeout_timer->stop(); |
409 | timeout_timer->start(gpppdata.modemTimeout()*1000); | 409 | timeout_timer->start(PPPData::data()->modemTimeout()*1000); |
410 | 410 | ||
411 | messg->setText(i18n("Line busy. Hanging up...")); | 411 | messg->setText(i18n("Line busy. Hanging up...")); |
412 | emit debugPutChar('\n'); | 412 | emit debugPutChar('\n'); |
413 | Modem::modem->hangup(); | 413 | Modem::modem->hangup(); |
414 | 414 | ||
415 | if(gpppdata.busyWait() > 0) { | 415 | if(PPPData::data()->busyWait() > 0) { |
416 | QString bm = i18n("Line busy. Waiting: %1 seconds").arg(gpppdata.busyWait()); | 416 | QString bm = i18n("Line busy. Waiting: %1 seconds").arg(PPPData::data()->busyWait()); |
417 | messg->setText(bm); | 417 | messg->setText(bm); |
418 | emit debugMessage(bm); | 418 | emit debugMessage(bm); |
419 | 419 | ||
420 | pausing = true; | 420 | pausing = true; |
421 | 421 | ||
422 | pausetimer->start(gpppdata.busyWait()*1000, true); | 422 | pausetimer->start(PPPData::data()->busyWait()*1000, true); |
423 | timeout_timer->stop(); | 423 | timeout_timer->stop(); |
424 | } | 424 | } |
425 | 425 | ||
426 | Modem::modem->setDataMode(false); | 426 | Modem::modem->setDataMode(false); |
427 | vmain = 0; | 427 | vmain = 0; |
428 | substate = -1; | 428 | substate = -1; |
429 | return; | 429 | return; |
430 | } | 430 | } |
431 | 431 | ||
432 | if(readbuffer.contains(gpppdata.modemNoDialtoneResp())) { | 432 | if(readbuffer.contains(PPPData::data()->modemNoDialtoneResp())) { |
433 | timeout_timer->stop(); | 433 | timeout_timer->stop(); |
434 | 434 | ||
435 | messg->setText(i18n("No Dialtone")); | 435 | messg->setText(i18n("No Dialtone")); |
436 | vmain = 20; | 436 | vmain = 20; |
437 | Modem::modem->unlockdevice(); | 437 | Modem::modem->unlockdevice(); |
438 | return; | 438 | return; |
439 | } | 439 | } |
440 | 440 | ||
441 | if(readbuffer.contains(gpppdata.modemNoCarrierResp())) { | 441 | if(readbuffer.contains(PPPData::data()->modemNoCarrierResp())) { |
442 | timeout_timer->stop(); | 442 | timeout_timer->stop(); |
443 | 443 | ||
444 | messg->setText(i18n("No Carrier")); | 444 | messg->setText(i18n("No Carrier")); |
445 | vmain = 20; | 445 | vmain = 20; |
446 | Modem::modem->unlockdevice(); | 446 | Modem::modem->unlockdevice(); |
447 | return; | 447 | return; |
448 | } | 448 | } |
449 | } | 449 | } |
450 | 450 | ||
451 | // wait for newline after CONNECT response (so we get the speed) | 451 | // wait for newline after CONNECT response (so we get the speed) |
452 | if(vmain == 101) { | 452 | if(vmain == 101) { |
453 | if(!expecting) { | 453 | if(!expecting) { |
454 | Modem::modem->setDataMode(true); // modem will no longer respond to AT commands | 454 | Modem::modem->setDataMode(true); // modem will no longer respond to AT commands |
455 | 455 | ||
456 | emit startAccounting(); | 456 | emit startAccounting(); |
457 | // p_kppp->con_win->startClock(); | 457 | // p_kppp->con_win->startClock(); |
458 | 458 | ||
459 | vmain = 2; | 459 | vmain = 2; |
460 | scriptTimeout=gpppdata.modemTimeout()*1000; | 460 | scriptTimeout=PPPData::data()->modemTimeout()*1000; |
461 | return; | 461 | return; |
462 | } | 462 | } |
463 | } | 463 | } |
464 | 464 | ||
465 | // execute the script | 465 | // execute the script |
466 | if(vmain == 2) { | 466 | if(vmain == 2) { |
467 | if(!expecting && !pausing && !scanning) { | 467 | if(!expecting && !pausing && !scanning) { |
468 | 468 | ||
469 | timeout_timer->stop(); | 469 | timeout_timer->stop(); |
470 | timeout_timer->start(scriptTimeout); | 470 | timeout_timer->start(scriptTimeout); |
471 | 471 | ||
472 | if((unsigned) scriptindex < comlist->count()) { | 472 | if((unsigned) scriptindex < comlist->count()) { |
473 | scriptCommand = *(comlist->at(scriptindex)); | 473 | scriptCommand = *(comlist->at(scriptindex)); |
474 | scriptArgument = *(arglist->at(scriptindex)); | 474 | scriptArgument = *(arglist->at(scriptindex)); |
475 | } else { | 475 | } else { |
476 | qDebug( "End of script" ); | 476 | qDebug( "End of script" ); |
477 | vmain = 10; | 477 | vmain = 10; |
478 | return; | 478 | return; |
479 | } | 479 | } |
480 | 480 | ||
481 | if (scriptCommand == "Scan") { | 481 | if (scriptCommand == "Scan") { |
482 | QString bm = i18n("Scanning %1").arg(scriptArgument); | 482 | QString bm = i18n("Scanning %1").arg(scriptArgument); |
483 | messg->setText(bm); | 483 | messg->setText(bm); |
484 | emit debugMessage(bm); | 484 | emit debugMessage(bm); |
485 | 485 | ||
486 | setScan(scriptArgument); | 486 | setScan(scriptArgument); |
487 | scriptindex++; | 487 | scriptindex++; |
488 | return; | 488 | return; |
489 | } | 489 | } |
490 | 490 | ||
491 | if (scriptCommand == "Save") { | 491 | if (scriptCommand == "Save") { |
492 | QString bm = i18n("Saving %1").arg(scriptArgument); | 492 | QString bm = i18n("Saving %1").arg(scriptArgument); |
493 | messg->setText(bm); | 493 | messg->setText(bm); |
494 | emit debugMessage(bm); | 494 | emit debugMessage(bm); |
495 | 495 | ||
496 | if (scriptArgument.lower() == "password") { | 496 | if (scriptArgument.lower() == "password") { |
497 | gpppdata.setPassword(scanvar); | 497 | PPPData::data()->setPassword(scanvar); |
498 | p_kppp->setPW_Edit(scanvar); | 498 | p_kppp->setPW_Edit(scanvar); |
499 | if(gpppdata.storePassword()) | 499 | if(PPPData::data()->storePassword()) |
500 | gpppdata.setStoredPassword(scanvar); | 500 | PPPData::data()->setStoredPassword(scanvar); |
501 | firstrunPW = true; | 501 | firstrunPW = true; |
502 | } | 502 | } |
503 | 503 | ||
504 | scriptindex++; | 504 | scriptindex++; |
505 | return; | 505 | return; |
506 | } | 506 | } |
507 | 507 | ||
508 | 508 | ||
509 | if (scriptCommand == "Send" || scriptCommand == "SendNoEcho") { | 509 | if (scriptCommand == "Send" || scriptCommand == "SendNoEcho") { |
510 | QString bm = i18n("Sending %1"); | 510 | QString bm = i18n("Sending %1"); |
511 | 511 | ||
512 | // replace %USERNAME% and %PASSWORD% | 512 | // replace %USERNAME% and %PASSWORD% |
513 | QString arg = scriptArgument; | 513 | QString arg = scriptArgument; |
514 | QRegExp re1("%USERNAME%"); | 514 | QRegExp re1("%USERNAME%"); |
515 | QRegExp re2("%PASSWORD%"); | 515 | QRegExp re2("%PASSWORD%"); |
516 | arg = arg.replace(re1, gpppdata.storedUsername()); | 516 | arg = arg.replace(re1, PPPData::data()->storedUsername()); |
517 | arg = arg.replace(re2, gpppdata.storedPassword()); | 517 | arg = arg.replace(re2, PPPData::data()->storedPassword()); |
518 | 518 | ||
519 | if (scriptCommand == "Send") | 519 | if (scriptCommand == "Send") |
520 | bm = bm.arg(scriptArgument); | 520 | bm = bm.arg(scriptArgument); |
521 | else { | 521 | else { |
522 | for(uint i = 0; i < scriptArgument.length(); i++) | 522 | for(uint i = 0; i < scriptArgument.length(); i++) |
523 | bm = bm.arg("*"); | 523 | bm = bm.arg("*"); |
524 | } | 524 | } |
525 | 525 | ||
526 | messg->setText(bm); | 526 | messg->setText(bm); |
527 | emit debugMessage(bm); | 527 | emit debugMessage(bm); |
528 | 528 | ||
529 | writeline(scriptArgument); | 529 | writeline(scriptArgument); |
530 | scriptindex++; | 530 | scriptindex++; |
531 | return; | 531 | return; |
532 | } | 532 | } |
533 | 533 | ||
534 | if (scriptCommand == "Expect") { | 534 | if (scriptCommand == "Expect") { |
535 | QString bm = i18n("Expecting %1").arg(scriptArgument); | 535 | QString bm = i18n("Expecting %1").arg(scriptArgument); |
536 | messg->setText(bm); | 536 | messg->setText(bm); |
537 | emit debugMessage(bm); | 537 | emit debugMessage(bm); |
538 | 538 | ||
539 | // The incrementing of the scriptindex MUST be before the | 539 | // The incrementing of the scriptindex MUST be before the |
540 | // call to setExpect otherwise the expect will miss a string that is | 540 | // call to setExpect otherwise the expect will miss a string that is |
541 | // already in the buffer. | 541 | // already in the buffer. |
542 | scriptindex++; | 542 | scriptindex++; |
543 | setExpect(scriptArgument); | 543 | setExpect(scriptArgument); |
544 | return; | 544 | return; |
545 | } | 545 | } |
546 | 546 | ||
547 | 547 | ||
548 | if (scriptCommand == "Pause") { | 548 | if (scriptCommand == "Pause") { |
549 | QString bm = i18n("Pause %1 seconds").arg(scriptArgument); | 549 | QString bm = i18n("Pause %1 seconds").arg(scriptArgument); |
550 | messg->setText(bm); | 550 | messg->setText(bm); |
551 | emit debugMessage(bm); | 551 | emit debugMessage(bm); |
552 | 552 | ||
553 | pausing = true; | 553 | pausing = true; |
554 | 554 | ||
555 | pausetimer->start(scriptArgument.toInt()*1000, true); | 555 | pausetimer->start(scriptArgument.toInt()*1000, true); |
556 | timeout_timer->stop(); | 556 | timeout_timer->stop(); |
557 | 557 | ||
558 | scriptindex++; | 558 | scriptindex++; |
559 | return; | 559 | return; |
560 | } | 560 | } |
561 | 561 | ||
562 | if (scriptCommand == "Timeout") { | 562 | if (scriptCommand == "Timeout") { |
563 | 563 | ||
564 | timeout_timer->stop(); | 564 | timeout_timer->stop(); |
565 | 565 | ||
566 | QString bm = i18n("Timeout %1 seconds").arg(scriptArgument); | 566 | QString bm = i18n("Timeout %1 seconds").arg(scriptArgument); |
567 | messg->setText(bm); | 567 | messg->setText(bm); |
568 | emit debugMessage(bm); | 568 | emit debugMessage(bm); |
569 | 569 | ||
570 | scriptTimeout=scriptArgument.toInt()*1000; | 570 | scriptTimeout=scriptArgument.toInt()*1000; |
571 | timeout_timer->start(scriptTimeout); | 571 | timeout_timer->start(scriptTimeout); |
572 | 572 | ||
573 | scriptindex++; | 573 | scriptindex++; |
574 | return; | 574 | return; |
575 | } | 575 | } |
576 | 576 | ||
577 | if (scriptCommand == "Hangup") { | 577 | if (scriptCommand == "Hangup") { |
578 | messg->setText(i18n("Hangup")); | 578 | messg->setText(i18n("Hangup")); |
579 | emit debugMessage(i18n("Hangup")); | 579 | emit debugMessage(i18n("Hangup")); |
580 | 580 | ||
581 | writeline(gpppdata.modemHangupStr()); | 581 | writeline(PPPData::data()->modemHangupStr()); |
582 | setExpect(gpppdata.modemHangupResp()); | 582 | setExpect(PPPData::data()->modemHangupResp()); |
583 | 583 | ||
584 | scriptindex++; | 584 | scriptindex++; |
585 | return; | 585 | return; |
586 | } | 586 | } |
587 | 587 | ||
588 | if (scriptCommand == "Answer") { | 588 | if (scriptCommand == "Answer") { |
589 | 589 | ||
590 | timeout_timer->stop(); | 590 | timeout_timer->stop(); |
591 | 591 | ||
592 | messg->setText(i18n("Answer")); | 592 | messg->setText(i18n("Answer")); |
593 | emit debugMessage(i18n("Answer")); | 593 | emit debugMessage(i18n("Answer")); |
594 | 594 | ||
595 | setExpect(gpppdata.modemRingResp()); | 595 | setExpect(PPPData::data()->modemRingResp()); |
596 | vmain = 150; | 596 | vmain = 150; |
597 | return; | 597 | return; |
598 | } | 598 | } |
599 | 599 | ||
600 | if (scriptCommand == "ID") { | 600 | if (scriptCommand == "ID") { |
601 | QString bm = i18n("ID %1").arg(scriptArgument); | 601 | QString bm = i18n("ID %1").arg(scriptArgument); |
602 | messg->setText(bm); | 602 | messg->setText(bm); |
603 | emit debugMessage(bm); | 603 | emit debugMessage(bm); |
604 | 604 | ||
605 | QString idstring = gpppdata.storedUsername(); | 605 | QString idstring = PPPData::data()->storedUsername(); |
606 | 606 | ||
607 | if(!idstring.isEmpty() && firstrunID) { | 607 | if(!idstring.isEmpty() && firstrunID) { |
608 | // the user entered an Id on the main kppp dialog | 608 | // the user entered an Id on the main kppp dialog |
609 | writeline(idstring); | 609 | writeline(idstring); |
610 | firstrunID = false; | 610 | firstrunID = false; |
611 | scriptindex++; | 611 | scriptindex++; |
612 | } | 612 | } |
613 | else { | 613 | else { |
614 | // the user didn't enter and Id on the main kppp dialog | 614 | // the user didn't enter and Id on the main kppp dialog |
615 | // let's query for an ID | 615 | // let's query for an ID |
616 | /* if not around yet, then post window... */ | 616 | /* if not around yet, then post window... */ |
617 | if (prompt->Consumed()) { | 617 | if (prompt->Consumed()) { |
618 | if (!(prompt->isVisible())) { | 618 | if (!(prompt->isVisible())) { |
619 | prompt->setPrompt(scriptArgument); | 619 | prompt->setPrompt(scriptArgument); |
620 | prompt->setEchoModeNormal(); | 620 | prompt->setEchoModeNormal(); |
621 | prompt->show(); | 621 | prompt->show(); |
622 | } | 622 | } |
623 | } else { | 623 | } else { |
624 | /* if prompt withdrawn ... then, */ | 624 | /* if prompt withdrawn ... then, */ |
625 | if(!(prompt->isVisible())) { | 625 | if(!(prompt->isVisible())) { |
626 | writeline(prompt->text()); | 626 | writeline(prompt->text()); |
627 | prompt->setConsumed(); | 627 | prompt->setConsumed(); |
628 | scriptindex++; | 628 | scriptindex++; |
629 | return; | 629 | return; |
630 | } | 630 | } |
631 | /* replace timeout value */ | 631 | /* replace timeout value */ |
632 | } | 632 | } |
633 | } | 633 | } |
634 | } | 634 | } |
635 | 635 | ||
636 | if (scriptCommand == "Password") { | 636 | if (scriptCommand == "Password") { |
637 | QString bm = i18n("Password %1").arg(scriptArgument); | 637 | QString bm = i18n("Password %1").arg(scriptArgument); |
638 | messg->setText(bm); | 638 | messg->setText(bm); |
639 | emit debugMessage(bm); | 639 | emit debugMessage(bm); |
640 | 640 | ||
641 | QString pwstring = gpppdata.password(); | 641 | QString pwstring = PPPData::data()->password(); |
642 | 642 | ||
643 | if(!pwstring.isEmpty() && firstrunPW) { | 643 | if(!pwstring.isEmpty() && firstrunPW) { |
644 | // the user entered a password on the main kppp dialog | 644 | // the user entered a password on the main kppp dialog |
645 | writeline(pwstring); | 645 | writeline(pwstring); |
646 | firstrunPW = false; | 646 | firstrunPW = false; |
647 | scriptindex++; | 647 | scriptindex++; |
648 | } | 648 | } |
649 | else { | 649 | else { |
650 | // the user didn't enter a password on the main kppp dialog | 650 | // the user didn't enter a password on the main kppp dialog |
651 | // let's query for a password | 651 | // let's query for a password |
652 | /* if not around yet, then post window... */ | 652 | /* if not around yet, then post window... */ |
653 | if (prompt->Consumed()) { | 653 | if (prompt->Consumed()) { |
654 | if (!(prompt->isVisible())) { | 654 | if (!(prompt->isVisible())) { |
655 | prompt->setPrompt(scriptArgument); | 655 | prompt->setPrompt(scriptArgument); |
656 | prompt->setEchoModePassword(); | 656 | prompt->setEchoModePassword(); |
657 | prompt->show(); | 657 | prompt->show(); |
658 | } | 658 | } |
659 | } else { | 659 | } else { |
660 | /* if prompt withdrawn ... then, */ | 660 | /* if prompt withdrawn ... then, */ |
661 | if(!(prompt->isVisible())) { | 661 | if(!(prompt->isVisible())) { |
662 | p_kppp->setPW_Edit(prompt->text()); | 662 | p_kppp->setPW_Edit(prompt->text()); |
663 | writeline(prompt->text()); | 663 | writeline(prompt->text()); |
664 | prompt->setConsumed(); | 664 | prompt->setConsumed(); |
665 | scriptindex++; | 665 | scriptindex++; |
666 | return; | 666 | return; |
667 | } | 667 | } |
668 | /* replace timeout value */ | 668 | /* replace timeout value */ |
669 | } | 669 | } |
670 | } | 670 | } |
671 | } | 671 | } |
672 | 672 | ||
673 | if (scriptCommand == "Prompt") { | 673 | if (scriptCommand == "Prompt") { |
674 | QString bm = i18n("Prompting %1"); | 674 | QString bm = i18n("Prompting %1"); |
675 | 675 | ||
676 | // if the scriptindex (aka the prompt text) includes a ## marker | 676 | // if the scriptindex (aka the prompt text) includes a ## marker |
677 | // this marker should get substituted with the contents of our stored | 677 | // this marker should get substituted with the contents of our stored |
678 | // variable (from the subsequent scan). | 678 | // variable (from the subsequent scan). |
679 | 679 | ||
680 | QString ts = scriptArgument; | 680 | QString ts = scriptArgument; |
681 | int vstart = ts.find( "##" ); | 681 | int vstart = ts.find( "##" ); |
682 | if( vstart != -1 ) { | 682 | if( vstart != -1 ) { |
683 | ts.remove( vstart, 2 ); | 683 | ts.remove( vstart, 2 ); |
684 | ts.insert( vstart, scanvar ); | 684 | ts.insert( vstart, scanvar ); |
685 | } | 685 | } |
686 | 686 | ||
687 | bm = bm.arg(ts); | 687 | bm = bm.arg(ts); |
688 | messg->setText(bm); | 688 | messg->setText(bm); |
689 | emit debugMessage(bm); | 689 | emit debugMessage(bm); |
690 | 690 | ||
691 | /* if not around yet, then post window... */ | 691 | /* if not around yet, then post window... */ |
692 | if (prompt->Consumed()) { | 692 | if (prompt->Consumed()) { |
693 | if (!(prompt->isVisible())) { | 693 | if (!(prompt->isVisible())) { |
694 | prompt->setPrompt( ts ); | 694 | prompt->setPrompt( ts ); |
695 | prompt->setEchoModeNormal(); | 695 | prompt->setEchoModeNormal(); |
696 | prompt->show(); | 696 | prompt->show(); |
697 | } | 697 | } |
698 | } else { | 698 | } else { |
699 | /* if prompt withdrawn ... then, */ | 699 | /* if prompt withdrawn ... then, */ |
700 | if (!(prompt->isVisible())) { | 700 | if (!(prompt->isVisible())) { |
701 | writeline(prompt->text()); | 701 | writeline(prompt->text()); |
702 | prompt->setConsumed(); | 702 | prompt->setConsumed(); |
703 | scriptindex++; | 703 | scriptindex++; |
704 | return; | 704 | return; |
705 | } | 705 | } |
706 | /* replace timeout value */ | 706 | /* replace timeout value */ |
707 | } | 707 | } |
708 | } | 708 | } |
709 | 709 | ||
710 | if (scriptCommand == "PWPrompt") { | 710 | if (scriptCommand == "PWPrompt") { |
711 | QString bm = i18n("PW Prompt %1").arg(scriptArgument); | 711 | QString bm = i18n("PW Prompt %1").arg(scriptArgument); |
712 | messg->setText(bm); | 712 | messg->setText(bm); |
713 | emit debugMessage(bm); | 713 | emit debugMessage(bm); |
714 | 714 | ||
715 | /* if not around yet, then post window... */ | 715 | /* if not around yet, then post window... */ |
716 | if (prompt->Consumed()) { | 716 | if (prompt->Consumed()) { |
717 | if (!(prompt->isVisible())) { | 717 | if (!(prompt->isVisible())) { |
718 | prompt->setPrompt(scriptArgument); | 718 | prompt->setPrompt(scriptArgument); |
719 | prompt->setEchoModePassword(); | 719 | prompt->setEchoModePassword(); |
720 | prompt->show(); | 720 | prompt->show(); |
721 | } | 721 | } |
722 | } else { | 722 | } else { |
723 | /* if prompt withdrawn ... then, */ | 723 | /* if prompt withdrawn ... then, */ |
724 | if (!(prompt->isVisible())) { | 724 | if (!(prompt->isVisible())) { |
725 | writeline(prompt->text()); | 725 | writeline(prompt->text()); |
726 | prompt->setConsumed(); | 726 | prompt->setConsumed(); |
727 | scriptindex++; | 727 | scriptindex++; |
728 | return; | 728 | return; |
729 | } | 729 | } |
730 | /* replace timeout value */ | 730 | /* replace timeout value */ |
731 | } | 731 | } |
732 | } | 732 | } |
733 | 733 | ||
734 | if (scriptCommand == "LoopStart") { | 734 | if (scriptCommand == "LoopStart") { |
735 | 735 | ||
736 | QString bm = i18n("Loop Start %1").arg(scriptArgument); | 736 | QString bm = i18n("Loop Start %1").arg(scriptArgument); |
737 | 737 | ||
738 | // The incrementing of the scriptindex MUST be before the | 738 | // The incrementing of the scriptindex MUST be before the |
739 | // call to setExpect otherwise the expect will miss a string that is | 739 | // call to setExpect otherwise the expect will miss a string that is |
740 | // already in the buffer. | 740 | // already in the buffer. |
741 | scriptindex++; | 741 | scriptindex++; |
742 | 742 | ||
743 | if ( loopnest > (MAXLOOPNEST-2) ) { | 743 | if ( loopnest > (MAXLOOPNEST-2) ) { |
744 | bm += i18n("ERROR: Nested too deep, ignored."); | 744 | bm += i18n("ERROR: Nested too deep, ignored."); |
745 | vmain=20; | 745 | vmain=20; |
746 | cancelbutton(); | 746 | cancelbutton(); |
747 | QMessageBox::critical(0, "error", i18n("Loops nested too deeply!")); | 747 | QMessageBox::critical(0, "error", i18n("Loops nested too deeply!")); |
748 | } else { | 748 | } else { |
749 | setExpect(scriptArgument); | 749 | setExpect(scriptArgument); |
750 | loopstartindex[loopnest] = scriptindex; | 750 | loopstartindex[loopnest] = scriptindex; |
751 | loopstr[loopnest] = scriptArgument; | 751 | loopstr[loopnest] = scriptArgument; |
752 | loopend = false; | 752 | loopend = false; |
753 | loopnest++; | 753 | loopnest++; |
754 | } | 754 | } |
755 | messg->setText(bm); | 755 | messg->setText(bm); |
756 | emit debugMessage(bm); | 756 | emit debugMessage(bm); |
757 | 757 | ||
758 | } | 758 | } |
759 | 759 | ||
760 | if (scriptCommand == "LoopEnd") { | 760 | if (scriptCommand == "LoopEnd") { |
761 | QString bm = i18n("Loop End %1").arg(scriptArgument); | 761 | QString bm = i18n("Loop End %1").arg(scriptArgument); |
762 | if ( loopnest <= 0 ) { | 762 | if ( loopnest <= 0 ) { |
763 | bm = i18n("LoopEnd without matching Start! Line: %1").arg(bm); | 763 | bm = i18n("LoopEnd without matching Start! Line: %1").arg(bm); |
764 | vmain=20; | 764 | vmain=20; |
765 | cancelbutton(); | 765 | cancelbutton(); |
766 | QMessageBox::critical(0, "error", bm); | 766 | QMessageBox::critical(0, "error", bm); |
767 | return; | 767 | return; |
768 | } else { | 768 | } else { |
769 | // NB! The incrementing of the scriptindex MUST be before the | 769 | // NB! The incrementing of the scriptindex MUST be before the |
770 | // call to setExpect otherwise the expect will miss a string | 770 | // call to setExpect otherwise the expect will miss a string |
771 | // that is already in the buffer. | 771 | // that is already in the buffer. |
772 | scriptindex++; | 772 | scriptindex++; |
773 | setExpect(scriptArgument); | 773 | setExpect(scriptArgument); |
774 | loopnest--; | 774 | loopnest--; |
775 | loopend = true; | 775 | loopend = true; |
776 | } | 776 | } |
777 | messg->setText(bm); | 777 | messg->setText(bm); |
778 | emit debugMessage(bm); | 778 | emit debugMessage(bm); |
779 | 779 | ||
780 | } | 780 | } |
781 | } | 781 | } |
782 | } | 782 | } |
783 | 783 | ||
784 | // this is a subroutine for the "Answer" script option | 784 | // this is a subroutine for the "Answer" script option |
785 | 785 | ||
786 | if(vmain == 150) { | 786 | if(vmain == 150) { |
787 | if(!expecting) { | 787 | if(!expecting) { |
788 | writeline(gpppdata.modemAnswerStr()); | 788 | writeline(PPPData::data()->modemAnswerStr()); |
789 | setExpect(gpppdata.modemAnswerResp()); | 789 | setExpect(PPPData::data()->modemAnswerResp()); |
790 | 790 | ||
791 | vmain = 2; | 791 | vmain = 2; |
792 | scriptindex++; | 792 | scriptindex++; |
793 | return; | 793 | return; |
794 | } | 794 | } |
795 | } | 795 | } |
796 | 796 | ||
797 | if(vmain == 30) { | 797 | if(vmain == 30) { |
798 | // if (termwindow->isVisible()) | 798 | // if (termwindow->isVisible()) |
799 | // return; | 799 | // return; |
800 | // if (termwindow->pressedContinue()) | 800 | // if (termwindow->pressedContinue()) |
801 | // vmain = 10; | 801 | // vmain = 10; |
802 | // else | 802 | // else |
803 | cancelbutton(); | 803 | cancelbutton(); |
804 | } | 804 | } |
805 | 805 | ||
806 | if(vmain == 10) { | 806 | if(vmain == 10) { |
807 | if(!expecting) { | 807 | if(!expecting) { |
808 | 808 | ||
809 | int result; | 809 | int result; |
810 | 810 | ||
811 | timeout_timer->stop(); | 811 | timeout_timer->stop(); |
812 | if_timeout_timer->stop(); // better be sure. | 812 | if_timeout_timer->stop(); // better be sure. |
813 | 813 | ||
814 | // stop reading of data | 814 | // stop reading of data |
815 | Modem::modem->stop(); | 815 | Modem::modem->stop(); |
816 | 816 | ||
817 | if(gpppdata.authMethod() == AUTH_TERMINAL) { | 817 | if(PPPData::data()->authMethod() == AUTH_TERMINAL) { |
818 | // if (termwindow) { | 818 | // if (termwindow) { |
819 | // delete termwindow; | 819 | // delete termwindow; |
820 | // termwindow = 0L; | 820 | // termwindow = 0L; |
821 | // this->show(); | 821 | // this->show(); |
822 | // } else { | 822 | // } else { |
823 | // termwindow = new LoginTerm(0L, 0L); | 823 | // termwindow = new LoginTerm(0L, 0L); |
824 | // hide(); | 824 | // hide(); |
825 | // termwindow->show(); | 825 | // termwindow->show(); |
826 | // vmain = 30; | 826 | // vmain = 30; |
827 | // return; | 827 | // return; |
828 | // } | 828 | // } |
829 | } | 829 | } |
830 | 830 | ||
831 | // Close the tty. This prevents the QTimer::singleShot() in | 831 | // Close the tty. This prevents the QTimer::singleShot() in |
832 | // Modem::readtty() from re-enabling the socket notifier. | 832 | // Modem::readtty() from re-enabling the socket notifier. |
833 | // The port is still held open by the helper process. | 833 | // The port is still held open by the helper process. |
834 | Modem::modem->closetty(); | 834 | Modem::modem->closetty(); |
835 | 835 | ||
836 | killTimer( main_timer_ID ); | 836 | killTimer( main_timer_ID ); |
837 | 837 | ||
838 | if_timeout_timer->start(gpppdata.pppdTimeout()*1000); | 838 | if_timeout_timer->start(PPPData::data()->pppdTimeout()*1000); |
839 | qDebug( "started if timeout timer with %i", gpppdata.pppdTimeout()*1000); | 839 | qDebug( "started if timeout timer with %i", PPPData::data()->pppdTimeout()*1000); |
840 | 840 | ||
841 | // find out PPP interface and notify the stats module | 841 | // find out PPP interface and notify the stats module |
842 | // stats->setUnit(pppInterfaceNumber()); | 842 | // stats->setUnit(pppInterfaceNumber()); |
843 | 843 | ||
844 | qApp->flushX(); | 844 | qApp->flushX(); |
845 | semaphore = true; | 845 | semaphore = true; |
846 | result = execppp(); | 846 | result = execppp(); |
847 | 847 | ||
848 | emit debugMessage(i18n("Starting pppd...")); | 848 | emit debugMessage(i18n("Starting pppd...")); |
849 | qDebug("execppp() returned with return-code %i", result ); | 849 | qDebug("execppp() returned with return-code %i", result ); |
850 | 850 | ||
851 | if(result) { | 851 | if(result) { |
852 | if(!gpppdata.autoDNS()) | 852 | if(!PPPData::data()->autoDNS()) |
853 | adddns(); | 853 | adddns(); |
854 | 854 | ||
855 | // O.K we are done here, let's change over to the if_waiting loop | 855 | // O.K we are done here, let's change over to the if_waiting loop |
856 | // where we wait for the ppp if (interface) to come up. | 856 | // where we wait for the ppp if (interface) to come up. |
857 | 857 | ||
858 | emit if_waiting_signal(); | 858 | emit if_waiting_signal(); |
859 | } else { | 859 | } else { |
860 | 860 | ||
861 | // starting pppd wasn't successful. Error messages were | 861 | // starting pppd wasn't successful. Error messages were |
862 | // handled by execppp(); | 862 | // handled by execppp(); |
863 | if_timeout_timer->stop(); | 863 | if_timeout_timer->stop(); |
864 | this->hide(); | 864 | this->hide(); |
865 | messg->setText(""); | 865 | messg->setText(""); |
866 | p_kppp->quit_b->setFocus(); | 866 | p_kppp->quit_b->setFocus(); |
867 | p_kppp->show(); | 867 | p_kppp->show(); |
868 | qApp->processEvents(); | 868 | qApp->processEvents(); |
869 | Modem::modem->hangup(); | 869 | Modem::modem->hangup(); |
870 | emit stopAccounting(); | 870 | emit stopAccounting(); |
871 | //p_kppp->con_win->stopClock(); | 871 | //p_kppp->con_win->stopClock(); |
872 | Modem::modem->closetty(); | 872 | Modem::modem->closetty(); |
873 | Modem::modem->unlockdevice(); | 873 | Modem::modem->unlockdevice(); |
874 | 874 | ||
875 | } | 875 | } |
876 | 876 | ||
877 | return; | 877 | return; |
878 | } | 878 | } |
879 | } | 879 | } |
880 | 880 | ||
881 | // this is a "wait until cancel" entry | 881 | // this is a "wait until cancel" entry |
882 | 882 | ||
883 | if(vmain == 20) { | 883 | if(vmain == 20) { |
884 | } | 884 | } |
885 | } | 885 | } |
886 | 886 | ||
887 | 887 | ||
888 | void ConnectWidget::set_con_speed_string() { | 888 | void ConnectWidget::set_con_speed_string() { |
889 | // Here we are trying to determine the speed at which we are connected. | 889 | // Here we are trying to determine the speed at which we are connected. |
890 | // Usually the modem responds after connect with something like | 890 | // Usually the modem responds after connect with something like |
891 | // CONNECT 115200, so all we need to do is find the number after CONNECT | 891 | // CONNECT 115200, so all we need to do is find the number after CONNECT |
892 | // or whatever the modemConnectResp() is. | 892 | // or whatever the modemConnectResp() is. |
893 | p_kppp->con_speed = Modem::modem->parseModemSpeed(myreadbuffer); | 893 | p_kppp->con_speed = Modem::modem->parseModemSpeed(myreadbuffer); |
894 | } | 894 | } |
895 | 895 | ||
896 | 896 | ||
897 | 897 | ||
898 | void ConnectWidget::readChar(unsigned char c) { | 898 | void ConnectWidget::readChar(unsigned char c) { |
899 | if(semaphore) | 899 | if(semaphore) |
900 | return; | 900 | return; |
901 | 901 | ||
902 | readbuffer += c; | 902 | readbuffer += c; |
903 | myreadbuffer += c; | 903 | myreadbuffer += c; |
904 | 904 | ||
905 | // While in scanning mode store each char to the scan buffer | 905 | // While in scanning mode store each char to the scan buffer |
906 | // for use in the prompt command | 906 | // for use in the prompt command |
907 | if( scanning ) | 907 | if( scanning ) |
908 | scanbuffer += c; | 908 | scanbuffer += c; |
909 | 909 | ||
910 | // add to debug window | 910 | // add to debug window |
911 | emit debugPutChar(c); | 911 | emit debugPutChar(c); |
912 | 912 | ||
913 | checkBuffers(); | 913 | checkBuffers(); |
914 | } | 914 | } |
915 | 915 | ||
916 | 916 | ||
917 | void ConnectWidget::checkBuffers() { | 917 | void ConnectWidget::checkBuffers() { |
918 | // Let's check if we are finished with scanning: | 918 | // Let's check if we are finished with scanning: |
919 | // The scanstring have to be in the buffer and the latest character | 919 | // The scanstring have to be in the buffer and the latest character |
920 | // was a carriage return or an linefeed (depending on modem setup) | 920 | // was a carriage return or an linefeed (depending on modem setup) |
921 | if( scanning && scanbuffer.contains(scanstr) && | 921 | if( scanning && scanbuffer.contains(scanstr) && |
922 | ( scanbuffer.right(1) == "\n" || scanbuffer.right(1) == "\r") ) { | 922 | ( scanbuffer.right(1) == "\n" || scanbuffer.right(1) == "\r") ) { |
923 | scanning = false; | 923 | scanning = false; |
924 | 924 | ||
925 | int vstart = scanbuffer.find( scanstr ) + scanstr.length(); | 925 | int vstart = scanbuffer.find( scanstr ) + scanstr.length(); |
926 | scanvar = scanbuffer.mid( vstart, scanbuffer.length() - vstart); | 926 | scanvar = scanbuffer.mid( vstart, scanbuffer.length() - vstart); |
927 | scanvar = scanvar.stripWhiteSpace(); | 927 | scanvar = scanvar.stripWhiteSpace(); |
928 | 928 | ||
929 | // Show the Variabel content in the debug window | 929 | // Show the Variabel content in the debug window |
930 | QString sv = i18n("Scan Var: %1").arg(scanvar); | 930 | QString sv = i18n("Scan Var: %1").arg(scanvar); |
931 | emit debugMessage(sv); | 931 | emit debugMessage(sv); |
932 | } | 932 | } |
933 | 933 | ||
934 | if(expecting) { | 934 | if(expecting) { |
935 | if(readbuffer.contains(expectstr)) { | 935 | if(readbuffer.contains(expectstr)) { |
936 | expecting = false; | 936 | expecting = false; |
937 | // keep everything after the expected string | 937 | // keep everything after the expected string |
938 | readbuffer.remove(0, readbuffer.find(expectstr) + expectstr.length()); | 938 | readbuffer.remove(0, readbuffer.find(expectstr) + expectstr.length()); |
939 | 939 | ||
940 | QString ts = i18n("Found: %1").arg(expectstr); | 940 | QString ts = i18n("Found: %1").arg(expectstr); |
941 | emit debugMessage(ts); | 941 | emit debugMessage(ts); |
942 | 942 | ||
943 | if (loopend) { | 943 | if (loopend) { |
944 | loopend=false; | 944 | loopend=false; |
945 | } | 945 | } |
946 | } | 946 | } |
947 | 947 | ||
948 | if (loopend && readbuffer.contains(loopstr[loopnest])) { | 948 | if (loopend && readbuffer.contains(loopstr[loopnest])) { |
949 | expecting = false; | 949 | expecting = false; |
950 | readbuffer = ""; | 950 | readbuffer = ""; |
951 | QString ts = i18n("Looping: %1").arg(loopstr[loopnest]); | 951 | QString ts = i18n("Looping: %1").arg(loopstr[loopnest]); |
952 | emit debugMessage(ts); | 952 | emit debugMessage(ts); |
953 | scriptindex = loopstartindex[loopnest]; | 953 | scriptindex = loopstartindex[loopnest]; |
954 | loopend = false; | 954 | loopend = false; |
955 | loopnest++; | 955 | loopnest++; |
956 | } | 956 | } |
957 | // notify event loop if expected string was found | 957 | // notify event loop if expected string was found |
958 | if(!expecting) | 958 | if(!expecting) |
959 | timerEvent((QTimerEvent *) 0); | 959 | timerEvent((QTimerEvent *) 0); |
960 | } | 960 | } |
961 | } | 961 | } |
962 | 962 | ||
963 | 963 | ||
964 | 964 | ||
965 | void ConnectWidget::pause() { | 965 | void ConnectWidget::pause() { |
966 | pausing = false; | 966 | pausing = false; |
967 | pausetimer->stop(); | 967 | pausetimer->stop(); |
968 | } | 968 | } |
969 | 969 | ||
970 | 970 | ||
971 | void ConnectWidget::cancelbutton() { | 971 | void ConnectWidget::cancelbutton() { |
972 | Modem::modem->stop(); | 972 | Modem::modem->stop(); |
973 | killTimer(main_timer_ID); | 973 | killTimer(main_timer_ID); |
974 | timeout_timer->stop(); | 974 | timeout_timer->stop(); |
975 | if_timer->stop(); | 975 | if_timer->stop(); |
976 | if_timeout_timer->stop(); | 976 | if_timeout_timer->stop(); |
977 | 977 | ||
978 | // if (termwindow) { | 978 | // if (termwindow) { |
979 | // delete termwindow; | 979 | // delete termwindow; |
980 | // termwindow = 0L; | 980 | // termwindow = 0L; |
981 | // this->show(); | 981 | // this->show(); |
982 | // } | 982 | // } |
983 | 983 | ||
984 | messg->setText(i18n("One moment please...")); | 984 | messg->setText(i18n("One moment please...")); |
985 | 985 | ||
986 | // just to be sure | 986 | // just to be sure |
987 | Modem::modem->removeSecret(AUTH_PAP); | 987 | Modem::modem->removeSecret(AUTH_PAP); |
988 | Modem::modem->removeSecret(AUTH_CHAP); | 988 | Modem::modem->removeSecret(AUTH_CHAP); |
989 | removedns(); | 989 | removedns(); |
990 | 990 | ||
991 | qApp->processEvents(); | 991 | qApp->processEvents(); |
992 | 992 | ||
993 | Modem::modem->killPPPDaemon(); | 993 | Modem::modem->killPPPDaemon(); |
994 | Modem::modem->hangup(); | 994 | Modem::modem->hangup(); |
995 | 995 | ||
996 | this->hide(); | 996 | this->hide(); |
997 | messg->setText(""); | 997 | messg->setText(""); |
998 | p_kppp->quit_b->setFocus(); | 998 | p_kppp->quit_b->setFocus(); |
999 | p_kppp->show(); | 999 | p_kppp->show(); |
1000 | emit stopAccounting();// just to be sure | 1000 | emit stopAccounting();// just to be sure |
1001 | // p_kppp->con_win->stopClock(); | 1001 | // p_kppp->con_win->stopClock(); |
1002 | Modem::modem->closetty(); | 1002 | Modem::modem->closetty(); |
1003 | Modem::modem->unlockdevice(); | 1003 | Modem::modem->unlockdevice(); |
1004 | 1004 | ||
1005 | //abort prompt window... | 1005 | //abort prompt window... |
1006 | if (prompt->isVisible()) { | 1006 | if (prompt->isVisible()) { |
1007 | prompt->hide(); | 1007 | prompt->hide(); |
1008 | } | 1008 | } |
1009 | prompt->setConsumed(); | 1009 | prompt->setConsumed(); |
1010 | 1010 | ||
1011 | // if(p_kppp->quitOnDisconnect()) | 1011 | // if(p_kppp->quitOnDisconnect()) |
1012 | // qApp->exit(0); | 1012 | // qApp->exit(0); |
1013 | } | 1013 | } |
1014 | 1014 | ||
1015 | 1015 | ||
1016 | void ConnectWidget::script_timed_out() { | 1016 | void ConnectWidget::script_timed_out() { |
1017 | if(vmain == 20) { // we are in the 'wait for the user to cancel' state | 1017 | if(vmain == 20) { // we are in the 'wait for the user to cancel' state |
1018 | timeout_timer->stop(); | 1018 | timeout_timer->stop(); |
1019 | emit stopAccounting(); | 1019 | emit stopAccounting(); |
1020 | // p_kppp->con_win->stopClock(); | 1020 | // p_kppp->con_win->stopClock(); |
1021 | return; | 1021 | return; |
1022 | } | 1022 | } |
1023 | 1023 | ||
1024 | if (prompt->isVisible()) | 1024 | if (prompt->isVisible()) |
1025 | prompt->hide(); | 1025 | prompt->hide(); |
1026 | 1026 | ||
1027 | prompt->setConsumed(); | 1027 | prompt->setConsumed(); |
1028 | messg->setText(i18n("Script timed out!")); | 1028 | messg->setText(i18n("Script timed out!")); |
1029 | Modem::modem->hangup(); | 1029 | Modem::modem->hangup(); |
1030 | emit stopAccounting(); | 1030 | emit stopAccounting(); |
1031 | // p_kppp->con_win->stopClock(); | 1031 | // p_kppp->con_win->stopClock(); |
1032 | 1032 | ||
1033 | vmain = 0; // let's try again. | 1033 | vmain = 0; // let's try again. |
1034 | substate = -1; | 1034 | substate = -1; |
1035 | } | 1035 | } |
1036 | 1036 | ||
1037 | 1037 | ||
1038 | void ConnectWidget::setScan(const QString &n) { | 1038 | void ConnectWidget::setScan(const QString &n) { |
1039 | scanning = true; | 1039 | scanning = true; |
1040 | scanstr = n; | 1040 | scanstr = n; |
1041 | scanbuffer = ""; | 1041 | scanbuffer = ""; |
1042 | 1042 | ||
1043 | QString ts = i18n("Scanning: %1").arg(n); | 1043 | QString ts = i18n("Scanning: %1").arg(n); |
1044 | emit debugMessage(ts); | 1044 | emit debugMessage(ts); |
1045 | } | 1045 | } |
1046 | 1046 | ||
1047 | 1047 | ||
1048 | void ConnectWidget::setExpect(const QString &n) { | 1048 | void ConnectWidget::setExpect(const QString &n) { |
1049 | expecting = true; | 1049 | expecting = true; |
1050 | expectstr = n; | 1050 | expectstr = n; |
1051 | 1051 | ||
1052 | QString ts = i18n("Expecting: %1").arg(n); | 1052 | QString ts = i18n("Expecting: %1").arg(n); |
1053 | ts.replace(QRegExp("\n"), "<LF>"); | 1053 | ts.replace(QRegExp("\n"), "<LF>"); |
1054 | emit debugMessage(ts); | 1054 | emit debugMessage(ts); |
1055 | 1055 | ||
1056 | // check if the expected string is in the read buffer already. | 1056 | // check if the expected string is in the read buffer already. |
1057 | checkBuffers(); | 1057 | checkBuffers(); |
1058 | } | 1058 | } |
1059 | 1059 | ||
1060 | 1060 | ||
1061 | void ConnectWidget::if_waiting_timed_out() { | 1061 | void ConnectWidget::if_waiting_timed_out() { |
1062 | if_timer->stop(); | 1062 | if_timer->stop(); |
1063 | if_timeout_timer->stop(); | 1063 | if_timeout_timer->stop(); |
1064 | qDebug("if_waiting_timed_out()"); | 1064 | qDebug("if_waiting_timed_out()"); |
1065 | 1065 | ||
1066 | gpppdata.setpppdError(E_IF_TIMEOUT); | 1066 | PPPData::data()->setpppdError(E_IF_TIMEOUT); |
1067 | 1067 | ||
1068 | // let's kill the stuck pppd | 1068 | // let's kill the stuck pppd |
1069 | Modem::modem->killPPPDaemon(); | 1069 | Modem::modem->killPPPDaemon(); |
1070 | 1070 | ||
1071 | emit stopAccounting(); | 1071 | emit stopAccounting(); |
1072 | // p_kppp->con_win->stopClock(); | 1072 | // p_kppp->con_win->stopClock(); |
1073 | 1073 | ||
1074 | 1074 | ||
1075 | // killing ppp will generate a SIGCHLD which will be caught in pppdie() | 1075 | // killing ppp will generate a SIGCHLD which will be caught in pppdie() |
1076 | // in main.cpp what happens next will depend on the boolean | 1076 | // in main.cpp what happens next will depend on the boolean |
1077 | // reconnect_on_disconnect which is set in ConnectWidget::init(); | 1077 | // reconnect_on_disconnect which is set in ConnectWidget::init(); |
1078 | } | 1078 | } |
1079 | 1079 | ||
1080 | void ConnectWidget::pppdDied() | 1080 | void ConnectWidget::pppdDied() |
1081 | { | 1081 | { |
1082 | if_timer->stop(); | 1082 | if_timer->stop(); |
1083 | if_timeout_timer->stop(); | 1083 | if_timeout_timer->stop(); |
1084 | } | 1084 | } |
1085 | 1085 | ||
1086 | void ConnectWidget::if_waiting_slot() { | 1086 | void ConnectWidget::if_waiting_slot() { |
1087 | messg->setText(i18n("Logging on to network...")); | 1087 | messg->setText(i18n("Logging on to network...")); |
1088 | 1088 | ||
1089 | // if(!stats->ifIsUp()) { | 1089 | // if(!stats->ifIsUp()) { |
1090 | 1090 | ||
1091 | // if(gpppdata.pppdError() != 0) { | 1091 | // if(PPPData::data()->pppdError() != 0) { |
1092 | // // we are here if pppd died immediately after starting it. | 1092 | // // we are here if pppd died immediately after starting it. |
1093 | // pppdDied(); | 1093 | // pppdDied(); |
1094 | // // error message handled in main.cpp: sigPPPDDied() | 1094 | // // error message handled in main.cpp: sigPPPDDied() |
1095 | // return; | 1095 | // return; |
1096 | // } | 1096 | // } |
1097 | 1097 | ||
1098 | // if_timer->start(100, TRUE); // single shot | 1098 | // if_timer->start(100, TRUE); // single shot |
1099 | // return; | 1099 | // return; |
1100 | // } | 1100 | // } |
1101 | 1101 | ||
1102 | // O.K the ppp interface is up and running | 1102 | // O.K the ppp interface is up and running |
1103 | // give it a few time to come up completly (0.2 seconds) | 1103 | // give it a few time to come up completly (0.2 seconds) |
1104 | if_timeout_timer->stop(); | 1104 | if_timeout_timer->stop(); |
1105 | if_timer->stop(); | 1105 | if_timer->stop(); |
1106 | usleep(200000); | 1106 | usleep(200000); |
1107 | 1107 | ||
1108 | if(gpppdata.autoDNS()) | 1108 | if(PPPData::data()->autoDNS()) |
1109 | addpeerdns(); | 1109 | addpeerdns(); |
1110 | 1110 | ||
1111 | // Close the debugging window. If we are connected, we | 1111 | // Close the debugging window. If we are connected, we |
1112 | // are not really interested in debug output | 1112 | // are not really interested in debug output |
1113 | emit closeDebugWindow(); | 1113 | emit closeDebugWindow(); |
1114 | // p_kppp->statdlg->take_stats(); // start taking ppp statistics | 1114 | // p_kppp->statdlg->take_stats(); // start taking ppp statistics |
1115 | auto_hostname(); | 1115 | auto_hostname(); |
1116 | 1116 | ||
1117 | if(!gpppdata.command_on_connect().isEmpty()) { | 1117 | if(!PPPData::data()->command_on_connect().isEmpty()) { |
1118 | messg->setText(i18n("Running startup command...")); | 1118 | messg->setText(i18n("Running startup command...")); |
1119 | 1119 | ||
1120 | // make sure that we don't get any async errors | 1120 | // make sure that we don't get any async errors |
1121 | qApp->flushX(); | 1121 | qApp->flushX(); |
1122 | execute_command(gpppdata.command_on_connect()); | 1122 | execute_command(PPPData::data()->command_on_connect()); |
1123 | messg->setText(i18n("Done")); | 1123 | messg->setText(i18n("Done")); |
1124 | } | 1124 | } |
1125 | 1125 | ||
1126 | // remove the authentication file | 1126 | // remove the authentication file |
1127 | Modem::modem->removeSecret(AUTH_PAP); | 1127 | Modem::modem->removeSecret(AUTH_PAP); |
1128 | Modem::modem->removeSecret(AUTH_CHAP); | 1128 | Modem::modem->removeSecret(AUTH_CHAP); |
1129 | 1129 | ||
1130 | emit debugMessage(i18n("Done")); | 1130 | emit debugMessage(i18n("Done")); |
1131 | set_con_speed_string(); | 1131 | set_con_speed_string(); |
1132 | 1132 | ||
1133 | // p_kppp->con_win->setConnectionSpeed(p_kppp->con_speed); | 1133 | // p_kppp->con_win->setConnectionSpeed(p_kppp->con_speed); |
1134 | this->hide(); | 1134 | this->hide(); |
1135 | messg->setText(""); | 1135 | messg->setText(""); |
1136 | 1136 | ||
1137 | // prepare the con_win so as to have the right size for | 1137 | // prepare the con_win so as to have the right size for |
1138 | // accounting / non-accounting mode | 1138 | // accounting / non-accounting mode |
1139 | // if(p_kppp->acct != 0) | 1139 | // if(p_kppp->acct != 0) |
1140 | // p_kppp->con_win->accounting(p_kppp->acct->running()); | 1140 | // p_kppp->con_win->accounting(p_kppp->acct->running()); |
1141 | // else | 1141 | // else |
1142 | // p_kppp->con_win->accounting(false); | 1142 | // p_kppp->con_win->accounting(false); |
1143 | 1143 | ||
1144 | if (gpppdata.get_dock_into_panel()) { | 1144 | if (PPPData::data()->get_dock_into_panel()) { |
1145 | // DockWidget::dock_widget->show(); | 1145 | // DockWidget::dock_widget->show(); |
1146 | // DockWidget::dock_widget->take_stats(); | 1146 | // DockWidget::dock_widget->take_stats(); |
1147 | // this->hide(); | 1147 | // this->hide(); |
1148 | } | 1148 | } |
1149 | else { | 1149 | else { |
1150 | // p_kppp->con_win->show(); | 1150 | // p_kppp->con_win->show(); |
1151 | 1151 | ||
1152 | if(gpppdata.get_iconify_on_connect()) { | 1152 | if(PPPData::data()->get_iconify_on_connect()) { |
1153 | // p_kppp->con_win->showMinimized(); | 1153 | // p_kppp->con_win->showMinimized(); |
1154 | } | 1154 | } |
1155 | } | 1155 | } |
1156 | 1156 | ||
1157 | Modem::modem->closetty(); | 1157 | Modem::modem->closetty(); |
1158 | } | 1158 | } |
1159 | 1159 | ||
1160 | 1160 | ||
1161 | bool ConnectWidget::execppp() { | 1161 | bool ConnectWidget::execppp() { |
1162 | QString command; | 1162 | QString command; |
1163 | 1163 | ||
1164 | command = "pppd"; | 1164 | command = "pppd"; |
1165 | 1165 | ||
1166 | // as of version 2.3.6 pppd falls back to the real user rights when | 1166 | // as of version 2.3.6 pppd falls back to the real user rights when |
1167 | // opening a device given in a command line. To avoid permission conflicts | 1167 | // opening a device given in a command line. To avoid permission conflicts |
1168 | // we'll simply leave this argument away. pppd will then use the default tty | 1168 | // we'll simply leave this argument away. pppd will then use the default tty |
1169 | // which is the serial port we connected stdin/stdout to in opener.cpp. | 1169 | // which is the serial port we connected stdin/stdout to in opener.cpp. |
1170 | // command += " "; | 1170 | // command += " "; |
1171 | // command += gpppdata.modemDevice(); | 1171 | // command += PPPData::data()->modemDevice(); |
1172 | 1172 | ||
1173 | command += " " + gpppdata.speed(); | 1173 | command += " " + PPPData::data()->speed(); |
1174 | 1174 | ||
1175 | command += " -detach"; | 1175 | command += " -detach"; |
1176 | 1176 | ||
1177 | if(gpppdata.ipaddr() != "0.0.0.0" || | 1177 | if(PPPData::data()->ipaddr() != "0.0.0.0" || |
1178 | gpppdata.gateway() != "0.0.0.0") { | 1178 | PPPData::data()->gateway() != "0.0.0.0") { |
1179 | if(gpppdata.ipaddr() != "0.0.0.0") { | 1179 | if(PPPData::data()->ipaddr() != "0.0.0.0") { |
1180 | command += " "; | 1180 | command += " "; |
1181 | command += gpppdata.ipaddr(); | 1181 | command += PPPData::data()->ipaddr(); |
1182 | command += ":"; | 1182 | command += ":"; |
1183 | } | 1183 | } |
1184 | else { | 1184 | else { |
1185 | command += " "; | 1185 | command += " "; |
1186 | command += ":"; | 1186 | command += ":"; |
1187 | } | 1187 | } |
1188 | 1188 | ||
1189 | if(gpppdata.gateway() != "0.0.0.0") | 1189 | if(PPPData::data()->gateway() != "0.0.0.0") |
1190 | command += gpppdata.gateway(); | 1190 | command += PPPData::data()->gateway(); |
1191 | } | 1191 | } |
1192 | 1192 | ||
1193 | if(gpppdata.subnetmask() != "0.0.0.0") | 1193 | if(PPPData::data()->subnetmask() != "0.0.0.0") |
1194 | command += " netmask " + gpppdata.subnetmask(); | 1194 | command += " netmask " + PPPData::data()->subnetmask(); |
1195 | 1195 | ||
1196 | if(gpppdata.flowcontrol() != "None") { | 1196 | if(PPPData::data()->flowcontrol() != "None") { |
1197 | if(gpppdata.flowcontrol() == "CRTSCTS") | 1197 | if(PPPData::data()->flowcontrol() == "CRTSCTS") |
1198 | command += " crtscts"; | 1198 | command += " crtscts"; |
1199 | else | 1199 | else |
1200 | command += " xonxoff"; | 1200 | command += " xonxoff"; |
1201 | } | 1201 | } |
1202 | 1202 | ||
1203 | if(gpppdata.defaultroute()) | 1203 | if(PPPData::data()->defaultroute()) |
1204 | command += " defaultroute"; | 1204 | command += " defaultroute"; |
1205 | 1205 | ||
1206 | if(gpppdata.autoDNS()) | 1206 | if(PPPData::data()->autoDNS()) |
1207 | command += " usepeerdns"; | 1207 | command += " usepeerdns"; |
1208 | 1208 | ||
1209 | QStringList &arglist = gpppdata.pppdArgument(); | 1209 | QStringList &arglist = PPPData::data()->pppdArgument(); |
1210 | for ( QStringList::Iterator it = arglist.begin(); | 1210 | for ( QStringList::Iterator it = arglist.begin(); |
1211 | it != arglist.end(); | 1211 | it != arglist.end(); |
1212 | ++it ) | 1212 | ++it ) |
1213 | { | 1213 | { |
1214 | command += " " + *it; | 1214 | command += " " + *it; |
1215 | } | 1215 | } |
1216 | 1216 | ||
1217 | // PAP settings | 1217 | // PAP settings |
1218 | if(gpppdata.authMethod() == AUTH_PAP) { | 1218 | if(PPPData::data()->authMethod() == AUTH_PAP) { |
1219 | command += " -chap user "; | 1219 | command += " -chap user "; |
1220 | command = command + "\"" + gpppdata.storedUsername() + "\""; | 1220 | command = command + "\"" + PPPData::data()->storedUsername() + "\""; |
1221 | } | 1221 | } |
1222 | 1222 | ||
1223 | // CHAP settings | 1223 | // CHAP settings |
1224 | if(gpppdata.authMethod() == AUTH_CHAP) { | 1224 | if(PPPData::data()->authMethod() == AUTH_CHAP) { |
1225 | command += " -pap user "; | 1225 | command += " -pap user "; |
1226 | command = command + "\"" + gpppdata.storedUsername() + "\""; | 1226 | command = command + "\"" + PPPData::data()->storedUsername() + "\""; |
1227 | } | 1227 | } |
1228 | 1228 | ||
1229 | // PAP/CHAP settings | 1229 | // PAP/CHAP settings |
1230 | if(gpppdata.authMethod() == AUTH_PAPCHAP) { | 1230 | if(PPPData::data()->authMethod() == AUTH_PAPCHAP) { |
1231 | command += " user "; | 1231 | command += " user "; |
1232 | command = command + "\"" + gpppdata.storedUsername() + "\""; | 1232 | command = command + "\"" + PPPData::data()->storedUsername() + "\""; |
1233 | } | 1233 | } |
1234 | 1234 | ||
1235 | // check for debug | 1235 | // check for debug |
1236 | if(gpppdata.getPPPDebug()) | 1236 | if(PPPData::data()->getPPPDebug()) |
1237 | command += " debug"; | 1237 | command += " debug"; |
1238 | 1238 | ||
1239 | if (command.length() > MAX_CMDLEN) { | 1239 | if (command.length() > MAX_CMDLEN) { |
1240 | QMessageBox::critical(this, "error", i18n( | 1240 | QMessageBox::critical(this, "error", i18n( |
1241 | "pppd command + command-line arguments exceed " | 1241 | "pppd command + command-line arguments exceed " |
1242 | "2024 characters in length." | 1242 | "2024 characters in length." |
1243 | )); | 1243 | )); |
1244 | 1244 | ||
1245 | return false; // nonsensically long command which would bust my buffer buf. | 1245 | return false; // nonsensically long command which would bust my buffer buf. |
1246 | } | 1246 | } |
1247 | 1247 | ||
1248 | qApp->flushX(); | 1248 | qApp->flushX(); |
1249 | 1249 | ||
1250 | return Modem::modem->execPPPDaemon(command); | 1250 | return Modem::modem->execPPPDaemon(command); |
1251 | } | 1251 | } |
1252 | 1252 | ||
1253 | 1253 | ||
1254 | void ConnectWidget::closeEvent( QCloseEvent *e ) { | 1254 | void ConnectWidget::closeEvent( QCloseEvent *e ) { |
1255 | e->ignore(); | 1255 | e->ignore(); |
1256 | emit cancelbutton(); | 1256 | emit cancelbutton(); |
1257 | } | 1257 | } |
1258 | 1258 | ||
1259 | 1259 | ||
1260 | void ConnectWidget::setMsg(const QString &msg) { | 1260 | void ConnectWidget::setMsg(const QString &msg) { |
1261 | messg->setText(msg); | 1261 | messg->setText(msg); |
1262 | } | 1262 | } |
1263 | 1263 | ||
1264 | void ConnectWidget::writeline(const QString &s) { | 1264 | void ConnectWidget::writeline(const QString &s) { |
1265 | Modem::modem->writeLine(s.local8Bit()); | 1265 | Modem::modem->writeLine(s.local8Bit()); |
1266 | } | 1266 | } |
1267 | 1267 | ||
1268 | // Set the hostname and domain from DNS Server | 1268 | // Set the hostname and domain from DNS Server |
1269 | void auto_hostname() { | 1269 | void auto_hostname() { |
1270 | struct in_addr local_ip; | 1270 | struct in_addr local_ip; |
1271 | struct hostent *hostname_entry; | 1271 | struct hostent *hostname_entry; |
1272 | QString new_hostname; | 1272 | QString new_hostname; |
1273 | int dot; | 1273 | int dot; |
1274 | char tmp_str[100]; // buffer overflow safe | 1274 | char tmp_str[100]; // buffer overflow safe |
1275 | 1275 | ||
1276 | gethostname(tmp_str, sizeof(tmp_str)); | 1276 | gethostname(tmp_str, sizeof(tmp_str)); |
1277 | tmp_str[sizeof(tmp_str)-1]=0; // panic | 1277 | tmp_str[sizeof(tmp_str)-1]=0; // panic |
1278 | old_hostname=tmp_str; // copy to QString | 1278 | old_hostname=tmp_str; // copy to QString |
1279 | 1279 | ||
1280 | // if (!p_kppp->stats->local_ip_address.isEmpty() && gpppdata.autoname()) { | 1280 | // if (!p_kppp->stats->local_ip_address.isEmpty() && PPPData::data()->autoname()) { |
1281 | if ( gpppdata.autoname()) { | 1281 | if ( PPPData::data()->autoname()) { |
1282 | // local_ip.s_addr=inet_addr(p_kppp->stats->local_ip_address.ascii()); | 1282 | // local_ip.s_addr=inet_addr(p_kppp->stats->local_ip_address.ascii()); |
1283 | hostname_entry=gethostbyaddr((const char *)&local_ip,sizeof(in_addr),AF_INET); | 1283 | hostname_entry=gethostbyaddr((const char *)&local_ip,sizeof(in_addr),AF_INET); |
1284 | 1284 | ||
1285 | if (hostname_entry != 0L) { | 1285 | if (hostname_entry != 0L) { |
1286 | new_hostname=hostname_entry->h_name; | 1286 | new_hostname=hostname_entry->h_name; |
1287 | dot=new_hostname.find('.'); | 1287 | dot=new_hostname.find('.'); |
1288 | new_hostname=new_hostname.remove(dot,new_hostname.length()-dot); | 1288 | new_hostname=new_hostname.remove(dot,new_hostname.length()-dot); |
1289 | Modem::modem->setHostname(new_hostname); | 1289 | Modem::modem->setHostname(new_hostname); |
1290 | modified_hostname = TRUE; | 1290 | modified_hostname = TRUE; |
1291 | 1291 | ||
1292 | new_hostname=hostname_entry->h_name; | 1292 | new_hostname=hostname_entry->h_name; |
1293 | new_hostname.remove(0,dot+1); | 1293 | new_hostname.remove(0,dot+1); |
1294 | 1294 | ||
1295 | add_domain(new_hostname); | 1295 | add_domain(new_hostname); |
1296 | } | 1296 | } |
1297 | } | 1297 | } |
1298 | 1298 | ||
1299 | } | 1299 | } |
1300 | 1300 | ||
1301 | // Replace the DNS domain entry in the /etc/resolv.conf file and | 1301 | // Replace the DNS domain entry in the /etc/resolv.conf file and |
1302 | // disable the nameserver entries if option is enabled | 1302 | // disable the nameserver entries if option is enabled |
1303 | void add_domain(const QString &domain) { | 1303 | void add_domain(const QString &domain) { |
1304 | 1304 | ||
1305 | int fd; | 1305 | int fd; |
1306 | char c; | 1306 | char c; |
1307 | QString resolv[MAX_RESOLVCONF_LINES]; | 1307 | QString resolv[MAX_RESOLVCONF_LINES]; |
1308 | 1308 | ||
1309 | if (domain.isEmpty()) | 1309 | if (domain.isEmpty()) |
1310 | return; | 1310 | return; |
1311 | 1311 | ||
1312 | if((fd = Modem::modem->openResolv(O_RDONLY)) >= 0) { | 1312 | if((fd = Modem::modem->openResolv(O_RDONLY)) >= 0) { |
1313 | 1313 | ||
1314 | int i=0; | 1314 | int i=0; |
1315 | while((read(fd, &c, 1) == 1) && (i < MAX_RESOLVCONF_LINES)) { | 1315 | while((read(fd, &c, 1) == 1) && (i < MAX_RESOLVCONF_LINES)) { |
1316 | if(c == '\n') { | 1316 | if(c == '\n') { |
1317 | i++; | 1317 | i++; |
1318 | } | 1318 | } |
1319 | else { | 1319 | else { |
1320 | resolv[i] += c; | 1320 | resolv[i] += c; |
1321 | } | 1321 | } |
1322 | } | 1322 | } |
1323 | close(fd); | 1323 | close(fd); |
1324 | if ((c != '\n') && (i < MAX_RESOLVCONF_LINES)) i++; | 1324 | if ((c != '\n') && (i < MAX_RESOLVCONF_LINES)) i++; |
1325 | 1325 | ||
1326 | if((fd = Modem::modem->openResolv(O_WRONLY|O_TRUNC)) >= 0) { | 1326 | if((fd = Modem::modem->openResolv(O_WRONLY|O_TRUNC)) >= 0) { |
1327 | QCString tmp = "domain " + domain.local8Bit() + | 1327 | QCString tmp = "domain " + domain.local8Bit() + |
1328 | " \t\t#kppp temp entry\n"; | 1328 | " \t\t#kppp temp entry\n"; |
1329 | write(fd, tmp.data(), tmp.length()); | 1329 | write(fd, tmp.data(), tmp.length()); |
1330 | 1330 | ||
1331 | for(int j=0; j < i; j++) { | 1331 | for(int j=0; j < i; j++) { |
1332 | if((resolv[j].contains("domain") || | 1332 | if((resolv[j].contains("domain") || |
1333 | ( resolv[j].contains("nameserver") | 1333 | ( resolv[j].contains("nameserver") |
1334 | && !resolv[j].contains("#kppp temp entry") | 1334 | && !resolv[j].contains("#kppp temp entry") |
1335 | && gpppdata.exDNSDisabled())) | 1335 | && PPPData::data()->exDNSDisabled())) |
1336 | && !resolv[j].contains("#entry disabled by kppp")) { | 1336 | && !resolv[j].contains("#entry disabled by kppp")) { |
1337 | QCString tmp = "# " + resolv[j].local8Bit() + | 1337 | QCString tmp = "# " + resolv[j].local8Bit() + |
1338 | " \t#entry disabled by kppp\n"; | 1338 | " \t#entry disabled by kppp\n"; |
1339 | write(fd, tmp, tmp.length()); | 1339 | write(fd, tmp, tmp.length()); |
1340 | } | 1340 | } |
1341 | else { | 1341 | else { |
1342 | QCString tmp = resolv[j].local8Bit() + "\n"; | 1342 | QCString tmp = resolv[j].local8Bit() + "\n"; |
1343 | write(fd, tmp, tmp.length()); | 1343 | write(fd, tmp, tmp.length()); |
1344 | } | 1344 | } |
1345 | } | 1345 | } |
1346 | } | 1346 | } |
1347 | close(fd); | 1347 | close(fd); |
1348 | } | 1348 | } |
1349 | } | 1349 | } |
1350 | 1350 | ||
1351 | 1351 | ||
1352 | // adds the DNS entries in the /etc/resolv.conf file | 1352 | // adds the DNS entries in the /etc/resolv.conf file |
1353 | void adddns() | 1353 | void adddns() |
1354 | { | 1354 | { |
1355 | int fd; | 1355 | int fd; |
1356 | 1356 | ||
1357 | if ((fd = Modem::modem->openResolv(O_WRONLY|O_APPEND)) >= 0) { | 1357 | if ((fd = Modem::modem->openResolv(O_WRONLY|O_APPEND)) >= 0) { |
1358 | QStringList &dnslist = gpppdata.dns(); | 1358 | QStringList &dnslist = PPPData::data()->dns(); |
1359 | for ( QStringList::Iterator it = dnslist.begin(); | 1359 | for ( QStringList::Iterator it = dnslist.begin(); |
1360 | it != dnslist.end(); | 1360 | it != dnslist.end(); |
1361 | ++it ) | 1361 | ++it ) |
1362 | { | 1362 | { |
1363 | QCString dns = "nameserver " + (*it).local8Bit() + | 1363 | QCString dns = "nameserver " + (*it).local8Bit() + |
1364 | " \t#kppp temp entry\n"; | 1364 | " \t#kppp temp entry\n"; |
1365 | write(fd, dns.data(), dns.length()); | 1365 | write(fd, dns.data(), dns.length()); |
1366 | } | 1366 | } |
1367 | close(fd); | 1367 | close(fd); |
1368 | } | 1368 | } |
1369 | add_domain(gpppdata.domain()); | 1369 | add_domain(PPPData::data()->domain()); |
1370 | } | 1370 | } |
1371 | 1371 | ||
1372 | void addpeerdns() { | 1372 | void addpeerdns() { |
1373 | int fd, fd2; | 1373 | int fd, fd2; |
1374 | 1374 | ||
1375 | if((fd = Modem::modem->openResolv(O_WRONLY|O_APPEND)) >= 0) { | 1375 | if((fd = Modem::modem->openResolv(O_WRONLY|O_APPEND)) >= 0) { |
1376 | if((fd2 = open("/etc/ppp/resolv.conf", O_RDONLY)) >= 0) { | 1376 | if((fd2 = open("/etc/ppp/resolv.conf", O_RDONLY)) >= 0) { |
1377 | char c; | 1377 | char c; |
1378 | int i = 0; | 1378 | int i = 0; |
1379 | while(i++ < 100 && read(fd2, &c, 1) == 1) { | 1379 | while(i++ < 100 && read(fd2, &c, 1) == 1) { |
1380 | if(c == '\n') | 1380 | if(c == '\n') |
1381 | write(fd, "\t#kppp temp entry\n", 18); | 1381 | write(fd, "\t#kppp temp entry\n", 18); |
1382 | else | 1382 | else |
1383 | write(fd, &c, 1); | 1383 | write(fd, &c, 1); |
1384 | } | 1384 | } |
1385 | close(fd2); | 1385 | close(fd2); |
1386 | } else | 1386 | } else |
1387 | fprintf(stderr, "failed to read from /etc/ppp/resolv.conf\n"); | 1387 | fprintf(stderr, "failed to read from /etc/ppp/resolv.conf\n"); |
1388 | close(fd); | 1388 | close(fd); |
1389 | } | 1389 | } |
1390 | add_domain(gpppdata.domain()); | 1390 | add_domain(PPPData::data()->domain()); |
1391 | } | 1391 | } |
1392 | 1392 | ||
1393 | // remove the dns entries from the /etc/resolv.conf file | 1393 | // remove the dns entries from the /etc/resolv.conf file |
1394 | void removedns() { | 1394 | void removedns() { |
1395 | 1395 | ||
1396 | int fd; | 1396 | int fd; |
1397 | char c; | 1397 | char c; |
1398 | QString resolv[MAX_RESOLVCONF_LINES]; | 1398 | QString resolv[MAX_RESOLVCONF_LINES]; |
1399 | 1399 | ||
1400 | if((fd = Modem::modem->openResolv(O_RDONLY)) >= 0) { | 1400 | if((fd = Modem::modem->openResolv(O_RDONLY)) >= 0) { |
1401 | 1401 | ||
1402 | int i=0; | 1402 | int i=0; |
1403 | while(read(fd, &c, 1) == 1 && i < MAX_RESOLVCONF_LINES) { | 1403 | while(read(fd, &c, 1) == 1 && i < MAX_RESOLVCONF_LINES) { |
1404 | if(c == '\n') { | 1404 | if(c == '\n') { |
1405 | i++; | 1405 | i++; |
1406 | } | 1406 | } |
1407 | else { | 1407 | else { |
1408 | resolv[i] += c; | 1408 | resolv[i] += c; |
1409 | } | 1409 | } |
1410 | } | 1410 | } |
1411 | close(fd); | 1411 | close(fd); |
1412 | 1412 | ||
1413 | if((fd = Modem::modem->openResolv(O_WRONLY|O_TRUNC)) >= 0) { | 1413 | if((fd = Modem::modem->openResolv(O_WRONLY|O_TRUNC)) >= 0) { |
1414 | for(int j=0; j < i; j++) { | 1414 | for(int j=0; j < i; j++) { |
1415 | if(resolv[j].contains("#kppp temp entry")) continue; | 1415 | if(resolv[j].contains("#kppp temp entry")) continue; |
1416 | if(resolv[j].contains("#entry disabled by kppp")) { | 1416 | if(resolv[j].contains("#entry disabled by kppp")) { |
1417 | QCString tmp = resolv[j].local8Bit(); | 1417 | QCString tmp = resolv[j].local8Bit(); |
1418 | write(fd, tmp.data()+2, tmp.length() - 27); | 1418 | write(fd, tmp.data()+2, tmp.length() - 27); |
1419 | write(fd, "\n", 1); | 1419 | write(fd, "\n", 1); |
1420 | } | 1420 | } |
1421 | else { | 1421 | else { |
1422 | QCString tmp = resolv[j].local8Bit() + "\n"; | 1422 | QCString tmp = resolv[j].local8Bit() + "\n"; |
1423 | write(fd, tmp, tmp.length()); | 1423 | write(fd, tmp, tmp.length()); |
1424 | } | 1424 | } |
1425 | } | 1425 | } |
1426 | } | 1426 | } |
1427 | close(fd); | 1427 | close(fd); |
1428 | 1428 | ||
1429 | } | 1429 | } |
1430 | 1430 | ||
1431 | if ( modified_hostname ) { | 1431 | if ( modified_hostname ) { |
1432 | Modem::modem->setHostname(old_hostname); | 1432 | Modem::modem->setHostname(old_hostname); |
1433 | modified_hostname = FALSE; | 1433 | modified_hostname = FALSE; |
1434 | } | 1434 | } |
1435 | 1435 | ||
1436 | } | 1436 | } |
1437 | 1437 | ||
1438 | 1438 | ||
diff --git a/noncore/settings/networksettings/ppp/conwindow.cpp b/noncore/settings/networksettings/ppp/conwindow.cpp index d6b3fbe..ad89005 100644 --- a/noncore/settings/networksettings/ppp/conwindow.cpp +++ b/noncore/settings/networksettings/ppp/conwindow.cpp | |||
@@ -1,341 +1,341 @@ | |||
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 | * This program is free software; you can redistribute it and/or | 9 | * This program is free software; you can redistribute it and/or |
10 | * modify it under the terms of the GNU Library General Public | 10 | * modify it under the terms of the GNU Library General Public |
11 | * License as published by the Free Software Foundation; either | 11 | * License as published by the Free Software Foundation; either |
12 | * version 2 of the License, or (at your option) any later version. | 12 | * version 2 of the License, or (at your option) any later version. |
13 | * | 13 | * |
14 | * This program is distributed in the hope that it will be useful, | 14 | * This program is distributed in the hope that it will be useful, |
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
17 | * Library General Public License for more details. | 17 | * Library General Public License for more details. |
18 | * | 18 | * |
19 | * You should have received a copy of the GNU Library General Public | 19 | * You should have received a copy of the GNU Library General Public |
20 | * License along with this program; if not, write to the Free | 20 | * License along with this program; if not, write to the Free |
21 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 21 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
22 | */ | 22 | */ |
23 | 23 | ||
24 | #include <qtooltip.h> | 24 | #include <qtooltip.h> |
25 | #include <qdialog.h> | 25 | #include <qdialog.h> |
26 | #include "conwindow.h" | 26 | #include "conwindow.h" |
27 | //#include "docking.h" | 27 | //#include "docking.h" |
28 | #include "pppdata.h" | 28 | #include "pppdata.h" |
29 | // #include "pppstats.h" | 29 | // #include "pppstats.h" |
30 | // #include <klocale.h> | 30 | // #include <klocale.h> |
31 | #define i18n QObject::tr | 31 | #define i18n QObject::tr |
32 | // #include <kglobal.h> | 32 | // #include <kglobal.h> |
33 | 33 | ||
34 | extern PPPData gpppdata; | 34 | extern PPPData gpppdata; |
35 | 35 | ||
36 | ConWindow::ConWindow(QWidget *parent, const char *name, QDialog *mainwidget ) | 36 | ConWindow::ConWindow(QWidget *parent, const char *name, QDialog *mainwidget ) |
37 | // PPPStats *st) | 37 | // PPPStats *st) |
38 | : QWidget(parent, name, 0), | 38 | : QWidget(parent, name, 0), |
39 | minutes(0), | 39 | minutes(0), |
40 | seconds(0), | 40 | seconds(0), |
41 | hours(0), | 41 | hours(0), |
42 | days(0), | 42 | days(0), |
43 | tl1(0), | 43 | tl1(0), |
44 | // stats(st), | 44 | // stats(st), |
45 | accountingEnabled(false), | 45 | accountingEnabled(false), |
46 | volumeAccountingEnabled(false) | 46 | volumeAccountingEnabled(false) |
47 | { | 47 | { |
48 | info1 = new QLabel(i18n("Connected at:"), this); | 48 | info1 = new QLabel(i18n("Connected at:"), this); |
49 | info2 = new QLabel("", this); | 49 | info2 = new QLabel("", this); |
50 | 50 | ||
51 | timelabel1 = new QLabel(i18n("Time connected:"), this); | 51 | timelabel1 = new QLabel(i18n("Time connected:"), this); |
52 | timelabel2 = new QLabel("000:00:00", this); | 52 | timelabel2 = new QLabel("000:00:00", this); |
53 | 53 | ||
54 | vollabel = new QLabel(i18n("Volume:"), this); | 54 | vollabel = new QLabel(i18n("Volume:"), this); |
55 | volinfo = new QLabel("", this); | 55 | volinfo = new QLabel("", this); |
56 | 56 | ||
57 | // now the stuff for accounting | 57 | // now the stuff for accounting |
58 | session_bill_l = new QLabel(i18n("Session Bill:"), this); | 58 | session_bill_l = new QLabel(i18n("Session Bill:"), this); |
59 | session_bill = new QLabel("", this); | 59 | session_bill = new QLabel("", this); |
60 | total_bill_l = new QLabel(i18n("Total Bill:"), this); | 60 | total_bill_l = new QLabel(i18n("Total Bill:"), this); |
61 | total_bill = new QLabel("", this); | 61 | total_bill = new QLabel("", this); |
62 | 62 | ||
63 | this->setCaption("kppp"); | 63 | this->setCaption("kppp"); |
64 | 64 | ||
65 | cancelbutton = new QPushButton(this); | 65 | cancelbutton = new QPushButton(this); |
66 | cancelbutton->setText(i18n("Disconnect")); | 66 | cancelbutton->setText(i18n("Disconnect")); |
67 | connect(cancelbutton, SIGNAL(clicked()), mainwidget, SLOT(disconnect())); | 67 | connect(cancelbutton, SIGNAL(clicked()), mainwidget, SLOT(disconnect())); |
68 | 68 | ||
69 | // statsbutton = new QPushButton(this); | 69 | // statsbutton = new QPushButton(this); |
70 | // statsbutton->setText(i18n("Details")); | 70 | // statsbutton->setText(i18n("Details")); |
71 | // statsbutton->setFocus(); | 71 | // statsbutton->setFocus(); |
72 | // connect(statsbutton, SIGNAL(clicked()), mainwidget, SLOT(showStats())); | 72 | // connect(statsbutton, SIGNAL(clicked()), mainwidget, SLOT(showStats())); |
73 | 73 | ||
74 | clocktimer = new QTimer(this); | 74 | clocktimer = new QTimer(this); |
75 | connect(clocktimer, SIGNAL(timeout()), SLOT(timeclick())); | 75 | connect(clocktimer, SIGNAL(timeout()), SLOT(timeclick())); |
76 | 76 | ||
77 | // read window position from config file | 77 | // read window position from config file |
78 | int p_x, p_y; | 78 | // int p_x, p_y; |
79 | gpppdata.winPosConWin(p_x, p_y); | 79 | // PPPData::data()->winPosConWin(p_x, p_y); |
80 | setGeometry(p_x, p_y, 320, 110); | 80 | // setGeometry(p_x, p_y, 320, 110); |
81 | } | 81 | } |
82 | 82 | ||
83 | ConWindow::~ConWindow() { | 83 | ConWindow::~ConWindow() { |
84 | stopClock(); | 84 | stopClock(); |
85 | } | 85 | } |
86 | 86 | ||
87 | // save window position when window was closed | 87 | // save window position when window was closed |
88 | bool ConWindow::event(QEvent *e) { | 88 | bool ConWindow::event(QEvent *e) { |
89 | if (e->type() == QEvent::Hide) | 89 | if (e->type() == QEvent::Hide) |
90 | { | 90 | { |
91 | gpppdata.setWinPosConWin(x(), y()); | 91 | // PPPData::data()->setWinPosConWin(x(), y()); |
92 | return true; | 92 | return true; |
93 | } | 93 | } |
94 | else | 94 | else |
95 | return QWidget::event(e); | 95 | return QWidget::event(e); |
96 | } | 96 | } |
97 | 97 | ||
98 | QString ConWindow::prettyPrintVolume(unsigned int n) { | 98 | QString ConWindow::prettyPrintVolume(unsigned int n) { |
99 | int idx = 0; | 99 | int idx = 0; |
100 | const QString quant[] = {i18n("Byte"), i18n("KB"), | 100 | const QString quant[] = {i18n("Byte"), i18n("KB"), |
101 | i18n("MB"), i18n("GB"), QString::null}; | 101 | i18n("MB"), i18n("GB"), QString::null}; |
102 | 102 | ||
103 | float n1 = n; | 103 | float n1 = n; |
104 | while(n >= 1024 && quant[idx] != QString::null) { | 104 | while(n >= 1024 && quant[idx] != QString::null) { |
105 | idx++; | 105 | idx++; |
106 | n /= 1024; | 106 | n /= 1024; |
107 | } | 107 | } |
108 | 108 | ||
109 | int i = idx; | 109 | int i = idx; |
110 | while(i--) | 110 | while(i--) |
111 | n1 = n1 / 1024.0; | 111 | n1 = n1 / 1024.0; |
112 | 112 | ||
113 | QString s = QString::number( n1, 'f', idx==0 ? 0 : 1 ); //KGlobal::locale()->formatNumber( n1, idx==0 ? 0 : 1 ); | 113 | QString s = QString::number( n1, 'f', idx==0 ? 0 : 1 ); //KGlobal::locale()->formatNumber( n1, idx==0 ? 0 : 1 ); |
114 | s += " " + quant[idx]; | 114 | s += " " + quant[idx]; |
115 | return s; | 115 | return s; |
116 | } | 116 | } |
117 | 117 | ||
118 | void ConWindow::accounting(bool on) { | 118 | void ConWindow::accounting(bool on) { |
119 | // cache accounting settings | 119 | // cache accounting settings |
120 | accountingEnabled = on; | 120 | accountingEnabled = on; |
121 | volumeAccountingEnabled = gpppdata.VolAcctEnabled(); | 121 | volumeAccountingEnabled = PPPData::data()->VolAcctEnabled(); |
122 | 122 | ||
123 | // delete old layout | 123 | // delete old layout |
124 | if(tl1 != 0) | 124 | if(tl1 != 0) |
125 | delete tl1; | 125 | delete tl1; |
126 | 126 | ||
127 | // add layout now | 127 | // add layout now |
128 | tl1 = new QVBoxLayout(this, 10, 10); | 128 | tl1 = new QVBoxLayout(this, 10, 10); |
129 | tl1->addSpacing(5); | 129 | tl1->addSpacing(5); |
130 | QHBoxLayout *tl = new QHBoxLayout; | 130 | QHBoxLayout *tl = new QHBoxLayout; |
131 | tl1->addLayout(tl); | 131 | tl1->addLayout(tl); |
132 | tl->addSpacing(20); | 132 | tl->addSpacing(20); |
133 | QGridLayout *l1; | 133 | QGridLayout *l1; |
134 | 134 | ||
135 | int vol_lines = 0; | 135 | int vol_lines = 0; |
136 | if(gpppdata.VolAcctEnabled()) | 136 | if(PPPData::data()->VolAcctEnabled()) |
137 | vol_lines = 1; | 137 | vol_lines = 1; |
138 | 138 | ||
139 | if(accountingEnabled) | 139 | if(accountingEnabled) |
140 | l1 = new QGridLayout(4 + vol_lines, 2, 5); | 140 | l1 = new QGridLayout(4 + vol_lines, 2, 5); |
141 | else | 141 | else |
142 | l1 = new QGridLayout(2 + vol_lines, 2, 5); | 142 | l1 = new QGridLayout(2 + vol_lines, 2, 5); |
143 | tl->addLayout(l1); | 143 | tl->addLayout(l1); |
144 | l1->setColStretch(0, 0); | 144 | l1->setColStretch(0, 0); |
145 | l1->setColStretch(1, 1); | 145 | l1->setColStretch(1, 1); |
146 | 146 | ||
147 | info2->setAlignment(AlignRight|AlignVCenter); | 147 | info2->setAlignment(AlignRight|AlignVCenter); |
148 | timelabel2->setAlignment(AlignRight|AlignVCenter); | 148 | timelabel2->setAlignment(AlignRight|AlignVCenter); |
149 | session_bill->setAlignment(AlignRight|AlignVCenter); | 149 | session_bill->setAlignment(AlignRight|AlignVCenter); |
150 | total_bill->setAlignment(AlignRight|AlignVCenter); | 150 | total_bill->setAlignment(AlignRight|AlignVCenter); |
151 | volinfo->setAlignment(AlignRight|AlignVCenter); | 151 | volinfo->setAlignment(AlignRight|AlignVCenter); |
152 | // make sure that there's enough space for the bills | 152 | // make sure that there's enough space for the bills |
153 | QString s1 = session_bill->text(); | 153 | QString s1 = session_bill->text(); |
154 | QString s2 = total_bill->text(); | 154 | QString s2 = total_bill->text(); |
155 | QString s3 = volinfo->text(); | 155 | QString s3 = volinfo->text(); |
156 | 156 | ||
157 | session_bill->setText("888888.88 XXX"); | 157 | session_bill->setText("888888.88 XXX"); |
158 | total_bill->setText("888888.88 XXX"); | 158 | total_bill->setText("888888.88 XXX"); |
159 | volinfo->setText("8888.8 MB"); | 159 | volinfo->setText("8888.8 MB"); |
160 | session_bill->setFixedSize(session_bill->sizeHint()); | 160 | session_bill->setFixedSize(session_bill->sizeHint()); |
161 | total_bill->setFixedSize(total_bill->sizeHint()); | 161 | total_bill->setFixedSize(total_bill->sizeHint()); |
162 | volinfo->setFixedSize(volinfo->sizeHint()); | 162 | volinfo->setFixedSize(volinfo->sizeHint()); |
163 | session_bill->setText(s1); | 163 | session_bill->setText(s1); |
164 | total_bill->setText(s2); | 164 | total_bill->setText(s2); |
165 | volinfo->setText(s3); | 165 | volinfo->setText(s3); |
166 | 166 | ||
167 | l1->addWidget(info1, 0, 0); | 167 | l1->addWidget(info1, 0, 0); |
168 | l1->addWidget(info2, 0, 1); | 168 | l1->addWidget(info2, 0, 1); |
169 | l1->addWidget(timelabel1, 1, 0); | 169 | l1->addWidget(timelabel1, 1, 0); |
170 | l1->addWidget(timelabel2, 1, 1); | 170 | l1->addWidget(timelabel2, 1, 1); |
171 | if(accountingEnabled) { | 171 | if(accountingEnabled) { |
172 | session_bill_l->show(); | 172 | session_bill_l->show(); |
173 | session_bill->show(); | 173 | session_bill->show(); |
174 | total_bill_l->show(); | 174 | total_bill_l->show(); |
175 | total_bill->show(); | 175 | total_bill->show(); |
176 | l1->addWidget(session_bill_l, 2, 0); | 176 | l1->addWidget(session_bill_l, 2, 0); |
177 | l1->addWidget(session_bill, 2, 1); | 177 | l1->addWidget(session_bill, 2, 1); |
178 | l1->addWidget(total_bill_l, 3, 0); | 178 | l1->addWidget(total_bill_l, 3, 0); |
179 | l1->addWidget(total_bill, 3, 1); | 179 | l1->addWidget(total_bill, 3, 1); |
180 | 180 | ||
181 | if(volumeAccountingEnabled) { | 181 | if(volumeAccountingEnabled) { |
182 | vollabel->show(); | 182 | vollabel->show(); |
183 | volinfo->show(); | 183 | volinfo->show(); |
184 | l1->addWidget(vollabel, 4, 0); | 184 | l1->addWidget(vollabel, 4, 0); |
185 | l1->addWidget(volinfo, 4, 1); | 185 | l1->addWidget(volinfo, 4, 1); |
186 | } else { | 186 | } else { |
187 | vollabel->hide(); | 187 | vollabel->hide(); |
188 | volinfo->hide(); | 188 | volinfo->hide(); |
189 | } | 189 | } |
190 | 190 | ||
191 | } else { | 191 | } else { |
192 | session_bill_l->hide(); | 192 | session_bill_l->hide(); |
193 | session_bill->hide(); | 193 | session_bill->hide(); |
194 | total_bill_l->hide(); | 194 | total_bill_l->hide(); |
195 | total_bill->hide(); | 195 | total_bill->hide(); |
196 | 196 | ||
197 | if(volumeAccountingEnabled) { | 197 | if(volumeAccountingEnabled) { |
198 | vollabel->show(); | 198 | vollabel->show(); |
199 | volinfo->show(); | 199 | volinfo->show(); |
200 | l1->addWidget(vollabel, 2, 0); | 200 | l1->addWidget(vollabel, 2, 0); |
201 | l1->addWidget(volinfo, 2, 1); | 201 | l1->addWidget(volinfo, 2, 1); |
202 | } else { | 202 | } else { |
203 | vollabel->hide(); | 203 | vollabel->hide(); |
204 | volinfo->hide(); | 204 | volinfo->hide(); |
205 | } | 205 | } |
206 | } | 206 | } |
207 | 207 | ||
208 | tl->addSpacing(10); | 208 | tl->addSpacing(10); |
209 | QVBoxLayout *l2 = new QVBoxLayout(5); | 209 | QVBoxLayout *l2 = new QVBoxLayout(5); |
210 | tl->addLayout(l2); | 210 | tl->addLayout(l2); |
211 | l2->addStretch(1); | 211 | l2->addStretch(1); |
212 | // l2->addWidget(statsbutton); | 212 | // l2->addWidget(statsbutton); |
213 | l2->addWidget(cancelbutton); | 213 | l2->addWidget(cancelbutton); |
214 | 214 | ||
215 | l2->addStretch(1); | 215 | l2->addStretch(1); |
216 | 216 | ||
217 | tl1->addSpacing(5); | 217 | tl1->addSpacing(5); |
218 | 218 | ||
219 | setFixedSize(sizeHint()); | 219 | setFixedSize(sizeHint()); |
220 | /* | 220 | /* |
221 | do not overwrite position read from config | 221 | do not overwrite position read from config |
222 | setGeometry((QApplication::desktop()->width() - width()) / 2, | 222 | setGeometry((QApplication::desktop()->width() - width()) / 2, |
223 | (QApplication::desktop()->height() - height())/2, | 223 | (QApplication::desktop()->height() - height())/2, |
224 | width(), | 224 | width(), |
225 | height()); | 225 | height()); |
226 | */ | 226 | */ |
227 | } | 227 | } |
228 | 228 | ||
229 | 229 | ||
230 | void ConWindow::dock() { | 230 | void ConWindow::dock() { |
231 | // DockWidget::dock_widget->show(); | 231 | // DockWidget::dock_widget->show(); |
232 | this->hide(); | 232 | this->hide(); |
233 | } | 233 | } |
234 | 234 | ||
235 | 235 | ||
236 | void ConWindow::startClock() { | 236 | void ConWindow::startClock() { |
237 | minutes = 0; | 237 | minutes = 0; |
238 | seconds = 0; | 238 | seconds = 0; |
239 | hours = 0; | 239 | hours = 0; |
240 | QString title ; | 240 | QString title ; |
241 | 241 | ||
242 | title = gpppdata.accname(); | 242 | title = PPPData::data()->accname(); |
243 | 243 | ||
244 | if(gpppdata.get_show_clock_on_caption()){ | 244 | if(PPPData::data()->get_show_clock_on_caption()){ |
245 | title += " 00:00" ; | 245 | title += " 00:00" ; |
246 | } | 246 | } |
247 | this->setCaption(title); | 247 | this->setCaption(title); |
248 | 248 | ||
249 | timelabel2->setText("00:00:00"); | 249 | timelabel2->setText("00:00:00"); |
250 | clocktimer->start(1000); | 250 | clocktimer->start(1000); |
251 | } | 251 | } |
252 | 252 | ||
253 | 253 | ||
254 | void ConWindow::setConnectionSpeed(const QString &speed) { | 254 | void ConWindow::setConnectionSpeed(const QString &speed) { |
255 | info2->setText(speed); | 255 | info2->setText(speed); |
256 | } | 256 | } |
257 | 257 | ||
258 | 258 | ||
259 | void ConWindow::stopClock() { | 259 | void ConWindow::stopClock() { |
260 | clocktimer->stop(); | 260 | clocktimer->stop(); |
261 | } | 261 | } |
262 | 262 | ||
263 | 263 | ||
264 | void ConWindow::timeclick() { | 264 | void ConWindow::timeclick() { |
265 | QString tooltip = i18n("Connection: %1\n" | 265 | QString tooltip = i18n("Connection: %1\n" |
266 | "Connected at: %2\n" | 266 | "Connected at: %2\n" |
267 | "Time connected: %3") | 267 | "Time connected: %3") |
268 | .arg(gpppdata.accname()).arg(info2->text()) | 268 | .arg(PPPData::data()->accname()).arg(info2->text()) |
269 | .arg(time_string2); | 269 | .arg(time_string2); |
270 | 270 | ||
271 | if(accountingEnabled) | 271 | if(accountingEnabled) |
272 | tooltip += i18n("\nSession Bill: %1\nTotal Bill: %2") | 272 | tooltip += i18n("\nSession Bill: %1\nTotal Bill: %2") |
273 | .arg(session_bill->text()).arg(total_bill->text()); | 273 | .arg(session_bill->text()).arg(total_bill->text()); |
274 | // volume accounting | 274 | // volume accounting |
275 | if(volumeAccountingEnabled) { | 275 | if(volumeAccountingEnabled) { |
276 | 276 | ||
277 | volinfo->setEnabled(TRUE); | 277 | volinfo->setEnabled(TRUE); |
278 | int bytes = gpppdata.totalBytes(); | 278 | int bytes = PPPData::data()->totalBytes(); |
279 | volinfo->setText(prettyPrintVolume(bytes)); | 279 | volinfo->setText(prettyPrintVolume(bytes)); |
280 | } | 280 | } |
281 | 281 | ||
282 | seconds++; | 282 | seconds++; |
283 | 283 | ||
284 | if(seconds >= 60 ) { | 284 | if(seconds >= 60 ) { |
285 | minutes ++; | 285 | minutes ++; |
286 | seconds = 0; | 286 | seconds = 0; |
287 | } | 287 | } |
288 | 288 | ||
289 | if (minutes >= 60){ | 289 | if (minutes >= 60){ |
290 | minutes = 0; | 290 | minutes = 0; |
291 | hours ++; | 291 | hours ++; |
292 | } | 292 | } |
293 | 293 | ||
294 | if( hours >= 24){ | 294 | if( hours >= 24){ |
295 | days ++; | 295 | days ++; |
296 | hours = 0; | 296 | hours = 0; |
297 | } | 297 | } |
298 | 298 | ||
299 | time_string.sprintf("%02d:%02d",hours,minutes); | 299 | time_string.sprintf("%02d:%02d",hours,minutes); |
300 | time_string2 = ""; | 300 | time_string2 = ""; |
301 | if (days) | 301 | if (days) |
302 | time_string2.sprintf("%d d %02d:%02d:%02d", | 302 | time_string2.sprintf("%d d %02d:%02d:%02d", |
303 | days,hours,minutes,seconds); | 303 | days,hours,minutes,seconds); |
304 | 304 | ||
305 | else | 305 | else |
306 | time_string2.sprintf("%02d:%02d:%02d",hours,minutes,seconds); | 306 | time_string2.sprintf("%02d:%02d:%02d",hours,minutes,seconds); |
307 | 307 | ||
308 | caption_string = gpppdata.accname(); | 308 | caption_string = PPPData::data()->accname(); |
309 | caption_string += " "; | 309 | caption_string += " "; |
310 | caption_string += time_string; | 310 | caption_string += time_string; |
311 | 311 | ||
312 | 312 | ||
313 | timelabel2->setText(time_string2); | 313 | timelabel2->setText(time_string2); |
314 | 314 | ||
315 | if(gpppdata.get_show_clock_on_caption() && (seconds == 1)){ | 315 | if(PPPData::data()->get_show_clock_on_caption() && (seconds == 1)){ |
316 | // we update the Caption only once per minute not every second | 316 | // we update the Caption only once per minute not every second |
317 | // otherwise I get a flickering icon | 317 | // otherwise I get a flickering icon |
318 | this->setCaption(caption_string); | 318 | this->setCaption(caption_string); |
319 | } | 319 | } |
320 | 320 | ||
321 | // QToolTip::add(DockWidget::dock_widget, tooltip); | 321 | // QToolTip::add(DockWidget::dock_widget, tooltip); |
322 | } | 322 | } |
323 | 323 | ||
324 | 324 | ||
325 | void ConWindow::closeEvent( QCloseEvent *e ){ | 325 | void ConWindow::closeEvent( QCloseEvent *e ){ |
326 | // we don't want to lose the | 326 | // we don't want to lose the |
327 | // conwindow since this is our last connection kppp. | 327 | // conwindow since this is our last connection kppp. |
328 | // if we lost it we could only kill the program by hand to get on with life. | 328 | // if we lost it we could only kill the program by hand to get on with life. |
329 | e->ignore(); | 329 | e->ignore(); |
330 | 330 | ||
331 | if(gpppdata.get_dock_into_panel()) | 331 | if(PPPData::data()->get_dock_into_panel()) |
332 | dock(); | 332 | dock(); |
333 | } | 333 | } |
334 | 334 | ||
335 | 335 | ||
336 | void ConWindow::slotAccounting(QString total, QString session) { | 336 | void ConWindow::slotAccounting(QString total, QString session) { |
337 | total_bill->setText(total); | 337 | total_bill->setText(total); |
338 | session_bill->setText(session); | 338 | session_bill->setText(session); |
339 | } | 339 | } |
340 | 340 | ||
341 | 341 | ||
diff --git a/noncore/settings/networksettings/ppp/debug.cpp b/noncore/settings/networksettings/ppp/debug.cpp index 8652931..447ccf2 100644 --- a/noncore/settings/networksettings/ppp/debug.cpp +++ b/noncore/settings/networksettings/ppp/debug.cpp | |||
@@ -1,141 +1,141 @@ | |||
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 | * Copyright (C) 1997 Bernd Wuebben | 5 | * Copyright (C) 1997 Bernd Wuebben |
6 | * wuebben@math.cornel.edu | 6 | * wuebben@math.cornel.edu |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or | 8 | * This program is free software; you can redistribute it and/or |
9 | * modify it under the terms of the GNU Library General Public | 9 | * modify it under the terms of the GNU Library General Public |
10 | * License as published by the Free Software Foundation; either | 10 | * License as published by the Free Software Foundation; either |
11 | * version 2 of the License, or (at your option) any later version. | 11 | * version 2 of the License, or (at your option) any later version. |
12 | * | 12 | * |
13 | * This program is distributed in the hope that it will be useful, | 13 | * This program is distributed in the hope that it will be useful, |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
16 | * Library General Public License for more details. | 16 | * Library General Public License for more details. |
17 | * | 17 | * |
18 | * You should have received a copy of the GNU Library General Public | 18 | * You should have received a copy of the GNU Library General Public |
19 | * License along with this program; if not, write to the Free | 19 | * License along with this program; if not, write to the Free |
20 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 20 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
21 | */ | 21 | */ |
22 | 22 | ||
23 | #include "debug.h" | 23 | #include "debug.h" |
24 | //#include "main.h" | 24 | //#include "main.h" |
25 | #include "pppdata.h" | 25 | #include "pppdata.h" |
26 | //#include <klocale.h> | 26 | //#include <klocale.h> |
27 | #define i18n QObject::tr | 27 | #define i18n QObject::tr |
28 | #include "kpppwidget.h" | 28 | #include "kpppwidget.h" |
29 | #include <assert.h> | 29 | #include <assert.h> |
30 | 30 | ||
31 | extern KPPPWidget *p_kppp; | 31 | extern KPPPWidget *p_kppp; |
32 | 32 | ||
33 | myMultiEdit::myMultiEdit(QWidget *parent, const char *name) | 33 | myMultiEdit::myMultiEdit(QWidget *parent, const char *name) |
34 | : QMultiLineEdit(parent, name) | 34 | : QMultiLineEdit(parent, name) |
35 | { | 35 | { |
36 | setReadOnly(true); | 36 | setReadOnly(true); |
37 | } | 37 | } |
38 | 38 | ||
39 | void myMultiEdit::insertChar(unsigned char c) { | 39 | void myMultiEdit::insertChar(unsigned char c) { |
40 | QMultiLineEdit::insert(QChar(c)); | 40 | QMultiLineEdit::insert(QChar(c)); |
41 | } | 41 | } |
42 | 42 | ||
43 | 43 | ||
44 | void myMultiEdit::newLine() { | 44 | void myMultiEdit::newLine() { |
45 | QMultiLineEdit::newLine(); | 45 | QMultiLineEdit::newLine(); |
46 | } | 46 | } |
47 | 47 | ||
48 | 48 | ||
49 | DebugWidget::DebugWidget(QWidget *parent, const char *name) | 49 | DebugWidget::DebugWidget(QWidget *parent, const char *name) |
50 | : QDialog(parent, name, FALSE) | 50 | : QDialog(parent, name, FALSE) |
51 | { | 51 | { |
52 | setCaption(i18n("Login Script Debug Window")); | 52 | setCaption(i18n("Login Script Debug Window")); |
53 | 53 | ||
54 | text_window = new myMultiEdit(this,"debugwindow"); | 54 | text_window = new myMultiEdit(this,"debugwindow"); |
55 | text_window->setGeometry(2,5,400, 300); | 55 | text_window->setGeometry(2,5,400, 300); |
56 | // text_window->setReadOnly(FALSE); | 56 | // text_window->setReadOnly(FALSE); |
57 | 57 | ||
58 | statuslabel = new QLabel("", this, "statuslabel"); | 58 | statuslabel = new QLabel("", this, "statuslabel"); |
59 | 59 | ||
60 | statuslabel->setFrameStyle( QFrame::Panel | QFrame::Sunken ); | 60 | statuslabel->setFrameStyle( QFrame::Panel | QFrame::Sunken ); |
61 | statuslabel->setAlignment( AlignLeft|AlignVCenter ); | 61 | statuslabel->setAlignment( AlignLeft|AlignVCenter ); |
62 | statuslabel->setGeometry(2, 307, 400, 20); | 62 | statuslabel->setGeometry(2, 307, 400, 20); |
63 | //statusPageLabel->setFont( QFont("helvetica",12,QFont::Normal) ); | 63 | //statusPageLabel->setFont( QFont("helvetica",12,QFont::Normal) ); |
64 | 64 | ||
65 | dismiss = new QPushButton(this); | 65 | dismiss = new QPushButton(this); |
66 | dismiss->setGeometry(330,340,70,30); | 66 | dismiss->setGeometry(330,340,70,30); |
67 | dismiss->setText(i18n("Close")); | 67 | dismiss->setText(i18n("Close")); |
68 | dismiss->setFocus(); | 68 | dismiss->setFocus(); |
69 | connect(dismiss, SIGNAL(clicked()), SLOT(hide())); | 69 | connect(dismiss, SIGNAL(clicked()), SLOT(hide())); |
70 | 70 | ||
71 | 71 | ||
72 | /* fline = new QFrame(this,"line"); | 72 | /* fline = new QFrame(this,"line"); |
73 | fline->setFrameStyle(QFrame::HLine |QFrame::Sunken); | 73 | fline->setFrameStyle(QFrame::HLine |QFrame::Sunken); |
74 | fline->setGeometry(2,332,398,5);*/ | 74 | fline->setGeometry(2,332,398,5);*/ |
75 | adjustSize(); | 75 | adjustSize(); |
76 | setMinimumSize(width(),height()); | 76 | setMinimumSize(width(),height()); |
77 | 77 | ||
78 | } | 78 | } |
79 | 79 | ||
80 | void DebugWidget::hideEvent(QHideEvent *) | 80 | void DebugWidget::hideEvent(QHideEvent *) |
81 | { | 81 | { |
82 | assert(p_kppp); | 82 | assert(p_kppp); |
83 | // p_kppp->con->debug->setOn(false); | 83 | // p_kppp->con->debug->setOn(false); |
84 | } | 84 | } |
85 | 85 | ||
86 | void DebugWidget::clear() { | 86 | void DebugWidget::clear() { |
87 | text_window->clear(); | 87 | text_window->clear(); |
88 | } | 88 | } |
89 | 89 | ||
90 | 90 | ||
91 | void DebugWidget::addChar(unsigned char c) { | 91 | void DebugWidget::addChar(unsigned char c) { |
92 | QString stuff; | 92 | QString stuff; |
93 | 93 | ||
94 | if(c == '\r' || c == '\n') { | 94 | if(c == '\r' || c == '\n') { |
95 | if(c == '\n') | 95 | if(c == '\n') |
96 | text_window->newLine(); | 96 | text_window->newLine(); |
97 | } else | 97 | } else |
98 | text_window->insertChar(c); | 98 | text_window->insertChar(c); |
99 | } | 99 | } |
100 | 100 | ||
101 | 101 | ||
102 | void DebugWidget::statusLabel(const QString &s) { | 102 | void DebugWidget::statusLabel(const QString &s) { |
103 | statuslabel->setText(s); | 103 | statuslabel->setText(s); |
104 | } | 104 | } |
105 | 105 | ||
106 | 106 | ||
107 | /* | 107 | /* |
108 | void DebugWidget::keyPressEvent(QKeyEvent *k) { | 108 | void DebugWidget::keyPressEvent(QKeyEvent *k) { |
109 | } | 109 | } |
110 | 110 | ||
111 | */ | 111 | */ |
112 | void DebugWidget::resizeEvent(QResizeEvent *e){ | 112 | void DebugWidget::resizeEvent(QResizeEvent *e){ |
113 | int w = width() ; | 113 | int w = width() ; |
114 | int h = height(); | 114 | int h = height(); |
115 | e = e; | 115 | e = e; |
116 | 116 | ||
117 | text_window->setGeometry(2,5,w - 2 ,h - 63); | 117 | text_window->setGeometry(2,5,w - 2 ,h - 63); |
118 | statuslabel->setGeometry(2, h - 56 , w -2 , 20); | 118 | statuslabel->setGeometry(2, h - 56 , w -2 , 20); |
119 | dismiss->setGeometry(w - 72 , h - 32, 70, 30); | 119 | dismiss->setGeometry(w - 72 , h - 32, 70, 30); |
120 | // fline->setGeometry(2,h -70 ,w - 4,5); | 120 | // fline->setGeometry(2,h -70 ,w - 4,5); |
121 | } | 121 | } |
122 | 122 | ||
123 | 123 | ||
124 | void DebugWidget::enter() { | 124 | void DebugWidget::enter() { |
125 | text_window->append("\r\n"); | 125 | text_window->append("\r\n"); |
126 | } | 126 | } |
127 | 127 | ||
128 | 128 | ||
129 | void DebugWidget::toggleVisibility() { | 129 | void DebugWidget::toggleVisibility() { |
130 | if(isVisible()) | 130 | if(isVisible()) |
131 | hide(); | 131 | hide(); |
132 | else | 132 | else |
133 | show(); | 133 | show(); |
134 | 134 | ||
135 | bool showlog = isVisible(); | 135 | bool showlog = isVisible(); |
136 | gpppdata.set_show_log_window(showlog); | 136 | PPPData::data()->set_show_log_window(showlog); |
137 | } | 137 | } |
138 | 138 | ||
139 | 139 | ||
140 | 140 | ||
141 | 141 | ||
diff --git a/noncore/settings/networksettings/ppp/edit.cpp b/noncore/settings/networksettings/ppp/edit.cpp index 961047b..6132b80 100644 --- a/noncore/settings/networksettings/ppp/edit.cpp +++ b/noncore/settings/networksettings/ppp/edit.cpp | |||
@@ -1,1193 +1,1193 @@ | |||
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 | * Copyright (C) 1997 Bernd Johannes Wuebben | 5 | * Copyright (C) 1997 Bernd Johannes Wuebben |
6 | * wuebben@math.cornell.edu | 6 | * wuebben@math.cornell.edu |
7 | * | 7 | * |
8 | * based on EzPPP: | 8 | * based on EzPPP: |
9 | * Copyright (C) 1997 Jay Painter | 9 | * Copyright (C) 1997 Jay Painter |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or | 11 | * This program is free software; you can redistribute it and/or |
12 | * modify it under the terms of the GNU Library General Public | 12 | * modify it under the terms of the GNU Library General Public |
13 | * License as published by the Free Software Foundation; either | 13 | * License as published by the Free Software Foundation; either |
14 | * version 2 of the License, or (at your option) any later version. | 14 | * version 2 of the License, or (at your option) any later version. |
15 | * | 15 | * |
16 | * This program is distributed in the hope that it will be useful, | 16 | * This program is distributed in the hope that it will be useful, |
17 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 17 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
18 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 18 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
19 | * Library General Public License for more details. | 19 | * Library General Public License for more details. |
20 | * | 20 | * |
21 | * You should have received a copy of the GNU Library General Public | 21 | * You should have received a copy of the GNU Library General Public |
22 | * License along with this program; if not, write to the Free | 22 | * License along with this program; if not, write to the Free |
23 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 23 | * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
24 | */ | 24 | */ |
25 | 25 | ||
26 | #include <string.h> | 26 | #include <string.h> |
27 | #include <termios.h> | 27 | #include <termios.h> |
28 | #include <qlayout.h> | 28 | #include <qlayout.h> |
29 | #include <qmessagebox.h> | 29 | #include <qmessagebox.h> |
30 | #include <qwhatsthis.h> | 30 | #include <qwhatsthis.h> |
31 | #include <qregexp.h> | 31 | #include <qregexp.h> |
32 | #include <qapplication.h> | 32 | #include <qapplication.h> |
33 | //#include <kiconloader.h> | 33 | //#include <kiconloader.h> |
34 | #include <qbuttongroup.h> | 34 | #include <qbuttongroup.h> |
35 | //#include <klocale.h> | 35 | //#include <klocale.h> |
36 | #define i18n QObject::tr | 36 | #define i18n QObject::tr |
37 | #include <qvgroupbox.h> | 37 | #include <qvgroupbox.h> |
38 | #include <qhbox.h> | 38 | #include <qhbox.h> |
39 | #include <qdialog.h> | 39 | #include <qdialog.h> |
40 | //#include <kwin.h> | 40 | //#include <kwin.h> |
41 | 41 | ||
42 | #include "edit.h" | 42 | #include "edit.h" |
43 | #include "pppdata.h" | 43 | #include "pppdata.h" |
44 | #include "newwidget.h" | 44 | //#include "newwidget.h" |
45 | #include "iplined.h" | 45 | #include "iplined.h" |
46 | #include "auth.h" | 46 | #include "auth.h" |
47 | 47 | ||
48 | DialWidget::DialWidget( QWidget *parent, bool isnewaccount, const char *name ) | 48 | DialWidget::DialWidget( QWidget *parent, bool isnewaccount, const char *name ) |
49 | : QWidget(parent, name) | 49 | : QWidget(parent, name) |
50 | { | 50 | { |
51 | const int GRIDROWS = 6; | 51 | const int GRIDROWS = 6; |
52 | 52 | ||
53 | QGridLayout *tl = new QGridLayout(parent, GRIDROWS, 2, 0 );//, KDialog::spacingHint()); | 53 | QGridLayout *tl = new QGridLayout(this, GRIDROWS, 2, 0 );//, KDialog::spacingHint()); |
54 | 54 | ||
55 | connect_label = new QLabel(i18n("Connection name:"), parent); | 55 | connect_label = new QLabel(i18n("Connection name:"), this); |
56 | tl->addWidget(connect_label, 0, 0); | 56 | tl->addWidget(connect_label, 0, 0); |
57 | 57 | ||
58 | connectname_l = new QLineEdit(parent); | 58 | connectname_l = new QLineEdit(this); |
59 | connectname_l->setMaxLength(ACCNAME_SIZE); | 59 | // connectname_l->setMaxLength(ACCNAME_SIZE); |
60 | tl->addWidget(connectname_l, 0, 1); | 60 | tl->addWidget(connectname_l, 0, 1); |
61 | QString tmp = i18n("Type in a unique name for this connection"); | 61 | QString tmp = i18n("Type in a unique name for this connection"); |
62 | 62 | ||
63 | QWhatsThis::add(connect_label,tmp); | 63 | QWhatsThis::add(connect_label,tmp); |
64 | QWhatsThis::add(connectname_l,tmp); | 64 | QWhatsThis::add(connectname_l,tmp); |
65 | 65 | ||
66 | 66 | ||
67 | number_label = new QLabel(i18n("Phone number:"), parent); | 67 | number_label = new QLabel(i18n("Phone number:"), this); |
68 | number_label->setAlignment(AlignTop|AlignLeft); | 68 | number_label->setAlignment(AlignTop|AlignLeft); |
69 | tl->addWidget(number_label, 1, 0); | 69 | tl->addWidget(number_label, 1, 0); |
70 | 70 | ||
71 | QHBoxLayout *lpn = new QHBoxLayout(5); | 71 | QHBoxLayout *lpn = new QHBoxLayout(5); |
72 | tl->addLayout(lpn, 1, 1); | 72 | tl->addLayout(lpn, 1, 1); |
73 | numbers = new QListBox(parent); | 73 | numbers = new QListBox(this); |
74 | numbers->setMinimumSize(120, 70); | 74 | numbers->setMinimumSize(120, 70); |
75 | lpn->addWidget(numbers); | 75 | lpn->addWidget(numbers); |
76 | QVBoxLayout *lpn1 = new QVBoxLayout; | 76 | QVBoxLayout *lpn1 = new QVBoxLayout; |
77 | lpn->addLayout(lpn1); | 77 | lpn->addLayout(lpn1); |
78 | add = new QPushButton(i18n("&Add..."), parent); | 78 | add = new QPushButton(i18n("&Add..."), this); |
79 | del = new QPushButton(i18n("&Remove"), parent); | 79 | del = new QPushButton(i18n("&Remove"), this); |
80 | 80 | ||
81 | up = new QPushButton(parent); | 81 | up = new QPushButton(this); |
82 | //FIXME: QPixmap pm = BarIcon("up"); | 82 | //FIXME: QPixmap pm = BarIcon("up"); |
83 | // up->setPixmap(pm); | 83 | // up->setPixmap(pm); |
84 | down = new QPushButton(parent); | 84 | down = new QPushButton(this); |
85 | //FIXME: pm = BarIcon("down"); | 85 | //FIXME: pm = BarIcon("down"); |
86 | // down->setPixmap(pm); | 86 | // down->setPixmap(pm); |
87 | lpn1->addWidget(add); | 87 | lpn1->addWidget(add); |
88 | lpn1->addWidget(del); | 88 | lpn1->addWidget(del); |
89 | lpn1->addStretch(1); | 89 | lpn1->addStretch(1); |
90 | lpn1->addWidget(up); | 90 | lpn1->addWidget(up); |
91 | lpn1->addWidget(down); | 91 | lpn1->addWidget(down); |
92 | connect(add, SIGNAL(clicked()), | 92 | connect(add, SIGNAL(clicked()), |
93 | this, SLOT(addNumber())); | 93 | this, SLOT(addNumber())); |
94 | connect(del, SIGNAL(clicked()), | 94 | connect(del, SIGNAL(clicked()), |
95 | this, SLOT(delNumber())); | 95 | this, SLOT(delNumber())); |
96 | connect(up, SIGNAL(clicked()), | 96 | connect(up, SIGNAL(clicked()), |
97 | this, SLOT(upNumber())); | 97 | this, SLOT(upNumber())); |
98 | connect(down, SIGNAL(clicked()), | 98 | connect(down, SIGNAL(clicked()), |
99 | this, SLOT(downNumber())); | 99 | this, SLOT(downNumber())); |
100 | connect(numbers, SIGNAL(highlighted(int)), | 100 | connect(numbers, SIGNAL(highlighted(int)), |
101 | this, SLOT(selectionChanged(int))); | 101 | this, SLOT(selectionChanged(int))); |
102 | numbersChanged(); | 102 | numbersChanged(); |
103 | 103 | ||
104 | tmp = i18n("<p>Specifies the phone numbers to dial. You\n" | 104 | tmp = i18n("<p>Specifies the phone numbers to dial. You\n" |
105 | "can supply multiple numbers here, simply\n" | 105 | "can supply multiple numbers here, simply\n" |
106 | "click on \"Add\". You can arrange the\n" | 106 | "click on \"Add\". You can arrange the\n" |
107 | "order the numbers are tried by using the\n" | 107 | "order the numbers are tried by using the\n" |
108 | "arrow buttons.\n\n" | 108 | "arrow buttons.\n\n" |
109 | "When a number is busy or fails, <i>kppp</i> will \n" | 109 | "When a number is busy or fails, <i>kppp</i> will \n" |
110 | "try the next number and so on"); | 110 | "try the next number and so on"); |
111 | 111 | ||
112 | QWhatsThis::add(number_label,tmp); | 112 | QWhatsThis::add(number_label,tmp); |
113 | QWhatsThis::add(numbers,tmp); | 113 | QWhatsThis::add(numbers,tmp); |
114 | 114 | ||
115 | auth_l = new QLabel(i18n("Authentication:"), parent); | 115 | auth_l = new QLabel(i18n("Authentication:"), this); |
116 | tl->addWidget(auth_l, 3, 0); | 116 | tl->addWidget(auth_l, 3, 0); |
117 | 117 | ||
118 | auth = new QComboBox(parent); | 118 | auth = new QComboBox(this); |
119 | auth->insertItem(i18n("Script-based")); | 119 | auth->insertItem(i18n("Script-based")); |
120 | auth->insertItem(i18n("PAP")); | 120 | auth->insertItem(i18n("PAP")); |
121 | auth->insertItem(i18n("Terminal-based")); | 121 | auth->insertItem(i18n("Terminal-based")); |
122 | auth->insertItem(i18n("CHAP")); | 122 | auth->insertItem(i18n("CHAP")); |
123 | auth->insertItem(i18n("PAP/CHAP")); | 123 | auth->insertItem(i18n("PAP/CHAP")); |
124 | tl->addWidget(auth, 3, 1); | 124 | tl->addWidget(auth, 3, 1); |
125 | tmp = i18n("<p>Specifies the method used to identify yourself to\n" | 125 | tmp = i18n("<p>Specifies the method used to identify yourself to\n" |
126 | "the PPP server. Most universities still use\n" | 126 | "the PPP server. Most universities still use\n" |
127 | "<b>Terminal</b>- or <b>Script</b>-based authentication,\n" | 127 | "<b>Terminal</b>- or <b>Script</b>-based authentication,\n" |
128 | "while most ISP use <b>PAP</b> and/or <b>CHAP</b>. If\n" | 128 | "while most ISP use <b>PAP</b> and/or <b>CHAP</b>. If\n" |
129 | "unsure, contact your ISP.\n" | 129 | "unsure, contact your ISP.\n" |
130 | "\n" | 130 | "\n" |
131 | "If you can choose between PAP and CHAP,\n" | 131 | "If you can choose between PAP and CHAP,\n" |
132 | "choose CHAP, because it's much safer. If you don't know\n" | 132 | "choose CHAP, because it's much safer. If you don't know\n" |
133 | "whether PAP or CHAP is right, choose PAP/CHAP."); | 133 | "whether PAP or CHAP is right, choose PAP/CHAP."); |
134 | 134 | ||
135 | QWhatsThis::add(auth_l,tmp); | 135 | QWhatsThis::add(auth_l,tmp); |
136 | QWhatsThis::add(auth,tmp); | 136 | QWhatsThis::add(auth,tmp); |
137 | 137 | ||
138 | store_password = new QCheckBox(i18n("Store password"), parent); | 138 | store_password = new QCheckBox(i18n("Store password"), this); |
139 | store_password->setChecked(true); | 139 | store_password->setChecked(true); |
140 | tl->addMultiCellWidget(store_password, 4, 4, 0, 1, AlignRight); | 140 | tl->addMultiCellWidget(store_password, 4, 4, 0, 1, AlignRight); |
141 | QWhatsThis::add(store_password, | 141 | QWhatsThis::add(store_password, |
142 | i18n("<p>When this is turned on, your ISP password\n" | 142 | i18n("<p>When this is turned on, your ISP password\n" |
143 | "will be saved in <i>kppp</i>'s config file, so\n" | 143 | "will be saved in <i>kppp</i>'s config file, so\n" |
144 | "you do not need to type it in every time.\n" | 144 | "you do not need to type it in every time.\n" |
145 | "\n" | 145 | "\n" |
146 | "<b><font color=\"red\">Warning:</font> your password will be stored as\n" | 146 | "<b><font color=\"red\">Warning:</font> your password will be stored as\n" |
147 | "plain text in the config file, which is\n" | 147 | "plain text in the config file, which is\n" |
148 | "readable only to you. Make sure nobody\n" | 148 | "readable only to you. Make sure nobody\n" |
149 | "gains access to this file!")); | 149 | "gains access to this file!")); |
150 | 150 | ||
151 | pppdargs = new QPushButton(i18n("Customize pppd Arguments..."), parent); | 151 | pppdargs = new QPushButton(i18n("Customize pppd Arguments..."), this); |
152 | connect(pppdargs, SIGNAL(clicked()), SLOT(pppdargsbutton())); | 152 | connect(pppdargs, SIGNAL(clicked()), SLOT(pppdargsbutton())); |
153 | tl->addMultiCellWidget(pppdargs, 5, 5, 0, 1, AlignCenter); | 153 | tl->addMultiCellWidget(pppdargs, 5, 5, 0, 1, AlignCenter); |
154 | 154 | ||
155 | // Set defaults if editing an existing connection | 155 | // Set defaults if editing an existing connection |
156 | if(!isnewaccount) { | 156 | if(!isnewaccount) { |
157 | connectname_l->setText(gpppdata.accname()); | 157 | connectname_l->setText(PPPData::data()->accname()); |
158 | 158 | ||
159 | // insert the phone numbers into the listbox | 159 | // insert the phone numbers into the listbox |
160 | QString n = gpppdata.phonenumber(); | 160 | QString n = PPPData::data()->phonenumber(); |
161 | QString tmp = ""; | 161 | QString tmp = ""; |
162 | uint idx = 0; | 162 | uint idx = 0; |
163 | while(idx != n.length()) { | 163 | while(idx != n.length()) { |
164 | if(n[idx] == ':') { | 164 | if(n[idx] == ':') { |
165 | if(tmp.length() > 0) | 165 | if(tmp.length() > 0) |
166 | numbers->insertItem(tmp); | 166 | numbers->insertItem(tmp); |
167 | tmp = ""; | 167 | tmp = ""; |
168 | } else | 168 | } else |
169 | tmp += n[idx]; | 169 | tmp += n[idx]; |
170 | idx++; | 170 | idx++; |
171 | } | 171 | } |
172 | if(tmp.length() > 0) | 172 | if(tmp.length() > 0) |
173 | numbers->insertItem(tmp); | 173 | numbers->insertItem(tmp); |
174 | 174 | ||
175 | auth->setCurrentItem(gpppdata.authMethod()); | 175 | auth->setCurrentItem(PPPData::data()->authMethod()); |
176 | store_password->setChecked(gpppdata.storePassword()); | 176 | store_password->setChecked(PPPData::data()->storePassword()); |
177 | } else { | 177 | } else { |
178 | // select PAP/CHAP as default | 178 | // select PAP/CHAP as default |
179 | auth->setCurrentItem(AUTH_PAPCHAP); | 179 | auth->setCurrentItem(AUTH_PAPCHAP); |
180 | } | 180 | } |
181 | 181 | ||
182 | numbersChanged(); | 182 | numbersChanged(); |
183 | tl->activate(); | 183 | tl->activate(); |
184 | } | 184 | } |
185 | 185 | ||
186 | 186 | ||
187 | bool DialWidget::save() { | 187 | bool DialWidget::save() { |
188 | //first check to make sure that the account name is unique! | 188 | //first check to make sure that the account name is unique! |
189 | if(connectname_l->text().isEmpty() || | 189 | if(connectname_l->text().isEmpty() || |
190 | !gpppdata.isUniqueAccname(connectname_l->text())) { | 190 | !PPPData::data()->isUniqueAccname(connectname_l->text())) { |
191 | return false; | 191 | return false; |
192 | } else { | 192 | } else { |
193 | gpppdata.setAccname(connectname_l->text()); | 193 | PPPData::data()->setAccname(connectname_l->text()); |
194 | 194 | ||
195 | QString number = ""; | 195 | QString number = ""; |
196 | for(uint i = 0; i < numbers->count(); i++) { | 196 | for(uint i = 0; i < numbers->count(); i++) { |
197 | if(i != 0) | 197 | if(i != 0) |
198 | number += ":"; | 198 | number += ":"; |
199 | number += numbers->text(i); | 199 | number += numbers->text(i); |
200 | } | 200 | } |
201 | 201 | ||
202 | gpppdata.setPhonenumber(number); | 202 | PPPData::data()->setPhonenumber(number); |
203 | gpppdata.setAuthMethod(auth->currentItem()); | 203 | PPPData::data()->setAuthMethod(auth->currentItem()); |
204 | gpppdata.setStorePassword(store_password->isChecked()); | 204 | PPPData::data()->setStorePassword(store_password->isChecked()); |
205 | return true; | 205 | return true; |
206 | } | 206 | } |
207 | } | 207 | } |
208 | 208 | ||
209 | 209 | ||
210 | void DialWidget::numbersChanged() { | 210 | void DialWidget::numbersChanged() { |
211 | int sel = numbers->currentItem(); | 211 | int sel = numbers->currentItem(); |
212 | 212 | ||
213 | del->setEnabled(sel != -1); | 213 | del->setEnabled(sel != -1); |
214 | up->setEnabled(sel != -1 && sel != 0); | 214 | up->setEnabled(sel != -1 && sel != 0); |
215 | down->setEnabled(sel != -1 && sel != (int)numbers->count()-1); | 215 | down->setEnabled(sel != -1 && sel != (int)numbers->count()-1); |
216 | } | 216 | } |
217 | 217 | ||
218 | 218 | ||
219 | void DialWidget::selectionChanged(int) { | 219 | void DialWidget::selectionChanged(int) { |
220 | numbersChanged(); | 220 | numbersChanged(); |
221 | } | 221 | } |
222 | 222 | ||
223 | 223 | ||
224 | void DialWidget::addNumber() { | 224 | void DialWidget::addNumber() { |
225 | PhoneNumberDialog dlg(this); | 225 | PhoneNumberDialog dlg(this); |
226 | if(dlg.exec()) { | 226 | if(dlg.exec()) { |
227 | numbers->insertItem(dlg.phoneNumber()); | 227 | numbers->insertItem(dlg.phoneNumber()); |
228 | numbersChanged(); | 228 | numbersChanged(); |
229 | } | 229 | } |
230 | } | 230 | } |
231 | 231 | ||
232 | 232 | ||
233 | void DialWidget::delNumber() { | 233 | void DialWidget::delNumber() { |
234 | if(numbers->currentItem() != -1) { | 234 | if(numbers->currentItem() != -1) { |
235 | numbers->removeItem(numbers->currentItem()); | 235 | numbers->removeItem(numbers->currentItem()); |
236 | numbersChanged(); | 236 | numbersChanged(); |
237 | } | 237 | } |
238 | } | 238 | } |
239 | 239 | ||
240 | 240 | ||
241 | void DialWidget::upNumber() { | 241 | void DialWidget::upNumber() { |
242 | int idx = numbers->currentItem(); | 242 | int idx = numbers->currentItem(); |
243 | if(idx != -1) { | 243 | if(idx != -1) { |
244 | QString item = numbers->text(idx); | 244 | QString item = numbers->text(idx); |
245 | numbers->removeItem(idx); | 245 | numbers->removeItem(idx); |
246 | numbers->insertItem(item, idx-1); | 246 | numbers->insertItem(item, idx-1); |
247 | numbers->setCurrentItem(idx-1); | 247 | numbers->setCurrentItem(idx-1); |
248 | numbersChanged(); | 248 | numbersChanged(); |
249 | } | 249 | } |
250 | } | 250 | } |
251 | 251 | ||
252 | 252 | ||
253 | void DialWidget::downNumber() { | 253 | void DialWidget::downNumber() { |
254 | int idx = numbers->currentItem(); | 254 | int idx = numbers->currentItem(); |
255 | if(idx != -1) { | 255 | if(idx != -1) { |
256 | QString item = numbers->text(idx); | 256 | QString item = numbers->text(idx); |
257 | numbers->removeItem(idx); | 257 | numbers->removeItem(idx); |
258 | numbers->insertItem(item, idx+1); | 258 | numbers->insertItem(item, idx+1); |
259 | numbers->setCurrentItem(idx+1); | 259 | numbers->setCurrentItem(idx+1); |
260 | numbersChanged(); | 260 | numbersChanged(); |
261 | } | 261 | } |
262 | } | 262 | } |
263 | 263 | ||
264 | 264 | ||
265 | void DialWidget::pppdargsbutton() { | 265 | void DialWidget::pppdargsbutton() { |
266 | PPPdArguments pa(this); | 266 | PPPdArguments pa(this); |
267 | pa.exec(); | 267 | pa.exec(); |
268 | } | 268 | } |
269 | 269 | ||
270 | 270 | ||
271 | 271 | ||
272 | ///////////////////////////////////////////////////////////////////////////// | 272 | ///////////////////////////////////////////////////////////////////////////// |
273 | // ExecWidget | 273 | // ExecWidget |
274 | ///////////////////////////////////////////////////////////////////////////// | 274 | ///////////////////////////////////////////////////////////////////////////// |
275 | ExecWidget::ExecWidget(QWidget *parent, bool isnewaccount, const char *name) : | 275 | ExecWidget::ExecWidget(QWidget *parent, bool isnewaccount, const char *name) : |
276 | QWidget(parent, name) | 276 | QWidget(parent, name) |
277 | { | 277 | { |
278 | QVBoxLayout *tl = new QVBoxLayout(parent, 0 );//, KDialog::spacingHint()); | 278 | QVBoxLayout *tl = new QVBoxLayout(this, 0 );//, KDialog::spacingHint()); |
279 | 279 | ||
280 | QLabel *l = new QLabel(\ | 280 | QLabel *l = new QLabel(\ |
281 | i18n("Here you can select commands to run at certain stages of the\n" | 281 | i18n("Here you can select commands to run at certain stages of the\n" |
282 | "connection. The commands are run with your real user id, so\n" | 282 | "connection. The commands are run with your real user id, so\n" |
283 | "you cannot run any commands here requiring root permissions\n" | 283 | "you cannot run any commands here requiring root permissions\n" |
284 | "(unless, of course, you are root).\n\n" | 284 | "(unless, of course, you are root).\n\n" |
285 | "Be sure to supply the whole path to the program otherwise\n" | 285 | "Be sure to supply the whole path to the program otherwise\n" |
286 | "kppp might be unable to find it."), parent); | 286 | "kppp might be unable to find it."), this); |
287 | l->setMinimumHeight(l->sizeHint().height()); | 287 | // l->setMinimumHeight(l->sizeHint().height()); |
288 | tl->addWidget(l); | 288 | tl->addWidget(l); |
289 | tl->addStretch(1); | 289 | tl->addStretch(1); |
290 | 290 | ||
291 | QGridLayout *l1 = new QGridLayout(4, 2, 10); | 291 | QGridLayout *l1 = new QGridLayout(4, 2, 10); |
292 | tl->addLayout(l1); | 292 | tl->addLayout(l1); |
293 | l1->setColStretch(0, 0); | 293 | l1->setColStretch(0, 0); |
294 | l1->setColStretch(1, 1); | 294 | l1->setColStretch(1, 1); |
295 | 295 | ||
296 | before_connect_l = new QLabel(i18n("Before connect:"), parent); | 296 | before_connect_l = new QLabel(i18n("Before connect:"), this); |
297 | before_connect_l->setAlignment(AlignVCenter); | 297 | before_connect_l->setAlignment(AlignVCenter); |
298 | l1->addWidget(before_connect_l, 0, 0); | 298 | l1->addWidget(before_connect_l, 0, 0); |
299 | before_connect = new QLineEdit(parent); | 299 | before_connect = new QLineEdit(this); |
300 | before_connect->setMaxLength(COMMAND_SIZE); | 300 | // before_connect->setMaxLength(COMMAND_SIZE); |
301 | l1->addWidget(before_connect, 0, 1); | 301 | l1->addWidget(before_connect, 0, 1); |
302 | QString tmp = i18n("Allows you to run a program <b>before</b> a connection\n" | 302 | QString tmp = i18n("Allows you to run a program <b>before</b> a connection\n" |
303 | "is established. It is called immediately before\n" | 303 | "is established. It is called immediately before\n" |
304 | "dialing has begun.\n\n" | 304 | "dialing has begun.\n\n" |
305 | "This might be useful, e.g. to stop HylaFAX blocking the\n" | 305 | "This might be useful, e.g. to stop HylaFAX blocking the\n" |
306 | "modem."); | 306 | "modem."); |
307 | 307 | ||
308 | QWhatsThis::add(before_connect_l,tmp); | 308 | QWhatsThis::add(before_connect_l,tmp); |
309 | QWhatsThis::add(before_connect,tmp); | 309 | QWhatsThis::add(before_connect,tmp); |
310 | 310 | ||
311 | command_label = new QLabel(i18n("Upon connect:"), parent); | 311 | command_label = new QLabel(i18n("Upon connect:"), this); |
312 | command_label->setAlignment(AlignVCenter); | 312 | command_label->setAlignment(AlignVCenter); |
313 | l1->addWidget(command_label, 1, 0); | 313 | l1->addWidget(command_label, 1, 0); |
314 | command = new QLineEdit(parent); | 314 | command = new QLineEdit(this); |
315 | command->setMaxLength(COMMAND_SIZE); | 315 | // command->setMaxLength(COMMAND_SIZE); |
316 | l1->addWidget(command, 1, 1); | 316 | l1->addWidget(command, 1, 1); |
317 | tmp = i18n("Allows you to run a program <b>after</b> a connection\n" | 317 | tmp = i18n("Allows you to run a program <b>after</b> a connection\n" |
318 | "is established. When your program is called, all\n" | 318 | "is established. When your program is called, all\n" |
319 | "preparations for an Internet connection are finished.\n" | 319 | "preparations for an Internet connection are finished.\n" |
320 | "\n" | 320 | "\n" |
321 | "Very useful for fetching mail and news"); | 321 | "Very useful for fetching mail and news"); |
322 | 322 | ||
323 | QWhatsThis::add(command_label,tmp); | 323 | QWhatsThis::add(command_label,tmp); |
324 | QWhatsThis::add(command,tmp); | 324 | QWhatsThis::add(command,tmp); |
325 | 325 | ||
326 | predisconnect_label = new QLabel(i18n("Before disconnect:"), | 326 | predisconnect_label = new QLabel(i18n("Before disconnect:"), |
327 | parent); | 327 | this); |
328 | predisconnect_label->setAlignment(AlignVCenter); | 328 | predisconnect_label->setAlignment(AlignVCenter); |
329 | l1->addWidget(predisconnect_label, 2, 0); | 329 | l1->addWidget(predisconnect_label, 2, 0); |
330 | predisconnect = new QLineEdit(parent); | 330 | predisconnect = new QLineEdit(this); |
331 | predisconnect->setMaxLength(COMMAND_SIZE); | 331 | // predisconnect->setMaxLength(COMMAND_SIZE); |
332 | l1->addWidget(predisconnect, 2, 1); | 332 | l1->addWidget(predisconnect, 2, 1); |
333 | tmp = i18n("Allows you to run a program <b>before</b> a connection\n" | 333 | tmp = i18n("Allows you to run a program <b>before</b> a connection\n" |
334 | "is closed. The connection will stay open until\n" | 334 | "is closed. The connection will stay open until\n" |
335 | "the program exits."); | 335 | "the program exits."); |
336 | 336 | ||
337 | QWhatsThis::add(predisconnect_label,tmp); | 337 | QWhatsThis::add(predisconnect_label,tmp); |
338 | QWhatsThis::add(predisconnect,tmp); | 338 | QWhatsThis::add(predisconnect,tmp); |
339 | 339 | ||
340 | discommand_label = new QLabel(i18n("Upon disconnect:"), | 340 | discommand_label = new QLabel(i18n("Upon disconnect:"), |
341 | parent); | 341 | this); |
342 | discommand_label->setAlignment(AlignVCenter); | 342 | discommand_label->setAlignment(AlignVCenter); |
343 | l1->addWidget(discommand_label, 3, 0); | 343 | l1->addWidget(discommand_label, 3, 0); |
344 | 344 | ||
345 | discommand = new QLineEdit(parent); | 345 | discommand = new QLineEdit(this); |
346 | discommand->setMaxLength(COMMAND_SIZE); | 346 | // discommand->setMaxLength(COMMAND_SIZE); |
347 | l1->addWidget(discommand, 3, 1); | 347 | l1->addWidget(discommand, 3, 1); |
348 | tmp = i18n("Allows you to run a program <b>after</b> a connection\n" | 348 | tmp = i18n("Allows you to run a program <b>after</b> a connection\n" |
349 | "has been closed."); | 349 | "has been closed."); |
350 | 350 | ||
351 | QWhatsThis::add(discommand_label,tmp); | 351 | QWhatsThis::add(discommand_label,tmp); |
352 | QWhatsThis::add(discommand,tmp); | 352 | QWhatsThis::add(discommand,tmp); |
353 | 353 | ||
354 | // extra space between entries | 354 | // extra space between entries |
355 | l1->addRowSpacing(1, 5); | 355 | l1->addRowSpacing(1, 5); |
356 | l1->addRowSpacing(3, 5); | 356 | l1->addRowSpacing(3, 5); |
357 | 357 | ||
358 | tl->addStretch(1); | 358 | tl->addStretch(1); |
359 | tl->activate(); | 359 | tl->activate(); |
360 | 360 | ||
361 | // Set defaults if editing an existing connection | 361 | // Set defaults if editing an existing connection |
362 | if(!isnewaccount) { | 362 | if(!isnewaccount) { |
363 | before_connect->setText(gpppdata.command_before_connect()); | 363 | before_connect->setText(PPPData::data()->command_before_connect()); |
364 | command->setText(gpppdata.command_on_connect()); | 364 | command->setText(PPPData::data()->command_on_connect()); |
365 | discommand->setText(gpppdata.command_on_disconnect()); | 365 | discommand->setText(PPPData::data()->command_on_disconnect()); |
366 | predisconnect->setText(gpppdata.command_before_disconnect()); | 366 | predisconnect->setText(PPPData::data()->command_before_disconnect()); |
367 | } | 367 | } |
368 | } | 368 | } |
369 | 369 | ||
370 | 370 | ||
371 | bool ExecWidget::save() { | 371 | bool ExecWidget::save() { |
372 | gpppdata.setCommand_before_connect(before_connect->text()); | 372 | PPPData::data()->setCommand_before_connect(before_connect->text()); |
373 | gpppdata.setCommand_on_connect(command->text()); | 373 | PPPData::data()->setCommand_on_connect(command->text()); |
374 | gpppdata.setCommand_before_disconnect(predisconnect->text()); | 374 | PPPData::data()->setCommand_before_disconnect(predisconnect->text()); |
375 | gpppdata.setCommand_on_disconnect(discommand->text()); | 375 | PPPData::data()->setCommand_on_disconnect(discommand->text()); |
376 | return true; | 376 | return true; |
377 | } | 377 | } |
378 | 378 | ||
379 | 379 | ||
380 | 380 | ||
381 | ///////////////////////////////////////////////////////////////////////////// | 381 | ///////////////////////////////////////////////////////////////////////////// |
382 | // | 382 | // |
383 | // IPWidget | 383 | // IPWidget |
384 | // | 384 | // |
385 | ///////////////////////////////////////////////////////////////////////////// | 385 | ///////////////////////////////////////////////////////////////////////////// |
386 | IPWidget::IPWidget( QWidget *parent, bool isnewaccount, const char *name ) | 386 | IPWidget::IPWidget( QWidget *parent, bool isnewaccount, const char *name ) |
387 | : QWidget(parent, name) | 387 | : QWidget(parent, name) |
388 | { | 388 | { |
389 | QVBoxLayout *topLayout = new QVBoxLayout(parent); | 389 | QVBoxLayout *topLayout = new QVBoxLayout(this); |
390 | topLayout->setSpacing( 3 );//KDialog::spacingHint()); | 390 | topLayout->setSpacing( 3 );//KDialog::spacingHint()); |
391 | 391 | ||
392 | box = new QVGroupBox(i18n("Configuration"), parent); | 392 | box = new QVGroupBox(i18n("Configuration"), this); |
393 | // box->setInsideSpacing( 1 );//KDialog::spacingHint()); | 393 | // box->setInsideSpacing( 1 );//KDialog::spacingHint()); |
394 | 394 | ||
395 | rb = new QButtonGroup(parent); | 395 | rb = new QButtonGroup(this); |
396 | rb->hide(); | 396 | rb->hide(); |
397 | connect(rb, SIGNAL(clicked(int)), | 397 | connect(rb, SIGNAL(clicked(int)), |
398 | SLOT(hitIPSelect(int))); | 398 | SLOT(hitIPSelect(int))); |
399 | 399 | ||
400 | dynamicadd_rb = new QRadioButton(box); | 400 | dynamicadd_rb = new QRadioButton(box); |
401 | dynamicadd_rb->setText(i18n("Dynamic IP address")); | 401 | dynamicadd_rb->setText(i18n("Dynamic IP address")); |
402 | QWhatsThis::add(dynamicadd_rb, | 402 | QWhatsThis::add(dynamicadd_rb, |
403 | i18n("Select this option when your computer gets an\n" | 403 | i18n("Select this option when your computer gets an\n" |
404 | "internet address (IP) every time a\n" | 404 | "internet address (IP) every time a\n" |
405 | "connection is made.\n" | 405 | "connection is made.\n" |
406 | "\n" | 406 | "\n" |
407 | "Almost every Internet Service Provider uses\n" | 407 | "Almost every Internet Service Provider uses\n" |
408 | "this method, so this should be turned on.")); | 408 | "this method, so this should be turned on.")); |
409 | 409 | ||
410 | staticadd_rb = new QRadioButton(box); | 410 | staticadd_rb = new QRadioButton(box); |
411 | staticadd_rb->setText(i18n("Static IP address")); | 411 | staticadd_rb->setText(i18n("Static IP address")); |
412 | rb->insert(dynamicadd_rb, 0); | 412 | rb->insert(dynamicadd_rb, 0); |
413 | rb->insert(staticadd_rb, 1); | 413 | rb->insert(staticadd_rb, 1); |
414 | QWhatsThis::add(staticadd_rb, | 414 | QWhatsThis::add(staticadd_rb, |
415 | i18n("Select this option when your computer has a\n" | 415 | i18n("Select this option when your computer has a\n" |
416 | "fixed internet address (IP). Most computers\n" | 416 | "fixed internet address (IP). Most computers\n" |
417 | "don't have this, so you should probably select\n" | 417 | "don't have this, so you should probably select\n" |
418 | "dynamic IP addressing unless you know what you\n" | 418 | "dynamic IP addressing unless you know what you\n" |
419 | "are doing.")); | 419 | "are doing.")); |
420 | 420 | ||
421 | QWidget *ipWidget = new QWidget(box); | 421 | QWidget *ipWidget = new QWidget(box); |
422 | QGridLayout *ipLayout = new QGridLayout(ipWidget, 2, 2); | 422 | QGridLayout *ipLayout = new QGridLayout(ipWidget, 2, 2); |
423 | ipLayout->setSpacing( 2 );//KDialog::spacingHint()); | 423 | ipLayout->setSpacing( 2 );//KDialog::spacingHint()); |
424 | 424 | ||
425 | ipaddress_label = new QLabel(i18n("IP address:"), ipWidget); | 425 | ipaddress_label = new QLabel(i18n("IP address:"), ipWidget); |
426 | QString tmp = i18n("If your computer has a permanent internet\n" | 426 | QString tmp = i18n("If your computer has a permanent internet\n" |
427 | "address, you must supply your IP address here."); | 427 | "address, you must supply your IP address here."); |
428 | ipLayout->addWidget(ipaddress_label, 0, 0); | 428 | ipLayout->addWidget(ipaddress_label, 0, 0); |
429 | 429 | ||
430 | ipaddress_l = new IPLineEdit(ipWidget); | 430 | ipaddress_l = new IPLineEdit(ipWidget); |
431 | ipLayout->addWidget(ipaddress_l, 0, 1); | 431 | ipLayout->addWidget(ipaddress_l, 0, 1); |
432 | 432 | ||
433 | QWhatsThis::add(ipaddress_label,tmp); | 433 | QWhatsThis::add(ipaddress_label,tmp); |
434 | QWhatsThis::add(ipaddress_l,tmp); | 434 | QWhatsThis::add(ipaddress_l,tmp); |
435 | 435 | ||
436 | sub_label = new QLabel(i18n("Subnet mask:"), ipWidget); | 436 | sub_label = new QLabel(i18n("Subnet mask:"), ipWidget); |
437 | tmp = i18n("<p>If your computer has a static Internet address,\n" | 437 | tmp = i18n("<p>If your computer has a static Internet address,\n" |
438 | "you must supply a network mask here. In almost\n" | 438 | "you must supply a network mask here. In almost\n" |
439 | "all cases this netmask will be <b>255.255.255.0</b>,\n" | 439 | "all cases this netmask will be <b>255.255.255.0</b>,\n" |
440 | "but your mileage may vary.\n" | 440 | "but your mileage may vary.\n" |
441 | "\n" | 441 | "\n" |
442 | "If unsure, contact your Internet Service Provider"); | 442 | "If unsure, contact your Internet Service Provider"); |
443 | ipLayout->addWidget(sub_label, 1, 0); | 443 | ipLayout->addWidget(sub_label, 1, 0); |
444 | 444 | ||
445 | subnetmask_l = new IPLineEdit(ipWidget); | 445 | subnetmask_l = new IPLineEdit(ipWidget); |
446 | ipLayout->addWidget(subnetmask_l, 1, 1); | 446 | ipLayout->addWidget(subnetmask_l, 1, 1); |
447 | 447 | ||
448 | QWhatsThis::add(sub_label,tmp); | 448 | QWhatsThis::add(sub_label,tmp); |
449 | QWhatsThis::add(subnetmask_l,tmp); | 449 | QWhatsThis::add(subnetmask_l,tmp); |
450 | 450 | ||
451 | autoname = new QCheckBox(i18n("Auto-configure hostname from this IP"), parent); | 451 | autoname = new QCheckBox(i18n("Auto-configure hostname from this IP"), this); |
452 | autoname->setChecked(gpppdata.autoname()); | 452 | autoname->setChecked(PPPData::data()->autoname()); |
453 | connect(autoname,SIGNAL(toggled(bool)), | 453 | connect(autoname,SIGNAL(toggled(bool)), |
454 | this,SLOT(autoname_t(bool))); | 454 | this,SLOT(autoname_t(bool))); |
455 | 455 | ||
456 | QWhatsThis::add(autoname, | 456 | QWhatsThis::add(autoname, |
457 | i18n("<p>Whenever you connect, this reconfigures\n" | 457 | i18n("<p>Whenever you connect, this reconfigures\n" |
458 | "your hostname to match the IP address you\n" | 458 | "your hostname to match the IP address you\n" |
459 | "got from the PPP server. This may be useful\n" | 459 | "got from the PPP server. This may be useful\n" |
460 | "if you need to use a protocol which depends\n" | 460 | "if you need to use a protocol which depends\n" |
461 | "on this information, but it can also cause several\n" | 461 | "on this information, but it can also cause several\n" |
462 | "<a href=\"kppp-7.html#autohostname\">problems</a>.\n" | 462 | "<a href=\"kppp-7.html#autohostname\">problems</a>.\n" |
463 | "\n" | 463 | "\n" |
464 | "Don't enable this unless you really need it.")); | 464 | "Don't enable this unless you really need it.")); |
465 | 465 | ||
466 | topLayout->addWidget(box); | 466 | topLayout->addWidget(box); |
467 | topLayout->addWidget(autoname); | 467 | topLayout->addWidget(autoname); |
468 | topLayout->addStretch(); | 468 | topLayout->addStretch(); |
469 | 469 | ||
470 | //load info from gpppdata | 470 | //load info from gpppdata |
471 | if(!isnewaccount) { | 471 | if(!isnewaccount) { |
472 | if(gpppdata.ipaddr() == "0.0.0.0" && | 472 | if(PPPData::data()->ipaddr() == "0.0.0.0" && |
473 | gpppdata.subnetmask() == "0.0.0.0") { | 473 | PPPData::data()->subnetmask() == "0.0.0.0") { |
474 | dynamicadd_rb->setChecked(true); | 474 | dynamicadd_rb->setChecked(true); |
475 | hitIPSelect(0); | 475 | hitIPSelect(0); |
476 | autoname->setChecked(gpppdata.autoname()); | 476 | autoname->setChecked(PPPData::data()->autoname()); |
477 | } | 477 | } |
478 | else { | 478 | else { |
479 | ipaddress_l->setText(gpppdata.ipaddr()); | 479 | ipaddress_l->setText(PPPData::data()->ipaddr()); |
480 | subnetmask_l->setText(gpppdata.subnetmask()); | 480 | subnetmask_l->setText(PPPData::data()->subnetmask()); |
481 | staticadd_rb->setChecked(true); | 481 | staticadd_rb->setChecked(true); |
482 | autoname->setChecked(false); | 482 | autoname->setChecked(false); |
483 | } | 483 | } |
484 | } | 484 | } |
485 | else { | 485 | else { |
486 | dynamicadd_rb->setChecked(true); | 486 | dynamicadd_rb->setChecked(true); |
487 | hitIPSelect(0); | 487 | hitIPSelect(0); |
488 | } | 488 | } |
489 | 489 | ||
490 | } | 490 | } |
491 | 491 | ||
492 | void IPWidget::autoname_t(bool on) { | 492 | void IPWidget::autoname_t(bool on) { |
493 | static bool was_warned = false; | 493 | static bool was_warned = false; |
494 | 494 | ||
495 | // big-fat warning when selecting the auto configure hostname option | 495 | // big-fat warning when selecting the auto configure hostname option |
496 | if(on && !was_warned) { | 496 | if(on && !was_warned) { |
497 | QMessageBox::information(this, | 497 | QMessageBox::information(this, |
498 | i18n("Selecting this option might cause some weird " | 498 | i18n("Selecting this option might cause some weird " |
499 | "problems with the X-server and applications " | 499 | "problems with the X-server and applications " |
500 | "while kppp is connected. Don't use it until " | 500 | "while kppp is connected. Don't use it until " |
501 | "you know what you are doing!\n" | 501 | "you know what you are doing!\n" |
502 | "For more information take a look at the " | 502 | "For more information take a look at the " |
503 | "handbook (or help) in the section \"Frequently " | 503 | "handbook (or help) in the section \"Frequently " |
504 | "asked questions\"."), | 504 | "asked questions\"."), |
505 | i18n("Warning")); | 505 | i18n("Warning")); |
506 | was_warned = true; | 506 | was_warned = true; |
507 | } | 507 | } |
508 | } | 508 | } |
509 | 509 | ||
510 | 510 | ||
511 | void IPWidget::save() { | 511 | void IPWidget::save() { |
512 | if(dynamicadd_rb->isChecked()) { | 512 | if(dynamicadd_rb->isChecked()) { |
513 | gpppdata.setIpaddr("0.0.0.0"); | 513 | PPPData::data()->setIpaddr("0.0.0.0"); |
514 | gpppdata.setSubnetmask("0.0.0.0"); | 514 | PPPData::data()->setSubnetmask("0.0.0.0"); |
515 | } else { | 515 | } else { |
516 | gpppdata.setIpaddr(ipaddress_l->text()); | 516 | PPPData::data()->setIpaddr(ipaddress_l->text()); |
517 | gpppdata.setSubnetmask(subnetmask_l->text()); | 517 | PPPData::data()->setSubnetmask(subnetmask_l->text()); |
518 | } | 518 | } |
519 | gpppdata.setAutoname(autoname->isChecked()); | 519 | PPPData::data()->setAutoname(autoname->isChecked()); |
520 | } | 520 | } |
521 | 521 | ||
522 | 522 | ||
523 | void IPWidget::hitIPSelect( int i ) { | 523 | void IPWidget::hitIPSelect( int i ) { |
524 | if(i == 0) { | 524 | if(i == 0) { |
525 | ipaddress_label->setEnabled(false); | 525 | ipaddress_label->setEnabled(false); |
526 | sub_label->setEnabled(false); | 526 | sub_label->setEnabled(false); |
527 | ipaddress_l->setEnabled(false); | 527 | ipaddress_l->setEnabled(false); |
528 | subnetmask_l->setEnabled(false); | 528 | subnetmask_l->setEnabled(false); |
529 | } | 529 | } |
530 | else { | 530 | else { |
531 | ipaddress_label->setEnabled(true); | 531 | ipaddress_label->setEnabled(true); |
532 | sub_label->setEnabled(true); | 532 | sub_label->setEnabled(true); |
533 | ipaddress_l->setEnabled(true); | 533 | ipaddress_l->setEnabled(true); |
534 | subnetmask_l->setEnabled(true); | 534 | subnetmask_l->setEnabled(true); |
535 | } | 535 | } |
536 | } | 536 | } |
537 | 537 | ||
538 | 538 | ||
539 | 539 | ||
540 | DNSWidget::DNSWidget( QWidget *parent, bool isnewaccount, const char *name ) | 540 | DNSWidget::DNSWidget( QWidget *parent, bool isnewaccount, const char *name ) |
541 | : QWidget(parent, name) | 541 | : QWidget(parent, name) |
542 | { | 542 | { |
543 | // box = new QGroupBox(parent); | 543 | // box = new QGroupBox(this); |
544 | QGridLayout *tl = new QGridLayout(parent, 7, 2, 0 );//, KDialog::spacingHint()); | 544 | QGridLayout *tl = new QGridLayout(this, 7, 2, 0 );//, KDialog::spacingHint()); |
545 | 545 | ||
546 | dnsdomain_label = new QLabel(i18n("Domain name:"), parent); | 546 | dnsdomain_label = new QLabel(i18n("Domain name:"), this); |
547 | tl->addWidget(dnsdomain_label, 0, 0); | 547 | tl->addWidget(dnsdomain_label, 0, 0); |
548 | 548 | ||
549 | dnsdomain = new QLineEdit(parent); | 549 | dnsdomain = new QLineEdit(this); |
550 | dnsdomain->setMaxLength(DOMAIN_SIZE); | 550 | // dnsdomain->setMaxLength(DOMAIN_SIZE); |
551 | tl->addWidget(dnsdomain, 0, 1); | 551 | tl->addWidget(dnsdomain, 0, 1); |
552 | QString tmp = i18n("If you enter a domain name here, this domain\n" | 552 | QString tmp = i18n("If you enter a domain name here, this domain\n" |
553 | "name is used for your computer while you are\n" | 553 | "name is used for your computer while you are\n" |
554 | "connected. When the connection is closed, the\n" | 554 | "connected. When the connection is closed, the\n" |
555 | "original domain name of your computer is\n" | 555 | "original domain name of your computer is\n" |
556 | "restored.\n" | 556 | "restored.\n" |
557 | "\n" | 557 | "\n" |
558 | "If you leave this field blank, no changes are\n" | 558 | "If you leave this field blank, no changes are\n" |
559 | "made to the domain name."); | 559 | "made to the domain name."); |
560 | 560 | ||
561 | QWhatsThis::add(dnsdomain_label,tmp); | 561 | QWhatsThis::add(dnsdomain_label,tmp); |
562 | QWhatsThis::add(dnsdomain,tmp); | 562 | QWhatsThis::add(dnsdomain,tmp); |
563 | 563 | ||
564 | conf_label = new QLabel(i18n("Configuration:"), parent); | 564 | conf_label = new QLabel(i18n("Configuration:"), this); |
565 | tl->addWidget(conf_label, 1, 0); | 565 | tl->addWidget(conf_label, 1, 0); |
566 | 566 | ||
567 | bg = new QButtonGroup("Group", this); | 567 | bg = new QButtonGroup("Group", this); |
568 | connect(bg, SIGNAL(clicked(int)), SLOT(DNS_Mode_Selected(int))); | 568 | connect(bg, SIGNAL(clicked(int)), SLOT(DNS_Mode_Selected(int))); |
569 | bg->hide(); | 569 | bg->hide(); |
570 | 570 | ||
571 | autodns = new QRadioButton(i18n("Automatic"), parent); | 571 | autodns = new QRadioButton(i18n("Automatic"), this); |
572 | bg->insert(autodns, 0); | 572 | bg->insert(autodns, 0); |
573 | tl->addWidget(autodns, 1, 1); | 573 | tl->addWidget(autodns, 1, 1); |
574 | // no automatic DNS detection for pppd < 2.3.7 | 574 | // no automatic DNS detection for pppd < 2.3.7 |
575 | if(!gpppdata.pppdVersionMin(2, 3, 7)) | 575 | if(!PPPData::data()->pppdVersionMin(2, 3, 7)) |
576 | autodns->setEnabled(false); | 576 | autodns->setEnabled(false); |
577 | 577 | ||
578 | mandns = new QRadioButton(i18n("Manual"), parent); | 578 | mandns = new QRadioButton(i18n("Manual"), this); |
579 | bg->insert(mandns, 1); | 579 | bg->insert(mandns, 1); |
580 | tl->addWidget(mandns, 2, 1); | 580 | tl->addWidget(mandns, 2, 1); |
581 | 581 | ||
582 | dns_label = new QLabel(i18n("DNS IP address:"), parent); | 582 | dns_label = new QLabel(i18n("DNS IP address:"), this); |
583 | tl->addWidget(dns_label, 3, 0); | 583 | tl->addWidget(dns_label, 3, 0); |
584 | 584 | ||
585 | QHBoxLayout *l2 = new QHBoxLayout; | 585 | QHBoxLayout *l2 = new QHBoxLayout; |
586 | tl->addLayout(l2, 3, 1); | 586 | tl->addLayout(l2, 3, 1); |
587 | dnsipaddr = new IPLineEdit(parent); | 587 | dnsipaddr = new IPLineEdit(this); |
588 | connect(dnsipaddr, SIGNAL(returnPressed()), | 588 | connect(dnsipaddr, SIGNAL(returnPressed()), |
589 | SLOT(adddns())); | 589 | SLOT(adddns())); |
590 | connect(dnsipaddr, SIGNAL(textChanged(const QString &)), | 590 | connect(dnsipaddr, SIGNAL(textChanged(const QString &)), |
591 | SLOT(DNS_Edit_Changed(const QString &))); | 591 | SLOT(DNS_Edit_Changed(const QString &))); |
592 | l2->addWidget(dnsipaddr, 1); | 592 | l2->addWidget(dnsipaddr, 1); |
593 | l2->addStretch(1); | 593 | l2->addStretch(1); |
594 | tmp = i18n("<p>Allows you to specify a new DNS server to be\n" | 594 | tmp = i18n("<p>Allows you to specify a new DNS server to be\n" |
595 | "used while you are connected. When the\n" | 595 | "used while you are connected. When the\n" |
596 | "connection is closed, this DNS entry will be\n" | 596 | "connection is closed, this DNS entry will be\n" |
597 | "removed again.\n" | 597 | "removed again.\n" |
598 | "\n" | 598 | "\n" |
599 | "To add a DNS server, type in the IP address of\n" | 599 | "To add a DNS server, type in the IP address of\n" |
600 | "the DNS server here and click on <b>Add</b>"); | 600 | "the DNS server here and click on <b>Add</b>"); |
601 | 601 | ||
602 | QWhatsThis::add(dns_label, tmp); | 602 | QWhatsThis::add(dns_label, tmp); |
603 | QWhatsThis::add(dnsipaddr, tmp); | 603 | QWhatsThis::add(dnsipaddr, tmp); |
604 | 604 | ||
605 | QHBoxLayout *l1 = new QHBoxLayout; | 605 | QHBoxLayout *l1 = new QHBoxLayout; |
606 | tl->addLayout(l1, 4, 1); | 606 | tl->addLayout(l1, 4, 1); |
607 | add = new QPushButton(i18n("Add"), parent); | 607 | add = new QPushButton(i18n("Add"), this); |
608 | connect(add, SIGNAL(clicked()), SLOT(adddns())); | 608 | connect(add, SIGNAL(clicked()), SLOT(adddns())); |
609 | int width = add->sizeHint().width(); | 609 | // int width = add->sizeHint().width(); |
610 | width = QMAX(width,60); | 610 | // width = QMAX(width,60); |
611 | add->setMinimumWidth(width); | 611 | // add->setMinimumWidth(width); |
612 | l1->addWidget(add); | 612 | l1->addWidget(add); |
613 | l1->addStretch(1); | 613 | l1->addStretch(1); |
614 | QWhatsThis::add(add, | 614 | QWhatsThis::add(add, |
615 | i18n("Click this button to add the DNS server\n" | 615 | i18n("Click this button to add the DNS server\n" |
616 | "specified in the field above. The entry\n" | 616 | "specified in the field above. The entry\n" |
617 | "will then be added to the list below")); | 617 | "will then be added to the list below")); |
618 | 618 | ||
619 | remove = new QPushButton(i18n("Remove"), parent); | 619 | remove = new QPushButton(i18n("Remove"), this); |
620 | connect(remove, SIGNAL(clicked()), SLOT(removedns())); | 620 | connect(remove, SIGNAL(clicked()), SLOT(removedns())); |
621 | width = remove->sizeHint().width(); | 621 | // width = remove->sizeHint().width(); |
622 | width = QMAX(width,60); | 622 | // width = QMAX(width,60); |
623 | remove->setMinimumWidth(width); | 623 | // remove->setMinimumWidth(width); |
624 | l1->addWidget(remove); | 624 | l1->addWidget(remove); |
625 | QWhatsThis::add(remove, | 625 | QWhatsThis::add(remove, |
626 | i18n("Click this button to remove the selected DNS\n" | 626 | i18n("Click this button to remove the selected DNS\n" |
627 | "server entry from the list below")); | 627 | "server entry from the list below")); |
628 | 628 | ||
629 | servers_label = new QLabel(i18n("DNS address list:"), parent); | 629 | servers_label = new QLabel(i18n("DNS address list:"), this); |
630 | servers_label->setAlignment(AlignTop|AlignLeft); | 630 | servers_label->setAlignment(AlignTop|AlignLeft); |
631 | tl->addWidget(servers_label, 5, 0); | 631 | tl->addWidget(servers_label, 5, 0); |
632 | 632 | ||
633 | dnsservers = new QListBox(parent); | 633 | dnsservers = new QListBox(this); |
634 | dnsservers->setMinimumSize(150, 80); | 634 | dnsservers->setMinimumSize(150, 80); |
635 | connect(dnsservers, SIGNAL(highlighted(int)), | 635 | connect(dnsservers, SIGNAL(highlighted(int)), |
636 | SLOT(DNS_Entry_Selected(int))); | 636 | SLOT(DNS_Entry_Selected(int))); |
637 | tl->addWidget(dnsservers, 5, 1); | 637 | tl->addWidget(dnsservers, 5, 1); |
638 | tmp = i18n("<p>This shows all defined DNS servers to use\n" | 638 | tmp = i18n("<p>This shows all defined DNS servers to use\n" |
639 | "while you are connected. Use the <b>Add</b> and\n" | 639 | "while you are connected. Use the <b>Add</b> and\n" |
640 | "<b>Remove</b> buttons to modify the list"); | 640 | "<b>Remove</b> buttons to modify the list"); |
641 | 641 | ||
642 | QWhatsThis::add(servers_label,tmp); | 642 | QWhatsThis::add(servers_label,tmp); |
643 | QWhatsThis::add(dnsservers,tmp); | 643 | QWhatsThis::add(dnsservers,tmp); |
644 | 644 | ||
645 | exdnsdisabled_toggle = new QCheckBox(i18n( \ | 645 | exdnsdisabled_toggle = new QCheckBox(i18n( \ |
646 | "Disable existing DNS servers during connection"), | 646 | "Disable existing DNS servers during connection"), |
647 | parent); | 647 | this); |
648 | exdnsdisabled_toggle->setChecked(gpppdata.exDNSDisabled()); | 648 | exdnsdisabled_toggle->setChecked(PPPData::data()->exDNSDisabled()); |
649 | tl->addMultiCellWidget(exdnsdisabled_toggle, 6, 6, 0, 1, AlignCenter); | 649 | tl->addMultiCellWidget(exdnsdisabled_toggle, 6, 6, 0, 1, AlignCenter); |
650 | QWhatsThis::add(exdnsdisabled_toggle, | 650 | QWhatsThis::add(exdnsdisabled_toggle, |
651 | i18n("<p>When this option is selected, all DNS\n" | 651 | i18n("<p>When this option is selected, all DNS\n" |
652 | "servers specified in <tt>/etc/resolv.conf</tt> are\n" | 652 | "servers specified in <tt>/etc/resolv.conf</tt> are\n" |
653 | "temporary disabled while the dialup connection\n" | 653 | "temporary disabled while the dialup connection\n" |
654 | "is established. After the connection is\n" | 654 | "is established. After the connection is\n" |
655 | "closed, the servers will be re-enabled\n" | 655 | "closed, the servers will be re-enabled\n" |
656 | "\n" | 656 | "\n" |
657 | "Typically, there is no reason to use this\n" | 657 | "Typically, there is no reason to use this\n" |
658 | "option, but it may become useful under \n" | 658 | "option, but it may become useful under \n" |
659 | "some circumstances.")); | 659 | "some circumstances.")); |
660 | 660 | ||
661 | 661 | ||
662 | // restore data if editing | 662 | // restore data if editing |
663 | if(!isnewaccount) { | 663 | if(!isnewaccount) { |
664 | dnsservers->insertStringList(gpppdata.dns()); | 664 | dnsservers->insertStringList(PPPData::data()->dns()); |
665 | dnsdomain->setText(gpppdata.domain()); | 665 | dnsdomain->setText(PPPData::data()->domain()); |
666 | } | 666 | } |
667 | 667 | ||
668 | int mode = gpppdata.autoDNS() ? 0 : 1; | 668 | int mode = PPPData::data()->autoDNS() ? 0 : 1; |
669 | bg->setButton(mode); | 669 | bg->setButton(mode); |
670 | DNS_Mode_Selected(mode); | 670 | DNS_Mode_Selected(mode); |
671 | 671 | ||
672 | tl->activate(); | 672 | tl->activate(); |
673 | } | 673 | } |
674 | 674 | ||
675 | void DNSWidget::DNS_Edit_Changed(const QString &text) { | 675 | void DNSWidget::DNS_Edit_Changed(const QString &text) { |
676 | QRegExp r("[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+"); | 676 | QRegExp r("[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+"); |
677 | add->setEnabled(text.find(r) != -1); | 677 | add->setEnabled(text.find(r) != -1); |
678 | } | 678 | } |
679 | 679 | ||
680 | void DNSWidget::DNS_Entry_Selected(int) { | 680 | void DNSWidget::DNS_Entry_Selected(int) { |
681 | remove->setEnabled(true); | 681 | remove->setEnabled(true); |
682 | } | 682 | } |
683 | 683 | ||
684 | void DNSWidget::DNS_Mode_Selected(int mode) { | 684 | void DNSWidget::DNS_Mode_Selected(int mode) { |
685 | bool on = (mode == 1); | 685 | bool on = (mode == 1); |
686 | dns_label->setEnabled(on); | 686 | dns_label->setEnabled(on); |
687 | servers_label->setEnabled(on); | 687 | servers_label->setEnabled(on); |
688 | dnsipaddr->setText(""); | 688 | dnsipaddr->setText(""); |
689 | dnsipaddr->setEnabled(on); | 689 | dnsipaddr->setEnabled(on); |
690 | add->setEnabled(false); | 690 | add->setEnabled(false); |
691 | remove->setEnabled(dnsservers->count()>0 && on); | 691 | remove->setEnabled(dnsservers->count()>0 && on); |
692 | dnsservers->clearSelection(); | 692 | dnsservers->clearSelection(); |
693 | dnsservers->setEnabled(on); | 693 | dnsservers->setEnabled(on); |
694 | dnsservers->triggerUpdate(false); | 694 | dnsservers->triggerUpdate(false); |
695 | } | 695 | } |
696 | 696 | ||
697 | void DNSWidget::save() { | 697 | void DNSWidget::save() { |
698 | gpppdata.setAutoDNS(bg->id(bg->selected()) == 0); | 698 | PPPData::data()->setAutoDNS(bg->id(bg->selected()) == 0); |
699 | QStringList serverlist; | 699 | QStringList serverlist; |
700 | for(uint i=0; i < dnsservers->count(); i++) | 700 | for(uint i=0; i < dnsservers->count(); i++) |
701 | serverlist.append(dnsservers->text(i)); | 701 | serverlist.append(dnsservers->text(i)); |
702 | gpppdata.setDns(serverlist); | 702 | PPPData::data()->setDns(serverlist); |
703 | 703 | ||
704 | // strip leading dot | 704 | // strip leading dot |
705 | QString s(dnsdomain->text()); | 705 | QString s(dnsdomain->text()); |
706 | if(s.left(1) == ".") | 706 | if(s.left(1) == ".") |
707 | gpppdata.setDomain(s.mid(1)); | 707 | PPPData::data()->setDomain(s.mid(1)); |
708 | else | 708 | else |
709 | gpppdata.setDomain(dnsdomain->text()); | 709 | PPPData::data()->setDomain(dnsdomain->text()); |
710 | 710 | ||
711 | gpppdata.setExDNSDisabled(exdnsdisabled_toggle->isChecked()); | 711 | PPPData::data()->setExDNSDisabled(exdnsdisabled_toggle->isChecked()); |
712 | } | 712 | } |
713 | 713 | ||
714 | 714 | ||
715 | void DNSWidget::adddns() { | 715 | void DNSWidget::adddns() { |
716 | if(dnsservers->count() < MAX_DNS_ENTRIES) { | 716 | if(dnsservers->count() < MAX_DNS_ENTRIES) { |
717 | dnsservers->insertItem(dnsipaddr->text()); | 717 | dnsservers->insertItem(dnsipaddr->text()); |
718 | dnsipaddr->setText(""); | 718 | dnsipaddr->setText(""); |
719 | } | 719 | } |
720 | } | 720 | } |
721 | 721 | ||
722 | 722 | ||
723 | void DNSWidget::removedns() { | 723 | void DNSWidget::removedns() { |
724 | int i; | 724 | int i; |
725 | i = dnsservers->currentItem(); | 725 | i = dnsservers->currentItem(); |
726 | if(i != -1) | 726 | if(i != -1) |
727 | dnsservers->removeItem(i); | 727 | dnsservers->removeItem(i); |
728 | remove->setEnabled(dnsservers->count()>0); | 728 | remove->setEnabled(dnsservers->count()>0); |
729 | } | 729 | } |
730 | 730 | ||
731 | 731 | ||
732 | // | 732 | // |
733 | // GatewayWidget | 733 | // GatewayWidget |
734 | // | 734 | // |
735 | GatewayWidget::GatewayWidget( QWidget *parent, bool isnewaccount, const char *name ) | 735 | GatewayWidget::GatewayWidget( QWidget *parent, bool isnewaccount, const char *name ) |
736 | : QWidget(parent, name) | 736 | : QWidget(parent, name) |
737 | { | 737 | { |
738 | QVBoxLayout *topLayout = new QVBoxLayout(parent); | 738 | QVBoxLayout *topLayout = new QVBoxLayout(this); |
739 | topLayout->setSpacing( 2 );//KDialog::spacingHint()); | 739 | topLayout->setSpacing( 2 );//KDialog::spacingHint()); |
740 | 740 | ||
741 | box = new QVGroupBox(i18n("Configuration"), parent); | 741 | box = new QVGroupBox(i18n("Configuration"), this); |
742 | // box->setInsideSpacing( 2 );//KDialog::spacingHint()); | 742 | // box->setInsideSpacing( 2 );//KDialog::spacingHint()); |
743 | 743 | ||
744 | rb = new QButtonGroup(parent); | 744 | rb = new QButtonGroup(this); |
745 | rb->hide(); | 745 | rb->hide(); |
746 | connect(rb, SIGNAL(clicked(int)), SLOT(hitGatewaySelect(int))); | 746 | connect(rb, SIGNAL(clicked(int)), SLOT(hitGatewaySelect(int))); |
747 | 747 | ||
748 | defaultgateway = new QRadioButton(box); | 748 | defaultgateway = new QRadioButton(box); |
749 | defaultgateway->setText(i18n("Default gateway")); | 749 | defaultgateway->setText(i18n("Default gateway")); |
750 | rb->insert(defaultgateway, 0); | 750 | rb->insert(defaultgateway, 0); |
751 | QWhatsThis::add(defaultgateway, | 751 | QWhatsThis::add(defaultgateway, |
752 | i18n("This makes the PPP peer computer (the computer\n" | 752 | i18n("This makes the PPP peer computer (the computer\n" |
753 | "you are connected to with your modem) to act as\n" | 753 | "you are connected to with your modem) to act as\n" |
754 | "a gateway. Your computer will send all packets not\n" | 754 | "a gateway. Your computer will send all packets not\n" |
755 | "going to a computer inside your local net to this\n" | 755 | "going to a computer inside your local net to this\n" |
756 | "computer, which will route these packets.\n" | 756 | "computer, which will route these packets.\n" |
757 | "\n" | 757 | "\n" |
758 | "This is the default for most ISPs, so you should\n" | 758 | "This is the default for most ISPs, so you should\n" |
759 | "probably leave this option on.")); | 759 | "probably leave this option on.")); |
760 | 760 | ||
761 | 761 | ||
762 | staticgateway = new QRadioButton(box); | 762 | staticgateway = new QRadioButton(box); |
763 | staticgateway->setText(i18n("Static gateway")); | 763 | staticgateway->setText(i18n("Static gateway")); |
764 | rb->insert(staticgateway, 1); | 764 | rb->insert(staticgateway, 1); |
765 | QWhatsThis::add(staticgateway, | 765 | QWhatsThis::add(staticgateway, |
766 | i18n("<p>Allows you to specify which computer you want\n" | 766 | i18n("<p>Allows you to specify which computer you want\n" |
767 | "to use as gateway (see <i>Default Gateway</i> above)")); | 767 | "to use as gateway (see <i>Default Gateway</i> above)")); |
768 | 768 | ||
769 | QHBox *gateBox = new QHBox(box); | 769 | QHBox *gateBox = new QHBox(box); |
770 | gate_label = new QLabel(i18n("Gateway IP address:"), gateBox); | 770 | gate_label = new QLabel(i18n("Gateway IP address:"), gateBox); |
771 | gatewayaddr = new IPLineEdit(gateBox); | 771 | gatewayaddr = new IPLineEdit(gateBox); |
772 | 772 | ||
773 | defaultroute = new QCheckBox(i18n("Assign the default route to this gateway"), | 773 | defaultroute = new QCheckBox(i18n("Assign the default route to this gateway"), |
774 | parent); | 774 | this); |
775 | QWhatsThis::add(defaultroute, | 775 | QWhatsThis::add(defaultroute, |
776 | i18n("If this option is enabled, all packets not\n" | 776 | i18n("If this option is enabled, all packets not\n" |
777 | "going to the local net are routed through\n" | 777 | "going to the local net are routed through\n" |
778 | "the PPP connection.\n" | 778 | "the PPP connection.\n" |
779 | "\n" | 779 | "\n" |
780 | "Normally, you should turn this on")); | 780 | "Normally, you should turn this on")); |
781 | 781 | ||
782 | topLayout->addWidget(box); | 782 | topLayout->addWidget(box); |
783 | topLayout->addWidget(defaultroute); | 783 | topLayout->addWidget(defaultroute); |
784 | topLayout->addStretch(); | 784 | topLayout->addStretch(); |
785 | 785 | ||
786 | //load info from gpppdata | 786 | //load info from gpppdata |
787 | if(!isnewaccount) { | 787 | if(!isnewaccount) { |
788 | if(gpppdata.gateway() == "0.0.0.0") { | 788 | if(PPPData::data()->gateway() == "0.0.0.0") { |
789 | defaultgateway->setChecked(true); | 789 | defaultgateway->setChecked(true); |
790 | hitGatewaySelect(0); | 790 | hitGatewaySelect(0); |
791 | } | 791 | } |
792 | else { | 792 | else { |
793 | gatewayaddr->setText(gpppdata.gateway()); | 793 | gatewayaddr->setText(PPPData::data()->gateway()); |
794 | staticgateway->setChecked(true); | 794 | staticgateway->setChecked(true); |
795 | } | 795 | } |
796 | defaultroute->setChecked(gpppdata.defaultroute()); | 796 | defaultroute->setChecked(PPPData::data()->defaultroute()); |
797 | } | 797 | } |
798 | else { | 798 | else { |
799 | defaultgateway->setChecked(true); | 799 | defaultgateway->setChecked(true); |
800 | hitGatewaySelect(0); | 800 | hitGatewaySelect(0); |
801 | defaultroute->setChecked(true); | 801 | defaultroute->setChecked(true); |
802 | } | 802 | } |
803 | } | 803 | } |
804 | 804 | ||
805 | void GatewayWidget::save() { | 805 | void GatewayWidget::save() { |
806 | gpppdata.setGateway(gatewayaddr->text()); | 806 | PPPData::data()->setGateway(gatewayaddr->text()); |
807 | gpppdata.setDefaultroute(defaultroute->isChecked()); | 807 | PPPData::data()->setDefaultroute(defaultroute->isChecked()); |
808 | } | 808 | } |
809 | 809 | ||
810 | 810 | ||
811 | void GatewayWidget::hitGatewaySelect( int i ) { | 811 | void GatewayWidget::hitGatewaySelect( int i ) { |
812 | if(i == 0) { | 812 | if(i == 0) { |
813 | gatewayaddr->setText("0.0.0.0"); | 813 | gatewayaddr->setText("0.0.0.0"); |
814 | gatewayaddr->setEnabled(false); | 814 | gatewayaddr->setEnabled(false); |
815 | gate_label->setEnabled(false); | 815 | gate_label->setEnabled(false); |
816 | } | 816 | } |
817 | else { | 817 | else { |
818 | gatewayaddr->setEnabled(true); | 818 | gatewayaddr->setEnabled(true); |
819 | gatewayaddr->setText(""); | 819 | gatewayaddr->setText(""); |
820 | gate_label->setEnabled(true); | 820 | gate_label->setEnabled(true); |
821 | } | 821 | } |
822 | } | 822 | } |
823 | 823 | ||
824 | 824 | ||
825 | 825 | ||
826 | ScriptWidget::ScriptWidget( QWidget *parent, bool isnewaccount, const char *name ) | 826 | ScriptWidget::ScriptWidget( QWidget *parent, bool isnewaccount, const char *name ) |
827 | : QWidget(parent, name) | 827 | : QWidget(parent, name) |
828 | { | 828 | { |
829 | QVBoxLayout *tl = new QVBoxLayout(parent, 0 );//, KDialog::spacingHint()); | 829 | QVBoxLayout *tl = new QVBoxLayout(this, 0 );//, KDialog::spacingHint()); |
830 | se = new ScriptEdit(parent); | 830 | se = new ScriptEdit(this); |
831 | connect(se, SIGNAL(returnPressed()), SLOT(addButton())); | 831 | connect(se, SIGNAL(returnPressed()), SLOT(addButton())); |
832 | tl->addWidget(se); | 832 | tl->addWidget(se); |
833 | 833 | ||
834 | // insert equal-sized buttons | 834 | // insert equal-sized buttons |
835 | QButtonGroup *bbox = new QButtonGroup(parent); | 835 | QButtonGroup *bbox = new QButtonGroup(this); |
836 | add = new QPushButton( bbox, i18n("Add") ); | 836 | add = new QPushButton( bbox, i18n("Add") ); |
837 | bbox->insert(add); | 837 | bbox->insert(add); |
838 | connect(add, SIGNAL(clicked()), SLOT(addButton())); | 838 | connect(add, SIGNAL(clicked()), SLOT(addButton())); |
839 | // bbox->addStretch(1); | 839 | // bbox->addStretch(1); |
840 | insert = new QPushButton( bbox, i18n("Insert") ); | 840 | insert = new QPushButton( bbox, i18n("Insert") ); |
841 | bbox->insert(insert); | 841 | bbox->insert(insert); |
842 | connect(insert, SIGNAL(clicked()), SLOT(insertButton())); | 842 | connect(insert, SIGNAL(clicked()), SLOT(insertButton())); |
843 | // bbox->addStretch(1); | 843 | // bbox->addStretch(1); |
844 | remove = new QPushButton( bbox, i18n("Remove") ); | 844 | remove = new QPushButton( bbox, i18n("Remove") ); |
845 | bbox->insert(remove); | 845 | bbox->insert(remove); |
846 | connect(remove, SIGNAL(clicked()), SLOT(removeButton())); | 846 | connect(remove, SIGNAL(clicked()), SLOT(removeButton())); |
847 | bbox->layout(); | 847 | bbox->layout(); |
848 | tl->addWidget(bbox); | 848 | tl->addWidget(bbox); |
849 | 849 | ||
850 | QHBoxLayout *l12 = new QHBoxLayout(0); | 850 | QHBoxLayout *l12 = new QHBoxLayout(0); |
851 | tl->addLayout(l12); | 851 | tl->addLayout(l12); |
852 | stl = new QListBox(parent); | 852 | stl = new QListBox(this); |
853 | stl->setVScrollBarMode( QScrollView::AlwaysOff ); | 853 | stl->setVScrollBarMode( QScrollView::AlwaysOff ); |
854 | connect(stl, SIGNAL(highlighted(int)), SLOT(stlhighlighted(int))); | 854 | connect(stl, SIGNAL(highlighted(int)), SLOT(stlhighlighted(int))); |
855 | stl->setMinimumSize(QSize(70, 140)); | 855 | stl->setMinimumSize(QSize(70, 140)); |
856 | 856 | ||
857 | sl = new QListBox(parent); | 857 | sl = new QListBox(this); |
858 | sl->setVScrollBarMode( QScrollView::AlwaysOff ); | 858 | sl->setVScrollBarMode( QScrollView::AlwaysOff ); |
859 | connect(sl, SIGNAL(highlighted(int)), SLOT(slhighlighted(int))); | 859 | connect(sl, SIGNAL(highlighted(int)), SLOT(slhighlighted(int))); |
860 | sl->setMinimumSize(QSize(150, 140)); | 860 | sl->setMinimumSize(QSize(150, 140)); |
861 | 861 | ||
862 | slb = new QScrollBar(parent); | 862 | slb = new QScrollBar(this); |
863 | slb->setFixedWidth(slb->sizeHint().width()); | 863 | // slb->setFixedWidth(slb->sizeHint().width()); |
864 | connect(slb, SIGNAL(valueChanged(int)), SLOT(scrolling(int))); | 864 | connect(slb, SIGNAL(valueChanged(int)), SLOT(scrolling(int))); |
865 | 865 | ||
866 | l12->addWidget(stl, 1); | 866 | l12->addWidget(stl, 1); |
867 | l12->addWidget(sl, 3); | 867 | l12->addWidget(sl, 3); |
868 | l12->addWidget(slb, 0); | 868 | l12->addWidget(slb, 0); |
869 | 869 | ||
870 | //load data from gpppdata | 870 | //load data from gpppdata |
871 | if(!isnewaccount) { | 871 | if(!isnewaccount) { |
872 | QStringList &comlist = gpppdata.scriptType(); | 872 | QStringList &comlist = PPPData::data()->scriptType(); |
873 | QStringList &arglist = gpppdata.script(); | 873 | QStringList &arglist = PPPData::data()->script(); |
874 | QStringList::Iterator itcom = comlist.begin(); | 874 | QStringList::Iterator itcom = comlist.begin(); |
875 | QStringList::Iterator itarg = arglist.begin(); | 875 | QStringList::Iterator itarg = arglist.begin(); |
876 | 876 | ||
877 | for ( ; | 877 | for ( ; |
878 | itcom != comlist.end() && itarg != arglist.end(); | 878 | itcom != comlist.end() && itarg != arglist.end(); |
879 | ++itcom, ++itarg ) | 879 | ++itcom, ++itarg ) |
880 | { | 880 | { |
881 | stl->insertItem(*itcom); | 881 | stl->insertItem(*itcom); |
882 | sl->insertItem(*itarg); | 882 | sl->insertItem(*itarg); |
883 | } | 883 | } |
884 | } | 884 | } |
885 | 885 | ||
886 | insert->setEnabled(false); | 886 | insert->setEnabled(false); |
887 | remove->setEnabled(false); | 887 | remove->setEnabled(false); |
888 | adjustScrollBar(); | 888 | adjustScrollBar(); |
889 | tl->activate(); | 889 | tl->activate(); |
890 | } | 890 | } |
891 | 891 | ||
892 | bool ScriptWidget::check() { | 892 | bool ScriptWidget::check() { |
893 | uint lstart = 0; | 893 | uint lstart = 0; |
894 | uint lend = 0; | 894 | uint lend = 0; |
895 | uint errcnt = 0; | 895 | uint errcnt = 0; |
896 | 896 | ||
897 | if(sl->count() > 0) { | 897 | if(sl->count() > 0) { |
898 | for( uint i=0; i <= sl->count()-1; i++) { | 898 | for( uint i=0; i <= sl->count()-1; i++) { |
899 | if(stl->text(i) == "LoopStart") { | 899 | if(stl->text(i) == "LoopStart") { |
900 | lstart++; | 900 | lstart++; |
901 | } | 901 | } |
902 | if (stl->text(i) == "LoopEnd") { | 902 | if (stl->text(i) == "LoopEnd") { |
903 | lend++; | 903 | lend++; |
904 | } | 904 | } |
905 | if ( lend > lstart ) errcnt++; | 905 | if ( lend > lstart ) errcnt++; |
906 | } | 906 | } |
907 | return ( (errcnt == 0 ) && (lstart == lend) ); | 907 | return ( (errcnt == 0 ) && (lstart == lend) ); |
908 | } | 908 | } |
909 | return true; | 909 | return true; |
910 | } | 910 | } |
911 | 911 | ||
912 | 912 | ||
913 | void ScriptWidget::save() { | 913 | void ScriptWidget::save() { |
914 | QStringList typelist, arglist; | 914 | QStringList typelist, arglist; |
915 | for(uint i=0; i < sl->count(); i++) { | 915 | for(uint i=0; i < sl->count(); i++) { |
916 | typelist.append(stl->text(i)); | 916 | typelist.append(stl->text(i)); |
917 | arglist.append(sl->text(i)); | 917 | arglist.append(sl->text(i)); |
918 | } | 918 | } |
919 | gpppdata.setScriptType(typelist); | 919 | PPPData::data()->setScriptType(typelist); |
920 | gpppdata.setScript(arglist); | 920 | PPPData::data()->setScript(arglist); |
921 | } | 921 | } |
922 | 922 | ||
923 | 923 | ||
924 | 924 | ||
925 | void ScriptWidget::adjustScrollBar() { | 925 | void ScriptWidget::adjustScrollBar() { |
926 | if((int)sl->count() <= sl->numItemsVisible()) | 926 | if((int)sl->count() <= sl->numItemsVisible()) |
927 | slb->setRange(0, 0); | 927 | slb->setRange(0, 0); |
928 | else | 928 | else |
929 | slb->setRange(0, (sl->count() - sl->numItemsVisible())+1); | 929 | slb->setRange(0, (sl->count() - sl->numItemsVisible())+1); |
930 | } | 930 | } |
931 | 931 | ||
932 | 932 | ||
933 | void ScriptWidget::scrolling(int i) { | 933 | void ScriptWidget::scrolling(int i) { |
934 | sl->setTopItem(i); | 934 | sl->setTopItem(i); |
935 | stl->setTopItem(i); | 935 | stl->setTopItem(i); |
936 | } | 936 | } |
937 | 937 | ||
938 | 938 | ||
939 | void ScriptWidget::slhighlighted(int i) { | 939 | void ScriptWidget::slhighlighted(int i) { |
940 | insert->setEnabled(true); | 940 | insert->setEnabled(true); |
941 | remove->setEnabled(true); | 941 | remove->setEnabled(true); |
942 | stl->setCurrentItem(i); | 942 | stl->setCurrentItem(i); |
943 | } | 943 | } |
944 | 944 | ||
945 | 945 | ||
946 | void ScriptWidget::stlhighlighted(int i) { | 946 | void ScriptWidget::stlhighlighted(int i) { |
947 | insert->setEnabled(true); | 947 | insert->setEnabled(true); |
948 | remove->setEnabled(true); | 948 | remove->setEnabled(true); |
949 | sl->setCurrentItem(i); | 949 | sl->setCurrentItem(i); |
950 | } | 950 | } |
951 | 951 | ||
952 | 952 | ||
953 | void ScriptWidget::addButton() { | 953 | void ScriptWidget::addButton() { |
954 | //don't allow more than the maximum script entries | 954 | //don't allow more than the maximum script entries |
955 | if(sl->count() == MAX_SCRIPT_ENTRIES-1) | 955 | if(sl->count() == MAX_SCRIPT_ENTRIES-1) |
956 | return; | 956 | return; |
957 | 957 | ||
958 | switch(se->type()) { | 958 | switch(se->type()) { |
959 | case ScriptEdit::Expect: | 959 | case ScriptEdit::Expect: |
960 | stl->insertItem("Expect"); | 960 | stl->insertItem("Expect"); |
961 | sl->insertItem(se->text()); | 961 | sl->insertItem(se->text()); |
962 | break; | 962 | break; |
963 | 963 | ||
964 | case ScriptEdit::Send: | 964 | case ScriptEdit::Send: |
965 | stl->insertItem("Send"); | 965 | stl->insertItem("Send"); |
966 | sl->insertItem(se->text()); | 966 | sl->insertItem(se->text()); |
967 | break; | 967 | break; |
968 | 968 | ||
969 | case ScriptEdit::SendNoEcho: | 969 | case ScriptEdit::SendNoEcho: |
970 | stl->insertItem("SendNoEcho"); | 970 | stl->insertItem("SendNoEcho"); |
971 | sl->insertItem(se->text()); | 971 | sl->insertItem(se->text()); |
972 | break; | 972 | break; |
973 | 973 | ||
974 | case ScriptEdit::Pause: | 974 | case ScriptEdit::Pause: |
975 | stl->insertItem("Pause"); | 975 | stl->insertItem("Pause"); |
976 | sl->insertItem(se->text()); | 976 | sl->insertItem(se->text()); |
977 | break; | 977 | break; |
978 | 978 | ||
979 | case ScriptEdit::Hangup: | 979 | case ScriptEdit::Hangup: |
980 | stl->insertItem("Hangup"); | 980 | stl->insertItem("Hangup"); |
981 | sl->insertItem(""); | 981 | sl->insertItem(""); |
982 | break; | 982 | break; |
983 | 983 | ||
984 | case ScriptEdit::Answer: | 984 | case ScriptEdit::Answer: |
985 | stl->insertItem("Answer"); | 985 | stl->insertItem("Answer"); |
986 | sl->insertItem(""); | 986 | sl->insertItem(""); |
987 | break; | 987 | break; |
988 | 988 | ||
989 | case ScriptEdit::Timeout: | 989 | case ScriptEdit::Timeout: |
990 | stl->insertItem("Timeout"); | 990 | stl->insertItem("Timeout"); |
991 | sl->insertItem(se->text()); | 991 | sl->insertItem(se->text()); |
992 | break; | 992 | break; |
993 | 993 | ||
994 | case ScriptEdit::Password: | 994 | case ScriptEdit::Password: |
995 | stl->insertItem("Password"); | 995 | stl->insertItem("Password"); |
996 | sl->insertItem(se->text()); | 996 | sl->insertItem(se->text()); |
997 | break; | 997 | break; |
998 | 998 | ||
999 | case ScriptEdit::ID: | 999 | case ScriptEdit::ID: |
1000 | stl->insertItem("ID"); | 1000 | stl->insertItem("ID"); |
1001 | sl->insertItem(se->text()); | 1001 | sl->insertItem(se->text()); |
1002 | break; | 1002 | break; |
1003 | 1003 | ||
1004 | case ScriptEdit::Prompt: | 1004 | case ScriptEdit::Prompt: |
1005 | stl->insertItem("Prompt"); | 1005 | stl->insertItem("Prompt"); |
1006 | sl->insertItem(se->text()); | 1006 | sl->insertItem(se->text()); |
1007 | break; | 1007 | break; |
1008 | 1008 | ||
1009 | case ScriptEdit::PWPrompt: | 1009 | case ScriptEdit::PWPrompt: |
1010 | stl->insertItem("PWPrompt"); | 1010 | stl->insertItem("PWPrompt"); |
1011 | sl->insertItem(se->text()); | 1011 | sl->insertItem(se->text()); |
1012 | break; | 1012 | break; |
1013 | 1013 | ||
1014 | case ScriptEdit::LoopStart: | 1014 | case ScriptEdit::LoopStart: |
1015 | stl->insertItem("LoopStart"); | 1015 | stl->insertItem("LoopStart"); |
1016 | sl->insertItem(se->text()); | 1016 | sl->insertItem(se->text()); |
1017 | break; | 1017 | break; |
1018 | 1018 | ||
1019 | case ScriptEdit::LoopEnd: | 1019 | case ScriptEdit::LoopEnd: |
1020 | stl->insertItem("LoopEnd"); | 1020 | stl->insertItem("LoopEnd"); |
1021 | sl->insertItem(se->text()); | 1021 | sl->insertItem(se->text()); |
1022 | break; | 1022 | break; |
1023 | 1023 | ||
1024 | case ScriptEdit::Scan: | 1024 | case ScriptEdit::Scan: |
1025 | stl->insertItem("Scan"); | 1025 | stl->insertItem("Scan"); |
1026 | sl->insertItem(se->text()); | 1026 | sl->insertItem(se->text()); |
1027 | break; | 1027 | break; |
1028 | 1028 | ||
1029 | case ScriptEdit::Save: | 1029 | case ScriptEdit::Save: |
1030 | stl->insertItem("Save"); | 1030 | stl->insertItem("Save"); |
1031 | sl->insertItem(se->text()); | 1031 | sl->insertItem(se->text()); |
1032 | break; | 1032 | break; |
1033 | 1033 | ||
1034 | default: | 1034 | default: |
1035 | break; | 1035 | break; |
1036 | } | 1036 | } |
1037 | 1037 | ||
1038 | //get the scrollbar adjusted, and scroll the list so we can see what | 1038 | //get the scrollbar adjusted, and scroll the list so we can see what |
1039 | //we're adding to | 1039 | //we're adding to |
1040 | adjustScrollBar(); | 1040 | adjustScrollBar(); |
1041 | slb->setValue(slb->maxValue()); | 1041 | slb->setValue(slb->maxValue()); |
1042 | 1042 | ||
1043 | //clear the text in the entry box | 1043 | //clear the text in the entry box |
1044 | se->setText(""); | 1044 | se->setText(""); |
1045 | } | 1045 | } |
1046 | 1046 | ||
1047 | 1047 | ||
1048 | void ScriptWidget::insertButton() { | 1048 | void ScriptWidget::insertButton() { |
1049 | //exit if there is no highlighted item, or we've reached the | 1049 | //exit if there is no highlighted item, or we've reached the |
1050 | //maximum entries in the script list | 1050 | //maximum entries in the script list |
1051 | if(sl->currentItem() < 0 || (sl->count() == MAX_SCRIPT_ENTRIES-1)) | 1051 | if(sl->currentItem() < 0 || (sl->count() == MAX_SCRIPT_ENTRIES-1)) |
1052 | return; | 1052 | return; |
1053 | 1053 | ||
1054 | switch(se->type()) { | 1054 | switch(se->type()) { |
1055 | case ScriptEdit::Expect: | 1055 | case ScriptEdit::Expect: |
1056 | stl->insertItem("Expect", stl->currentItem()); | 1056 | stl->insertItem("Expect", stl->currentItem()); |
1057 | sl->insertItem(se->text(), sl->currentItem()); | 1057 | sl->insertItem(se->text(), sl->currentItem()); |
1058 | break; | 1058 | break; |
1059 | 1059 | ||
1060 | case ScriptEdit::Send: | 1060 | case ScriptEdit::Send: |
1061 | stl->insertItem("Send", stl->currentItem()); | 1061 | stl->insertItem("Send", stl->currentItem()); |
1062 | sl->insertItem(se->text(), sl->currentItem()); | 1062 | sl->insertItem(se->text(), sl->currentItem()); |
1063 | break; | 1063 | break; |
1064 | 1064 | ||
1065 | case ScriptEdit::SendNoEcho: | 1065 | case ScriptEdit::SendNoEcho: |
1066 | stl->insertItem("SendNoEcho", stl->currentItem()); | 1066 | stl->insertItem("SendNoEcho", stl->currentItem()); |
1067 | sl->insertItem(se->text(), sl->currentItem()); | 1067 | sl->insertItem(se->text(), sl->currentItem()); |
1068 | break; | 1068 | break; |
1069 | 1069 | ||
1070 | case ScriptEdit::Pause: | 1070 | case ScriptEdit::Pause: |
1071 | stl->insertItem("Pause", stl->currentItem()); | 1071 | stl->insertItem("Pause", stl->currentItem()); |
1072 | sl->insertItem(se->text(), sl->currentItem()); | 1072 | sl->insertItem(se->text(), sl->currentItem()); |
1073 | break; | 1073 | break; |
1074 | 1074 | ||
1075 | case ScriptEdit::Hangup: | 1075 | case ScriptEdit::Hangup: |
1076 | stl->insertItem("Hangup", stl->currentItem()); | 1076 | stl->insertItem("Hangup", stl->currentItem()); |
1077 | sl->insertItem("", sl->currentItem()); | 1077 | sl->insertItem("", sl->currentItem()); |
1078 | break; | 1078 | break; |
1079 | 1079 | ||
1080 | case ScriptEdit::Answer: | 1080 | case ScriptEdit::Answer: |
1081 | stl->insertItem("Answer", stl->currentItem()); | 1081 | stl->insertItem("Answer", stl->currentItem()); |
1082 | sl->insertItem("", sl->currentItem()); | 1082 | sl->insertItem("", sl->currentItem()); |
1083 | break; | 1083 | break; |
1084 | 1084 | ||
1085 | case ScriptEdit::Timeout: | 1085 | case ScriptEdit::Timeout: |
1086 | stl->insertItem("Timeout", stl->currentItem()); | 1086 | stl->insertItem("Timeout", stl->currentItem()); |
1087 | sl->insertItem(se->text(), sl->currentItem()); | 1087 | sl->insertItem(se->text(), sl->currentItem()); |
1088 | break; | 1088 | break; |
1089 | 1089 | ||
1090 | case ScriptEdit::Password: | 1090 | case ScriptEdit::Password: |
1091 | stl->insertItem("Password", stl->currentItem()); | 1091 | stl->insertItem("Password", stl->currentItem()); |
1092 | sl->insertItem(se->text(), sl->currentItem()); | 1092 | sl->insertItem(se->text(), sl->currentItem()); |
1093 | break; | 1093 | break; |
1094 | 1094 | ||
1095 | case ScriptEdit::ID: | 1095 | case ScriptEdit::ID: |
1096 | stl->insertItem("ID", stl->currentItem()); | 1096 | stl->insertItem("ID", stl->currentItem()); |
1097 | sl->insertItem(se->text(), sl->currentItem()); | 1097 | sl->insertItem(se->text(), sl->currentItem()); |
1098 | break; | 1098 | break; |
1099 | 1099 | ||
1100 | case ScriptEdit::Prompt: | 1100 | case ScriptEdit::Prompt: |
1101 | stl->insertItem("Prompt", stl->currentItem()); | 1101 | stl->insertItem("Prompt", stl->currentItem()); |
1102 | sl->insertItem(se->text(), sl->currentItem()); | 1102 | sl->insertItem(se->text(), sl->currentItem()); |
1103 | break; | 1103 | break; |
1104 | 1104 | ||
1105 | case ScriptEdit::PWPrompt: | 1105 | case ScriptEdit::PWPrompt: |
1106 | stl->insertItem("PWPrompt", stl->currentItem()); | 1106 | stl->insertItem("PWPrompt", stl->currentItem()); |
1107 | sl->insertItem(se->text(), sl->currentItem()); | 1107 | sl->insertItem(se->text(), sl->currentItem()); |
1108 | break; | 1108 | break; |
1109 | 1109 | ||
1110 | case ScriptEdit::LoopStart: | 1110 | case ScriptEdit::LoopStart: |
1111 | stl->insertItem("LoopStart", stl->currentItem()); | 1111 | stl->insertItem("LoopStart", stl->currentItem()); |
1112 | sl->insertItem(se->text(), sl->currentItem()); | 1112 | sl->insertItem(se->text(), sl->currentItem()); |
1113 | break; | 1113 | break; |
1114 | 1114 | ||
1115 | case ScriptEdit::LoopEnd: | 1115 | case ScriptEdit::LoopEnd: |
1116 | stl->insertItem("LoopEnd", stl->currentItem()); | 1116 | stl->insertItem("LoopEnd", stl->currentItem()); |
1117 | sl->insertItem(se->text(), sl->currentItem()); | 1117 | sl->insertItem(se->text(), sl->currentItem()); |
1118 | break; | 1118 | break; |
1119 | 1119 | ||
1120 | case ScriptEdit::Scan: | 1120 | case ScriptEdit::Scan: |
1121 | stl->insertItem("Scan", stl->currentItem()); | 1121 | stl->insertItem("Scan", stl->currentItem()); |
1122 | sl->insertItem(se->text(), sl->currentItem()); | 1122 | sl->insertItem(se->text(), sl->currentItem()); |
1123 | break; | 1123 | break; |
1124 | 1124 | ||
1125 | case ScriptEdit::Save: | 1125 | case ScriptEdit::Save: |
1126 | stl->insertItem("Save", stl->currentItem()); | 1126 | stl->insertItem("Save", stl->currentItem()); |
1127 | sl->insertItem(se->text(), sl->currentItem()); | 1127 | sl->insertItem(se->text(), sl->currentItem()); |
1128 | break; | 1128 | break; |
1129 | 1129 | ||
1130 | default: | 1130 | default: |
1131 | break; | 1131 | break; |
1132 | } | 1132 | } |
1133 | adjustScrollBar(); | 1133 | adjustScrollBar(); |
1134 | se->setText(""); | 1134 | se->setText(""); |
1135 | } | 1135 | } |
1136 | 1136 | ||
1137 | 1137 | ||
1138 | void ScriptWidget::removeButton() { | 1138 | void ScriptWidget::removeButton() { |
1139 | if(sl->currentItem() >= 0) { | 1139 | if(sl->currentItem() >= 0) { |
1140 | int stlc = stl->currentItem(); | 1140 | int stlc = stl->currentItem(); |
1141 | sl->removeItem(sl->currentItem()); | 1141 | sl->removeItem(sl->currentItem()); |
1142 | stl->removeItem(stlc); | 1142 | stl->removeItem(stlc); |
1143 | adjustScrollBar(); | 1143 | adjustScrollBar(); |
1144 | insert->setEnabled(sl->currentItem() != -1); | 1144 | insert->setEnabled(sl->currentItem() != -1); |
1145 | remove->setEnabled(sl->currentItem() != -1); | 1145 | remove->setEnabled(sl->currentItem() != -1); |
1146 | } | 1146 | } |
1147 | } | 1147 | } |
1148 | 1148 | ||
1149 | 1149 | ||
1150 | 1150 | ||
1151 | ///////////////////////////////////////////////////////////////////////////// | 1151 | ///////////////////////////////////////////////////////////////////////////// |
1152 | // | 1152 | // |
1153 | // Used to specify a new phone number | 1153 | // Used to specify a new phone number |
1154 | // | 1154 | // |
1155 | ///////////////////////////////////////////////////////////////////////////// | 1155 | ///////////////////////////////////////////////////////////////////////////// |
1156 | PhoneNumberDialog::PhoneNumberDialog(QWidget *parent) | 1156 | PhoneNumberDialog::PhoneNumberDialog(QWidget *parent) |
1157 | : QDialog(parent, 0, true ) { | 1157 | : QDialog(parent,"PhoneNumberDialog",true) { |
1158 | setCaption( i18n("Add Phone Number") ); | 1158 | setCaption( i18n("Add Phone Number") ); |
1159 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); | 1159 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); |
1160 | 1160 | ||
1161 | QHBox *hbox = new QHBox(this); | 1161 | QHBox *hbox = new QHBox(this); |
1162 | // setMainWidget(hbox); | 1162 | // setMainWidget(hbox); |
1163 | 1163 | ||
1164 | hbox->setSpacing( 2 );//KDialog::spacingHint()); | 1164 | hbox->setSpacing( 2 );//KDialog::spacingHint()); |
1165 | 1165 | ||
1166 | new QLabel(i18n("Enter a phone number:"), hbox); | 1166 | new QLabel(i18n("Enter a phone number:"), hbox); |
1167 | 1167 | ||
1168 | le = newLineEdit(14, hbox); | 1168 | le = new QLineEdit(hbox); |
1169 | le->setMinimumWidth(125); | 1169 | // le->setMinimumWidth(125); |
1170 | 1170 | ||
1171 | connect(le, SIGNAL(textChanged(const QString &)), | 1171 | connect(le, SIGNAL(textChanged(const QString &)), |
1172 | this, SLOT(textChanged(const QString &))); | 1172 | this, SLOT(textChanged(const QString &))); |
1173 | 1173 | ||
1174 | le->setFocus(); | 1174 | le->setFocus(); |
1175 | textChanged(""); | 1175 | textChanged(""); |
1176 | 1176 | ||
1177 | // enableButtonSeparator(true); | 1177 | // enableButtonSeparator(true); |
1178 | } | 1178 | } |
1179 | 1179 | ||
1180 | 1180 | ||
1181 | QString PhoneNumberDialog::phoneNumber() { | 1181 | QString PhoneNumberDialog::phoneNumber() { |
1182 | QString s = le->text(); | 1182 | QString s = le->text(); |
1183 | 1183 | ||
1184 | return s; | 1184 | return s; |
1185 | } | 1185 | } |
1186 | 1186 | ||
1187 | 1187 | ||
1188 | void PhoneNumberDialog::textChanged(const QString &s) { | 1188 | void PhoneNumberDialog::textChanged(const QString &s) { |
1189 | // enableButtonOK(s.length() > 0); | 1189 | // enableButtonOK(s.length() > 0); |
1190 | } | 1190 | } |
1191 | 1191 | ||
1192 | 1192 | ||
1193 | //#include "edit.moc" | 1193 | //#include "edit.moc" |
diff --git a/noncore/settings/networksettings/ppp/general.cpp b/noncore/settings/networksettings/ppp/general.cpp index f803628..a02ee35 100644 --- a/noncore/settings/networksettings/ppp/general.cpp +++ b/noncore/settings/networksettings/ppp/general.cpp | |||
@@ -1,421 +1,421 @@ | |||
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 <termios.h> | 27 | #include <termios.h> |
28 | #include <string.h> | 28 | #include <string.h> |
29 | #include <qwhatsthis.h> | 29 | #include <qwhatsthis.h> |
30 | 30 | ||
31 | #include "knuminput.h" | 31 | #include "knuminput.h" |
32 | #include <qslider.h> | 32 | #include <qslider.h> |
33 | #include <qlayout.h> | 33 | #include <qlayout.h> |
34 | #include "general.h" | 34 | #include "general.h" |
35 | //#include "version.h" | 35 | //#include "version.h" |
36 | //#include "miniterm.h" | 36 | //#include "miniterm.h" |
37 | #include "modeminfo.h" | 37 | #include "modeminfo.h" |
38 | #include "modemcmds.h" | 38 | #include "modemcmds.h" |
39 | #include "devices.h" | 39 | #include "devices.h" |
40 | #include "pppdata.h" | 40 | #include "pppdata.h" |
41 | //#include <klocale.h> | 41 | //#include <klocale.h> |
42 | #define i18n QObject::tr | 42 | #define i18n QObject::tr |
43 | 43 | ||
44 | 44 | ||
45 | 45 | ||
46 | ModemWidget::ModemWidget( QWidget *parent, const char *name) | 46 | ModemWidget::ModemWidget( QWidget *parent, const char *name) |
47 | : QWidget(parent, name) | 47 | : QWidget(parent, name) |
48 | { | 48 | { |
49 | int k; | 49 | int k; |
50 | 50 | ||
51 | QGridLayout *tl = new QGridLayout(this, 8, 2, 0 );//, KDialog::spacingHint()); | 51 | QGridLayout *tl = new QGridLayout(this, 8, 2, 0 );//, KDialog::spacingHint()); |
52 | 52 | ||
53 | label1 = new QLabel(i18n("Modem de&vice:"), this); | 53 | label1 = new QLabel(i18n("Modem de&vice:"), this); |
54 | tl->addWidget(label1, 0, 0); | 54 | tl->addWidget(label1, 0, 0); |
55 | 55 | ||
56 | modemdevice = new QComboBox(false, this); | 56 | modemdevice = new QComboBox(false, this); |
57 | label1->setBuddy(modemdevice); | 57 | label1->setBuddy(modemdevice); |
58 | 58 | ||
59 | for(k = 0; devices[k]; k++) | 59 | for(k = 0; devices[k]; k++) |
60 | modemdevice->insertItem(devices[k]); | 60 | modemdevice->insertItem(devices[k]); |
61 | 61 | ||
62 | tl->addWidget(modemdevice, 0, 1); | 62 | tl->addWidget(modemdevice, 0, 1); |
63 | connect(modemdevice, SIGNAL(activated(int)), | 63 | connect(modemdevice, SIGNAL(activated(int)), |
64 | SLOT(setmodemdc(int))); | 64 | SLOT(setmodemdc(int))); |
65 | QString tmp = i18n("This specifies the serial port your modem is attached \n" | 65 | QString tmp = i18n("This specifies the serial port your modem is attached \n" |
66 | "to. On Linux/x86, typically this is either /dev/ttyS0 \n" | 66 | "to. On Linux/x86, typically this is either /dev/ttyS0 \n" |
67 | "(COM1 under DOS) or /dev/ttyS1 (COM2 under DOS).\n" | 67 | "(COM1 under DOS) or /dev/ttyS1 (COM2 under DOS).\n" |
68 | "\n" | 68 | "\n" |
69 | "If you have an internal ISDN card with AT command\n" | 69 | "If you have an internal ISDN card with AT command\n" |
70 | "emulation (most cards under Linux support this), you\n" | 70 | "emulation (most cards under Linux support this), you\n" |
71 | "should select one of the /dev/ttyIx devices."); | 71 | "should select one of the /dev/ttyIx devices."); |
72 | 72 | ||
73 | QWhatsThis::add(label1,tmp); | 73 | QWhatsThis::add(label1,tmp); |
74 | QWhatsThis::add(modemdevice,tmp); | 74 | QWhatsThis::add(modemdevice,tmp); |
75 | 75 | ||
76 | 76 | ||
77 | label2 = new QLabel(i18n("&Flow control:"), this); | 77 | label2 = new QLabel(i18n("&Flow control:"), this); |
78 | tl->addWidget(label2, 1, 0); | 78 | tl->addWidget(label2, 1, 0); |
79 | 79 | ||
80 | flowcontrol = new QComboBox(false, this); | 80 | flowcontrol = new QComboBox(false, this); |
81 | label2->setBuddy(flowcontrol); | 81 | label2->setBuddy(flowcontrol); |
82 | flowcontrol->insertItem(i18n("Hardware [CRTSCTS]")); | 82 | flowcontrol->insertItem(i18n("Hardware [CRTSCTS]")); |
83 | flowcontrol->insertItem(i18n("Software [XON/XOFF]")); | 83 | flowcontrol->insertItem(i18n("Software [XON/XOFF]")); |
84 | flowcontrol->insertItem(i18n("None")); | 84 | flowcontrol->insertItem(i18n("None")); |
85 | tl->addWidget(flowcontrol, 1, 1); | 85 | tl->addWidget(flowcontrol, 1, 1); |
86 | connect(flowcontrol, SIGNAL(activated(int)), | 86 | connect(flowcontrol, SIGNAL(activated(int)), |
87 | SLOT(setflowcontrol(int))); | 87 | SLOT(setflowcontrol(int))); |
88 | 88 | ||
89 | tmp = i18n("<p>Specifies how the serial port and modem\n" | 89 | tmp = i18n("<p>Specifies how the serial port and modem\n" |
90 | "communicate. You should not change this unless\n" | 90 | "communicate. You should not change this unless\n" |
91 | "you know what you are doing.\n" | 91 | "you know what you are doing.\n" |
92 | "\n" | 92 | "\n" |
93 | "<b>Default</b>: CRTSCTS"); | 93 | "<b>Default</b>: CRTSCTS"); |
94 | 94 | ||
95 | QWhatsThis::add(label2,tmp); | 95 | QWhatsThis::add(label2,tmp); |
96 | QWhatsThis::add(flowcontrol,tmp); | 96 | QWhatsThis::add(flowcontrol,tmp); |
97 | 97 | ||
98 | labelenter = new QLabel(i18n("&Line termination:"), this); | 98 | labelenter = new QLabel(i18n("&Line termination:"), this); |
99 | tl->addWidget(labelenter, 2, 0); | 99 | tl->addWidget(labelenter, 2, 0); |
100 | 100 | ||
101 | enter = new QComboBox(false, this); | 101 | enter = new QComboBox(false, this); |
102 | labelenter->setBuddy(enter); | 102 | labelenter->setBuddy(enter); |
103 | enter->insertItem("CR"); | 103 | enter->insertItem("CR"); |
104 | enter->insertItem("LF"); | 104 | enter->insertItem("LF"); |
105 | enter->insertItem("CR/LF"); | 105 | enter->insertItem("CR/LF"); |
106 | tl->addWidget(enter, 2, 1); | 106 | tl->addWidget(enter, 2, 1); |
107 | connect(enter, SIGNAL(activated(int)), SLOT(setenter(int))); | 107 | connect(enter, SIGNAL(activated(int)), SLOT(setenter(int))); |
108 | tmp = i18n("<p>Specifies how AT commands are sent to your\n" | 108 | tmp = i18n("<p>Specifies how AT commands are sent to your\n" |
109 | "modem. Most modems will work fine with the\n" | 109 | "modem. Most modems will work fine with the\n" |
110 | "default <i>CR/LF</i>. If your modem does not react\n" | 110 | "default <i>CR/LF</i>. If your modem does not react\n" |
111 | "to the init string, you should try different\n" | 111 | "to the init string, you should try different\n" |
112 | "settings here\n" | 112 | "settings here\n" |
113 | "\n" | 113 | "\n" |
114 | "<b>Default</b>: CR/LF"); | 114 | "<b>Default</b>: CR/LF"); |
115 | 115 | ||
116 | QWhatsThis::add(labelenter,tmp); | 116 | QWhatsThis::add(labelenter,tmp); |
117 | QWhatsThis::add(enter, tmp); | 117 | QWhatsThis::add(enter, tmp); |
118 | 118 | ||
119 | baud_label = new QLabel(i18n("Co&nnection speed:"), this); | 119 | baud_label = new QLabel(i18n("Co&nnection speed:"), this); |
120 | tl->addWidget(baud_label, 3, 0); | 120 | tl->addWidget(baud_label, 3, 0); |
121 | baud_c = new QComboBox(this); | 121 | baud_c = new QComboBox(this); |
122 | baud_label->setBuddy(baud_c); | 122 | baud_label->setBuddy(baud_c); |
123 | 123 | ||
124 | static const char *baudrates[] = { | 124 | static const char *baudrates[] = { |
125 | 125 | ||
126 | #ifdef B460800 | 126 | #ifdef B460800 |
127 | "460800", | 127 | "460800", |
128 | #endif | 128 | #endif |
129 | 129 | ||
130 | #ifdef B230400 | 130 | #ifdef B230400 |
131 | "230400", | 131 | "230400", |
132 | #endif | 132 | #endif |
133 | 133 | ||
134 | #ifdef B115200 | 134 | #ifdef B115200 |
135 | "115200", | 135 | "115200", |
136 | #endif | 136 | #endif |
137 | 137 | ||
138 | #ifdef B57600 | 138 | #ifdef B57600 |
139 | "57600", | 139 | "57600", |
140 | #endif | 140 | #endif |
141 | 141 | ||
142 | "38400", | 142 | "38400", |
143 | "19200", | 143 | "19200", |
144 | "9600", | 144 | "9600", |
145 | "2400", | 145 | "2400", |
146 | 0}; | 146 | 0}; |
147 | 147 | ||
148 | for(k = 0; baudrates[k]; k++) | 148 | for(k = 0; baudrates[k]; k++) |
149 | baud_c->insertItem(baudrates[k]); | 149 | baud_c->insertItem(baudrates[k]); |
150 | 150 | ||
151 | baud_c->setCurrentItem(3); | 151 | baud_c->setCurrentItem(3); |
152 | connect(baud_c, SIGNAL(activated(int)), | 152 | connect(baud_c, SIGNAL(activated(int)), |
153 | this, SLOT(speed_selection(int))); | 153 | this, SLOT(speed_selection(int))); |
154 | tl->addWidget(baud_c, 3, 1); | 154 | tl->addWidget(baud_c, 3, 1); |
155 | 155 | ||
156 | tmp = i18n("Specifies the speed your modem and the serial\n" | 156 | tmp = i18n("Specifies the speed your modem and the serial\n" |
157 | "port talk to each other. You should begin with\n" | 157 | "port talk to each other. You should begin with\n" |
158 | "the default of 38400 bits/sec. If everything\n" | 158 | "the default of 38400 bits/sec. If everything\n" |
159 | "works you can try to increase this value, but to\n" | 159 | "works you can try to increase this value, but to\n" |
160 | "no more than 115200 bits/sec (unless you know\n" | 160 | "no more than 115200 bits/sec (unless you know\n" |
161 | "that your serial port supports higher speeds)."); | 161 | "that your serial port supports higher speeds)."); |
162 | 162 | ||
163 | QWhatsThis::add(baud_label,tmp); | 163 | QWhatsThis::add(baud_label,tmp); |
164 | QWhatsThis::add(baud_c,tmp); | 164 | QWhatsThis::add(baud_c,tmp); |
165 | 165 | ||
166 | for(int i=0; i <= enter->count()-1; i++) { | 166 | for(int i=0; i <= enter->count()-1; i++) { |
167 | if(gpppdata.enter() == enter->text(i)) | 167 | if(PPPData::data()->enter() == enter->text(i)) |
168 | enter->setCurrentItem(i); | 168 | enter->setCurrentItem(i); |
169 | } | 169 | } |
170 | 170 | ||
171 | tl->addRowSpacing(4, 10); | 171 | tl->addRowSpacing(4, 10); |
172 | 172 | ||
173 | //Modem Lock File | 173 | //Modem Lock File |
174 | modemlockfile = new QCheckBox(i18n("&Use lock file"), this); | 174 | modemlockfile = new QCheckBox(i18n("&Use lock file"), this); |
175 | 175 | ||
176 | modemlockfile->setChecked(gpppdata.modemLockFile()); | 176 | modemlockfile->setChecked(PPPData::data()->modemLockFile()); |
177 | connect(modemlockfile, SIGNAL(toggled(bool)), | 177 | connect(modemlockfile, SIGNAL(toggled(bool)), |
178 | SLOT(modemlockfilechanged(bool))); | 178 | SLOT(modemlockfilechanged(bool))); |
179 | tl->addMultiCellWidget(modemlockfile, 5, 5, 0, 1); | 179 | tl->addMultiCellWidget(modemlockfile, 5, 5, 0, 1); |
180 | // l12->addStretch(1); | 180 | // l12->addStretch(1); |
181 | QWhatsThis::add(modemlockfile, | 181 | QWhatsThis::add(modemlockfile, |
182 | i18n("<p>To prevent other programs from accessing the\n" | 182 | i18n("<p>To prevent other programs from accessing the\n" |
183 | "modem while a connection is established, a\n" | 183 | "modem while a connection is established, a\n" |
184 | "file can be created to indicate that the modem\n" | 184 | "file can be created to indicate that the modem\n" |
185 | "is in use. On Linux an example file would be\n" | 185 | "is in use. On Linux an example file would be\n" |
186 | "<tt>/var/lock/LCK..ttyS1</tt>\n" | 186 | "<tt>/var/lock/LCK..ttyS1</tt>\n" |
187 | "Here you can select whether this locking will\n" | 187 | "Here you can select whether this locking will\n" |
188 | "be done.\n" | 188 | "be done.\n" |
189 | "\n" | 189 | "\n" |
190 | "<b>Default</b>: On")); | 190 | "<b>Default</b>: On")); |
191 | 191 | ||
192 | // Modem Timeout Line Edit Box | 192 | // Modem Timeout Line Edit Box |
193 | 193 | ||
194 | modemtimeout = new KIntNumInput(gpppdata.modemTimeout(), this); | 194 | modemtimeout = new KIntNumInput(PPPData::data()->modemTimeout(), this); |
195 | modemtimeout->setLabel(i18n("Modem &timeout:")); | 195 | modemtimeout->setLabel(i18n("Modem &timeout:")); |
196 | modemtimeout->setRange(1, 120, 1); | 196 | modemtimeout->setRange(1, 120, 1); |
197 | modemtimeout->setSuffix(i18n(" sec")); | 197 | modemtimeout->setSuffix(i18n(" sec")); |
198 | connect(modemtimeout, SIGNAL(valueChanged(int)), | 198 | connect(modemtimeout, SIGNAL(valueChanged(int)), |
199 | SLOT(modemtimeoutchanged(int))); | 199 | SLOT(modemtimeoutchanged(int))); |
200 | tl->addMultiCellWidget(modemtimeout, 6, 6, 0, 1); | 200 | tl->addMultiCellWidget(modemtimeout, 6, 6, 0, 1); |
201 | 201 | ||
202 | QWhatsThis::add(modemtimeout, | 202 | QWhatsThis::add(modemtimeout, |
203 | i18n("This specifies how long <i>kppp</i> waits for a\n" | 203 | i18n("This specifies how long <i>kppp</i> waits for a\n" |
204 | "<i>CONNECT</i> response from your modem. The\n" | 204 | "<i>CONNECT</i> response from your modem. The\n" |
205 | "recommended value is 30 seconds.")); | 205 | "recommended value is 30 seconds.")); |
206 | 206 | ||
207 | //set stuff from gpppdata | 207 | //set stuff from gpppdata |
208 | for(int i=0; i <= enter->count()-1; i++) { | 208 | for(int i=0; i <= enter->count()-1; i++) { |
209 | if(gpppdata.enter() == enter->text(i)) | 209 | if(PPPData::data()->enter() == enter->text(i)) |
210 | enter->setCurrentItem(i); | 210 | enter->setCurrentItem(i); |
211 | } | 211 | } |
212 | 212 | ||
213 | for(int i=0; i <= modemdevice->count()-1; i++) { | 213 | for(int i=0; i <= modemdevice->count()-1; i++) { |
214 | if(gpppdata.modemDevice() == modemdevice->text(i)) | 214 | if(PPPData::data()->modemDevice() == modemdevice->text(i)) |
215 | modemdevice->setCurrentItem(i); | 215 | modemdevice->setCurrentItem(i); |
216 | } | 216 | } |
217 | 217 | ||
218 | for(int i=0; i <= flowcontrol->count()-1; i++) { | 218 | for(int i=0; i <= flowcontrol->count()-1; i++) { |
219 | if(gpppdata.flowcontrol() == flowcontrol->text(i)) | 219 | if(PPPData::data()->flowcontrol() == flowcontrol->text(i)) |
220 | flowcontrol->setCurrentItem(i); | 220 | flowcontrol->setCurrentItem(i); |
221 | } | 221 | } |
222 | 222 | ||
223 | //set the modem speed | 223 | //set the modem speed |
224 | for(int i=0; i < baud_c->count(); i++) | 224 | for(int i=0; i < baud_c->count(); i++) |
225 | if(baud_c->text(i) == gpppdata.speed()) | 225 | if(baud_c->text(i) == PPPData::data()->speed()) |
226 | baud_c->setCurrentItem(i); | 226 | baud_c->setCurrentItem(i); |
227 | 227 | ||
228 | tl->setRowStretch(7, 1); | 228 | tl->setRowStretch(7, 1); |
229 | } | 229 | } |
230 | 230 | ||
231 | 231 | ||
232 | void ModemWidget::speed_selection(int) { | 232 | void ModemWidget::speed_selection(int) { |
233 | gpppdata.setSpeed(baud_c->text(baud_c->currentItem())); | 233 | PPPData::data()->setSpeed(baud_c->text(baud_c->currentItem())); |
234 | } | 234 | } |
235 | 235 | ||
236 | 236 | ||
237 | void ModemWidget::setenter(int ) { | 237 | void ModemWidget::setenter(int ) { |
238 | gpppdata.setEnter(enter->text(enter->currentItem())); | 238 | PPPData::data()->setEnter(enter->text(enter->currentItem())); |
239 | } | 239 | } |
240 | 240 | ||
241 | 241 | ||
242 | void ModemWidget::setmodemdc(int i) { | 242 | void ModemWidget::setmodemdc(int i) { |
243 | gpppdata.setModemDevice(modemdevice->text(i)); | 243 | PPPData::data()->setModemDevice(modemdevice->text(i)); |
244 | } | 244 | } |
245 | 245 | ||
246 | 246 | ||
247 | void ModemWidget::setflowcontrol(int i) { | 247 | void ModemWidget::setflowcontrol(int i) { |
248 | gpppdata.setFlowcontrol(flowcontrol->text(i)); | 248 | PPPData::data()->setFlowcontrol(flowcontrol->text(i)); |
249 | } | 249 | } |
250 | 250 | ||
251 | 251 | ||
252 | void ModemWidget::modemlockfilechanged(bool set) { | 252 | void ModemWidget::modemlockfilechanged(bool set) { |
253 | gpppdata.setModemLockFile(set); | 253 | PPPData::data()->setModemLockFile(set); |
254 | } | 254 | } |
255 | 255 | ||
256 | 256 | ||
257 | void ModemWidget::modemtimeoutchanged(int n) { | 257 | void ModemWidget::modemtimeoutchanged(int n) { |
258 | gpppdata.setModemTimeout(n); | 258 | PPPData::data()->setModemTimeout(n); |
259 | } | 259 | } |
260 | 260 | ||
261 | 261 | ||
262 | ModemWidget2::ModemWidget2( QWidget *parent, const char *name) | 262 | ModemWidget2::ModemWidget2( QWidget *parent, const char *name) |
263 | : QWidget(parent, name) | 263 | : QWidget(parent, name) |
264 | { | 264 | { |
265 | QVBoxLayout *l1 = new QVBoxLayout(this, 0 );//, KDialog::spacingHint()); | 265 | QVBoxLayout *l1 = new QVBoxLayout(this, 0 );//, KDialog::spacingHint()); |
266 | 266 | ||
267 | 267 | ||
268 | waitfordt = new QCheckBox(i18n("&Wait for dial tone before dialing"), this); | 268 | waitfordt = new QCheckBox(i18n("&Wait for dial tone before dialing"), this); |
269 | waitfordt->setChecked(gpppdata.waitForDialTone()); | 269 | waitfordt->setChecked(PPPData::data()->waitForDialTone()); |
270 | connect(waitfordt, SIGNAL(toggled(bool)), SLOT(waitfordtchanged(bool))); | 270 | connect(waitfordt, SIGNAL(toggled(bool)), SLOT(waitfordtchanged(bool))); |
271 | l1->addWidget(waitfordt); | 271 | l1->addWidget(waitfordt); |
272 | QWhatsThis::add(waitfordt, | 272 | QWhatsThis::add(waitfordt, |
273 | i18n("<p>Normally the modem waits for a dial tone\n" | 273 | i18n("<p>Normally the modem waits for a dial tone\n" |
274 | "from your phone line, indicating that it can\n" | 274 | "from your phone line, indicating that it can\n" |
275 | "start to dial a number. If your modem does not\n" | 275 | "start to dial a number. If your modem does not\n" |
276 | "recognize this sound, or your local phone system\n" | 276 | "recognize this sound, or your local phone system\n" |
277 | "does not emit such a tone, uncheck this option\n" | 277 | "does not emit such a tone, uncheck this option\n" |
278 | "\n" | 278 | "\n" |
279 | "<b>Default:</b>: On")); | 279 | "<b>Default:</b>: On")); |
280 | 280 | ||
281 | busywait = new KIntNumInput(gpppdata.busyWait(), this); | 281 | busywait = new KIntNumInput(PPPData::data()->busyWait(), this); |
282 | busywait->setLabel(i18n("B&usy wait:")); | 282 | busywait->setLabel(i18n("B&usy wait:")); |
283 | busywait->setRange(0, 300, 5, true); | 283 | busywait->setRange(0, 300, 5, true); |
284 | busywait->setSuffix(i18n(" sec")); | 284 | busywait->setSuffix(i18n(" sec")); |
285 | connect(busywait, SIGNAL(valueChanged(int)), SLOT(busywaitchanged(int))); | 285 | connect(busywait, SIGNAL(valueChanged(int)), SLOT(busywaitchanged(int))); |
286 | l1->addWidget(busywait); | 286 | l1->addWidget(busywait); |
287 | 287 | ||
288 | QWhatsThis::add(busywait, | 288 | QWhatsThis::add(busywait, |
289 | i18n("Specifies the number of seconds to wait before\n" | 289 | i18n("Specifies the number of seconds to wait before\n" |
290 | "redial if all dialed numbers are busy. This is\n" | 290 | "redial if all dialed numbers are busy. This is\n" |
291 | "necessary because some modems get stuck if the\n" | 291 | "necessary because some modems get stuck if the\n" |
292 | "same number is busy too often.\n" | 292 | "same number is busy too often.\n" |
293 | "\n" | 293 | "\n" |
294 | "The default is 0 seconds, you should not change\n" | 294 | "The default is 0 seconds, you should not change\n" |
295 | "this unless you need to.")); | 295 | "this unless you need to.")); |
296 | 296 | ||
297 | l1->addSpacing(10); | 297 | l1->addSpacing(10); |
298 | 298 | ||
299 | QHBoxLayout *hbl = new QHBoxLayout; | 299 | QHBoxLayout *hbl = new QHBoxLayout; |
300 | hbl->setSpacing(2);//KDialog::spacingHint()); | 300 | hbl->setSpacing(2);//KDialog::spacingHint()); |
301 | 301 | ||
302 | QLabel *volumeLabel = new QLabel(i18n("Modem &volume:"), this); | 302 | QLabel *volumeLabel = new QLabel(i18n("Modem &volume:"), this); |
303 | hbl->addWidget(volumeLabel); | 303 | hbl->addWidget(volumeLabel); |
304 | volume = new QSlider(0, 2, 1, gpppdata.volume(), QSlider::Horizontal, this); | 304 | volume = new QSlider(0, 2, 1, PPPData::data()->volume(), QSlider::Horizontal, this); |
305 | volumeLabel->setBuddy(volume); | 305 | volumeLabel->setBuddy(volume); |
306 | volume->setTickmarks(QSlider::Below); | 306 | volume->setTickmarks(QSlider::Below); |
307 | hbl->addWidget(volume); | 307 | hbl->addWidget(volume); |
308 | 308 | ||
309 | l1->addLayout(hbl); | 309 | l1->addLayout(hbl); |
310 | 310 | ||
311 | connect(volume, SIGNAL(valueChanged(int)), | 311 | connect(volume, SIGNAL(valueChanged(int)), |
312 | this, SLOT(volumeChanged(int))); | 312 | this, SLOT(volumeChanged(int))); |
313 | QString tmp = i18n("Most modems have a speaker which makes\n" | 313 | QString tmp = i18n("Most modems have a speaker which makes\n" |
314 | "a lot of noise when dialing. Here you can\n" | 314 | "a lot of noise when dialing. Here you can\n" |
315 | "either turn this completely off or select a\n" | 315 | "either turn this completely off or select a\n" |
316 | "lower volume.\n" | 316 | "lower volume.\n" |
317 | "\n" | 317 | "\n" |
318 | "If this does not work for your modem,\n" | 318 | "If this does not work for your modem,\n" |
319 | "you must modify the modem volume command."); | 319 | "you must modify the modem volume command."); |
320 | 320 | ||
321 | QWhatsThis::add(volumeLabel,tmp); | 321 | QWhatsThis::add(volumeLabel,tmp); |
322 | QWhatsThis::add(volume, tmp); | 322 | QWhatsThis::add(volume, tmp); |
323 | 323 | ||
324 | l1->addSpacing(20); | 324 | l1->addSpacing(20); |
325 | 325 | ||
326 | #if 0 | 326 | #if 0 |
327 | chkbox1 = new QCheckBox(i18n("Modem asserts CD line"), this); | 327 | chkbox1 = new QCheckBox(i18n("Modem asserts CD line"), this); |
328 | chkbox1->setChecked(gpppdata.UseCDLine()); | 328 | chkbox1->setChecked(PPPData::data()->UseCDLine()); |
329 | connect(chkbox1,SIGNAL(toggled(bool)), | 329 | connect(chkbox1,SIGNAL(toggled(bool)), |
330 | this,SLOT(use_cdline_toggled(bool))); | 330 | this,SLOT(use_cdline_toggled(bool))); |
331 | l12->addWidget(chkbox1); | 331 | l12->addWidget(chkbox1); |
332 | l12->addStretch(1); | 332 | l12->addStretch(1); |
333 | l1->addStretch(1); | 333 | l1->addStretch(1); |
334 | QWhatsThis::add(chkbox1, | 334 | QWhatsThis::add(chkbox1, |
335 | i18n("This controls how <i>kppp</i> detects that the modem\n" | 335 | i18n("This controls how <i>kppp</i> detects that the modem\n" |
336 | "is not responding. Unless you are having\n" | 336 | "is not responding. Unless you are having\n" |
337 | "problems with this, do not modify this setting.\n" | 337 | "problems with this, do not modify this setting.\n" |
338 | "\n" | 338 | "\n" |
339 | "<b>Default</b>: Off")); | 339 | "<b>Default</b>: Off")); |
340 | #endif | 340 | #endif |
341 | 341 | ||
342 | modemcmds = new QPushButton(i18n("Mod&em Commands..."), this); | 342 | modemcmds = new QPushButton(i18n("Mod&em Commands..."), this); |
343 | QWhatsThis::add(modemcmds, | 343 | QWhatsThis::add(modemcmds, |
344 | i18n("Allows you to change the AT command for\n" | 344 | i18n("Allows you to change the AT command for\n" |
345 | "your modem.")); | 345 | "your modem.")); |
346 | 346 | ||
347 | modeminfo_button = new QPushButton(i18n("&Query Modem..."), this); | 347 | modeminfo_button = new QPushButton(i18n("&Query Modem..."), this); |
348 | QWhatsThis::add(modeminfo_button, | 348 | QWhatsThis::add(modeminfo_button, |
349 | i18n("Most modems support the ATI command set to\n" | 349 | i18n("Most modems support the ATI command set to\n" |
350 | "find out vendor and revision of your modem.\n" | 350 | "find out vendor and revision of your modem.\n" |
351 | "\n" | 351 | "\n" |
352 | "Press this button to query your modem for\n" | 352 | "Press this button to query your modem for\n" |
353 | "this information. It can be useful to help\n" | 353 | "this information. It can be useful to help\n" |
354 | "you setup the modem")); | 354 | "you setup the modem")); |
355 | 355 | ||
356 | // terminal_button = new QPushButton(i18n("&Terminal..."), this); | 356 | // terminal_button = new QPushButton(i18n("&Terminal..."), this); |
357 | // QWhatsThis::add(terminal_button, | 357 | // QWhatsThis::add(terminal_button, |
358 | // i18n("Opens the built-in terminal program. You\n" | 358 | // i18n("Opens the built-in terminal program. You\n" |
359 | // "can use this if you want to play around\n" | 359 | // "can use this if you want to play around\n" |
360 | // "with your modem's AT command set")); | 360 | // "with your modem's AT command set")); |
361 | 361 | ||
362 | QHBoxLayout *hbox = new QHBoxLayout(); | 362 | QHBoxLayout *hbox = new QHBoxLayout(); |
363 | l1->addLayout(hbox); | 363 | l1->addLayout(hbox); |
364 | hbox->addStretch(1); | 364 | hbox->addStretch(1); |
365 | QVBoxLayout *vbox = new QVBoxLayout(); | 365 | QVBoxLayout *vbox = new QVBoxLayout(); |
366 | hbox->addLayout(vbox); | 366 | hbox->addLayout(vbox); |
367 | 367 | ||
368 | vbox->addWidget(modemcmds); | 368 | vbox->addWidget(modemcmds); |
369 | vbox->addWidget(modeminfo_button); | 369 | vbox->addWidget(modeminfo_button); |
370 | // vbox->addWidget(terminal_button); | 370 | // vbox->addWidget(terminal_button); |
371 | 371 | ||
372 | hbox->addStretch(1); | 372 | hbox->addStretch(1); |
373 | l1->addStretch(1); | 373 | l1->addStretch(1); |
374 | 374 | ||
375 | connect(modemcmds, SIGNAL(clicked()), | 375 | connect(modemcmds, SIGNAL(clicked()), |
376 | SLOT(modemcmdsbutton())); | 376 | SLOT(modemcmdsbutton())); |
377 | connect(modeminfo_button, SIGNAL(clicked()), | 377 | connect(modeminfo_button, SIGNAL(clicked()), |
378 | SLOT(query_modem())); | 378 | SLOT(query_modem())); |
379 | // connect(terminal_button, SIGNAL(clicked()), | 379 | // connect(terminal_button, SIGNAL(clicked()), |
380 | // SLOT(terminal())); | 380 | // SLOT(terminal())); |
381 | } | 381 | } |
382 | 382 | ||
383 | 383 | ||
384 | void ModemWidget2::modemcmdsbutton() { | 384 | void ModemWidget2::modemcmdsbutton() { |
385 | ModemCommands mc(this); | 385 | ModemCommands mc(this); |
386 | mc.showMaximized(); | 386 | mc.showMaximized(); |
387 | mc.exec(); | 387 | mc.exec(); |
388 | } | 388 | } |
389 | 389 | ||
390 | 390 | ||
391 | void ModemWidget2::query_modem() { | 391 | void ModemWidget2::query_modem() { |
392 | ModemTransfer mt(this); | 392 | ModemTransfer mt(this); |
393 | mt.exec(); | 393 | mt.exec(); |
394 | } | 394 | } |
395 | 395 | ||
396 | 396 | ||
397 | // void ModemWidget2::terminal() { | 397 | // void ModemWidget2::terminal() { |
398 | // MiniTerm terminal(NULL,NULL); | 398 | // MiniTerm terminal(NULL,NULL); |
399 | // terminal.exec(); | 399 | // terminal.exec(); |
400 | // } | 400 | // } |
401 | 401 | ||
402 | 402 | ||
403 | #if 0 | 403 | #if 0 |
404 | void ModemWidget2::use_cdline_toggled(bool on) { | 404 | void ModemWidget2::use_cdline_toggled(bool on) { |
405 | gpppdata.setUseCDLine(on); | 405 | PPPData::data()->setUseCDLine(on); |
406 | } | 406 | } |
407 | #endif | 407 | #endif |
408 | 408 | ||
409 | void ModemWidget2::waitfordtchanged(bool b) { | 409 | void ModemWidget2::waitfordtchanged(bool b) { |
410 | gpppdata.setWaitForDialTone((int)b); | 410 | PPPData::data()->setWaitForDialTone((int)b); |
411 | } | 411 | } |
412 | 412 | ||
413 | void ModemWidget2::busywaitchanged(int n) { | 413 | void ModemWidget2::busywaitchanged(int n) { |
414 | gpppdata.setbusyWait(n); | 414 | PPPData::data()->setbusyWait(n); |
415 | } | 415 | } |
416 | 416 | ||
417 | 417 | ||
418 | void ModemWidget2::volumeChanged(int v) { | 418 | void ModemWidget2::volumeChanged(int v) { |
419 | gpppdata.setVolume(v); | 419 | PPPData::data()->setVolume(v); |
420 | } | 420 | } |
421 | 421 | ||
diff --git a/noncore/settings/networksettings/ppp/kpppwidget.cpp b/noncore/settings/networksettings/ppp/kpppwidget.cpp index 2f9feda..8d70cd4 100644 --- a/noncore/settings/networksettings/ppp/kpppwidget.cpp +++ b/noncore/settings/networksettings/ppp/kpppwidget.cpp | |||
@@ -1,905 +1,905 @@ | |||
1 | /* | 1 | /* |
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 | * Copyright (C) 1998-2002 Harri Porten <porten@kde.org> | 10 | * Copyright (C) 1998-2002 Harri Porten <porten@kde.org> |
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 "kpppwidget.h" | 27 | #include "kpppwidget.h" |
28 | 28 | ||
29 | #include <qapplication.h> | 29 | #include <qapplication.h> |
30 | #include <qcombobox.h> | 30 | #include <qcombobox.h> |
31 | #include <qdir.h> | 31 | #include <qdir.h> |
32 | #include <qevent.h> | 32 | #include <qevent.h> |
33 | #include <qdialog.h> | 33 | #include <qdialog.h> |
34 | #include <qlabel.h> | 34 | #include <qlabel.h> |
35 | #include <qpushbutton.h> | 35 | #include <qpushbutton.h> |
36 | #include <qregexp.h> | 36 | #include <qregexp.h> |
37 | #include <qtabwidget.h> | 37 | #include <qtabwidget.h> |
38 | #include <qdialog.h> | 38 | #include <qdialog.h> |
39 | #include <qwhatsthis.h> | 39 | #include <qwhatsthis.h> |
40 | 40 | ||
41 | // #include <kaboutdata.h> | 41 | // #include <kaboutdata.h> |
42 | // #include <kapplication.h> | 42 | // #include <kapplication.h> |
43 | #include <qbuttongroup.h> | 43 | #include <qbuttongroup.h> |
44 | //#include <kcmdlineargs.h> | 44 | //#include <kcmdlineargs.h> |
45 | //#include <kconfig.h> | 45 | //#include <kconfig.h> |
46 | //#include <kdebug.h> | 46 | //#include <kdebug.h> |
47 | #define i18n QObject::tr | 47 | #define i18n QObject::tr |
48 | //#include <kiconloader.h> // For BarIcon | 48 | //#include <kiconloader.h> // For BarIcon |
49 | //#include <klocale.h> | 49 | //#include <klocale.h> |
50 | #include <qmessagebox.h> | 50 | #include <qmessagebox.h> |
51 | // #include <kseparator.h> | 51 | // #include <kseparator.h> |
52 | // #include <kstandarddirs.h> | 52 | // #include <kstandarddirs.h> |
53 | // #include <kwin.h> | 53 | // #include <kwin.h> |
54 | // #include <khelpmenu.h> | 54 | // #include <khelpmenu.h> |
55 | #include <qpushbutton.h> | 55 | #include <qpushbutton.h> |
56 | //#include <kguiitem.h> | 56 | //#include <kguiitem.h> |
57 | 57 | ||
58 | #include <stdlib.h> | 58 | #include <stdlib.h> |
59 | #include <errno.h> | 59 | #include <errno.h> |
60 | #include <signal.h> | 60 | #include <signal.h> |
61 | 61 | ||
62 | #include "runtests.h" | 62 | #include "runtests.h" |
63 | 63 | ||
64 | //#include "main.h" | 64 | //#include "main.h" |
65 | #include "auth.h" | 65 | #include "auth.h" |
66 | #include "modem.h" | 66 | #include "modem.h" |
67 | //#include "ppplog.h" | 67 | //#include "ppplog.h" |
68 | //#include "opener.h" | 68 | //#include "opener.h" |
69 | //#include "requester.h" | 69 | //#include "requester.h" |
70 | //#include "pppstats.h" | 70 | //#include "pppstats.h" |
71 | #include "pppdata.h" | 71 | #include "pppdata.h" |
72 | #include "general.h" | 72 | #include "general.h" |
73 | 73 | ||
74 | #define execute_command system | 74 | #define execute_command system |
75 | 75 | ||
76 | KPPPWidget *p_kppp = 0; | 76 | KPPPWidget *p_kppp = 0; |
77 | 77 | ||
78 | KPPPWidget::KPPPWidget( QWidget *parent, const char *name, bool modal, WFlags fl ) | 78 | KPPPWidget::KPPPWidget( QWidget *parent, const char *name, bool modal, WFlags fl ) |
79 | : QDialog(parent, name, modal, fl) | 79 | : QDialog(parent, name, modal, fl) |
80 | // , acct(0) | 80 | // , acct(0) |
81 | // , m_bCmdlAccount (false) | 81 | // , m_bCmdlAccount (false) |
82 | { | 82 | { |
83 | // tabWindow = 0; | 83 | // tabWindow = 0; |
84 | p_kppp = this; | 84 | p_kppp = this; |
85 | // before doing anything else, run a few tests | 85 | // before doing anything else, run a few tests |
86 | 86 | ||
87 | int result = runTests(); | 87 | int result = runTests(); |
88 | if(result == TEST_CRITICAL) | 88 | if(result == TEST_CRITICAL) |
89 | exit(4); | 89 | exit(4); |
90 | 90 | ||
91 | // installEventFilter(this); | 91 | // installEventFilter(this); |
92 | 92 | ||
93 | // QVBoxLayout *tl = new QVBoxLayout(this, 10, 10); | 93 | // QVBoxLayout *tl = new QVBoxLayout(this, 10, 10); |
94 | 94 | ||
95 | // QGridLayout *l1 = new QGridLayout(3, 4); | 95 | // QGridLayout *l1 = new QGridLayout(3, 4); |
96 | // tl->addLayout(l1); | 96 | // tl->addLayout(l1); |
97 | // l1->addColSpacing(0, 10); | 97 | // l1->addColSpacing(0, 10); |
98 | // l1->addColSpacing(3, 10); | 98 | // l1->addColSpacing(3, 10); |
99 | // l1->setColStretch(1, 3); | 99 | // l1->setColStretch(1, 3); |
100 | // l1->setColStretch(2, 4); | 100 | // l1->setColStretch(2, 4); |
101 | 101 | ||
102 | // label1 = new QLabel(i18n("C&onnect to: "), this); | 102 | // label1 = new QLabel(i18n("C&onnect to: "), this); |
103 | // l1->addWidget(label1, 0, 1); | 103 | // l1->addWidget(label1, 0, 1); |
104 | 104 | ||
105 | // connectto_c = new QComboBox(false, this); | 105 | // connectto_c = new QComboBox(false, this); |
106 | // label1->setBuddy(connectto_c); | 106 | // label1->setBuddy(connectto_c); |
107 | 107 | ||
108 | // connect(connectto_c, SIGNAL(activated(int)), | 108 | // connect(connectto_c, SIGNAL(activated(int)), |
109 | // SLOT(newdefaultaccount(int))); | 109 | // SLOT(newdefaultaccount(int))); |
110 | // l1->addWidget(connectto_c, 0, 2); | 110 | // l1->addWidget(connectto_c, 0, 2); |
111 | 111 | ||
112 | // ID_Label = new QLabel(i18n("&Login ID:"), this); | 112 | // ID_Label = new QLabel(i18n("&Login ID:"), this); |
113 | // l1->addWidget(ID_Label, 1, 1); | 113 | // l1->addWidget(ID_Label, 1, 1); |
114 | 114 | ||
115 | // // the entry line for usernames | 115 | // // the entry line for usernames |
116 | // ID_Edit = new QLineEdit(this); | 116 | // ID_Edit = new QLineEdit(this); |
117 | // ID_Label->setBuddy(ID_Edit); | 117 | // ID_Label->setBuddy(ID_Edit); |
118 | // l1->addWidget(ID_Edit, 1, 2); | 118 | // l1->addWidget(ID_Edit, 1, 2); |
119 | // connect(ID_Edit, SIGNAL(returnPressed()), | 119 | // connect(ID_Edit, SIGNAL(returnPressed()), |
120 | // this, SLOT(enterPressedInID())); | 120 | // this, SLOT(enterPressedInID())); |
121 | // QString tmp = i18n("<p>Type in the username that you got from your\n" | 121 | // QString tmp = i18n("<p>Type in the username that you got from your\n" |
122 | // "ISP. This is especially important for PAP\n" | 122 | // "ISP. This is especially important for PAP\n" |
123 | // "and CHAP. You may omit this when you use\n" | 123 | // "and CHAP. You may omit this when you use\n" |
124 | // "terminal-based or script-based authentication.\n" | 124 | // "terminal-based or script-based authentication.\n" |
125 | // "\n" | 125 | // "\n" |
126 | // "<b>Important</b>: case is important here:\n" | 126 | // "<b>Important</b>: case is important here:\n" |
127 | // "<i>myusername</i> is not the same as <i>MyUserName</i>!"); | 127 | // "<i>myusername</i> is not the same as <i>MyUserName</i>!"); |
128 | 128 | ||
129 | // QWhatsThis::add(ID_Label,tmp); | 129 | // QWhatsThis::add(ID_Label,tmp); |
130 | // QWhatsThis::add(ID_Edit,tmp); | 130 | // QWhatsThis::add(ID_Edit,tmp); |
131 | 131 | ||
132 | // PW_Label = new QLabel(i18n("&Password:"), this); | 132 | // PW_Label = new QLabel(i18n("&Password:"), this); |
133 | // l1->addWidget(PW_Label, 2, 1); | 133 | // l1->addWidget(PW_Label, 2, 1); |
134 | 134 | ||
135 | // PW_Edit= new QLineEdit(this); | 135 | // PW_Edit= new QLineEdit(this); |
136 | // PW_Label->setBuddy(PW_Edit); | 136 | // PW_Label->setBuddy(PW_Edit); |
137 | // PW_Edit->setEchoMode(QLineEdit::Password); | 137 | // PW_Edit->setEchoMode(QLineEdit::Password); |
138 | // l1->addWidget(PW_Edit, 2, 2); | 138 | // l1->addWidget(PW_Edit, 2, 2); |
139 | // connect(PW_Edit, SIGNAL(returnPressed()), | 139 | // connect(PW_Edit, SIGNAL(returnPressed()), |
140 | // this, SLOT(enterPressedInPW())); | 140 | // this, SLOT(enterPressedInPW())); |
141 | 141 | ||
142 | // tmp = i18n("<p>Type in the password that you got from your\n" | 142 | // tmp = i18n("<p>Type in the password that you got from your\n" |
143 | // "ISP. This is especially important for PAP\n" | 143 | // "ISP. This is especially important for PAP\n" |
144 | // "and CHAP. You may omit this when you use\n" | 144 | // "and CHAP. You may omit this when you use\n" |
145 | // "terminal-based or script-based authentication.\n" | 145 | // "terminal-based or script-based authentication.\n" |
146 | // "\n" | 146 | // "\n" |
147 | // "<b>Important</b>: case is important here:\n" | 147 | // "<b>Important</b>: case is important here:\n" |
148 | // "<i>mypassword</i> is not the same as <i>MyPassword</i>!"); | 148 | // "<i>mypassword</i> is not the same as <i>MyPassword</i>!"); |
149 | 149 | ||
150 | // QWhatsThis::add(PW_Label,tmp); | 150 | // QWhatsThis::add(PW_Label,tmp); |
151 | // QWhatsThis::add(PW_Edit,tmp); | 151 | // QWhatsThis::add(PW_Edit,tmp); |
152 | 152 | ||
153 | // QHBoxLayout *l3 = new QHBoxLayout; | 153 | // QHBoxLayout *l3 = new QHBoxLayout; |
154 | // tl->addSpacing(5); | 154 | // tl->addSpacing(5); |
155 | // tl->addLayout(l3); | 155 | // tl->addLayout(l3); |
156 | // tl->addSpacing(5); | 156 | // tl->addSpacing(5); |
157 | // l3->addSpacing(10); | 157 | // l3->addSpacing(10); |
158 | // log = new QCheckBox(i18n("Show lo&g window"), this); | 158 | // log = new QCheckBox(i18n("Show lo&g window"), this); |
159 | // connect(log, SIGNAL(toggled(bool)), | 159 | // connect(log, SIGNAL(toggled(bool)), |
160 | // this, SLOT(log_window_toggled(bool))); | 160 | // this, SLOT(log_window_toggled(bool))); |
161 | // log->setChecked(gpppdata.get_show_log_window()); | 161 | // log->setChecked(PPPData::data()->get_show_log_window()); |
162 | // l3->addWidget(log); | 162 | // l3->addWidget(log); |
163 | 163 | ||
164 | // QWhatsThis::add(log, | 164 | // QWhatsThis::add(log, |
165 | // i18n("<p>This controls whether a log window is shown.\n" | 165 | // i18n("<p>This controls whether a log window is shown.\n" |
166 | // "A log window shows the communication between\n" | 166 | // "A log window shows the communication between\n" |
167 | // "<i>kppp</i> and your modem. This will help you\n" | 167 | // "<i>kppp</i> and your modem. This will help you\n" |
168 | // "in tracking down problems.\n" | 168 | // "in tracking down problems.\n" |
169 | // "\n" | 169 | // "\n" |
170 | // "Turn it off if <i>kppp</i> routinely connects without\n" | 170 | // "Turn it off if <i>kppp</i> routinely connects without\n" |
171 | // "problems")); | 171 | // "problems")); |
172 | 172 | ||
173 | // // fline = new QSeparator( KSeparator::HLine, this); | 173 | // // fline = new QSeparator( KSeparator::HLine, this); |
174 | // // tl->addWidget(fline); | 174 | // // tl->addWidget(fline); |
175 | 175 | ||
176 | // QHBoxLayout *l2 = new QHBoxLayout(this); | 176 | // QHBoxLayout *l2 = new QHBoxLayout(this); |
177 | // tl->addLayout(l2); | 177 | // tl->addLayout(l2); |
178 | 178 | ||
179 | // int minw = 0; | 179 | // int minw = 0; |
180 | // quit_b = new QPushButton(i18n("&Quit"), this); | 180 | // quit_b = new QPushButton(i18n("&Quit"), this); |
181 | // // quit_b-> setGuiItem (KGuiItem(i18n("&Quit"), "exit" ) ); | 181 | // // quit_b-> setGuiItem (KGuiItem(i18n("&Quit"), "exit" ) ); |
182 | // connect( quit_b, SIGNAL(clicked()), SLOT(quitbutton())); | 182 | // connect( quit_b, SIGNAL(clicked()), SLOT(quitbutton())); |
183 | // if(quit_b->sizeHint().width() > minw) | 183 | // if(quit_b->sizeHint().width() > minw) |
184 | // minw = quit_b->sizeHint().width(); | 184 | // minw = quit_b->sizeHint().width(); |
185 | 185 | ||
186 | // setup_b = new QPushButton(i18n("&Setup..."), this); | 186 | // setup_b = new QPushButton(i18n("&Setup..."), this); |
187 | // // setup_b->setGuiItem (KGuiItem(i18n("&Setup...")) ); | 187 | // // setup_b->setGuiItem (KGuiItem(i18n("&Setup...")) ); |
188 | // connect( setup_b, SIGNAL(clicked()), SLOT(expandbutton())); | 188 | // connect( setup_b, SIGNAL(clicked()), SLOT(expandbutton())); |
189 | // if(setup_b->sizeHint().width() > minw) | 189 | // if(setup_b->sizeHint().width() > minw) |
190 | // minw = setup_b->sizeHint().width(); | 190 | // minw = setup_b->sizeHint().width(); |
191 | 191 | ||
192 | 192 | ||
193 | 193 | ||
194 | // if(gpppdata.access() != KConfig::ReadWrite) | 194 | // if(PPPData::data()->access() != KConfig::ReadWrite) |
195 | // setup_b->setEnabled(false); | 195 | // setup_b->setEnabled(false); |
196 | 196 | ||
197 | // help_b = new QPushButton(i18n("&Help"), this); | 197 | // help_b = new QPushButton(i18n("&Help"), this); |
198 | // connect( help_b, SIGNAL(clicked()), SLOT(helpbutton())); | 198 | // connect( help_b, SIGNAL(clicked()), SLOT(helpbutton())); |
199 | 199 | ||
200 | // KHelpMenu *helpMenu = new KHelpMenu(this, KGlobal::instance()->aboutData(), true); | 200 | // KHelpMenu *helpMenu = new KHelpMenu(this, KGlobal::instance()->aboutData(), true); |
201 | // help_b->setPopup((QPopupMenu*)helpMenu->menu()); | 201 | // help_b->setPopup((QPopupMenu*)helpMenu->menu()); |
202 | // help_b->setGuiItem (KGuiItem(i18n("&Help"), "help" ) ); | 202 | // help_b->setGuiItem (KGuiItem(i18n("&Help"), "help" ) ); |
203 | 203 | ||
204 | // if(help_b->sizeHint().width() > minw) | 204 | // if(help_b->sizeHint().width() > minw) |
205 | // minw = help_b->sizeHint().width(); | 205 | // minw = help_b->sizeHint().width(); |
206 | 206 | ||
207 | // connect_b = new QPushButton(i18n("&Connect"), this); | 207 | // connect_b = new QPushButton(i18n("&Connect"), this); |
208 | // connect_b->setDefault(true); | 208 | // connect_b->setDefault(true); |
209 | // connect_b->setFocus(); | 209 | // connect_b->setFocus(); |
210 | // connect(connect_b, SIGNAL(clicked()), SLOT(beginConnect())); | 210 | // connect(connect_b, SIGNAL(clicked()), SLOT(beginConnect())); |
211 | // if(connect_b->sizeHint().width() > minw) | 211 | // if(connect_b->sizeHint().width() > minw) |
212 | // minw = connect_b->sizeHint().width(); | 212 | // minw = connect_b->sizeHint().width(); |
213 | 213 | ||
214 | // quit_b->setFixedWidth(minw); | 214 | // quit_b->setFixedWidth(minw); |
215 | // setup_b->setFixedWidth(minw); | 215 | // setup_b->setFixedWidth(minw); |
216 | // // help_b->setFixedWidth(help_b->sizeHint().width()); | 216 | // // help_b->setFixedWidth(help_b->sizeHint().width()); |
217 | // connect_b->setFixedWidth(minw); | 217 | // connect_b->setFixedWidth(minw); |
218 | 218 | ||
219 | // l2->addWidget(quit_b); | 219 | // l2->addWidget(quit_b); |
220 | // l2->addWidget(setup_b); | 220 | // l2->addWidget(setup_b); |
221 | // // l2->addWidget(help_b); | 221 | // // l2->addWidget(help_b); |
222 | // l2->addSpacing(20); | 222 | // l2->addSpacing(20); |
223 | // l2->addWidget(connect_b); | 223 | // l2->addWidget(connect_b); |
224 | 224 | ||
225 | setFixedSize(sizeHint()); | 225 | setFixedSize(sizeHint()); |
226 | 226 | ||
227 | (void)new Modem; | 227 | (void)new Modem; |
228 | 228 | ||
229 | // we also connect cmld_start to the beginConnect so that I can run | 229 | // we also connect cmld_start to the beginConnect so that I can run |
230 | // the dialer through a command line argument | 230 | // the dialer through a command line argument |
231 | connect(this,SIGNAL(cmdl_start()),this,SLOT(beginConnect())); | 231 | connect(this,SIGNAL(cmdl_start()),this,SLOT(beginConnect())); |
232 | 232 | ||
233 | // stats = new PPPStats; | 233 | // stats = new PPPStats; |
234 | 234 | ||
235 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); | 235 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); |
236 | 236 | ||
237 | // constructor of con_win reads position from config file | 237 | // constructor of con_win reads position from config file |
238 | // con_win = new ConWindow(0, "conw", this); | 238 | // con_win = new ConWindow(0, "conw", this); |
239 | // KWin::setIcons(con_win->winId(), kapp->icon(), kapp->miniIcon()); | 239 | // KWin::setIcons(con_win->winId(), kapp->icon(), kapp->miniIcon()); |
240 | 240 | ||
241 | // statdlg = new PPPStatsDlg(0, "stats", this, stats); | 241 | // statdlg = new PPPStatsDlg(0, "stats", this, stats); |
242 | // statdlg->hide(); | 242 | // statdlg->hide(); |
243 | 243 | ||
244 | debugwindow = new DebugWidget(0,"debugwindow"); | 244 | debugwindow = new DebugWidget(0,"debugwindow"); |
245 | // KWin::setIcons(debugwindow->winId(), kapp->icon(), kapp->miniIcon()); | 245 | // KWin::setIcons(debugwindow->winId(), kapp->icon(), kapp->miniIcon()); |
246 | debugwindow->hide(); | 246 | debugwindow->hide(); |
247 | 247 | ||
248 | // load up the accounts combo box | 248 | // load up the accounts combo box |
249 | 249 | ||
250 | // resetaccounts(); | 250 | // resetaccounts(); |
251 | // con = new ConnectWidget(0, "con"); | 251 | // con = new ConnectWidget(0, "con"); |
252 | //KWin::setIcons(con->winId(), kapp->icon(), kapp->miniIcon() ); | 252 | //KWin::setIcons(con->winId(), kapp->icon(), kapp->miniIcon() ); |
253 | // connect(this, SIGNAL(begin_connect()),con, SLOT(preinit())); | 253 | // connect(this, SIGNAL(begin_connect()),con, SLOT(preinit())); |
254 | // Is this the best we can do here? it's not right. | 254 | // Is this the best we can do here? it's not right. |
255 | // QRect desk = QApplication::desktop()->screenGeometry( | 255 | // QRect desk = QApplication::desktop()->screenGeometry( |
256 | // QApplication::desktop()->screenNumber(topLevelWidget())); | 256 | // QApplication::desktop()->screenNumber(topLevelWidget())); |
257 | // con->setGeometry(desk.center().x()-175, desk.center().y()-55, 350,110); | 257 | // con->setGeometry(desk.center().x()-175, desk.center().y()-55, 350,110); |
258 | 258 | ||
259 | // connect the ConnectWidgets various signals | 259 | // connect the ConnectWidgets various signals |
260 | // connect(con, SIGNAL(closeDebugWindow()), | 260 | // connect(con, SIGNAL(closeDebugWindow()), |
261 | // debugwindow, SLOT(hide())); | 261 | // debugwindow, SLOT(hide())); |
262 | // connect(con, SIGNAL(debugMessage(const QString &)), | 262 | // connect(con, SIGNAL(debugMessage(const QString &)), |
263 | // debugwindow, SLOT(statusLabel(const QString &))); | 263 | // debugwindow, SLOT(statusLabel(const QString &))); |
264 | // connect(con, SIGNAL(toggleDebugWindow()), | 264 | // connect(con, SIGNAL(toggleDebugWindow()), |
265 | // debugwindow, SLOT(toggleVisibility())); | 265 | // debugwindow, SLOT(toggleVisibility())); |
266 | // connect(con, SIGNAL(debugPutChar(unsigned char)), | 266 | // connect(con, SIGNAL(debugPutChar(unsigned char)), |
267 | // debugwindow, SLOT(addChar(unsigned char))); | 267 | // debugwindow, SLOT(addChar(unsigned char))); |
268 | // // connect(con, SIGNAL(startAccounting()), | 268 | // // connect(con, SIGNAL(startAccounting()), |
269 | // // this, SLOT(startAccounting())); | 269 | // // this, SLOT(startAccounting())); |
270 | // // connect(con, SIGNAL(stopAccounting()), | 270 | // // connect(con, SIGNAL(stopAccounting()), |
271 | // // this, SLOT(stopAccounting())); | 271 | // // this, SLOT(stopAccounting())); |
272 | // connect(qApp, SIGNAL(saveYourself()), | 272 | // connect(qApp, SIGNAL(saveYourself()), |
273 | // this, SLOT(saveMyself())); | 273 | // this, SLOT(saveMyself())); |
274 | // connect(qApp, SIGNAL(shutDown()), | 274 | // connect(qApp, SIGNAL(shutDown()), |
275 | // this, SLOT(shutDown())); | 275 | // this, SLOT(shutDown())); |
276 | 276 | ||
277 | // debugwindow->setGeometry(desk.center().x()+190, desk.center().y()-55, | 277 | // debugwindow->setGeometry(desk.center().x()+190, desk.center().y()-55, |
278 | // debugwindow->width(),debugwindow->height()); | 278 | // debugwindow->width(),debugwindow->height()); |
279 | 279 | ||
280 | // move(desk.center().x()-width()/2, desk.center().y()-height()/2); | 280 | // move(desk.center().x()-width()/2, desk.center().y()-height()/2); |
281 | 281 | ||
282 | 282 | ||
283 | // KCmdLineArgs *args = KCmdLineArgs::parsedArgs(); | 283 | // KCmdLineArgs *args = KCmdLineArgs::parsedArgs(); |
284 | 284 | ||
285 | // m_strCmdlAccount = args->getOption("c"); | 285 | // m_strCmdlAccount = args->getOption("c"); |
286 | // m_bQuitOnDisconnect = args->isSet("q"); | 286 | // m_bQuitOnDisconnect = args->isSet("q"); |
287 | 287 | ||
288 | // if(!m_strCmdlAccount.isEmpty()) { | 288 | // if(!m_strCmdlAccount.isEmpty()) { |
289 | // m_bCmdlAccount = true; | 289 | // m_bCmdlAccount = true; |
290 | // kdDebug(5002) << "cmdl_account: " << m_bCmdlAccount << endl; | 290 | // kdDebug(5002) << "cmdl_account: " << m_bCmdlAccount << endl; |
291 | // } | 291 | // } |
292 | 292 | ||
293 | // if(m_bCmdlAccount){ | 293 | // if(m_bCmdlAccount){ |
294 | // bool result = gpppdata.setAccount(m_strCmdlAccount); | 294 | // bool result = PPPData::data()->setAccount(m_strCmdlAccount); |
295 | // if (!result){ | 295 | // if (!result){ |
296 | // QString string; | 296 | // QString string; |
297 | // string = i18n("No such Account:\n%1").arg(m_strCmdlAccount); | 297 | // string = i18n("No such Account:\n%1").arg(m_strCmdlAccount); |
298 | // KMessageBox::error(this, string); | 298 | // KMessageBox::error(this, string); |
299 | // m_bCmdlAccount = false; | 299 | // m_bCmdlAccount = false; |
300 | // this->show(); | 300 | // this->show(); |
301 | // } else { | 301 | // } else { |
302 | // beginConnect(); | 302 | // beginConnect(); |
303 | // } | 303 | // } |
304 | // } else | 304 | // } else |
305 | // expandbutton(); | 305 | // expandbutton(); |
306 | // show(); | 306 | // show(); |
307 | 307 | ||
308 | 308 | ||
309 | //#define KPPP_SHOW_NEWS | 309 | //#define KPPP_SHOW_NEWS |
310 | #ifdef KPPP_SHOW_NEWS | 310 | #ifdef KPPP_SHOW_NEWS |
311 | // keep user informed about recent changes | 311 | // keep user informed about recent changes |
312 | if(!m_bCmdlAccount) | 312 | if(!m_bCmdlAccount) |
313 | showNews(); | 313 | showNews(); |
314 | #endif | 314 | #endif |
315 | } | 315 | } |
316 | 316 | ||
317 | KPPPWidget::~KPPPWidget() | 317 | KPPPWidget::~KPPPWidget() |
318 | { | 318 | { |
319 | p_kppp = 0; | 319 | p_kppp = 0; |
320 | // delete stats; | 320 | // delete stats; |
321 | } | 321 | } |
322 | 322 | ||
323 | // bool KPPPWidget::eventFilter(QObject *o, QEvent *e) { | 323 | // bool KPPPWidget::eventFilter(QObject *o, QEvent *e) { |
324 | // if(e->type() == QEvent::User) { | 324 | // if(e->type() == QEvent::User) { |
325 | // switch(((SignalEvent*)e)->sigType()) { | 325 | // switch(((SignalEvent*)e)->sigType()) { |
326 | // case SIGINT: | 326 | // case SIGINT: |
327 | // qDebug( "Received a SIGINT" ); | 327 | // qDebug( "Received a SIGINT" ); |
328 | // interruptConnection(); | 328 | // interruptConnection(); |
329 | // break; | 329 | // break; |
330 | // case SIGCHLD: | 330 | // case SIGCHLD: |
331 | // sigChld(); | 331 | // sigChld(); |
332 | // break; | 332 | // break; |
333 | // case SIGUSR1: | 333 | // case SIGUSR1: |
334 | // sigPPPDDied(); | 334 | // sigPPPDDied(); |
335 | // break; | 335 | // break; |
336 | // } | 336 | // } |
337 | // return true; | 337 | // return true; |
338 | // } | 338 | // } |
339 | 339 | ||
340 | // if(o == connect_b) { | 340 | // if(o == connect_b) { |
341 | // if(e->type() == QEvent::KeyPress) { | 341 | // if(e->type() == QEvent::KeyPress) { |
342 | // if(connect_b->hasFocus() && ((QKeyEvent *)e)->key() == Qt::Key_Return) { | 342 | // if(connect_b->hasFocus() && ((QKeyEvent *)e)->key() == Qt::Key_Return) { |
343 | // beginConnect(); | 343 | // beginConnect(); |
344 | // return true; | 344 | // return true; |
345 | // } | 345 | // } |
346 | // } | 346 | // } |
347 | // } | 347 | // } |
348 | 348 | ||
349 | // return false; | 349 | // return false; |
350 | // } | 350 | // } |
351 | 351 | ||
352 | 352 | ||
353 | 353 | ||
354 | 354 | ||
355 | void KPPPWidget::enterPressedInID() { | 355 | void KPPPWidget::enterPressedInID() { |
356 | PW_Edit->setFocus(); | 356 | PW_Edit->setFocus(); |
357 | } | 357 | } |
358 | 358 | ||
359 | 359 | ||
360 | void KPPPWidget::enterPressedInPW() { | 360 | void KPPPWidget::enterPressedInPW() { |
361 | connect_b->setFocus(); | 361 | connect_b->setFocus(); |
362 | } | 362 | } |
363 | 363 | ||
364 | // triggered by the session manager | 364 | // triggered by the session manager |
365 | void KPPPWidget::saveMyself() { | 365 | void KPPPWidget::saveMyself() { |
366 | gpppdata.save(); | 366 | PPPData::data()->save(); |
367 | } | 367 | } |
368 | 368 | ||
369 | void KPPPWidget::shutDown() { | 369 | void KPPPWidget::shutDown() { |
370 | interruptConnection(); | 370 | interruptConnection(); |
371 | saveMyself(); | 371 | saveMyself(); |
372 | } | 372 | } |
373 | 373 | ||
374 | void KPPPWidget::log_window_toggled(bool on) { | 374 | void KPPPWidget::log_window_toggled(bool on) { |
375 | gpppdata.set_show_log_window(on); | 375 | PPPData::data()->set_show_log_window(on); |
376 | } | 376 | } |
377 | 377 | ||
378 | 378 | ||
379 | 379 | ||
380 | 380 | ||
381 | // void KPPPWidget::resetaccounts() { | 381 | // void KPPPWidget::resetaccounts() { |
382 | // connectto_c->clear(); | 382 | // connectto_c->clear(); |
383 | 383 | ||
384 | // int count = gpppdata.count(); | 384 | // int count = PPPData::data()->count(); |
385 | 385 | ||
386 | // // enable/disable controls | 386 | // // enable/disable controls |
387 | // connectto_c->setEnabled(count > 0); | 387 | // connectto_c->setEnabled(count > 0); |
388 | // connect_b->setEnabled(count > 0); | 388 | // connect_b->setEnabled(count > 0); |
389 | // log->setEnabled(count > 0); | 389 | // log->setEnabled(count > 0); |
390 | // ID_Edit->setEnabled(count > 0); | 390 | // ID_Edit->setEnabled(count > 0); |
391 | // PW_Edit->setEnabled(count > 0); | 391 | // PW_Edit->setEnabled(count > 0); |
392 | 392 | ||
393 | // //load the accounts | 393 | // //load the accounts |
394 | // for(int i=0; i < count; i++) { | 394 | // for(int i=0; i < count; i++) { |
395 | // gpppdata.setAccountbyIndex(i); | 395 | // PPPData::data()->setAccountbyIndex(i); |
396 | // connectto_c->insertItem(gpppdata.accname()); | 396 | // connectto_c->insertItem(PPPData::data()->accname()); |
397 | // } | 397 | // } |
398 | 398 | ||
399 | // //set the default account | 399 | // //set the default account |
400 | // if(!gpppdata.defaultAccount().isEmpty()) { | 400 | // if(!PPPData::data()->defaultAccount().isEmpty()) { |
401 | // for(int i=0; i < count; i++) | 401 | // for(int i=0; i < count; i++) |
402 | // if(gpppdata.defaultAccount() == connectto_c->text(i)) { | 402 | // if(PPPData::data()->defaultAccount() == connectto_c->text(i)) { |
403 | // connectto_c->setCurrentItem(i); | 403 | // connectto_c->setCurrentItem(i); |
404 | // gpppdata.setAccountbyIndex(i); | 404 | // PPPData::data()->setAccountbyIndex(i); |
405 | 405 | ||
406 | // ID_Edit->setText(gpppdata.storedUsername()); | 406 | // ID_Edit->setText(PPPData::data()->storedUsername()); |
407 | // PW_Edit->setText(gpppdata.storedPassword()); | 407 | // PW_Edit->setText(PPPData::data()->storedPassword()); |
408 | // } | 408 | // } |
409 | // } | 409 | // } |
410 | // else | 410 | // else |
411 | // if(count > 0) { | 411 | // if(count > 0) { |
412 | // gpppdata.setDefaultAccount(connectto_c->text(0)); | 412 | // PPPData::data()->setDefaultAccount(connectto_c->text(0)); |
413 | // gpppdata.save(); | 413 | // PPPData::data()->save(); |
414 | // ID_Edit->setText(gpppdata.storedUsername()); | 414 | // ID_Edit->setText(PPPData::data()->storedUsername()); |
415 | // PW_Edit->setText(gpppdata.storedPassword()); | 415 | // PW_Edit->setText(PPPData::data()->storedPassword()); |
416 | // } | 416 | // } |
417 | 417 | ||
418 | // connect(ID_Edit, SIGNAL(textChanged(const QString &)), | 418 | // connect(ID_Edit, SIGNAL(textChanged(const QString &)), |
419 | // this, SLOT(usernameChanged(const QString &))); | 419 | // this, SLOT(usernameChanged(const QString &))); |
420 | 420 | ||
421 | // connect(PW_Edit, SIGNAL(textChanged(const QString &)), | 421 | // connect(PW_Edit, SIGNAL(textChanged(const QString &)), |
422 | // this, SLOT(passwordChanged(const QString &))); | 422 | // this, SLOT(passwordChanged(const QString &))); |
423 | 423 | ||
424 | // if (ID_Edit->text().isEmpty()) | 424 | // if (ID_Edit->text().isEmpty()) |
425 | // ID_Edit->setFocus(); | 425 | // ID_Edit->setFocus(); |
426 | // else if (PW_Edit->text().isEmpty()) | 426 | // else if (PW_Edit->text().isEmpty()) |
427 | // PW_Edit->setFocus(); | 427 | // PW_Edit->setFocus(); |
428 | // } | 428 | // } |
429 | 429 | ||
430 | 430 | ||
431 | void KPPPWidget::interruptConnection() { | 431 | void KPPPWidget::interruptConnection() { |
432 | // interrupt dial up | 432 | // interrupt dial up |
433 | // if (con->isVisible()) | 433 | // if (con->isVisible()) |
434 | // emit con->cancelbutton(); | 434 | // emit con->cancelbutton(); |
435 | 435 | ||
436 | // disconnect if online | 436 | // disconnect if online |
437 | if (gpppdata.pppdRunning()) | 437 | if (PPPData::data()->pppdRunning()) |
438 | emit disconnect(); | 438 | emit disconnect(); |
439 | } | 439 | } |
440 | 440 | ||
441 | 441 | ||
442 | void KPPPWidget::sigPPPDDied() { | 442 | void KPPPWidget::sigPPPDDied() { |
443 | qDebug( "Received a SIGUSR1" ); | 443 | qDebug( "Received a SIGUSR1" ); |
444 | 444 | ||
445 | // if we are not connected pppdpid is -1 so have have to check for that | 445 | // if we are not connected pppdpid is -1 so have have to check for that |
446 | // in the followin line to make sure that we don't raise a false alarm | 446 | // in the followin line to make sure that we don't raise a false alarm |
447 | // such as would be the case when the log file viewer exits. | 447 | // such as would be the case when the log file viewer exits. |
448 | if(gpppdata.pppdRunning() || gpppdata.pppdError()) { | 448 | if(PPPData::data()->pppdRunning() || PPPData::data()->pppdError()) { |
449 | qDebug( "It was pppd that died" ); | 449 | qDebug( "It was pppd that died" ); |
450 | 450 | ||
451 | // when we killpppd() on Cancel in ConnectWidget | 451 | // when we killpppd() on Cancel in ConnectWidget |
452 | // we set pppid to -1 so we won't | 452 | // we set pppid to -1 so we won't |
453 | // enter this block | 453 | // enter this block |
454 | 454 | ||
455 | // just to be sure | 455 | // just to be sure |
456 | 456 | ||
457 | Modem::modem->removeSecret(AUTH_PAP); | 457 | Modem::modem->removeSecret(AUTH_PAP); |
458 | Modem::modem->removeSecret(AUTH_CHAP); | 458 | Modem::modem->removeSecret(AUTH_CHAP); |
459 | 459 | ||
460 | gpppdata.setpppdRunning(false); | 460 | PPPData::data()->setpppdRunning(false); |
461 | 461 | ||
462 | qDebug( "Executing command on disconnect since pppd has died." ); | 462 | qDebug( "Executing command on disconnect since pppd has died." ); |
463 | QApplication::flushX(); | 463 | QApplication::flushX(); |
464 | execute_command(gpppdata.command_on_disconnect()); | 464 | execute_command(PPPData::data()->command_on_disconnect()); |
465 | 465 | ||
466 | // stopAccounting(); | 466 | // stopAccounting(); |
467 | 467 | ||
468 | // con_win->stopClock(); | 468 | // con_win->stopClock(); |
469 | // DockWidget::dock_widget->stop_stats(); | 469 | // DockWidget::dock_widget->stop_stats(); |
470 | // DockWidget::dock_widget->hide(); | 470 | // DockWidget::dock_widget->hide(); |
471 | 471 | ||
472 | if(!gpppdata.pppdError()) | 472 | if(!PPPData::data()->pppdError()) |
473 | gpppdata.setpppdError(E_PPPD_DIED); | 473 | PPPData::data()->setpppdError(E_PPPD_DIED); |
474 | removedns(); | 474 | removedns(); |
475 | Modem::modem->unlockdevice(); | 475 | Modem::modem->unlockdevice(); |
476 | // con->pppdDied(); | 476 | // con->pppdDied(); |
477 | 477 | ||
478 | if(!gpppdata.automatic_redial()) { | 478 | if(!PPPData::data()->automatic_redial()) { |
479 | quit_b->setFocus(); | 479 | quit_b->setFocus(); |
480 | show(); | 480 | show(); |
481 | // con_win->stopClock(); | 481 | // con_win->stopClock(); |
482 | //stopAccounting(); | 482 | //stopAccounting(); |
483 | // con_win->hide(); | 483 | // con_win->hide(); |
484 | // con->hide(); | 484 | // con->hide(); |
485 | 485 | ||
486 | gpppdata.setpppdRunning(false); | 486 | PPPData::data()->setpppdRunning(false); |
487 | // // not in a signal handler !!! KNotifyClient::beep(); | 487 | // // not in a signal handler !!! KNotifyClient::beep(); |
488 | QString msg; | 488 | QString msg; |
489 | if (gpppdata.pppdError() == E_IF_TIMEOUT) | 489 | if (PPPData::data()->pppdError() == E_IF_TIMEOUT) |
490 | msg = i18n("Timeout expired while waiting for the PPP interface " | 490 | msg = i18n("Timeout expired while waiting for the PPP interface " |
491 | "to come up!"); | 491 | "to come up!"); |
492 | else { | 492 | else { |
493 | msg = i18n("<p>The pppd daemon died unexpectedly!</p>"); | 493 | msg = i18n("<p>The pppd daemon died unexpectedly!</p>"); |
494 | Modem::modem->pppdExitStatus(); | 494 | Modem::modem->pppdExitStatus(); |
495 | if (Modem::modem->lastStatus != 99) {// more recent pppds only | 495 | if (Modem::modem->lastStatus != 99) {// more recent pppds only |
496 | msg += i18n("<p>Exit status: %1").arg(Modem::modem->lastStatus); | 496 | msg += i18n("<p>Exit status: %1").arg(Modem::modem->lastStatus); |
497 | msg += i18n("</p><p>See 'man pppd' for an explanation of the error " | 497 | msg += i18n("</p><p>See 'man pppd' for an explanation of the error " |
498 | "codes or take a look at the kppp FAQ on " | 498 | "codes or take a look at the kppp FAQ on " |
499 | " <a href=http://devel-home.kde.org/~kppp/index.html>" | 499 | " <a href=http://devel-home.kde.org/~kppp/index.html>" |
500 | "http://devel-home.kde.org/~kppp/index.html</a></p>"); | 500 | "http://devel-home.kde.org/~kppp/index.html</a></p>"); |
501 | } | 501 | } |
502 | } | 502 | } |
503 | 503 | ||
504 | // if(QMessageBox::warning(0, msg, i18n("Error"), i18n("&OK"), i18n("&Details...")) == QMessageBox::No) | 504 | // if(QMessageBox::warning(0, msg, i18n("Error"), i18n("&OK"), i18n("&Details...")) == QMessageBox::No) |
505 | // // PPPL_ShowLog(); | 505 | // // PPPL_ShowLog(); |
506 | // } else { /* reconnect on disconnect */ | 506 | // } else { /* reconnect on disconnect */ |
507 | if (false){ | 507 | if (false){ |
508 | qDebug( "Trying to reconnect... " ); | 508 | qDebug( "Trying to reconnect... " ); |
509 | 509 | ||
510 | if(gpppdata.authMethod() == AUTH_PAP || | 510 | if(PPPData::data()->authMethod() == AUTH_PAP || |
511 | gpppdata.authMethod() == AUTH_CHAP || | 511 | PPPData::data()->authMethod() == AUTH_CHAP || |
512 | gpppdata.authMethod() == AUTH_PAPCHAP) | 512 | PPPData::data()->authMethod() == AUTH_PAPCHAP) |
513 | Modem::modem->setSecret(gpppdata.authMethod(), | 513 | Modem::modem->setSecret(PPPData::data()->authMethod(), |
514 | encodeWord(gpppdata.storedUsername()), | 514 | encodeWord(PPPData::data()->storedUsername()), |
515 | encodeWord(gpppdata.password())); | 515 | encodeWord(PPPData::data()->password())); |
516 | 516 | ||
517 | // con_win->hide(); | 517 | // con_win->hide(); |
518 | // con_win->stopClock(); | 518 | // con_win->stopClock(); |
519 | //stopAccounting(); | 519 | //stopAccounting(); |
520 | gpppdata.setpppdRunning(false); | 520 | PPPData::data()->setpppdRunning(false); |
521 | // not in a signal handler !!!KNotifyClient::beep(); | 521 | // not in a signal handler !!!KNotifyClient::beep(); |
522 | emit cmdl_start(); | 522 | emit cmdl_start(); |
523 | } | 523 | } |
524 | } | 524 | } |
525 | gpppdata.setpppdError(0); | 525 | PPPData::data()->setpppdError(0); |
526 | } | 526 | } |
527 | } | 527 | } |
528 | 528 | ||
529 | // void KPPPWidget::sigChld() { | 529 | // void KPPPWidget::sigChld() { |
530 | // qDebug( "sigchld()" ); | 530 | // qDebug( "sigchld()" ); |
531 | // // pid_t id = wait(0L); | 531 | // // pid_t id = wait(0L); |
532 | // // if(id == helperPid && helperPid != -1) { | 532 | // // if(id == helperPid && helperPid != -1) { |
533 | // // kdDebug(5002) << "It was the setuid child that died" << endl; | 533 | // // kdDebug(5002) << "It was the setuid child that died" << endl; |
534 | // // helperPid = -1; | 534 | // // helperPid = -1; |
535 | // QString msg = i18n("kppp's helper process just died.\n" | 535 | // QString msg = i18n("kppp's helper process just died.\n" |
536 | // "Since a further execution would be pointless, " | 536 | // "Since a further execution would be pointless, " |
537 | // "kppp will shut down now."); | 537 | // "kppp will shut down now."); |
538 | // QMessageBox::warning(0L,"error", msg); | 538 | // QMessageBox::warning(0L,"error", msg); |
539 | // //remove_pidfile(); | 539 | // //remove_pidfile(); |
540 | // exit(1); | 540 | // exit(1); |
541 | // // } | 541 | // // } |
542 | // } | 542 | // } |
543 | 543 | ||
544 | 544 | ||
545 | void KPPPWidget::newdefaultaccount(int i) { | 545 | void KPPPWidget::newdefaultaccount(int i) { |
546 | gpppdata.setDefaultAccount(connectto_c->text(i)); | 546 | PPPData::data()->setDefaultAccount(connectto_c->text(i)); |
547 | gpppdata.save(); | 547 | PPPData::data()->save(); |
548 | ID_Edit->setText(gpppdata.storedUsername()); | 548 | ID_Edit->setText(PPPData::data()->storedUsername()); |
549 | PW_Edit->setText(gpppdata.storedPassword()); | 549 | PW_Edit->setText(PPPData::data()->storedPassword()); |
550 | } | 550 | } |
551 | 551 | ||
552 | 552 | ||
553 | 553 | ||
554 | 554 | ||
555 | void KPPPWidget::beginConnect() { | 555 | void KPPPWidget::beginConnect() { |
556 | // make sure to connect to the account that is selected in the combo box | 556 | // make sure to connect to the account that is selected in the combo box |
557 | // (exeption: an account given by a command line argument) | 557 | // (exeption: an account given by a command line argument) |
558 | // if(!m_bCmdlAccount) { | 558 | // if(!m_bCmdlAccount) { |
559 | // gpppdata.setAccount(connectto_c->currentText()); | 559 | // PPPData::data()->setAccount(connectto_c->currentText()); |
560 | // gpppdata.setPassword(PW_Edit->text()); | 560 | // PPPData::data()->setPassword(PW_Edit->text()); |
561 | // } else { | 561 | // } else { |
562 | gpppdata.setPassword(gpppdata.storedPassword()); | 562 | PPPData::data()->setPassword(PPPData::data()->storedPassword()); |
563 | // } | 563 | // } |
564 | 564 | ||
565 | QFileInfo info(pppdPath()); | 565 | QFileInfo info(pppdPath()); |
566 | 566 | ||
567 | if(!info.exists()){ | 567 | if(!info.exists()){ |
568 | QMessageBox::warning(this, "error", i18n("Cannot find the PPP daemon!\n" | 568 | QMessageBox::warning(this, "error", i18n("Cannot find the PPP daemon!\n" |
569 | "Make sure that pppd is installed and " | 569 | "Make sure that pppd is installed and " |
570 | "that you have entered the correct path.")); | 570 | "that you have entered the correct path.")); |
571 | return; | 571 | return; |
572 | } | 572 | } |
573 | #if 0 | 573 | #if 0 |
574 | if(!info.isExecutable()){ | 574 | if(!info.isExecutable()){ |
575 | 575 | ||
576 | QString string; | 576 | QString string; |
577 | string = i18n("kppp cannot execute:\n %1\n" | 577 | string = i18n("kppp cannot execute:\n %1\n" |
578 | "Please make sure that you have given kppp " | 578 | "Please make sure that you have given kppp " |
579 | "setuid permission and that " | 579 | "setuid permission and that " |
580 | "pppd is executable.").arg(gpppdata.pppdPath()); | 580 | "pppd is executable.").arg(PPPData::data()->pppdPath()); |
581 | KMessageBox::error(this, string); | 581 | KMessageBox::error(this, string); |
582 | return; | 582 | return; |
583 | 583 | ||
584 | } | 584 | } |
585 | #endif | 585 | #endif |
586 | 586 | ||
587 | QFileInfo info2(gpppdata.modemDevice()); | 587 | QFileInfo info2(PPPData::data()->modemDevice()); |
588 | 588 | ||
589 | if(!info2.exists()){ | 589 | if(!info2.exists()){ |
590 | QString string; | 590 | QString string; |
591 | string = i18n("kppp can not find:\n %1\nPlease make sure you have setup " | 591 | string = i18n("kppp can not find:\n %1\nPlease make sure you have setup " |
592 | "your modem device properly " | 592 | "your modem device properly " |
593 | "and/or adjust the location of the modem device on " | 593 | "and/or adjust the location of the modem device on " |
594 | "the modem tab of " | 594 | "the modem tab of " |
595 | "the setup dialog.").arg(gpppdata.modemDevice()); | 595 | "the setup dialog.").arg(PPPData::data()->modemDevice()); |
596 | QMessageBox::warning(this, "error", string); | 596 | QMessageBox::warning(this, "error", string); |
597 | return; | 597 | return; |
598 | } | 598 | } |
599 | 599 | ||
600 | // if this is a PAP or CHAP account, ensure that username is | 600 | // if this is a PAP or CHAP account, ensure that username is |
601 | // supplied | 601 | // supplied |
602 | if(gpppdata.authMethod() == AUTH_PAP || | 602 | if(PPPData::data()->authMethod() == AUTH_PAP || |
603 | gpppdata.authMethod() == AUTH_CHAP || | 603 | PPPData::data()->authMethod() == AUTH_CHAP || |
604 | gpppdata.authMethod() == AUTH_PAPCHAP ) { | 604 | PPPData::data()->authMethod() == AUTH_PAPCHAP ) { |
605 | if(ID_Edit->text().isEmpty()) { | 605 | if(ID_Edit->text().isEmpty()) { |
606 | QMessageBox::warning(this,"error", | 606 | QMessageBox::warning(this,"error", |
607 | i18n( | 607 | i18n( |
608 | "You have selected the authentication " | 608 | "You have selected the authentication " |
609 | "method PAP or CHAP. This requires that you " | 609 | "method PAP or CHAP. This requires that you " |
610 | "supply a username and a password!")); | 610 | "supply a username and a password!")); |
611 | return; | 611 | return; |
612 | } else { | 612 | } else { |
613 | if(!Modem::modem->setSecret(gpppdata.authMethod(), | 613 | if(!Modem::modem->setSecret(PPPData::data()->authMethod(), |
614 | encodeWord(gpppdata.storedUsername()), | 614 | encodeWord(PPPData::data()->storedUsername()), |
615 | encodeWord(gpppdata.password()))) { | 615 | encodeWord(PPPData::data()->password()))) { |
616 | QString s; | 616 | QString s; |
617 | s = i18n("Cannot create PAP/CHAP authentication\n" | 617 | s = i18n("Cannot create PAP/CHAP authentication\n" |
618 | "file \"%1\"").arg(PAP_AUTH_FILE); | 618 | "file \"%1\"").arg(PAP_AUTH_FILE); |
619 | QMessageBox::warning(this, "error", s); | 619 | QMessageBox::warning(this, "error", s); |
620 | return; | 620 | return; |
621 | } | 621 | } |
622 | } | 622 | } |
623 | } | 623 | } |
624 | 624 | ||
625 | if (gpppdata.phonenumber().isEmpty()) { | 625 | if (PPPData::data()->phonenumber().isEmpty()) { |
626 | QString s = i18n("You must specify a telephone number!"); | 626 | QString s = i18n("You must specify a telephone number!"); |
627 | QMessageBox::warning(this, "error", s); | 627 | QMessageBox::warning(this, "error", s); |
628 | return; | 628 | return; |
629 | } | 629 | } |
630 | 630 | ||
631 | this->hide(); | 631 | this->hide(); |
632 | 632 | ||
633 | QString tit = i18n("Connecting to: %1").arg(gpppdata.accname()); | 633 | QString tit = i18n("Connecting to: %1").arg(PPPData::data()->accname()); |
634 | // con->setCaption(tit); | 634 | // con->setCaption(tit); |
635 | 635 | ||
636 | // con->show(); | 636 | // con->show(); |
637 | 637 | ||
638 | bool show_debug = gpppdata.get_show_log_window(); | 638 | bool show_debug = PPPData::data()->get_show_log_window(); |
639 | // con->debug->setOn(show_debug);// toggle button | 639 | // con->debug->setOn(show_debug);// toggle button |
640 | debugwindow->clear(); | 640 | debugwindow->clear(); |
641 | if (!show_debug) | 641 | if (!show_debug) |
642 | debugwindow->hide(); | 642 | debugwindow->hide(); |
643 | else { | 643 | else { |
644 | debugwindow->show(); | 644 | debugwindow->show(); |
645 | // con->raise(); | 645 | // con->raise(); |
646 | } | 646 | } |
647 | 647 | ||
648 | emit begin_connect(); | 648 | emit begin_connect(); |
649 | } | 649 | } |
650 | 650 | ||
651 | 651 | ||
652 | void KPPPWidget::disconnect() { | 652 | void KPPPWidget::disconnect() { |
653 | if (!gpppdata.command_before_disconnect().isEmpty()) { | 653 | if (!PPPData::data()->command_before_disconnect().isEmpty()) { |
654 | // con_win->hide(); | 654 | // con_win->hide(); |
655 | // con->show(); | 655 | // con->show(); |
656 | // con->setCaption(i18n("Disconnecting...")); | 656 | // con->setCaption(i18n("Disconnecting...")); |
657 | // con->setMsg(i18n("Executing command before disconnection.")); | 657 | // con->setMsg(i18n("Executing command before disconnection.")); |
658 | 658 | ||
659 | qApp->processEvents(); | 659 | qApp->processEvents(); |
660 | QApplication::flushX(); | 660 | QApplication::flushX(); |
661 | // pid_t id = | 661 | // pid_t id = |
662 | execute_command(gpppdata.command_before_disconnect()); | 662 | execute_command(PPPData::data()->command_before_disconnect()); |
663 | // int i, status; | 663 | // int i, status; |
664 | 664 | ||
665 | // do { | 665 | // do { |
666 | // kapp->processEvents(); | 666 | // kapp->processEvents(); |
667 | // i = waitpid(id, &status, WNOHANG); | 667 | // i = waitpid(id, &status, WNOHANG); |
668 | // usleep(500000); | 668 | // usleep(500000); |
669 | // } while (i == 0 && errno == 0); | 669 | // } while (i == 0 && errno == 0); |
670 | 670 | ||
671 | // con->hide(); | 671 | // con->hide(); |
672 | } | 672 | } |
673 | 673 | ||
674 | qApp->processEvents(); | 674 | qApp->processEvents(); |
675 | 675 | ||
676 | // statdlg->stop_stats(); | 676 | // statdlg->stop_stats(); |
677 | Modem::modem->killPPPDaemon(); | 677 | Modem::modem->killPPPDaemon(); |
678 | 678 | ||
679 | QApplication::flushX(); | 679 | QApplication::flushX(); |
680 | execute_command(gpppdata.command_on_disconnect()); | 680 | execute_command(PPPData::data()->command_on_disconnect()); |
681 | 681 | ||
682 | Modem::modem->removeSecret(AUTH_PAP); | 682 | Modem::modem->removeSecret(AUTH_PAP); |
683 | Modem::modem->removeSecret(AUTH_CHAP); | 683 | Modem::modem->removeSecret(AUTH_CHAP); |
684 | 684 | ||
685 | removedns(); | 685 | removedns(); |
686 | Modem::modem->unlockdevice(); | 686 | Modem::modem->unlockdevice(); |
687 | 687 | ||
688 | // con_win->stopClock(); | 688 | // con_win->stopClock(); |
689 | // p_kppp->stopAccounting(); | 689 | // p_kppp->stopAccounting(); |
690 | // con_win->hide(); | 690 | // con_win->hide(); |
691 | 691 | ||
692 | // DockWidget::dock_widget->stop_stats(); | 692 | // DockWidget::dock_widget->stop_stats(); |
693 | // DockWidget::dock_widget->hide(); | 693 | // DockWidget::dock_widget->hide(); |
694 | 694 | ||
695 | // if(m_bQuitOnDisconnect) | 695 | // if(m_bQuitOnDisconnect) |
696 | // kapp->exit(0); | 696 | // kapp->exit(0); |
697 | // else { | 697 | // else { |
698 | this->quit_b->setFocus(); | 698 | this->quit_b->setFocus(); |
699 | this->show(); | 699 | this->show(); |
700 | // } | 700 | // } |
701 | } | 701 | } |
702 | 702 | ||
703 | 703 | ||
704 | // void KPPPWidget::helpbutton() { | 704 | // void KPPPWidget::helpbutton() { |
705 | // kapp->invokeHelp(); | 705 | // kapp->invokeHelp(); |
706 | // } | 706 | // } |
707 | 707 | ||
708 | 708 | ||
709 | void KPPPWidget::quitbutton() { | 709 | void KPPPWidget::quitbutton() { |
710 | if(gpppdata.pppdRunning()) { | 710 | if(PPPData::data()->pppdRunning()) { |
711 | int ok = QMessageBox::warning(this, | 711 | int ok = QMessageBox::warning(this, |
712 | i18n("Exiting kPPP will close your PPP Session."), | 712 | i18n("Exiting kPPP will close your PPP Session."), |
713 | i18n("Quit kPPP?")); | 713 | i18n("Quit kPPP?")); |
714 | if(ok == QMessageBox::Yes) { | 714 | if(ok == QMessageBox::Yes) { |
715 | Modem::modem->killPPPDaemon(); | 715 | Modem::modem->killPPPDaemon(); |
716 | QApplication::flushX(); | 716 | QApplication::flushX(); |
717 | execute_command(gpppdata.command_on_disconnect()); | 717 | execute_command(PPPData::data()->command_on_disconnect()); |
718 | removedns(); | 718 | removedns(); |
719 | Modem::modem->unlockdevice(); | 719 | Modem::modem->unlockdevice(); |
720 | } | 720 | } |
721 | } else { | 721 | } else { |
722 | if (!gpppdata.accname().isEmpty() && !gpppdata.storePassword()) | 722 | if (!PPPData::data()->accname().isEmpty() && !PPPData::data()->storePassword()) |
723 | gpppdata.setStoredPassword(""); | 723 | PPPData::data()->setStoredPassword(""); |
724 | } | 724 | } |
725 | gpppdata.save(); | 725 | PPPData::data()->save(); |
726 | qApp->quit(); | 726 | qApp->quit(); |
727 | } | 727 | } |
728 | 728 | ||
729 | 729 | ||
730 | // void KPPPWidget::rulesetLoadError() { | 730 | // void KPPPWidget::rulesetLoadError() { |
731 | // QMessageBox::warning(this,"error", ruleset_load_errmsg); | 731 | // QMessageBox::warning(this,"error", ruleset_load_errmsg); |
732 | // } | 732 | // } |
733 | 733 | ||
734 | 734 | ||
735 | // void KPPPWidget::startAccounting() { | 735 | // void KPPPWidget::startAccounting() { |
736 | // // volume accounting | 736 | // // volume accounting |
737 | // stats->totalbytes = 0; | 737 | // stats->totalbytes = 0; |
738 | 738 | ||
739 | // kdDebug() << "AcctEnabled: " << gpppdata.AcctEnabled() << endl; | 739 | // kdDebug() << "AcctEnabled: " << PPPData::data()->AcctEnabled() << endl; |
740 | 740 | ||
741 | // // load the ruleset | 741 | // // load the ruleset |
742 | // if(!gpppdata.AcctEnabled()) | 742 | // if(!PPPData::data()->AcctEnabled()) |
743 | // return; | 743 | // return; |
744 | 744 | ||
745 | // QString d = AccountingBase::getAccountingFile(gpppdata.accountingFile()); | 745 | // QString d = AccountingBase::getAccountingFile(PPPData::data()->accountingFile()); |
746 | // // if(::access(d.data(), X_OK) != 0) | 746 | // // if(::access(d.data(), X_OK) != 0) |
747 | // acct = new Accounting(this, stats); | 747 | // acct = new Accounting(this, stats); |
748 | // // else | 748 | // // else |
749 | // // acct = new ExecutableAccounting(this); | 749 | // // acct = new ExecutableAccounting(this); |
750 | 750 | ||
751 | // // connect to the accounting object | 751 | // // connect to the accounting object |
752 | // connect(acct, SIGNAL(changed(QString, QString)), | 752 | // connect(acct, SIGNAL(changed(QString, QString)), |
753 | // con_win, SLOT(slotAccounting(QString, QString))); | 753 | // con_win, SLOT(slotAccounting(QString, QString))); |
754 | 754 | ||
755 | // // if(!acct->loadRuleSet(gpppdata.accountingFile())) { | 755 | // // if(!acct->loadRuleSet(PPPData::data()->accountingFile())) { |
756 | // // QString s= i18n("Can not load the accounting " | 756 | // // QString s= i18n("Can not load the accounting " |
757 | // // "ruleset \"%1\"!").arg(gpppdata.accountingFile()); | 757 | // // "ruleset \"%1\"!").arg(PPPData::data()->accountingFile()); |
758 | 758 | ||
759 | // // starting the messagebox with a timer will prevent us | 759 | // // starting the messagebox with a timer will prevent us |
760 | // // from blocking the calling function ConnectWidget::timerEvent | 760 | // // from blocking the calling function ConnectWidget::timerEvent |
761 | // ruleset_load_errmsg = s; | 761 | // ruleset_load_errmsg = s; |
762 | // QTimer::singleShot(0, this, SLOT(rulesetLoadError())); | 762 | // QTimer::singleShot(0, this, SLOT(rulesetLoadError())); |
763 | // return; | 763 | // return; |
764 | // } | 764 | // } |
765 | // //else | 765 | // //else |
766 | // // acct->slotStart(); | 766 | // // acct->slotStart(); |
767 | // } | 767 | // } |
768 | 768 | ||
769 | // void KPPPWidget::stopAccounting() { | 769 | // void KPPPWidget::stopAccounting() { |
770 | // // store volume accounting | 770 | // // store volume accounting |
771 | // // if(stats->totalbytes != 0) | 771 | // // if(stats->totalbytes != 0) |
772 | // // gpppdata.setTotalBytes(stats->totalbytes); | 772 | // // PPPData::data()->setTotalBytes(stats->totalbytes); |
773 | 773 | ||
774 | // if(!gpppdata.AcctEnabled()) | 774 | // if(!PPPData::data()->AcctEnabled()) |
775 | // return; | 775 | // return; |
776 | 776 | ||
777 | // // if(acct != 0) { | 777 | // // if(acct != 0) { |
778 | // // acct->slotStop(); | 778 | // // acct->slotStop(); |
779 | // // delete acct; | 779 | // // delete acct; |
780 | // // acct = 0; | 780 | // // acct = 0; |
781 | // // } | 781 | // // } |
782 | // } | 782 | // } |
783 | 783 | ||
784 | 784 | ||
785 | // void KPPPWidget::showStats() { | 785 | // void KPPPWidget::showStats() { |
786 | // if(statdlg) { | 786 | // if(statdlg) { |
787 | // statdlg->show(); | 787 | // statdlg->show(); |
788 | // statdlg->raise(); | 788 | // statdlg->raise(); |
789 | // } | 789 | // } |
790 | // } | 790 | // } |
791 | 791 | ||
792 | 792 | ||
793 | void KPPPWidget::usernameChanged(const QString &) { | 793 | void KPPPWidget::usernameChanged(const QString &) { |
794 | // store username for later use | 794 | // store username for later use |
795 | gpppdata.setStoredUsername(ID_Edit->text()); | 795 | PPPData::data()->setStoredUsername(ID_Edit->text()); |
796 | } | 796 | } |
797 | 797 | ||
798 | 798 | ||
799 | void KPPPWidget::passwordChanged(const QString &) { | 799 | void KPPPWidget::passwordChanged(const QString &) { |
800 | // store the password if so requested | 800 | // store the password if so requested |
801 | if(gpppdata.storePassword()) | 801 | if(PPPData::data()->storePassword()) |
802 | gpppdata.setStoredPassword(PW_Edit->text()); | 802 | PPPData::data()->setStoredPassword(PW_Edit->text()); |
803 | else | 803 | else |
804 | gpppdata.setStoredPassword(""); | 804 | PPPData::data()->setStoredPassword(""); |
805 | } | 805 | } |
806 | 806 | ||
807 | 807 | ||
808 | void KPPPWidget::setPW_Edit(const QString &pw) { | 808 | void KPPPWidget::setPW_Edit(const QString &pw) { |
809 | PW_Edit->setText(pw); | 809 | PW_Edit->setText(pw); |
810 | } | 810 | } |
811 | 811 | ||
812 | 812 | ||
813 | // void KPPPWidget::resetCosts(const QString &s) { | 813 | // void KPPPWidget::resetCosts(const QString &s) { |
814 | // AccountingBase::resetCosts(s); | 814 | // AccountingBase::resetCosts(s); |
815 | // } | 815 | // } |
816 | 816 | ||
817 | 817 | ||
818 | // void KPPPWidget::resetVolume(const QString &s) { | 818 | // void KPPPWidget::resetVolume(const QString &s) { |
819 | // AccountingBase::resetVolume(s); | 819 | // AccountingBase::resetVolume(s); |
820 | // } | 820 | // } |
821 | 821 | ||
822 | /** | 822 | /** |
823 | * pppd's getword() function knows about escape characters. | 823 | * pppd's getword() function knows about escape characters. |
824 | * If we write the username and password to the secrets file | 824 | * If we write the username and password to the secrets file |
825 | * we'll therefore have to escape back slashes. | 825 | * we'll therefore have to escape back slashes. |
826 | */ | 826 | */ |
827 | QString KPPPWidget::encodeWord(const QString &s) { | 827 | QString KPPPWidget::encodeWord(const QString &s) { |
828 | QString r = s; | 828 | QString r = s; |
829 | r.replace(QRegExp("\\"), "\\\\"); | 829 | r.replace(QRegExp("\\"), "\\\\"); |
830 | return r; | 830 | return r; |
831 | } | 831 | } |
832 | 832 | ||
833 | // void KPPPWidget::setQuitOnDisconnect (bool b) | 833 | // void KPPPWidget::setQuitOnDisconnect (bool b) |
834 | // { | 834 | // { |
835 | // m_bQuitOnDisconnect = b; | 835 | // m_bQuitOnDisconnect = b; |
836 | // } | 836 | // } |
837 | 837 | ||
838 | void KPPPWidget::showNews() { | 838 | void KPPPWidget::showNews() { |
839 | #ifdef KPPP_SHOW_NEWS | 839 | #ifdef KPPP_SHOW_NEWS |
840 | /* | 840 | /* |
841 | * Introduce the QuickHelp feature to new users of this version | 841 | * Introduce the QuickHelp feature to new users of this version |
842 | */ | 842 | */ |
843 | #define QUICKHELP_HINT "Hint_QuickHelp" | 843 | #define QUICKHELP_HINT "Hint_QuickHelp" |
844 | if(gpppdata.readNumConfig(GENERAL_GRP, QUICKHELP_HINT, 0) == 0) { | 844 | if(PPPData::data()->readNumConfig(GENERAL_GRP, QUICKHELP_HINT, 0) == 0) { |
845 | QDialog dlg(0, 0, true); | 845 | QDialog dlg(0, 0, true); |
846 | dlg.setCaption(i18n("Recent Changes in KPPP")); | 846 | dlg.setCaption(i18n("Recent Changes in KPPP")); |
847 | 847 | ||
848 | QVBoxLayout *tl = new QVBoxLayout(&dlg, 10, 10); | 848 | QVBoxLayout *tl = new QVBoxLayout(&dlg, 10, 10); |
849 | QHBoxLayout *l1 = new QHBoxLayout(10); | 849 | QHBoxLayout *l1 = new QHBoxLayout(10); |
850 | QVBoxLayout *l2 = new QVBoxLayout(10); | 850 | QVBoxLayout *l2 = new QVBoxLayout(10); |
851 | tl->addLayout(l1); | 851 | tl->addLayout(l1); |
852 | 852 | ||
853 | QLabel *icon = new QLabel(&dlg); | 853 | QLabel *icon = new QLabel(&dlg); |
854 | icon->setPixmap(BarIcon("exclamation")); | 854 | icon->setPixmap(BarIcon("exclamation")); |
855 | icon->setFixedSize(icon->sizeHint()); | 855 | icon->setFixedSize(icon->sizeHint()); |
856 | l1->addWidget(icon); | 856 | l1->addWidget(icon); |
857 | l1->addLayout(l2); | 857 | l1->addLayout(l2); |
858 | 858 | ||
859 | QLabel *l = new QLabel(i18n("From version 1.4.8 on, kppp has a new feature\n" | 859 | QLabel *l = new QLabel(i18n("From version 1.4.8 on, kppp has a new feature\n" |
860 | "called \"Quickhelp\". It's similar to a tooltip,\n" | 860 | "called \"Quickhelp\". It's similar to a tooltip,\n" |
861 | "but you can activate it whenever you want.\n" | 861 | "but you can activate it whenever you want.\n" |
862 | "\n" | 862 | "\n" |
863 | "To activate it, simply click on a control like\n" | 863 | "To activate it, simply click on a control like\n" |
864 | "a button or a label with the right mouse button.\n" | 864 | "a button or a label with the right mouse button.\n" |
865 | "If the item supports Quickhelp, a popup menu\n" | 865 | "If the item supports Quickhelp, a popup menu\n" |
866 | "will appear leading to Quickhelp.\n" | 866 | "will appear leading to Quickhelp.\n" |
867 | "\n" | 867 | "\n" |
868 | "To test it, right-click somewhere in this text."), | 868 | "To test it, right-click somewhere in this text."), |
869 | &dlg); | 869 | &dlg); |
870 | 870 | ||
871 | QCheckBox *cb = new QCheckBox(i18n("Don't show this hint again"), &dlg); | 871 | QCheckBox *cb = new QCheckBox(i18n("Don't show this hint again"), &dlg); |
872 | cb->setFixedSize(cb->sizeHint()); | 872 | cb->setFixedSize(cb->sizeHint()); |
873 | 873 | ||
874 | KButtonBox *bbox = new KButtonBox(&dlg); | 874 | KButtonBox *bbox = new KButtonBox(&dlg); |
875 | bbox->addStretch(1); | 875 | bbox->addStretch(1); |
876 | QPushButton *ok = bbox->addButton(i18n("OK")); | 876 | QPushButton *ok = bbox->addButton(i18n("OK")); |
877 | ok->setDefault(true); | 877 | ok->setDefault(true); |
878 | dlg.connect(ok, SIGNAL(clicked()), | 878 | dlg.connect(ok, SIGNAL(clicked()), |
879 | &dlg, SLOT(accept())); | 879 | &dlg, SLOT(accept())); |
880 | bbox->addStretch(1); | 880 | bbox->addStretch(1); |
881 | bbox->layout(); | 881 | bbox->layout(); |
882 | 882 | ||
883 | l2->addWidget(l); | 883 | l2->addWidget(l); |
884 | l2->addWidget(cb); | 884 | l2->addWidget(cb); |
885 | tl->addWidget(bbox); | 885 | tl->addWidget(bbox); |
886 | 886 | ||
887 | QString tmp = i18n("This is an example of <b>QuickHelp</b>.\n" | 887 | QString tmp = i18n("This is an example of <b>QuickHelp</b>.\n" |
888 | "This window will stay open until you\n" | 888 | "This window will stay open until you\n" |
889 | "click a mouse button or a press a key.\n"); | 889 | "click a mouse button or a press a key.\n"); |
890 | 890 | ||
891 | QWhatsThis::add(cb,tmp); | 891 | QWhatsThis::add(cb,tmp); |
892 | QWhatsThis::add(l, tmp); | 892 | QWhatsThis::add(l, tmp); |
893 | 893 | ||
894 | dlg.exec(); | 894 | dlg.exec(); |
895 | if(cb->isChecked()) { | 895 | if(cb->isChecked()) { |
896 | gpppdata.writeConfig(GENERAL_GRP, QUICKHELP_HINT, 1); | 896 | PPPData::data()->writeConfig(GENERAL_GRP, QUICKHELP_HINT, 1); |
897 | gpppdata.save(); | 897 | PPPData::data()->save(); |
898 | } | 898 | } |
899 | } | 899 | } |
900 | #endif | 900 | #endif |
901 | } | 901 | } |
902 | 902 | ||
903 | 903 | ||
904 | //#include "kpppwidget.moc" | 904 | //#include "kpppwidget.moc" |
905 | 905 | ||
diff --git a/noncore/settings/networksettings/ppp/modem.cpp b/noncore/settings/networksettings/ppp/modem.cpp index a2f77c5..cd5d21c 100644 --- a/noncore/settings/networksettings/ppp/modem.cpp +++ b/noncore/settings/networksettings/ppp/modem.cpp | |||
@@ -1,795 +1,795 @@ | |||
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 | * This file was added by Harri Porten <porten@tu-harburg.de> | 9 | * This file was added by Harri Porten <porten@tu-harburg.de> |
10 | * | 10 | * |
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 <errno.h> | 27 | #include <errno.h> |
28 | #include <stdlib.h> | 28 | #include <stdlib.h> |
29 | #include <fcntl.h> | 29 | #include <fcntl.h> |
30 | #include <signal.h> | 30 | #include <signal.h> |
31 | #include <sys/ioctl.h> | 31 | #include <sys/ioctl.h> |
32 | #include <setjmp.h> | 32 | #include <setjmp.h> |
33 | #include <regex.h> | 33 | #include <regex.h> |
34 | #include <qregexp.h> | 34 | #include <qregexp.h> |
35 | #include <assert.h> | 35 | #include <assert.h> |
36 | 36 | ||
37 | #include "auth.h" | 37 | #include "auth.h" |
38 | #include "modem.h" | 38 | #include "modem.h" |
39 | #include "pppdata.h" | 39 | #include "pppdata.h" |
40 | //#include <klocale.h> | 40 | //#include <klocale.h> |
41 | #define i18n QObject::tr | 41 | #define i18n QObject::tr |
42 | #define qError qDebug | 42 | #define qError qDebug |
43 | //#include <kdebug.h> | 43 | //#include <kdebug.h> |
44 | //#include <config.h> | 44 | //#include <config.h> |
45 | 45 | ||
46 | #define MY_ASSERT(x) if (!(x)) { \ | 46 | #define MY_ASSERT(x) if (!(x)) { \ |
47 | qFatal( "ASSERT: \"%s\" in %s (%d)\n",#x,__FILE__,__LINE__); \ | 47 | qFatal( "ASSERT: \"%s\" in %s (%d)\n",#x,__FILE__,__LINE__); \ |
48 | exit(1); } | 48 | exit(1); } |
49 | 49 | ||
50 | 50 | ||
51 | static sigjmp_buf jmp_buffer; | 51 | static sigjmp_buf jmp_buffer; |
52 | 52 | ||
53 | Modem *Modem::modem = 0; | 53 | Modem *Modem::modem = 0; |
54 | 54 | ||
55 | 55 | ||
56 | const char* pppdPath() { | 56 | const char* pppdPath() { |
57 | // wasting a few bytes | 57 | // wasting a few bytes |
58 | static char buffer[sizeof(PPPDSEARCHPATH)+sizeof(PPPDNAME)]; | 58 | static char buffer[sizeof(PPPDSEARCHPATH)+sizeof(PPPDNAME)]; |
59 | static char *pppdPath = 0L; | 59 | static char *pppdPath = 0L; |
60 | char *p; | 60 | char *p; |
61 | 61 | ||
62 | if(pppdPath == 0L) { | 62 | if(pppdPath == 0L) { |
63 | const char *c = PPPDSEARCHPATH; | 63 | const char *c = PPPDSEARCHPATH; |
64 | while(*c != '\0') { | 64 | while(*c != '\0') { |
65 | while(*c == ':') | 65 | while(*c == ':') |
66 | c++; | 66 | c++; |
67 | p = buffer; | 67 | p = buffer; |
68 | while(*c != '\0' && *c != ':') | 68 | while(*c != '\0' && *c != ':') |
69 | *p++ = *c++; | 69 | *p++ = *c++; |
70 | *p = '\0'; | 70 | *p = '\0'; |
71 | strcat(p, "/"); | 71 | strcat(p, "/"); |
72 | strcat(p, PPPDNAME); | 72 | strcat(p, PPPDNAME); |
73 | if(access(buffer, F_OK) == 0) | 73 | if(access(buffer, F_OK) == 0) |
74 | return (pppdPath = buffer); | 74 | return (pppdPath = buffer); |
75 | } | 75 | } |
76 | } | 76 | } |
77 | 77 | ||
78 | return pppdPath; | 78 | return pppdPath; |
79 | } | 79 | } |
80 | 80 | ||
81 | 81 | ||
82 | Modem::Modem() | 82 | Modem::Modem() |
83 | { | 83 | { |
84 | if (Modem::modem != 0) return; //CORRECT? | 84 | if (Modem::modem != 0) return; //CORRECT? |
85 | modemfd = -1; | 85 | modemfd = -1; |
86 | sn = 0L; | 86 | sn = 0L; |
87 | data_mode = false; | 87 | data_mode = false; |
88 | modem_is_locked = false; | 88 | modem_is_locked = false; |
89 | lockfile[0] = '\0'; | 89 | lockfile[0] = '\0'; |
90 | device = "/dev/modem"; | 90 | device = "/dev/modem"; |
91 | modem = this; | 91 | modem = this; |
92 | } | 92 | } |
93 | 93 | ||
94 | 94 | ||
95 | Modem::~Modem() { | 95 | Modem::~Modem() { |
96 | modem = 0; | 96 | modem = 0; |
97 | } | 97 | } |
98 | 98 | ||
99 | 99 | ||
100 | speed_t Modem::modemspeed() { | 100 | speed_t Modem::modemspeed() { |
101 | // convert the string modem speed int the gpppdata object to a t_speed type | 101 | // convert the string modem speed int the gpppdata object to a t_speed type |
102 | // to set the modem. The constants here should all be ifdef'd because | 102 | // to set the modem. The constants here should all be ifdef'd because |
103 | // other systems may not have them | 103 | // other systems may not have them |
104 | int i = gpppdata.speed().toInt()/100; | 104 | int i = PPPData::data()->speed().toInt()/100; |
105 | 105 | ||
106 | switch(i) { | 106 | switch(i) { |
107 | case 24: | 107 | case 24: |
108 | return B2400; | 108 | return B2400; |
109 | break; | 109 | break; |
110 | case 96: | 110 | case 96: |
111 | return B9600; | 111 | return B9600; |
112 | break; | 112 | break; |
113 | case 192: | 113 | case 192: |
114 | return B19200; | 114 | return B19200; |
115 | break; | 115 | break; |
116 | case 384: | 116 | case 384: |
117 | return B38400; | 117 | return B38400; |
118 | break; | 118 | break; |
119 | #ifdef B57600 | 119 | #ifdef B57600 |
120 | case 576: | 120 | case 576: |
121 | return B57600; | 121 | return B57600; |
122 | break; | 122 | break; |
123 | #endif | 123 | #endif |
124 | 124 | ||
125 | #ifdef B115200 | 125 | #ifdef B115200 |
126 | case 1152: | 126 | case 1152: |
127 | return B115200; | 127 | return B115200; |
128 | break; | 128 | break; |
129 | #endif | 129 | #endif |
130 | 130 | ||
131 | #ifdef B230400 | 131 | #ifdef B230400 |
132 | case 2304: | 132 | case 2304: |
133 | return B230400; | 133 | return B230400; |
134 | break; | 134 | break; |
135 | #endif | 135 | #endif |
136 | 136 | ||
137 | #ifdef B460800 | 137 | #ifdef B460800 |
138 | case 4608: | 138 | case 4608: |
139 | return B460800; | 139 | return B460800; |
140 | break; | 140 | break; |
141 | #endif | 141 | #endif |
142 | 142 | ||
143 | default: | 143 | default: |
144 | return B38400; | 144 | return B38400; |
145 | break; | 145 | break; |
146 | } | 146 | } |
147 | } | 147 | } |
148 | 148 | ||
149 | bool Modem::opentty() { | 149 | bool Modem::opentty() { |
150 | // int flags; | 150 | // int flags; |
151 | 151 | ||
152 | //begin if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { | 152 | //begin if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { |
153 | close(modemfd); | 153 | close(modemfd); |
154 | // device = "/dev/modem";//deviceByIndex(request.modem.deviceNum); | 154 | device = PPPData::data()->modemDevice(); |
155 | if ((modemfd = open(device, O_RDWR|O_NDELAY|O_NOCTTY)) == -1) { | 155 | if ((modemfd = open(device, O_RDWR|O_NDELAY|O_NOCTTY)) == -1) { |
156 | qDebug("error opening modem device !"); | 156 | qDebug("error opening modem device !"); |
157 | errmsg = i18n("Unable to open modem."); | 157 | errmsg = i18n("Unable to open modem."); |
158 | return false; | 158 | return false; |
159 | } | 159 | } |
160 | //bend if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { | 160 | //bend if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { |
161 | //} | 161 | //} |
162 | 162 | ||
163 | #if 0 | 163 | #if 0 |
164 | if(gpppdata.UseCDLine()) { | 164 | if(PPPData::data()->UseCDLine()) { |
165 | if(ioctl(modemfd, TIOCMGET, &flags) == -1) { | 165 | if(ioctl(modemfd, TIOCMGET, &flags) == -1) { |
166 | errmsg = i18n("Unable to detect state of CD line."); | 166 | errmsg = i18n("Unable to detect state of CD line."); |
167 | ::close(modemfd); | 167 | ::close(modemfd); |
168 | modemfd = -1; | 168 | modemfd = -1; |
169 | return false; | 169 | return false; |
170 | } | 170 | } |
171 | if ((flags&TIOCM_CD) == 0) { | 171 | if ((flags&TIOCM_CD) == 0) { |
172 | errmsg = i18n("The modem is not ready."); | 172 | errmsg = i18n("The modem is not ready."); |
173 | ::close(modemfd); | 173 | ::close(modemfd); |
174 | modemfd = -1; | 174 | modemfd = -1; |
175 | return false; | 175 | return false; |
176 | } | 176 | } |
177 | } | 177 | } |
178 | #endif | 178 | #endif |
179 | 179 | ||
180 | tcdrain (modemfd); | 180 | tcdrain (modemfd); |
181 | tcflush (modemfd, TCIOFLUSH); | 181 | tcflush (modemfd, TCIOFLUSH); |
182 | 182 | ||
183 | if(tcgetattr(modemfd, &tty) < 0){ | 183 | if(tcgetattr(modemfd, &tty) < 0){ |
184 | // this helps in some cases | 184 | // this helps in some cases |
185 | tcsendbreak(modemfd, 0); | 185 | tcsendbreak(modemfd, 0); |
186 | sleep(1); | 186 | sleep(1); |
187 | if(tcgetattr(modemfd, &tty) < 0){ | 187 | if(tcgetattr(modemfd, &tty) < 0){ |
188 | errmsg = i18n("The modem is busy."); | 188 | errmsg = i18n("The modem is busy."); |
189 | ::close(modemfd); | 189 | ::close(modemfd); |
190 | modemfd = -1; | 190 | modemfd = -1; |
191 | return false; | 191 | return false; |
192 | } | 192 | } |
193 | } | 193 | } |
194 | 194 | ||
195 | memset(&initial_tty,'\0',sizeof(initial_tty)); | 195 | memset(&initial_tty,'\0',sizeof(initial_tty)); |
196 | 196 | ||
197 | initial_tty = tty; | 197 | initial_tty = tty; |
198 | 198 | ||
199 | tty.c_cc[VMIN] = 0; // nonblocking | 199 | tty.c_cc[VMIN] = 0; // nonblocking |
200 | tty.c_cc[VTIME] = 0; | 200 | tty.c_cc[VTIME] = 0; |
201 | tty.c_oflag = 0; | 201 | tty.c_oflag = 0; |
202 | tty.c_lflag = 0; | 202 | tty.c_lflag = 0; |
203 | 203 | ||
204 | tty.c_cflag &= ~(CSIZE | CSTOPB | PARENB); | 204 | tty.c_cflag &= ~(CSIZE | CSTOPB | PARENB); |
205 | tty.c_cflag |= CS8 | CREAD; | 205 | tty.c_cflag |= CS8 | CREAD; |
206 | tty.c_cflag |= CLOCAL; // ignore modem status lines | 206 | tty.c_cflag |= CLOCAL; // ignore modem status lines |
207 | tty.c_iflag = IGNBRK | IGNPAR /* | ISTRIP */ ; | 207 | tty.c_iflag = IGNBRK | IGNPAR /* | ISTRIP */ ; |
208 | tty.c_lflag &= ~ICANON; // non-canonical mode | 208 | tty.c_lflag &= ~ICANON; // non-canonical mode |
209 | tty.c_lflag &= ~(ECHO|ECHOE|ECHOK|ECHOKE); | 209 | tty.c_lflag &= ~(ECHO|ECHOE|ECHOK|ECHOKE); |
210 | 210 | ||
211 | 211 | ||
212 | if(gpppdata.flowcontrol() != "None") { | 212 | if(PPPData::data()->flowcontrol() != "None") { |
213 | if(gpppdata.flowcontrol() == "CRTSCTS") { | 213 | if(PPPData::data()->flowcontrol() == "CRTSCTS") { |
214 | tty.c_cflag |= CRTSCTS; | 214 | tty.c_cflag |= CRTSCTS; |
215 | } | 215 | } |
216 | else { | 216 | else { |
217 | tty.c_iflag |= IXON | IXOFF; | 217 | tty.c_iflag |= IXON | IXOFF; |
218 | tty.c_cc[VSTOP] = 0x13; /* DC3 = XOFF = ^S */ | 218 | tty.c_cc[VSTOP] = 0x13; /* DC3 = XOFF = ^S */ |
219 | tty.c_cc[VSTART] = 0x11; /* DC1 = XON = ^Q */ | 219 | tty.c_cc[VSTART] = 0x11; /* DC1 = XON = ^Q */ |
220 | } | 220 | } |
221 | } | 221 | } |
222 | else { | 222 | else { |
223 | tty.c_cflag &= ~CRTSCTS; | 223 | tty.c_cflag &= ~CRTSCTS; |
224 | tty.c_iflag &= ~(IXON | IXOFF); | 224 | tty.c_iflag &= ~(IXON | IXOFF); |
225 | } | 225 | } |
226 | 226 | ||
227 | cfsetospeed(&tty, modemspeed()); | 227 | cfsetospeed(&tty, modemspeed()); |
228 | cfsetispeed(&tty, modemspeed()); | 228 | cfsetispeed(&tty, modemspeed()); |
229 | 229 | ||
230 | tcdrain(modemfd); | 230 | tcdrain(modemfd); |
231 | 231 | ||
232 | if(tcsetattr(modemfd, TCSANOW, &tty) < 0){ | 232 | if(tcsetattr(modemfd, TCSANOW, &tty) < 0){ |
233 | errmsg = i18n("The modem is busy."); | 233 | errmsg = i18n("The modem is busy."); |
234 | ::close(modemfd); | 234 | ::close(modemfd); |
235 | modemfd=-1; | 235 | modemfd=-1; |
236 | return false; | 236 | return false; |
237 | } | 237 | } |
238 | 238 | ||
239 | errmsg = i18n("Modem Ready."); | 239 | errmsg = i18n("Modem Ready."); |
240 | return true; | 240 | return true; |
241 | } | 241 | } |
242 | 242 | ||
243 | 243 | ||
244 | bool Modem::closetty() { | 244 | bool Modem::closetty() { |
245 | if(modemfd >=0 ) { | 245 | if(modemfd >=0 ) { |
246 | stop(); | 246 | stop(); |
247 | /* discard data not read or transmitted */ | 247 | /* discard data not read or transmitted */ |
248 | tcflush(modemfd, TCIOFLUSH); | 248 | tcflush(modemfd, TCIOFLUSH); |
249 | 249 | ||
250 | if(tcsetattr(modemfd, TCSANOW, &initial_tty) < 0){ | 250 | if(tcsetattr(modemfd, TCSANOW, &initial_tty) < 0){ |
251 | errmsg = i18n("Can't restore tty settings: tcsetattr()\n"); | 251 | errmsg = i18n("Can't restore tty settings: tcsetattr()\n"); |
252 | ::close(modemfd); | 252 | ::close(modemfd); |
253 | modemfd = -1; | 253 | modemfd = -1; |
254 | return false; | 254 | return false; |
255 | } | 255 | } |
256 | ::close(modemfd); | 256 | ::close(modemfd); |
257 | modemfd = -1; | 257 | modemfd = -1; |
258 | } | 258 | } |
259 | 259 | ||
260 | return true; | 260 | return true; |
261 | } | 261 | } |
262 | 262 | ||
263 | 263 | ||
264 | void Modem::readtty(int) { | 264 | void Modem::readtty(int) { |
265 | char buffer[200]; | 265 | char buffer[200]; |
266 | unsigned char c; | 266 | unsigned char c; |
267 | int len; | 267 | int len; |
268 | 268 | ||
269 | // read data in chunks of up to 200 bytes | 269 | // read data in chunks of up to 200 bytes |
270 | if((len = ::read(modemfd, buffer, 200)) > 0) { | 270 | if((len = ::read(modemfd, buffer, 200)) > 0) { |
271 | // split buffer into single characters for further processing | 271 | // split buffer into single characters for further processing |
272 | for(int i = 0; i < len; i++) { | 272 | for(int i = 0; i < len; i++) { |
273 | c = buffer[i] & 0x7F; | 273 | c = buffer[i] & 0x7F; |
274 | emit charWaiting(c); | 274 | emit charWaiting(c); |
275 | } | 275 | } |
276 | } | 276 | } |
277 | } | 277 | } |
278 | 278 | ||
279 | 279 | ||
280 | void Modem::notify(const QObject *receiver, const char *member) { | 280 | void Modem::notify(const QObject *receiver, const char *member) { |
281 | connect(this, SIGNAL(charWaiting(unsigned char)), receiver, member); | 281 | connect(this, SIGNAL(charWaiting(unsigned char)), receiver, member); |
282 | startNotifier(); | 282 | startNotifier(); |
283 | } | 283 | } |
284 | 284 | ||
285 | 285 | ||
286 | void Modem::stop() { | 286 | void Modem::stop() { |
287 | disconnect(SIGNAL(charWaiting(unsigned char))); | 287 | disconnect(SIGNAL(charWaiting(unsigned char))); |
288 | stopNotifier(); | 288 | stopNotifier(); |
289 | } | 289 | } |
290 | 290 | ||
291 | 291 | ||
292 | void Modem::startNotifier() { | 292 | void Modem::startNotifier() { |
293 | if(modemfd >= 0) { | 293 | if(modemfd >= 0) { |
294 | if(sn == 0) { | 294 | if(sn == 0) { |
295 | sn = new QSocketNotifier(modemfd, QSocketNotifier::Read, this); | 295 | sn = new QSocketNotifier(modemfd, QSocketNotifier::Read, this); |
296 | connect(sn, SIGNAL(activated(int)), SLOT(readtty(int))); | 296 | connect(sn, SIGNAL(activated(int)), SLOT(readtty(int))); |
297 | qDebug("QSocketNotifier started!"); | 297 | qDebug("QSocketNotifier started!"); |
298 | } else { | 298 | } else { |
299 | qDebug("QSocketNotifier re-enabled!"); | 299 | qDebug("QSocketNotifier re-enabled!"); |
300 | sn->setEnabled(true); | 300 | sn->setEnabled(true); |
301 | } | 301 | } |
302 | } | 302 | } |
303 | } | 303 | } |
304 | 304 | ||
305 | 305 | ||
306 | void Modem::stopNotifier() { | 306 | void Modem::stopNotifier() { |
307 | if(sn != 0) { | 307 | if(sn != 0) { |
308 | sn->setEnabled(false); | 308 | sn->setEnabled(false); |
309 | disconnect(sn); | 309 | disconnect(sn); |
310 | delete sn; | 310 | delete sn; |
311 | sn = 0; | 311 | sn = 0; |
312 | qDebug( "QSocketNotifier stopped!" ); | 312 | qDebug( "QSocketNotifier stopped!" ); |
313 | } | 313 | } |
314 | } | 314 | } |
315 | 315 | ||
316 | 316 | ||
317 | void Modem::flush() { | 317 | void Modem::flush() { |
318 | char c; | 318 | char c; |
319 | while(read(modemfd, &c, 1) == 1); | 319 | while(read(modemfd, &c, 1) == 1); |
320 | } | 320 | } |
321 | 321 | ||
322 | 322 | ||
323 | bool Modem::writeChar(unsigned char c) { | 323 | bool Modem::writeChar(unsigned char c) { |
324 | int s; | 324 | int s; |
325 | do { | 325 | do { |
326 | s = write(modemfd, &c, 1); | 326 | s = write(modemfd, &c, 1); |
327 | if (s < 0) { | 327 | if (s < 0) { |
328 | qError( "write() in Modem::writeChar failed" ); | 328 | qError( "write() in Modem::writeChar failed" ); |
329 | return false; | 329 | return false; |
330 | } | 330 | } |
331 | } while(s == 0); | 331 | } while(s == 0); |
332 | 332 | ||
333 | return true; | 333 | return true; |
334 | } | 334 | } |
335 | 335 | ||
336 | 336 | ||
337 | bool Modem::writeLine(const char *buf) { | 337 | bool Modem::writeLine(const char *buf) { |
338 | int len = strlen(buf); | 338 | int len = strlen(buf); |
339 | char *b = new char[len+2]; | 339 | char *b = new char[len+2]; |
340 | memcpy(b, buf, len); | 340 | memcpy(b, buf, len); |
341 | // different modems seem to need different line terminations | 341 | // different modems seem to need different line terminations |
342 | QString term = gpppdata.enter(); | 342 | QString term = PPPData::data()->enter(); |
343 | if(term == "LF") | 343 | if(term == "LF") |
344 | b[len++]='\n'; | 344 | b[len++]='\n'; |
345 | else if(term == "CR") | 345 | else if(term == "CR") |
346 | b[len++]='\r'; | 346 | b[len++]='\r'; |
347 | else if(term == "CR/LF") { | 347 | else if(term == "CR/LF") { |
348 | b[len++]='\r'; | 348 | b[len++]='\r'; |
349 | b[len++]='\n'; | 349 | b[len++]='\n'; |
350 | } | 350 | } |
351 | int l = len; | 351 | int l = len; |
352 | while(l) { | 352 | while(l) { |
353 | int wr = write(modemfd, &b[len-l], l); | 353 | int wr = write(modemfd, &b[len-l], l); |
354 | if(wr < 0) { | 354 | if(wr < 0) { |
355 | // TODO do something meaningful with the error code (or ignore it | 355 | // TODO do something meaningful with the error code (or ignore it |
356 | qError( "write() in Modem::writeLine failed" ); | 356 | qError( "write() in Modem::writeLine failed" ); |
357 | delete[] b; | 357 | delete[] b; |
358 | return false; | 358 | return false; |
359 | } | 359 | } |
360 | l -= wr; | 360 | l -= wr; |
361 | } | 361 | } |
362 | delete[] b; | 362 | delete[] b; |
363 | return true; | 363 | return true; |
364 | } | 364 | } |
365 | 365 | ||
366 | 366 | ||
367 | bool Modem::hangup() { | 367 | bool Modem::hangup() { |
368 | // this should really get the modem to hang up and go into command mode | 368 | // this should really get the modem to hang up and go into command mode |
369 | // If anyone sees a fault in the following please let me know, since | 369 | // If anyone sees a fault in the following please let me know, since |
370 | // this is probably the most imporant snippet of code in the whole of | 370 | // this is probably the most imporant snippet of code in the whole of |
371 | // kppp. If people complain about kppp being stuck, this piece of code | 371 | // kppp. If people complain about kppp being stuck, this piece of code |
372 | // is most likely the reason. | 372 | // is most likely the reason. |
373 | struct termios temptty; | 373 | struct termios temptty; |
374 | 374 | ||
375 | if(modemfd >= 0) { | 375 | if(modemfd >= 0) { |
376 | 376 | ||
377 | // is this Escape & HangupStr stuff really necessary ? (Harri) | 377 | // is this Escape & HangupStr stuff really necessary ? (Harri) |
378 | 378 | ||
379 | if (data_mode) escape_to_command_mode(); | 379 | if (data_mode) escape_to_command_mode(); |
380 | 380 | ||
381 | // Then hangup command | 381 | // Then hangup command |
382 | writeLine(gpppdata.modemHangupStr().local8Bit()); | 382 | writeLine(PPPData::data()->modemHangupStr().local8Bit()); |
383 | 383 | ||
384 | usleep(gpppdata.modemInitDelay() * 10000); // 0.01 - 3.0 sec | 384 | usleep(PPPData::data()->modemInitDelay() * 10000); // 0.01 - 3.0 sec |
385 | 385 | ||
386 | #ifndef DEBUG_WO_DIALING | 386 | #ifndef DEBUG_WO_DIALING |
387 | if (sigsetjmp(jmp_buffer, 1) == 0) { | 387 | if (sigsetjmp(jmp_buffer, 1) == 0) { |
388 | // set alarm in case tcsendbreak() hangs | 388 | // set alarm in case tcsendbreak() hangs |
389 | signal(SIGALRM, alarm_handler); | 389 | signal(SIGALRM, alarm_handler); |
390 | alarm(2); | 390 | alarm(2); |
391 | 391 | ||
392 | tcsendbreak(modemfd, 0); | 392 | tcsendbreak(modemfd, 0); |
393 | 393 | ||
394 | alarm(0); | 394 | alarm(0); |
395 | signal(SIGALRM, SIG_IGN); | 395 | signal(SIGALRM, SIG_IGN); |
396 | } else { | 396 | } else { |
397 | // we reach this point if the alarm handler got called | 397 | // we reach this point if the alarm handler got called |
398 | closetty(); | 398 | closetty(); |
399 | close(modemfd); | 399 | close(modemfd); |
400 | modemfd = -1; | 400 | modemfd = -1; |
401 | errmsg = i18n("The modem does not respond."); | 401 | errmsg = i18n("The modem does not respond."); |
402 | return false; | 402 | return false; |
403 | } | 403 | } |
404 | 404 | ||
405 | #ifndef __svr4__ // drops DTR but doesn't set it afterwards again. not good for init. | 405 | #ifndef __svr4__ // drops DTR but doesn't set it afterwards again. not good for init. |
406 | tcgetattr(modemfd, &temptty); | 406 | tcgetattr(modemfd, &temptty); |
407 | cfsetospeed(&temptty, B0); | 407 | cfsetospeed(&temptty, B0); |
408 | cfsetispeed(&temptty, B0); | 408 | cfsetispeed(&temptty, B0); |
409 | tcsetattr(modemfd, TCSAFLUSH, &temptty); | 409 | tcsetattr(modemfd, TCSAFLUSH, &temptty); |
410 | #else | 410 | #else |
411 | int modemstat; | 411 | int modemstat; |
412 | ioctl(modemfd, TIOCMGET, &modemstat); | 412 | ioctl(modemfd, TIOCMGET, &modemstat); |
413 | modemstat &= ~TIOCM_DTR; | 413 | modemstat &= ~TIOCM_DTR; |
414 | ioctl(modemfd, TIOCMSET, &modemstat); | 414 | ioctl(modemfd, TIOCMSET, &modemstat); |
415 | ioctl(modemfd, TIOCMGET, &modemstat); | 415 | ioctl(modemfd, TIOCMGET, &modemstat); |
416 | modemstat |= TIOCM_DTR; | 416 | modemstat |= TIOCM_DTR; |
417 | ioctl(modemfd, TIOCMSET, &modemstat); | 417 | ioctl(modemfd, TIOCMSET, &modemstat); |
418 | #endif | 418 | #endif |
419 | 419 | ||
420 | usleep(gpppdata.modemInitDelay() * 10000); // 0.01 - 3.0 secs | 420 | usleep(PPPData::data()->modemInitDelay() * 10000); // 0.01 - 3.0 secs |
421 | 421 | ||
422 | cfsetospeed(&temptty, modemspeed()); | 422 | cfsetospeed(&temptty, modemspeed()); |
423 | cfsetispeed(&temptty, modemspeed()); | 423 | cfsetispeed(&temptty, modemspeed()); |
424 | tcsetattr(modemfd, TCSAFLUSH, &temptty); | 424 | tcsetattr(modemfd, TCSAFLUSH, &temptty); |
425 | #endif | 425 | #endif |
426 | return true; | 426 | return true; |
427 | } else | 427 | } else |
428 | return false; | 428 | return false; |
429 | } | 429 | } |
430 | 430 | ||
431 | 431 | ||
432 | void Modem::escape_to_command_mode() { | 432 | void Modem::escape_to_command_mode() { |
433 | // Send Properly bracketed escape code to put the modem back into command state. | 433 | // Send Properly bracketed escape code to put the modem back into command state. |
434 | // A modem will accept AT commands only when it is in command state. | 434 | // A modem will accept AT commands only when it is in command state. |
435 | // When a modem sends the host the CONNECT string, that signals | 435 | // When a modem sends the host the CONNECT string, that signals |
436 | // that the modem is now in the connect state (no long accepts AT commands.) | 436 | // that the modem is now in the connect state (no long accepts AT commands.) |
437 | // Need to send properly timed escape sequence to put modem in command state. | 437 | // Need to send properly timed escape sequence to put modem in command state. |
438 | // Escape codes and guard times are controlled by S2 and S12 values. | 438 | // Escape codes and guard times are controlled by S2 and S12 values. |
439 | // | 439 | // |
440 | tcflush(modemfd, TCIOFLUSH); | 440 | tcflush(modemfd, TCIOFLUSH); |
441 | 441 | ||
442 | // +3 because quiet time must be greater than guard time. | 442 | // +3 because quiet time must be greater than guard time. |
443 | usleep((gpppdata.modemEscapeGuardTime()+3)*20000); | 443 | usleep((PPPData::data()->modemEscapeGuardTime()+3)*20000); |
444 | QCString tmp = gpppdata.modemEscapeStr().local8Bit(); | 444 | QCString tmp = PPPData::data()->modemEscapeStr().local8Bit(); |
445 | write(modemfd, tmp.data(), tmp.length()); | 445 | write(modemfd, tmp.data(), tmp.length()); |
446 | tcflush(modemfd, TCIOFLUSH); | 446 | tcflush(modemfd, TCIOFLUSH); |
447 | usleep((gpppdata.modemEscapeGuardTime()+3)*20000); | 447 | usleep((PPPData::data()->modemEscapeGuardTime()+3)*20000); |
448 | 448 | ||
449 | data_mode = false; | 449 | data_mode = false; |
450 | } | 450 | } |
451 | 451 | ||
452 | 452 | ||
453 | const QString Modem::modemMessage() { | 453 | const QString Modem::modemMessage() { |
454 | return errmsg; | 454 | return errmsg; |
455 | } | 455 | } |
456 | 456 | ||
457 | 457 | ||
458 | QString Modem::parseModemSpeed(const QString &s) { | 458 | QString Modem::parseModemSpeed(const QString &s) { |
459 | // this is a small (and bad) parser for modem speeds | 459 | // this is a small (and bad) parser for modem speeds |
460 | int rx = -1; | 460 | int rx = -1; |
461 | int tx = -1; | 461 | int tx = -1; |
462 | int i; | 462 | int i; |
463 | QString result; | 463 | QString result; |
464 | 464 | ||
465 | qDebug( "Modem reported result string: %s", s.latin1()); | 465 | qDebug( "Modem reported result string: %s", s.latin1()); |
466 | 466 | ||
467 | const int RXMAX = 7; | 467 | const int RXMAX = 7; |
468 | const int TXMAX = 2; | 468 | const int TXMAX = 2; |
469 | QRegExp rrx[RXMAX] = { | 469 | QRegExp rrx[RXMAX] = { |
470 | QRegExp("[0-9]+[:/ ]RX", false), | 470 | QRegExp("[0-9]+[:/ ]RX", false), |
471 | QRegExp("[0-9]+RX", false), | 471 | QRegExp("[0-9]+RX", false), |
472 | QRegExp("[/: -][0-9]+[/: ]", false), | 472 | QRegExp("[/: -][0-9]+[/: ]", false), |
473 | QRegExp("[/: -][0-9]+$", false), | 473 | QRegExp("[/: -][0-9]+$", false), |
474 | QRegExp("CARRIER [^0-9]*[0-9]+", false), | 474 | QRegExp("CARRIER [^0-9]*[0-9]+", false), |
475 | QRegExp("CONNECT [^0-9]*[0-9]+", false), | 475 | QRegExp("CONNECT [^0-9]*[0-9]+", false), |
476 | QRegExp("[0-9]+") // panic mode | 476 | QRegExp("[0-9]+") // panic mode |
477 | }; | 477 | }; |
478 | 478 | ||
479 | QRegExp trx[TXMAX] = { | 479 | QRegExp trx[TXMAX] = { |
480 | QRegExp("[0-9]+[:/ ]TX", false), | 480 | QRegExp("[0-9]+[:/ ]TX", false), |
481 | QRegExp("[0-9]+TX", false) | 481 | QRegExp("[0-9]+TX", false) |
482 | }; | 482 | }; |
483 | 483 | ||
484 | for(i = 0; i < RXMAX; i++) { | 484 | for(i = 0; i < RXMAX; i++) { |
485 | int len, idx, result; | 485 | int len, idx, result; |
486 | if((idx = rrx[i].match(s,0,&len)) > -1) { | 486 | if((idx = rrx[i].match(s,0,&len)) > -1) { |
487 | // if((idx = rrx[i].search(s)) > -1) { | 487 | // if((idx = rrx[i].search(s)) > -1) { |
488 | // len = rrx[i].matchedLength(); | 488 | // len = rrx[i].matchedLength(); |
489 | 489 | ||
490 | // | 490 | // |
491 | // rrx[i] has been matched, idx contains the start of the match | 491 | // rrx[i] has been matched, idx contains the start of the match |
492 | // and len contains how long the match is. Extract the match. | 492 | // and len contains how long the match is. Extract the match. |
493 | // | 493 | // |
494 | QString sub = s.mid(idx, len); | 494 | QString sub = s.mid(idx, len); |
495 | 495 | ||
496 | // | 496 | // |
497 | // Now extract the digits only from the match, which will | 497 | // Now extract the digits only from the match, which will |
498 | // then be converted to an int. | 498 | // then be converted to an int. |
499 | // | 499 | // |
500 | if ((idx = rrx[RXMAX-1].match( sub,0,&len )) > -1) { | 500 | if ((idx = rrx[RXMAX-1].match( sub,0,&len )) > -1) { |
501 | // if ((idx = rrx[RXMAX-1].search( sub )) > -1) { | 501 | // if ((idx = rrx[RXMAX-1].search( sub )) > -1) { |
502 | // len = rrx[RXMAX-1].matchedLength(); | 502 | // len = rrx[RXMAX-1].matchedLength(); |
503 | sub = sub.mid(idx, len); | 503 | sub = sub.mid(idx, len); |
504 | result = sub.toInt(); | 504 | result = sub.toInt(); |
505 | if(result > 0) { | 505 | if(result > 0) { |
506 | rx = result; | 506 | rx = result; |
507 | break; | 507 | break; |
508 | } | 508 | } |
509 | } | 509 | } |
510 | } | 510 | } |
511 | } | 511 | } |
512 | 512 | ||
513 | for(i = 0; i < TXMAX; i++) { | 513 | for(i = 0; i < TXMAX; i++) { |
514 | int len, idx, result; | 514 | int len, idx, result; |
515 | if((idx = trx[i].match(s,0,&len)) > -1) { | 515 | if((idx = trx[i].match(s,0,&len)) > -1) { |
516 | // if((idx = trx[i].search(s)) > -1) { | 516 | // if((idx = trx[i].search(s)) > -1) { |
517 | // len = trx[i].matchedLength(); | 517 | // len = trx[i].matchedLength(); |
518 | 518 | ||
519 | // | 519 | // |
520 | // trx[i] has been matched, idx contains the start of the match | 520 | // trx[i] has been matched, idx contains the start of the match |
521 | // and len contains how long the match is. Extract the match. | 521 | // and len contains how long the match is. Extract the match. |
522 | // | 522 | // |
523 | QString sub = s.mid(idx, len); | 523 | QString sub = s.mid(idx, len); |
524 | 524 | ||
525 | // | 525 | // |
526 | // Now extract the digits only from the match, which will then | 526 | // Now extract the digits only from the match, which will then |
527 | // be converted to an int. | 527 | // be converted to an int. |
528 | // | 528 | // |
529 | if((idx = rrx[RXMAX-1].match(sub,0,&len)) > -1) { | 529 | if((idx = rrx[RXMAX-1].match(sub,0,&len)) > -1) { |
530 | // if((idx = rrx[RXMAX-1].search(sub)) > -1) { | 530 | // if((idx = rrx[RXMAX-1].search(sub)) > -1) { |
531 | // len = rrx[RXMAX-1].matchedLength(); | 531 | // len = rrx[RXMAX-1].matchedLength(); |
532 | sub = sub.mid(idx, len); | 532 | sub = sub.mid(idx, len); |
533 | result = sub.toInt(); | 533 | result = sub.toInt(); |
534 | if(result > 0) { | 534 | if(result > 0) { |
535 | tx = result; | 535 | tx = result; |
536 | break; | 536 | break; |
537 | } | 537 | } |
538 | } | 538 | } |
539 | } | 539 | } |
540 | } | 540 | } |
541 | 541 | ||
542 | if(rx == -1 && tx == -1) | 542 | if(rx == -1 && tx == -1) |
543 | result = i18n("Unknown speed"); | 543 | result = i18n("Unknown speed"); |
544 | else if(tx == -1) | 544 | else if(tx == -1) |
545 | result.setNum(rx); | 545 | result.setNum(rx); |
546 | else if(rx == -1) // should not happen | 546 | else if(rx == -1) // should not happen |
547 | result.setNum(tx); | 547 | result.setNum(tx); |
548 | else | 548 | else |
549 | result.sprintf("%d/%d", rx, tx); | 549 | result.sprintf("%d/%d", rx, tx); |
550 | 550 | ||
551 | qDebug( "The parsed result is: %s", result.latin1()); | 551 | qDebug( "The parsed result is: %s", result.latin1()); |
552 | 552 | ||
553 | return result; | 553 | return result; |
554 | } | 554 | } |
555 | 555 | ||
556 | 556 | ||
557 | // Lock modem device. Returns 0 on success 1 if the modem is locked and -1 if | 557 | // Lock modem device. Returns 0 on success 1 if the modem is locked and -1 if |
558 | // a lock file can't be created ( permission problem ) | 558 | // a lock file can't be created ( permission problem ) |
559 | int Modem::lockdevice() { | 559 | int Modem::lockdevice() { |
560 | int fd; | 560 | int fd; |
561 | char newlock[80]=""; // safe | 561 | char newlock[80]=""; // safe |
562 | 562 | ||
563 | if(!gpppdata.modemLockFile()) { | 563 | if(!PPPData::data()->modemLockFile()) { |
564 | qDebug("The user doesn't want a lockfile."); | 564 | qDebug("The user doesn't want a lockfile."); |
565 | return 0; | 565 | return 0; |
566 | } | 566 | } |
567 | 567 | ||
568 | if (modem_is_locked) | 568 | if (modem_is_locked) |
569 | return 1; | 569 | return 1; |
570 | 570 | ||
571 | QString lockfile = LOCK_DIR"/LCK.."; | 571 | QString lockfile = LOCK_DIR"/LCK.."; |
572 | lockfile += gpppdata.modemDevice().mid(5); // append everything after /dev/ | 572 | lockfile += PPPData::data()->modemDevice().mid(5); // append everything after /dev/ |
573 | 573 | ||
574 | if(access(QFile::encodeName(lockfile), F_OK) == 0) { | 574 | if(access(QFile::encodeName(lockfile), F_OK) == 0) { |
575 | // if ((fd = Requester::rq-> | 575 | // if ((fd = Requester::rq-> |
576 | if ((fd = openLockfile(QFile::encodeName(lockfile), O_RDONLY)) >= 0) { | 576 | if ((fd = openLockfile(QFile::encodeName(lockfile), O_RDONLY)) >= 0) { |
577 | // Mario: it's not necessary to read more than lets say 32 bytes. If | 577 | // Mario: it's not necessary to read more than lets say 32 bytes. If |
578 | // file has more than 32 bytes, skip the rest | 578 | // file has more than 32 bytes, skip the rest |
579 | char oldlock[33]; // safe | 579 | char oldlock[33]; // safe |
580 | int sz = read(fd, &oldlock, 32); | 580 | int sz = read(fd, &oldlock, 32); |
581 | close (fd); | 581 | close (fd); |
582 | if (sz <= 0) | 582 | if (sz <= 0) |
583 | return 1; | 583 | return 1; |
584 | oldlock[sz] = '\0'; | 584 | oldlock[sz] = '\0'; |
585 | 585 | ||
586 | qDebug( "Device is locked by: %s", oldlock); | 586 | qDebug( "Device is locked by: %s", oldlock); |
587 | 587 | ||
588 | int oldpid; | 588 | int oldpid; |
589 | int match = sscanf(oldlock, "%d", &oldpid); | 589 | int match = sscanf(oldlock, "%d", &oldpid); |
590 | 590 | ||
591 | // found a pid in lockfile ? | 591 | // found a pid in lockfile ? |
592 | if (match < 1 || oldpid <= 0) | 592 | if (match < 1 || oldpid <= 0) |
593 | return 1; | 593 | return 1; |
594 | 594 | ||
595 | // check if process exists | 595 | // check if process exists |
596 | if (kill((pid_t)oldpid, 0) == 0 || errno != ESRCH) | 596 | if (kill((pid_t)oldpid, 0) == 0 || errno != ESRCH) |
597 | return 1; | 597 | return 1; |
598 | 598 | ||
599 | qDebug( "lockfile is stale" ); | 599 | qDebug( "lockfile is stale" ); |
600 | } | 600 | } |
601 | } | 601 | } |
602 | 602 | ||
603 | fd = openLockfile(gpppdata.modemDevice(),O_WRONLY|O_TRUNC|O_CREAT); | 603 | fd = openLockfile(PPPData::data()->modemDevice(),O_WRONLY|O_TRUNC|O_CREAT); |
604 | if(fd >= 0) { | 604 | if(fd >= 0) { |
605 | sprintf(newlock,"%010d\n", getpid()); | 605 | sprintf(newlock,"%010d\n", getpid()); |
606 | qDebug("Locking Device: %s", newlock); | 606 | qDebug("Locking Device: %s", newlock); |
607 | 607 | ||
608 | write(fd, newlock, strlen(newlock)); | 608 | write(fd, newlock, strlen(newlock)); |
609 | close(fd); | 609 | close(fd); |
610 | modem_is_locked=true; | 610 | modem_is_locked=true; |
611 | 611 | ||
612 | return 0; | 612 | return 0; |
613 | } | 613 | } |
614 | 614 | ||
615 | return -1; | 615 | return -1; |
616 | 616 | ||
617 | } | 617 | } |
618 | 618 | ||
619 | 619 | ||
620 | // UnLock modem device | 620 | // UnLock modem device |
621 | void Modem::unlockdevice() { | 621 | void Modem::unlockdevice() { |
622 | if (modem_is_locked) { | 622 | if (modem_is_locked) { |
623 | qDebug( "UnLocking Modem Device" ); | 623 | qDebug( "UnLocking Modem Device" ); |
624 | close(modemfd); | 624 | close(modemfd); |
625 | modemfd = -1; | 625 | modemfd = -1; |
626 | unlink(lockfile); | 626 | unlink(lockfile); |
627 | lockfile[0] = '\0'; | 627 | lockfile[0] = '\0'; |
628 | modem_is_locked=false; | 628 | modem_is_locked=false; |
629 | } | 629 | } |
630 | } | 630 | } |
631 | 631 | ||
632 | int Modem::openLockfile( QString lockfile, int flags) | 632 | int Modem::openLockfile( QString lockfile, int flags) |
633 | { | 633 | { |
634 | int fd; | 634 | int fd; |
635 | int mode; | 635 | int mode; |
636 | flags = O_RDONLY; | 636 | flags = O_RDONLY; |
637 | if(flags == O_WRONLY|O_TRUNC|O_CREAT) | 637 | if(flags == O_WRONLY|O_TRUNC|O_CREAT) |
638 | mode = 0644; | 638 | mode = 0644; |
639 | else | 639 | else |
640 | mode = 0; | 640 | mode = 0; |
641 | 641 | ||
642 | lockfile = LOCK_DIR; | 642 | lockfile = LOCK_DIR; |
643 | lockfile += "/LCK.."; | 643 | lockfile += "/LCK.."; |
644 | lockfile += device.right( device.length() - device.findRev("/") -1 ); | 644 | lockfile += device.right( device.length() - device.findRev("/") -1 ); |
645 | qDebug("lockfile >%s<",lockfile.latin1()); | 645 | qDebug("lockfile >%s<",lockfile.latin1()); |
646 | // TODO: | 646 | // TODO: |
647 | // struct stat st; | 647 | // struct stat st; |
648 | // if(stat(lockfile.data(), &st) == -1) { | 648 | // if(stat(lockfile.data(), &st) == -1) { |
649 | // if(errno == EBADF) | 649 | // if(errno == EBADF) |
650 | // return -1; | 650 | // return -1; |
651 | // } else { | 651 | // } else { |
652 | // // make sure that this is a regular file | 652 | // // make sure that this is a regular file |
653 | // if(!S_ISREG(st.st_mode)) | 653 | // if(!S_ISREG(st.st_mode)) |
654 | // return -1; | 654 | // return -1; |
655 | // } | 655 | // } |
656 | if ((fd = open(lockfile, flags, mode)) == -1) { | 656 | if ((fd = open(lockfile, flags, mode)) == -1) { |
657 | qDebug("error opening lockfile!"); | 657 | qDebug("error opening lockfile!"); |
658 | lockfile = QString::null; | 658 | lockfile = QString::null; |
659 | fd = open(DEVNULL, O_RDONLY); | 659 | fd = open(DEVNULL, O_RDONLY); |
660 | } else | 660 | } else |
661 | fchown(fd, 0, 0); | 661 | fchown(fd, 0, 0); |
662 | return fd; | 662 | return fd; |
663 | } | 663 | } |
664 | 664 | ||
665 | 665 | ||
666 | 666 | ||
667 | void alarm_handler(int) { | 667 | void alarm_handler(int) { |
668 | // fprintf(stderr, "alarm_handler(): Received SIGALRM\n"); | 668 | // fprintf(stderr, "alarm_handler(): Received SIGALRM\n"); |
669 | 669 | ||
670 | // jump | 670 | // jump |
671 | siglongjmp(jmp_buffer, 1); | 671 | siglongjmp(jmp_buffer, 1); |
672 | } | 672 | } |
673 | 673 | ||
674 | 674 | ||
675 | const char* Modem::authFile(Auth method, int version) { | 675 | const char* Modem::authFile(Auth method, int version) { |
676 | switch(method|version) { | 676 | switch(method|version) { |
677 | case PAP|Original: | 677 | case PAP|Original: |
678 | return PAP_AUTH_FILE; | 678 | return PAP_AUTH_FILE; |
679 | break; | 679 | break; |
680 | case PAP|New: | 680 | case PAP|New: |
681 | return PAP_AUTH_FILE".new"; | 681 | return PAP_AUTH_FILE".new"; |
682 | break; | 682 | break; |
683 | case PAP|Old: | 683 | case PAP|Old: |
684 | return PAP_AUTH_FILE".old"; | 684 | return PAP_AUTH_FILE".old"; |
685 | break; | 685 | break; |
686 | case CHAP|Original: | 686 | case CHAP|Original: |
687 | return CHAP_AUTH_FILE; | 687 | return CHAP_AUTH_FILE; |
688 | break; | 688 | break; |
689 | case CHAP|New: | 689 | case CHAP|New: |
690 | return CHAP_AUTH_FILE".new"; | 690 | return CHAP_AUTH_FILE".new"; |
691 | break; | 691 | break; |
692 | case CHAP|Old: | 692 | case CHAP|Old: |
693 | return CHAP_AUTH_FILE".old"; | 693 | return CHAP_AUTH_FILE".old"; |
694 | break; | 694 | break; |
695 | default: | 695 | default: |
696 | return 0L; | 696 | return 0L; |
697 | } | 697 | } |
698 | } | 698 | } |
699 | 699 | ||
700 | 700 | ||
701 | bool Modem::createAuthFile(Auth method, const char *username, const char *password) { | 701 | bool Modem::createAuthFile(Auth method, const char *username, const char *password) { |
702 | const char *authfile, *oldName, *newName; | 702 | const char *authfile, *oldName, *newName; |
703 | char line[100]; | 703 | char line[100]; |
704 | char regexp[2*MaxStrLen+30]; | 704 | char regexp[2*MaxStrLen+30]; |
705 | regex_t preg; | 705 | regex_t preg; |
706 | 706 | ||
707 | if(!(authfile = authFile(method))) | 707 | if(!(authfile = authFile(method))) |
708 | return false; | 708 | return false; |
709 | 709 | ||
710 | if(!(newName = authFile(method, New))) | 710 | if(!(newName = authFile(method, New))) |
711 | return false; | 711 | return false; |
712 | 712 | ||
713 | // look for username, "username" or 'username' | 713 | // look for username, "username" or 'username' |
714 | // if you modify this RE you have to adapt regexp's size above | 714 | // if you modify this RE you have to adapt regexp's size above |
715 | snprintf(regexp, sizeof(regexp), "^[ \t]*%s[ \t]\\|^[ \t]*[\"\']%s[\"\']", | 715 | snprintf(regexp, sizeof(regexp), "^[ \t]*%s[ \t]\\|^[ \t]*[\"\']%s[\"\']", |
716 | username,username); | 716 | username,username); |
717 | MY_ASSERT(regcomp(&preg, regexp, 0) == 0); | 717 | MY_ASSERT(regcomp(&preg, regexp, 0) == 0); |
718 | 718 | ||
719 | // copy to new file pap- or chap-secrets | 719 | // copy to new file pap- or chap-secrets |
720 | int old_umask = umask(0077); | 720 | int old_umask = umask(0077); |
721 | FILE *fout = fopen(newName, "w"); | 721 | FILE *fout = fopen(newName, "w"); |
722 | if(fout) { | 722 | if(fout) { |
723 | // copy old file | 723 | // copy old file |
724 | FILE *fin = fopen(authfile, "r"); | 724 | FILE *fin = fopen(authfile, "r"); |
725 | if(fin) { | 725 | if(fin) { |
726 | while(fgets(line, sizeof(line), fin)) { | 726 | while(fgets(line, sizeof(line), fin)) { |
727 | if(regexec(&preg, line, 0, 0L, 0) == 0) | 727 | if(regexec(&preg, line, 0, 0L, 0) == 0) |
728 | continue; | 728 | continue; |
729 | fputs(line, fout); | 729 | fputs(line, fout); |
730 | } | 730 | } |
731 | fclose(fin); | 731 | fclose(fin); |
732 | } | 732 | } |
733 | 733 | ||
734 | // append user/pass pair | 734 | // append user/pass pair |
735 | fprintf(fout, "\"%s\"\t*\t\"%s\"\n", username, password); | 735 | fprintf(fout, "\"%s\"\t*\t\"%s\"\n", username, password); |
736 | fclose(fout); | 736 | fclose(fout); |
737 | } | 737 | } |
738 | 738 | ||
739 | // restore umask | 739 | // restore umask |
740 | umask(old_umask); | 740 | umask(old_umask); |
741 | 741 | ||
742 | // free memory allocated by regcomp | 742 | // free memory allocated by regcomp |
743 | regfree(&preg); | 743 | regfree(&preg); |
744 | 744 | ||
745 | if(!(oldName = authFile(method, Old))) | 745 | if(!(oldName = authFile(method, Old))) |
746 | return false; | 746 | return false; |
747 | 747 | ||
748 | // delete old file if any | 748 | // delete old file if any |
749 | unlink(oldName); | 749 | unlink(oldName); |
750 | 750 | ||
751 | rename(authfile, oldName); | 751 | rename(authfile, oldName); |
752 | rename(newName, authfile); | 752 | rename(newName, authfile); |
753 | 753 | ||
754 | return true; | 754 | return true; |
755 | } | 755 | } |
756 | 756 | ||
757 | 757 | ||
758 | bool Modem::setSecret(int method, const char* name, const char* password) | 758 | bool Modem::setSecret(int method, const char* name, const char* password) |
759 | { | 759 | { |
760 | 760 | ||
761 | Auth auth; | 761 | Auth auth; |
762 | if(method == AUTH_PAPCHAP) | 762 | if(method == AUTH_PAPCHAP) |
763 | return setSecret(AUTH_PAP, name, password) && | 763 | return setSecret(AUTH_PAP, name, password) && |
764 | setSecret(AUTH_CHAP, name, password); | 764 | setSecret(AUTH_CHAP, name, password); |
765 | 765 | ||
766 | switch(method) { | 766 | switch(method) { |
767 | case AUTH_PAP: | 767 | case AUTH_PAP: |
768 | auth = Modem::PAP; | 768 | auth = Modem::PAP; |
769 | break; | 769 | break; |
770 | case AUTH_CHAP: | 770 | case AUTH_CHAP: |
771 | auth = Modem::CHAP; | 771 | auth = Modem::CHAP; |
772 | break; | 772 | break; |
773 | default: | 773 | default: |
774 | return false; | 774 | return false; |
775 | } | 775 | } |
776 | 776 | ||
777 | return createAuthFile(auth, name, password); | 777 | return createAuthFile(auth, name, password); |
778 | 778 | ||
779 | } | 779 | } |
780 | 780 | ||
781 | bool Modem::removeSecret(int) | 781 | bool Modem::removeSecret(int) |
782 | { | 782 | { |
783 | return true; | 783 | return true; |
784 | } | 784 | } |
785 | 785 | ||
786 | void Modem::killPPPDaemon() | 786 | void Modem::killPPPDaemon() |
787 | { | 787 | { |
788 | } | 788 | } |
789 | 789 | ||
790 | int Modem::pppdExitStatus() | 790 | int Modem::pppdExitStatus() |
791 | { | 791 | { |
792 | return -1; | 792 | return -1; |
793 | } | 793 | } |
794 | 794 | ||
795 | bool Modem::execPPPDaemon(const QString & arguments) | 795 | bool Modem::execPPPDaemon(const QString & arguments) |
diff --git a/noncore/settings/networksettings/ppp/modemcmds.cpp b/noncore/settings/networksettings/ppp/modemcmds.cpp index 766ba0f..65032e8 100644 --- a/noncore/settings/networksettings/ppp/modemcmds.cpp +++ b/noncore/settings/networksettings/ppp/modemcmds.cpp | |||
@@ -1,321 +1,318 @@ | |||
1 | /* | 1 | /* |
2 | * kPPP: A front end for pppd for the KDE project | 2 | * kPPP: A front end for pppd 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 library is free software; you can redistribute it and/or | 12 | * This library 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 library is distributed in the hope that it will be useful, | 17 | * This library 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 dummyWidget program; if not, write to the Free | 23 | * License along with dummyWidget 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 <qlayout.h> | 27 | #include <qlayout.h> |
28 | #include <qslider.h> | 28 | #include <qslider.h> |
29 | #include <qbuttongroup.h> | 29 | #include <qbuttongroup.h> |
30 | #include <stdlib.h> | 30 | #include <stdlib.h> |
31 | //#include <kapplication.h> // for getMiniIcon() | 31 | //#include <kapplication.h> // for getMiniIcon() |
32 | //#include <klocale.h> | 32 | //#include <klocale.h> |
33 | #define i18n QObject::tr | 33 | #define i18n QObject::tr |
34 | #include "modemcmds.h" | 34 | #include "modemcmds.h" |
35 | #include "pppdata.h" | 35 | #include "pppdata.h" |
36 | //#include <kwin.h> | 36 | //#include <kwin.h> |
37 | 37 | ||
38 | #define ADJUSTEDIT(e) //e->setText("XXXXXXXXqy"); e->setMinimumSize(e->sizeHint()); /*e->setFixedHeight(e->sizeHint().height());*/ e->setText(""); e->setMaxLength(MODEMSTR_SIZE); | 38 | #define ADJUSTEDIT(e) //e->setText("XXXXXXXXqy"); e->setMinimumSize(e->sizeHint()); /*e->setFixedHeight(e->sizeHint().height());*/ e->setText(""); e->setMaxLength(MODEMSTR_SIZE); |
39 | 39 | ||
40 | // a little trick to make the label look like a disabled lineedit | 40 | // a little trick to make the label look like a disabled lineedit |
41 | #define FORMATSLIDERLABEL(l) //l->setFixedWidth(l->sizeHint().width()); l->setFixedHeight(QLineEdit(dummyWidget).sizeHint().height()); l->setAlignment(AlignCenter); l->setFrameStyle(QFrame::WinPanel|QFrame::Sunken); l->setLineWidth(2); | 41 | #define FORMATSLIDERLABEL(l) //l->setFixedWidth(l->sizeHint().width()); l->setFixedHeight(QLineEdit(dummyWidget).sizeHint().height()); l->setAlignment(AlignCenter); l->setFrameStyle(QFrame::WinPanel|QFrame::Sunken); l->setLineWidth(2); |
42 | 42 | ||
43 | ModemCommands::ModemCommands(QWidget *parent, const char *name) | 43 | ModemCommands::ModemCommands(QWidget *parent, const char *name) |
44 | : QDialog(parent, name, true ) //, i18n("Edit Modem Commands") , Ok|Cancel) | 44 | : QDialog(parent, name, true ) //, i18n("Edit Modem Commands") , Ok|Cancel) |
45 | { | 45 | { |
46 | setCaption(i18n("Edit Modem Commands")); | 46 | setCaption(i18n("Edit Modem Commands")); |
47 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); | ||
48 | QWidget *dummyWidget = new QWidget(this); | ||
49 | // setMainWidget(dummyWidget); | ||
50 | 47 | ||
51 | const int GRIDROWS = 22; | 48 | const int GRIDROWS = 22; |
52 | int row = 0; | 49 | int row = 0; |
53 | 50 | ||
54 | // toplevel layout | 51 | // toplevel layout |
55 | QVBoxLayout *tl = new QVBoxLayout(this, 10, 4); | 52 | QVBoxLayout *tl = new QVBoxLayout(this, 10, 4); |
56 | 53 | ||
57 | // add grid + frame | 54 | // add grid + frame |
58 | QGridLayout *l1 = new QGridLayout(GRIDROWS, 4); | 55 | QGridLayout *l1 = new QGridLayout(GRIDROWS, 4); |
59 | tl->addLayout(l1); | 56 | tl->addLayout(l1); |
60 | box = new QGroupBox(this, "box"); | 57 | box = new QGroupBox(this, "box"); |
61 | l1->addMultiCellWidget(box, row++, GRIDROWS, 0, 3); | 58 | l1->addMultiCellWidget(box, row++, GRIDROWS, 0, 3); |
62 | 59 | ||
63 | // put slider and label into a separate H-Box | 60 | // put slider and label into a separate H-Box |
64 | QHBoxLayout *l2 = new QHBoxLayout; | 61 | QHBoxLayout *l2 = new QHBoxLayout; |
65 | l1->addLayout(l2, row, 2); | 62 | l1->addLayout(l2, row, 2); |
66 | lpreinitslider = new QLabel("MMMM", this); | 63 | lpreinitslider = new QLabel("MMMM", this); |
67 | FORMATSLIDERLABEL(lpreinitslider); | 64 | FORMATSLIDERLABEL(lpreinitslider); |
68 | 65 | ||
69 | QSlider *preinitslider = new QSlider(0, 300, 1, 0, | 66 | QSlider *preinitslider = new QSlider(0, 300, 1, 0, |
70 | QSlider::Horizontal, this); | 67 | QSlider::Horizontal, this); |
71 | // preinitslider->setFixedHeight(preinitslider->sizeHint().height()); | 68 | // preinitslider->setFixedHeight(preinitslider->sizeHint().height()); |
72 | connect(preinitslider, SIGNAL(valueChanged(int)), | 69 | connect(preinitslider, SIGNAL(valueChanged(int)), |
73 | lpreinitslider, SLOT(setNum(int))); | 70 | lpreinitslider, SLOT(setNum(int))); |
74 | l2->addWidget(lpreinitslider, 0); | 71 | l2->addWidget(lpreinitslider, 0); |
75 | l2->addWidget(preinitslider, 1); | 72 | l2->addWidget(preinitslider, 1); |
76 | 73 | ||
77 | lpreinit = new QLabel(i18n("Pre-init delay (sec/100):"), this); | 74 | lpreinit = new QLabel(i18n("Pre-init delay (sec/100):"), this); |
78 | l1->addWidget(lpreinit, row++, 1); | 75 | l1->addWidget(lpreinit, row++, 1); |
79 | 76 | ||
80 | for(int i = 0; i < PPPData::NumInitStrings; i++) { | 77 | for(int i = 0; i < PPPData::NumInitStrings; i++) { |
81 | initstr[i] = new QLineEdit(this); | 78 | initstr[i] = new QLineEdit(this); |
82 | QLabel *initLabel = new QLabel(i18n("Initialization string %1:").arg(i + 1), | 79 | QLabel *initLabel = new QLabel(i18n("Initialization string %1:").arg(i + 1), |
83 | this); | 80 | this); |
84 | ADJUSTEDIT(initstr[i]); | 81 | ADJUSTEDIT(initstr[i]); |
85 | l1->addWidget(initLabel, row, 1); | 82 | l1->addWidget(initLabel, row, 1); |
86 | l1->addWidget(initstr[i], row++, 2); | 83 | l1->addWidget(initstr[i], row++, 2); |
87 | } | 84 | } |
88 | 85 | ||
89 | QHBoxLayout *l3 = new QHBoxLayout; | 86 | QHBoxLayout *l3 = new QHBoxLayout; |
90 | l1->addLayout(l3, row, 2); | 87 | l1->addLayout(l3, row, 2); |
91 | linitslider = new QLabel("MMMM", this); | 88 | linitslider = new QLabel("MMMM", this); |
92 | FORMATSLIDERLABEL(linitslider); | 89 | FORMATSLIDERLABEL(linitslider); |
93 | QSlider *initslider = new QSlider(1, 300, 1, 0, | 90 | QSlider *initslider = new QSlider(1, 300, 1, 0, |
94 | QSlider::Horizontal, this); | 91 | QSlider::Horizontal, this); |
95 | // initslider->setFixedHeight(initslider->sizeHint().height()); | 92 | // initslider->setFixedHeight(initslider->sizeHint().height()); |
96 | connect(initslider, SIGNAL(valueChanged(int)), | 93 | connect(initslider, SIGNAL(valueChanged(int)), |
97 | linitslider, SLOT(setNum(int))); | 94 | linitslider, SLOT(setNum(int))); |
98 | l3->addWidget(linitslider, 0); | 95 | l3->addWidget(linitslider, 0); |
99 | l3->addWidget(initslider, 1); | 96 | l3->addWidget(initslider, 1); |
100 | 97 | ||
101 | label3 = new QLabel(i18n("Post-init delay (sec/100):"), this); | 98 | label3 = new QLabel(i18n("Post-init delay (sec/100):"), this); |
102 | l1->addWidget(label3, row++, 1); | 99 | l1->addWidget(label3, row++, 1); |
103 | 100 | ||
104 | /* Set ATS11 (Dial tone duration) between 0-255 (Default ~ 70) */ | 101 | /* Set ATS11 (Dial tone duration) between 0-255 (Default ~ 70) */ |
105 | QHBoxLayout *l4 = new QHBoxLayout; | 102 | QHBoxLayout *l4 = new QHBoxLayout; |
106 | l1->addLayout(l4, row, 2); | 103 | l1->addLayout(l4, row, 2); |
107 | ldurationslider = new QLabel("MMMM", this); | 104 | ldurationslider = new QLabel("MMMM", this); |
108 | FORMATSLIDERLABEL(ldurationslider); | 105 | FORMATSLIDERLABEL(ldurationslider); |
109 | QSlider *durationslider = new QSlider(1, 255, 1, 0, | 106 | QSlider *durationslider = new QSlider(1, 255, 1, 0, |
110 | QSlider::Horizontal, this); | 107 | QSlider::Horizontal, this); |
111 | // durationslider->setFixedHeight(durationslider->sizeHint().height()); | 108 | // durationslider->setFixedHeight(durationslider->sizeHint().height()); |
112 | connect(durationslider, SIGNAL(valueChanged(int)), | 109 | connect(durationslider, SIGNAL(valueChanged(int)), |
113 | ldurationslider, SLOT(setNum(int))); | 110 | ldurationslider, SLOT(setNum(int))); |
114 | l4->addWidget(ldurationslider, 0); | 111 | l4->addWidget(ldurationslider, 0); |
115 | l4->addWidget(durationslider, 1); | 112 | l4->addWidget(durationslider, 1); |
116 | 113 | ||
117 | lduration = new QLabel(i18n("Dialing speed (sec/100):"), this); | 114 | lduration = new QLabel(i18n("Dialing speed (sec/100):"), this); |
118 | l1->addWidget(lduration, row++, 1); | 115 | l1->addWidget(lduration, row++, 1); |
119 | 116 | ||
120 | 117 | ||
121 | initresp = new QLineEdit(this); | 118 | initresp = new QLineEdit(this); |
122 | label2 = new QLabel(i18n("Init response:"), this); | 119 | label2 = new QLabel(i18n("Init response:"), this); |
123 | ADJUSTEDIT(initresp); | 120 | ADJUSTEDIT(initresp); |
124 | l1->addWidget(label2, row, 1); | 121 | l1->addWidget(label2, row, 1); |
125 | l1->addWidget(initresp, row++, 2); | 122 | l1->addWidget(initresp, row++, 2); |
126 | 123 | ||
127 | nodetectdialtone = new QLineEdit(this); | 124 | nodetectdialtone = new QLineEdit(this); |
128 | lnodetectdialtone = new QLabel(i18n("No dial tone detection:"), this); | 125 | lnodetectdialtone = new QLabel(i18n("No dial tone detection:"), this); |
129 | ADJUSTEDIT(nodetectdialtone); | 126 | ADJUSTEDIT(nodetectdialtone); |
130 | l1->addWidget(lnodetectdialtone, row, 1); | 127 | l1->addWidget(lnodetectdialtone, row, 1); |
131 | l1->addWidget(nodetectdialtone, row++, 2); | 128 | l1->addWidget(nodetectdialtone, row++, 2); |
132 | 129 | ||
133 | dialstr = new QLineEdit(this); | 130 | dialstr = new QLineEdit(this); |
134 | label4 = new QLabel(i18n("Dial string:"),this); | 131 | label4 = new QLabel(i18n("Dial string:"),this); |
135 | ADJUSTEDIT(dialstr); | 132 | ADJUSTEDIT(dialstr); |
136 | l1->addWidget(label4, row, 1); | 133 | l1->addWidget(label4, row, 1); |
137 | l1->addWidget(dialstr, row++, 2); | 134 | l1->addWidget(dialstr, row++, 2); |
138 | 135 | ||
139 | connectresp = new QLineEdit(this); | 136 | connectresp = new QLineEdit(this); |
140 | label5 = new QLabel(i18n("Connect response:"), this); | 137 | label5 = new QLabel(i18n("Connect response:"), this); |
141 | ADJUSTEDIT(connectresp); | 138 | ADJUSTEDIT(connectresp); |
142 | l1->addWidget(label5, row, 1); | 139 | l1->addWidget(label5, row, 1); |
143 | l1->addWidget(connectresp, row++, 2); | 140 | l1->addWidget(connectresp, row++, 2); |
144 | 141 | ||
145 | busyresp = new QLineEdit(this); | 142 | busyresp = new QLineEdit(this); |
146 | label6 = new QLabel(i18n("Busy response:"), this); | 143 | label6 = new QLabel(i18n("Busy response:"), this); |
147 | ADJUSTEDIT(busyresp); | 144 | ADJUSTEDIT(busyresp); |
148 | l1->addWidget(label6, row, 1); | 145 | l1->addWidget(label6, row, 1); |
149 | l1->addWidget(busyresp, row++, 2); | 146 | l1->addWidget(busyresp, row++, 2); |
150 | 147 | ||
151 | nocarrierresp = new QLineEdit(this); | 148 | nocarrierresp = new QLineEdit(this); |
152 | label7 = new QLabel(i18n("No carrier response:"), this); | 149 | label7 = new QLabel(i18n("No carrier response:"), this); |
153 | ADJUSTEDIT(nocarrierresp); | 150 | ADJUSTEDIT(nocarrierresp); |
154 | l1->addWidget(label7, row, 1); | 151 | l1->addWidget(label7, row, 1); |
155 | l1->addWidget(nocarrierresp, row++, 2); | 152 | l1->addWidget(nocarrierresp, row++, 2); |
156 | 153 | ||
157 | nodialtoneresp = new QLineEdit(this); | 154 | nodialtoneresp = new QLineEdit(this); |
158 | label8 = new QLabel(i18n("No dial tone response:"), this); | 155 | label8 = new QLabel(i18n("No dial tone response:"), this); |
159 | ADJUSTEDIT(nodialtoneresp); | 156 | ADJUSTEDIT(nodialtoneresp); |
160 | l1->addWidget(label8, row, 1); | 157 | l1->addWidget(label8, row, 1); |
161 | l1->addWidget(nodialtoneresp, row++, 2); | 158 | l1->addWidget(nodialtoneresp, row++, 2); |
162 | 159 | ||
163 | hangupstr = new QLineEdit(this); | 160 | hangupstr = new QLineEdit(this); |
164 | label9 = new QLabel(i18n("Hangup string:"), this); | 161 | label9 = new QLabel(i18n("Hangup string:"), this); |
165 | ADJUSTEDIT(hangupstr); | 162 | ADJUSTEDIT(hangupstr); |
166 | l1->addWidget(label9, row, 1); | 163 | l1->addWidget(label9, row, 1); |
167 | l1->addWidget(hangupstr, row++, 2); | 164 | l1->addWidget(hangupstr, row++, 2); |
168 | 165 | ||
169 | hangupresp = new QLineEdit(this); | 166 | hangupresp = new QLineEdit(this); |
170 | label10 = new QLabel(i18n("Hangup response:"), this); | 167 | label10 = new QLabel(i18n("Hangup response:"), this); |
171 | ADJUSTEDIT(hangupresp); | 168 | ADJUSTEDIT(hangupresp); |
172 | l1->addWidget(label10, row, 1); | 169 | l1->addWidget(label10, row, 1); |
173 | l1->addWidget(hangupresp, row++, 2); | 170 | l1->addWidget(hangupresp, row++, 2); |
174 | 171 | ||
175 | answerstr = new QLineEdit(this); | 172 | answerstr = new QLineEdit(this); |
176 | label11 = new QLabel(i18n("Answer string:"), this); | 173 | label11 = new QLabel(i18n("Answer string:"), this); |
177 | ADJUSTEDIT(answerstr); | 174 | ADJUSTEDIT(answerstr); |
178 | l1->addWidget(label11, row, 1); | 175 | l1->addWidget(label11, row, 1); |
179 | l1->addWidget(answerstr, row++, 2); | 176 | l1->addWidget(answerstr, row++, 2); |
180 | 177 | ||
181 | ringresp = new QLineEdit(this); | 178 | ringresp = new QLineEdit(this); |
182 | label12 = new QLabel(i18n("Ring response:"), this); | 179 | label12 = new QLabel(i18n("Ring response:"), this); |
183 | ADJUSTEDIT(ringresp); | 180 | ADJUSTEDIT(ringresp); |
184 | l1->addWidget(label12, row, 1); | 181 | l1->addWidget(label12, row, 1); |
185 | l1->addWidget(ringresp, row++, 2); | 182 | l1->addWidget(ringresp, row++, 2); |
186 | 183 | ||
187 | answerresp = new QLineEdit(this); | 184 | answerresp = new QLineEdit(this); |
188 | label13 = new QLabel(i18n("Answer response:"), this); | 185 | label13 = new QLabel(i18n("Answer response:"), this); |
189 | ADJUSTEDIT(answerresp); | 186 | ADJUSTEDIT(answerresp); |
190 | l1->addWidget(label13, row, 1); | 187 | l1->addWidget(label13, row, 1); |
191 | l1->addWidget(answerresp, row++, 2); | 188 | l1->addWidget(answerresp, row++, 2); |
192 | 189 | ||
193 | escapestr = new QLineEdit(this); | 190 | escapestr = new QLineEdit(this); |
194 | label14 = new QLabel(i18n("Escape string:"), this); | 191 | label14 = new QLabel(i18n("Escape string:"), this); |
195 | ADJUSTEDIT(escapestr); | 192 | ADJUSTEDIT(escapestr); |
196 | l1->addWidget(label14, row, 1); | 193 | l1->addWidget(label14, row, 1); |
197 | l1->addWidget(escapestr, row++, 2); | 194 | l1->addWidget(escapestr, row++, 2); |
198 | 195 | ||
199 | escaperesp = new QLineEdit(this); | 196 | escaperesp = new QLineEdit(this); |
200 | label15 = new QLabel(i18n("Escape response:"), this); | 197 | label15 = new QLabel(i18n("Escape response:"), this); |
201 | ADJUSTEDIT(escaperesp); | 198 | ADJUSTEDIT(escaperesp); |
202 | l1->addWidget(label15, row, 1); | 199 | l1->addWidget(label15, row, 1); |
203 | l1->addWidget(escaperesp, row++, 2); | 200 | l1->addWidget(escaperesp, row++, 2); |
204 | 201 | ||
205 | QHBoxLayout *l5 = new QHBoxLayout; | 202 | QHBoxLayout *l5 = new QHBoxLayout; |
206 | l1->addLayout(l5, row, 2); | 203 | l1->addLayout(l5, row, 2); |
207 | lslider = new QLabel("MMMM", this); | 204 | lslider = new QLabel("MMMM", this); |
208 | FORMATSLIDERLABEL(lslider); | 205 | FORMATSLIDERLABEL(lslider); |
209 | 206 | ||
210 | QSlider *slider = new QSlider(0, 255, 1, 0, | 207 | QSlider *slider = new QSlider(0, 255, 1, 0, |
211 | QSlider::Horizontal, this); | 208 | QSlider::Horizontal, this); |
212 | // slider->setFixedHeight(slider->sizeHint().height()); | 209 | // slider->setFixedHeight(slider->sizeHint().height()); |
213 | connect(slider, SIGNAL(valueChanged(int)), | 210 | connect(slider, SIGNAL(valueChanged(int)), |
214 | lslider, SLOT(setNum(int))); | 211 | lslider, SLOT(setNum(int))); |
215 | l5->addWidget(lslider, 0); | 212 | l5->addWidget(lslider, 0); |
216 | l5->addWidget(slider, 1); | 213 | l5->addWidget(slider, 1); |
217 | 214 | ||
218 | label16 = new QLabel(i18n("Guard time (sec/50):"), this); | 215 | label16 = new QLabel(i18n("Guard time (sec/50):"), this); |
219 | l1->addWidget(label16, row++, 1); | 216 | l1->addWidget(label16, row++, 1); |
220 | 217 | ||
221 | QLabel *l = new QLabel(i18n("Volume off/low/high:"), this); | 218 | QLabel *l = new QLabel(i18n("Volume off/low/high:"), this); |
222 | l1->addWidget(l, row, 1); | 219 | l1->addWidget(l, row, 1); |
223 | QHBoxLayout *l6 = new QHBoxLayout; | 220 | QHBoxLayout *l6 = new QHBoxLayout; |
224 | l1->addLayout(l6, row++, 2); | 221 | l1->addLayout(l6, row++, 2); |
225 | volume_off = new QLineEdit(this); | 222 | volume_off = new QLineEdit(this); |
226 | // volume_off->setFixedHeight(volume_off->sizeHint().height()); | 223 | // volume_off->setFixedHeight(volume_off->sizeHint().height()); |
227 | // volume_off->setMinimumWidth((int)(volume_off->sizeHint().width() / 2)); | 224 | // volume_off->setMinimumWidth((int)(volume_off->sizeHint().width() / 2)); |
228 | volume_medium = new QLineEdit(this); | 225 | volume_medium = new QLineEdit(this); |
229 | // volume_medium->setFixedHeight(volume_medium->sizeHint().height()); | 226 | // volume_medium->setFixedHeight(volume_medium->sizeHint().height()); |
230 | // volume_medium->setMinimumWidth((int)(volume_medium->sizeHint().width() / 2)); | 227 | // volume_medium->setMinimumWidth((int)(volume_medium->sizeHint().width() / 2)); |
231 | volume_high = new QLineEdit(this); | 228 | volume_high = new QLineEdit(this); |
232 | // volume_high->setFixedHeight(volume_high->sizeHint().height()); | 229 | // volume_high->setFixedHeight(volume_high->sizeHint().height()); |
233 | // volume_high->setMinimumWidth((int)(volume_high->sizeHint().width() / 2)); | 230 | // volume_high->setMinimumWidth((int)(volume_high->sizeHint().width() / 2)); |
234 | l6->addWidget(volume_off); | 231 | l6->addWidget(volume_off); |
235 | l6->addWidget(volume_medium); | 232 | l6->addWidget(volume_medium); |
236 | l6->addWidget(volume_high); | 233 | l6->addWidget(volume_high); |
237 | 234 | ||
238 | initstr[0]->setFocus(); | 235 | initstr[0]->setFocus(); |
239 | 236 | ||
240 | l1->addColSpacing(0, 10); | 237 | l1->addColSpacing(0, 10); |
241 | l1->addColSpacing(3, 10); | 238 | l1->addColSpacing(3, 10); |
242 | l1->addRowSpacing(0, 5); | 239 | l1->addRowSpacing(0, 5); |
243 | l1->addRowSpacing(GRIDROWS, 5); | 240 | l1->addRowSpacing(GRIDROWS, 5); |
244 | 241 | ||
245 | //set stuff from gpppdata | 242 | //set stuff from gpppdata |
246 | preinitslider->setValue(gpppdata.modemPreInitDelay()); | 243 | preinitslider->setValue(PPPData::data()->modemPreInitDelay()); |
247 | lpreinitslider->setNum(gpppdata.modemPreInitDelay()); | 244 | lpreinitslider->setNum(PPPData::data()->modemPreInitDelay()); |
248 | for(int i = 0; i < PPPData::NumInitStrings; i++) | 245 | for(int i = 0; i < PPPData::NumInitStrings; i++) |
249 | initstr[i]->setText(gpppdata.modemInitStr(i)); | 246 | initstr[i]->setText(PPPData::data()->modemInitStr(i)); |
250 | initslider->setValue(gpppdata.modemInitDelay()); | 247 | initslider->setValue(PPPData::data()->modemInitDelay()); |
251 | linitslider->setNum(gpppdata.modemInitDelay()); | 248 | linitslider->setNum(PPPData::data()->modemInitDelay()); |
252 | initresp->setText(gpppdata.modemInitResp()); | 249 | initresp->setText(PPPData::data()->modemInitResp()); |
253 | 250 | ||
254 | durationslider->setValue(gpppdata.modemToneDuration()); | 251 | durationslider->setValue(PPPData::data()->modemToneDuration()); |
255 | ldurationslider->setNum(gpppdata.modemToneDuration()); | 252 | ldurationslider->setNum(PPPData::data()->modemToneDuration()); |
256 | 253 | ||
257 | nodetectdialtone->setText(gpppdata.modemNoDialToneDetectionStr()); | 254 | nodetectdialtone->setText(PPPData::data()->modemNoDialToneDetectionStr()); |
258 | dialstr->setText(gpppdata.modemDialStr()); | 255 | dialstr->setText(PPPData::data()->modemDialStr()); |
259 | connectresp->setText(gpppdata.modemConnectResp()); | 256 | connectresp->setText(PPPData::data()->modemConnectResp()); |
260 | busyresp->setText(gpppdata.modemBusyResp()); | 257 | busyresp->setText(PPPData::data()->modemBusyResp()); |
261 | nocarrierresp->setText(gpppdata.modemNoCarrierResp()); | 258 | nocarrierresp->setText(PPPData::data()->modemNoCarrierResp()); |
262 | nodialtoneresp->setText(gpppdata.modemNoDialtoneResp()); | 259 | nodialtoneresp->setText(PPPData::data()->modemNoDialtoneResp()); |
263 | 260 | ||
264 | escapestr->setText(gpppdata.modemEscapeStr()); | 261 | escapestr->setText(PPPData::data()->modemEscapeStr()); |
265 | escaperesp->setText(gpppdata.modemEscapeResp()); | 262 | escaperesp->setText(PPPData::data()->modemEscapeResp()); |
266 | 263 | ||
267 | hangupstr->setText(gpppdata.modemHangupStr()); | 264 | hangupstr->setText(PPPData::data()->modemHangupStr()); |
268 | hangupresp->setText(gpppdata.modemHangupResp()); | 265 | hangupresp->setText(PPPData::data()->modemHangupResp()); |
269 | 266 | ||
270 | answerstr->setText(gpppdata.modemAnswerStr()); | 267 | answerstr->setText(PPPData::data()->modemAnswerStr()); |
271 | ringresp->setText(gpppdata.modemRingResp()); | 268 | ringresp->setText(PPPData::data()->modemRingResp()); |
272 | answerresp->setText(gpppdata.modemAnswerResp()); | 269 | answerresp->setText(PPPData::data()->modemAnswerResp()); |
273 | 270 | ||
274 | slider->setValue(gpppdata.modemEscapeGuardTime()); | 271 | slider->setValue(PPPData::data()->modemEscapeGuardTime()); |
275 | lslider->setNum(gpppdata.modemEscapeGuardTime()); | 272 | lslider->setNum(PPPData::data()->modemEscapeGuardTime()); |
276 | 273 | ||
277 | volume_off->setText(gpppdata.volumeOff()); | 274 | volume_off->setText(PPPData::data()->volumeOff()); |
278 | volume_medium->setText(gpppdata.volumeMedium()); | 275 | volume_medium->setText(PPPData::data()->volumeMedium()); |
279 | volume_high->setText(gpppdata.volumeHigh()); | 276 | volume_high->setText(PPPData::data()->volumeHigh()); |
280 | } | 277 | } |
281 | 278 | ||
282 | 279 | ||
283 | void ModemCommands::slotOk() { | 280 | void ModemCommands::slotOk() { |
284 | gpppdata.setModemPreInitDelay(lpreinitslider->text().toInt()); | 281 | PPPData::data()->setModemPreInitDelay(lpreinitslider->text().toInt()); |
285 | for(int i = 0; i < PPPData::NumInitStrings; i++) | 282 | for(int i = 0; i < PPPData::NumInitStrings; i++) |
286 | gpppdata.setModemInitStr(i, initstr[i]->text()); | 283 | PPPData::data()->setModemInitStr(i, initstr[i]->text()); |
287 | gpppdata.setModemInitResp(initresp->text()); | 284 | PPPData::data()->setModemInitResp(initresp->text()); |
288 | gpppdata.setModemInitDelay(linitslider->text().toInt()); | 285 | PPPData::data()->setModemInitDelay(linitslider->text().toInt()); |
289 | 286 | ||
290 | gpppdata.setModemToneDuration(ldurationslider->text().toInt()); | 287 | PPPData::data()->setModemToneDuration(ldurationslider->text().toInt()); |
291 | gpppdata.setModemNoDialToneDetectionStr(nodetectdialtone->text()); | 288 | PPPData::data()->setModemNoDialToneDetectionStr(nodetectdialtone->text()); |
292 | gpppdata.setModemDialStr(dialstr->text()); | 289 | PPPData::data()->setModemDialStr(dialstr->text()); |
293 | gpppdata.setModemConnectResp(connectresp->text()); | 290 | PPPData::data()->setModemConnectResp(connectresp->text()); |
294 | gpppdata.setModemBusyResp(busyresp->text()); | 291 | PPPData::data()->setModemBusyResp(busyresp->text()); |
295 | gpppdata.setModemNoCarrierResp(nocarrierresp->text()); | 292 | PPPData::data()->setModemNoCarrierResp(nocarrierresp->text()); |
296 | gpppdata.setModemNoDialtoneResp(nodialtoneresp->text()); | 293 | PPPData::data()->setModemNoDialtoneResp(nodialtoneresp->text()); |
297 | 294 | ||
298 | gpppdata.setModemEscapeStr(escapestr->text()); | 295 | PPPData::data()->setModemEscapeStr(escapestr->text()); |
299 | gpppdata.setModemEscapeResp(escaperesp->text()); | 296 | PPPData::data()->setModemEscapeResp(escaperesp->text()); |
300 | gpppdata.setModemEscapeGuardTime(lslider->text().toInt()); | 297 | PPPData::data()->setModemEscapeGuardTime(lslider->text().toInt()); |
301 | gpppdata.setModemHangupStr(hangupstr->text()); | 298 | PPPData::data()->setModemHangupStr(hangupstr->text()); |
302 | gpppdata.setModemHangupResp(hangupresp->text()); | 299 | PPPData::data()->setModemHangupResp(hangupresp->text()); |
303 | 300 | ||
304 | gpppdata.setModemAnswerStr(answerstr->text()); | 301 | PPPData::data()->setModemAnswerStr(answerstr->text()); |
305 | gpppdata.setModemRingResp(ringresp->text()); | 302 | PPPData::data()->setModemRingResp(ringresp->text()); |
306 | gpppdata.setModemAnswerResp(answerresp->text()); | 303 | PPPData::data()->setModemAnswerResp(answerresp->text()); |
307 | 304 | ||
308 | gpppdata.setVolumeHigh(volume_high->text()); | 305 | PPPData::data()->setVolumeHigh(volume_high->text()); |
309 | gpppdata.setVolumeMedium(volume_medium->text()); | 306 | PPPData::data()->setVolumeMedium(volume_medium->text()); |
310 | gpppdata.setVolumeOff(volume_off->text()); | 307 | PPPData::data()->setVolumeOff(volume_off->text()); |
311 | 308 | ||
312 | gpppdata.save(); | 309 | PPPData::data()->save(); |
313 | accept(); | 310 | accept(); |
314 | } | 311 | } |
315 | 312 | ||
316 | 313 | ||
317 | void ModemCommands::slotCancel() { | 314 | void ModemCommands::slotCancel() { |
318 | reject(); | 315 | reject(); |
319 | } | 316 | } |
320 | 317 | ||
321 | //#include "modemcmds.moc" | 318 | //#include "modemcmds.moc" |
diff --git a/noncore/settings/networksettings/ppp/newwidget.cpp b/noncore/settings/networksettings/ppp/newwidget.cpp deleted file mode 100644 index d2182fb..0000000 --- a/noncore/settings/networksettings/ppp/newwidget.cpp +++ b/dev/null | |||
@@ -1,17 +0,0 @@ | |||
1 | ///////////////////////////////////////////////////////////////////////////// | ||
2 | // | ||
3 | // functions generating layout-aware widgets | ||
4 | // | ||
5 | ///////////////////////////////////////////////////////////////////////////// | ||
6 | |||
7 | #include "newwidget.h" | ||
8 | |||
9 | QLineEdit *newLineEdit(int visiblewidth, QWidget *parent) { | ||
10 | QLineEdit *l = new QLineEdit(parent); | ||
11 | if(visiblewidth == 0) | ||
12 | l->setMinimumWidth(l->sizeHint().width()); | ||
13 | else | ||
14 | l->setFixedWidth(l->fontMetrics().width('H') * visiblewidth); | ||
15 | |||
16 | return l; | ||
17 | } | ||
diff --git a/noncore/settings/networksettings/ppp/newwidget.h b/noncore/settings/networksettings/ppp/newwidget.h deleted file mode 100644 index 52f2ec7..0000000 --- a/noncore/settings/networksettings/ppp/newwidget.h +++ b/dev/null | |||
@@ -1,19 +0,0 @@ | |||
1 | ///////////////////////////////////////////////////////////////////////////// | ||
2 | // | ||
3 | // functions generating layout-aware widgets | ||
4 | // | ||
5 | ///////////////////////////////////////////////////////////////////////////// | ||
6 | |||
7 | #ifndef __NEWWIDGET__H__ | ||
8 | #define __NEWWIDGET__H__ | ||
9 | |||
10 | #include <qwidget.h> | ||
11 | #include <qlineedit.h> | ||
12 | |||
13 | #define L_FIXEDW 1 | ||
14 | #define L_FIXEDH 2 | ||
15 | #define L_FIXED (L_FIXEDW | L_FIXEDH) | ||
16 | |||
17 | QLineEdit *newLineEdit(int visiblewidth, QWidget *parent); | ||
18 | |||
19 | #endif | ||
diff --git a/noncore/settings/networksettings/ppp/ppp.pro b/noncore/settings/networksettings/ppp/ppp.pro index a456427..ebfc713 100644 --- a/noncore/settings/networksettings/ppp/ppp.pro +++ b/noncore/settings/networksettings/ppp/ppp.pro | |||
@@ -1,18 +1,18 @@ | |||
1 | #TEMPLATE = app | 1 | #TEMPLATE = app |
2 | # | 2 | # |
3 | TEMPLATE = lib | 3 | TEMPLATE = lib |
4 | #CONFIG += qt warn_on release | 4 | #CONFIG += qt warn_on release |
5 | CONFIG += qt warn_on debug | 5 | CONFIG += qt warn_on debug |
6 | DESTDIR = $(OPIEDIR)/plugins/networksettings | 6 | DESTDIR = $(OPIEDIR)/plugins/networksettings |
7 | HEADERS = pppmodule.h devices.h modem.h modeminfo.h pppdata.h kpppconfig.h pppdata.h runtests.h general.h modemcmds.h knuminput.h knumvalidator.h kpppwidget.h conwindow.h debug.h accounts.h connect.h edit.h scriptedit.h pppdargs.h newwidget.h iplined.h pwentry.h pppconfig.h | 7 | HEADERS = pppmodule.h devices.h modem.h modeminfo.h pppdata.h kpppconfig.h pppdata.h runtests.h general.h modemcmds.h knuminput.h knumvalidator.h kpppwidget.h conwindow.h debug.h accounts.h connect.h edit.h scriptedit.h pppdargs.h iplined.h pwentry.h pppconfig.h |
8 | SOURCES = pppmodule.cpp modem.cpp modeminfo.cpp pppdata.cpp runtests.cpp general.cpp modemcmds.cpp knuminput.cpp knumvalidator.cpp kpppwidget.cpp conwindow.cpp debug.cpp accounts.cpp connect.cpp edit.cpp scriptedit.cpp pppdargs.cpp newwidget.cpp iplined.cpp pwentry.cpp pppconfig.cpp | 8 | SOURCES = pppmodule.cpp modem.cpp modeminfo.cpp pppdata.cpp runtests.cpp general.cpp modemcmds.cpp knuminput.cpp knumvalidator.cpp kpppwidget.cpp conwindow.cpp debug.cpp accounts.cpp connect.cpp edit.cpp scriptedit.cpp pppdargs.cpp iplined.cpp pwentry.cpp pppconfig.cpp |
9 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ | 9 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ |
10 | DEPENDPATH+= $(OPIEDIR)/include | 10 | DEPENDPATH+= $(OPIEDIR)/include |
11 | LIBS += -lqpe -L../interfaces/ -linterfaces | 11 | LIBS += -lqpe -L../interfaces/ -linterfaces |
12 | INTERFACES= | 12 | INTERFACES= |
13 | TARGET = pppplugin | 13 | TARGET = pppplugin |
14 | VERSION = 1.0.0 | 14 | VERSION = 1.0.0 |
15 | 15 | ||
16 | 16 | ||
17 | 17 | ||
18 | include ( $(OPIEDIR)/include.pro ) | 18 | include ( $(OPIEDIR)/include.pro ) |
diff --git a/noncore/settings/networksettings/ppp/pppconfig.cpp b/noncore/settings/networksettings/ppp/pppconfig.cpp index 7b2b21b..c0f1fef 100644 --- a/noncore/settings/networksettings/ppp/pppconfig.cpp +++ b/noncore/settings/networksettings/ppp/pppconfig.cpp | |||
@@ -1,62 +1,62 @@ | |||
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 "pppconfig.h" | 8 | #include "pppconfig.h" |
9 | #include "pppdata.h" | 9 | #include "pppdata.h" |
10 | #include "runtests.h" | 10 | #include "runtests.h" |
11 | #include "modem.h" | 11 | #include "modem.h" |
12 | 12 | ||
13 | PPPConfigWidget::PPPConfigWidget( QWidget *parent, const char *name, | 13 | PPPConfigWidget::PPPConfigWidget( QWidget *parent, const char *name, |
14 | bool modal, WFlags fl ) | 14 | bool modal, WFlags fl ) |
15 | : QDialog(parent, name, modal, fl) | 15 | : QDialog(parent, name, modal, fl) |
16 | { | 16 | { |
17 | setCaption(tr("Configure Modem")); | 17 | setCaption(tr("Configure Modem")); |
18 | int result = runTests(); | 18 | int result = runTests(); |
19 | if(result == TEST_CRITICAL){ | 19 | if(result == TEST_CRITICAL){ |
20 | QMessageBox::critical(0, tr("Modem failure"), tr("A critical failure appeard while testing the modem") ); | 20 | QMessageBox::critical(0, tr("Modem failure"), tr("A critical failure appeard while testing the modem") ); |
21 | return; | 21 | return; |
22 | } | 22 | } |
23 | 23 | ||
24 | // setFixedSize(sizeHint()); | 24 | // setFixedSize(sizeHint()); |
25 | 25 | ||
26 | (void)new Modem; | 26 | (void)new Modem; |
27 | 27 | ||
28 | QVBoxLayout *layout = new QVBoxLayout( this ); | 28 | QVBoxLayout *layout = new QVBoxLayout( this ); |
29 | layout->setSpacing( 0 ); | 29 | layout->setSpacing( 0 ); |
30 | layout->setMargin( 1 ); | 30 | layout->setMargin( 1 ); |
31 | tabWindow = new QTabWidget( this, "tabWidget" ); | 31 | tabWindow = new QTabWidget( this, "tabWidget" ); |
32 | layout->addWidget( tabWindow ); | 32 | layout->addWidget( tabWindow ); |
33 | 33 | ||
34 | accounts = new AccountWidget( tabWindow, "accounts" ); | 34 | accounts = new AccountWidget( tabWindow, "accounts" ); |
35 | tabWindow->addTab( accounts, tr("&Accounts") ); | 35 | tabWindow->addTab( accounts, tr("&Accounts") ); |
36 | modem1 = new ModemWidget( tabWindow, "modem1" ); | 36 | modem1 = new ModemWidget( tabWindow, "modem1" ); |
37 | tabWindow->addTab( modem1, tr("&Device") ); | 37 | tabWindow->addTab( modem1, tr("&Device") ); |
38 | modem2 = new ModemWidget2( tabWindow, "modem2" ); | 38 | modem2 = new ModemWidget2( tabWindow, "modem2" ); |
39 | tabWindow->addTab( modem2, tr("&Modem") ); | 39 | tabWindow->addTab( modem2, tr("&Modem") ); |
40 | // graph = new GraphSetup( tabWindow->addPage( tr("&Graph"), tr("Throughput Graph" ) ) ); | 40 | // graph = new GraphSetup( tabWindow->addPage( tr("&Graph"), tr("Throughput Graph" ) ) ); |
41 | // general = new GeneralWidget( tabWindow->addPage( tr("M&isc"), tr("Miscellaneous Settings") ) ); | 41 | // general = new GeneralWidget( tabWindow->addPage( tr("M&isc"), tr("Miscellaneous Settings") ) ); |
42 | 42 | ||
43 | } | 43 | } |
44 | 44 | ||
45 | 45 | ||
46 | PPPConfigWidget::~PPPConfigWidget() | 46 | PPPConfigWidget::~PPPConfigWidget() |
47 | { | 47 | { |
48 | 48 | ||
49 | } | 49 | } |
50 | 50 | ||
51 | void PPPConfigWidget::accept() | 51 | void PPPConfigWidget::accept() |
52 | { | 52 | { |
53 | gpppdata.save(); | 53 | PPPData::data()->save(); |
54 | QDialog::accept(); | 54 | QDialog::accept(); |
55 | } | 55 | } |
56 | 56 | ||
57 | 57 | ||
58 | void PPPConfigWidget::reject() | 58 | void PPPConfigWidget::reject() |
59 | { | 59 | { |
60 | gpppdata.cancel(); | 60 | PPPData::data()->cancel(); |
61 | QDialog::reject(); | 61 | QDialog::reject(); |
62 | } | 62 | } |
diff --git a/noncore/settings/networksettings/ppp/pppdargs.cpp b/noncore/settings/networksettings/ppp/pppdargs.cpp index 04d0dd0..b7fca3f 100644 --- a/noncore/settings/networksettings/ppp/pppdargs.cpp +++ b/noncore/settings/networksettings/ppp/pppdargs.cpp | |||
@@ -1,166 +1,166 @@ | |||
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 | * | 12 | * |
13 | * This library is free software; you can redistribute it and/or | 13 | * This library 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 library is distributed in the hope that it will be useful, | 18 | * This library 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 | #include <qlayout.h> | 28 | #include <qlayout.h> |
29 | #include <qbuttongroup.h> | 29 | #include <qbuttongroup.h> |
30 | //#include <kwin.h> | 30 | //#include <kwin.h> |
31 | #include <qapplication.h> | 31 | #include <qapplication.h> |
32 | #include "pppdargs.h" | 32 | #include "pppdargs.h" |
33 | #include "pppdata.h" | 33 | #include "pppdata.h" |
34 | //#include <klocale.h> | 34 | //#include <klocale.h> |
35 | #define i18n QObject::tr | 35 | #define i18n QObject::tr |
36 | 36 | ||
37 | PPPdArguments::PPPdArguments(QWidget *parent, const char *name) | 37 | PPPdArguments::PPPdArguments(QWidget *parent, const char *name) |
38 | : QDialog(parent, name, TRUE) | 38 | : QDialog(parent, name, TRUE) |
39 | { | 39 | { |
40 | setCaption(i18n("Customize pppd Arguments")); | 40 | setCaption(i18n("Customize pppd Arguments")); |
41 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); | 41 | // KWin::setIcons(winId(), kapp->icon(), kapp->miniIcon()); |
42 | QVBoxLayout *l = new QVBoxLayout(this, 10, 10); | 42 | QVBoxLayout *l = new QVBoxLayout(this, 10, 10); |
43 | QHBoxLayout *tl = new QHBoxLayout(10); | 43 | QHBoxLayout *tl = new QHBoxLayout(10); |
44 | l->addLayout(tl); | 44 | l->addLayout(tl); |
45 | QVBoxLayout *l1 = new QVBoxLayout(); | 45 | QVBoxLayout *l1 = new QVBoxLayout(); |
46 | QVBoxLayout *l2 = new QVBoxLayout(); | 46 | QVBoxLayout *l2 = new QVBoxLayout(); |
47 | tl->addLayout(l1, 1); | 47 | tl->addLayout(l1, 1); |
48 | tl->addLayout(l2, 0); | 48 | tl->addLayout(l2, 0); |
49 | 49 | ||
50 | QHBoxLayout *l11 = new QHBoxLayout(10); | 50 | QHBoxLayout *l11 = new QHBoxLayout(10); |
51 | l1->addLayout(l11); | 51 | l1->addLayout(l11); |
52 | 52 | ||
53 | argument_label = new QLabel(i18n("Argument:"), this); | 53 | argument_label = new QLabel(i18n("Argument:"), this); |
54 | l11->addWidget(argument_label); | 54 | l11->addWidget(argument_label); |
55 | 55 | ||
56 | argument = new QLineEdit(this); | 56 | argument = new QLineEdit(this); |
57 | connect(argument, SIGNAL(returnPressed()), | 57 | connect(argument, SIGNAL(returnPressed()), |
58 | SLOT(addbutton())); | 58 | SLOT(addbutton())); |
59 | l11->addWidget(argument); | 59 | l11->addWidget(argument); |
60 | connect(argument, SIGNAL(textChanged(const QString &)), | 60 | connect(argument, SIGNAL(textChanged(const QString &)), |
61 | this, SLOT(textChanged(const QString &))); | 61 | this, SLOT(textChanged(const QString &))); |
62 | 62 | ||
63 | arguments = new QListBox(this); | 63 | arguments = new QListBox(this); |
64 | arguments->setMinimumSize(1, fontMetrics().lineSpacing()*10); | 64 | arguments->setMinimumSize(1, fontMetrics().lineSpacing()*10); |
65 | connect(arguments, SIGNAL(highlighted(int)), | 65 | connect(arguments, SIGNAL(highlighted(int)), |
66 | this, SLOT(itemSelected(int))); | 66 | this, SLOT(itemSelected(int))); |
67 | l1->addWidget(arguments, 1); | 67 | l1->addWidget(arguments, 1); |
68 | 68 | ||
69 | add = new QPushButton(i18n("Add"), this); | 69 | add = new QPushButton(i18n("Add"), this); |
70 | connect(add, SIGNAL(clicked()), SLOT(addbutton())); | 70 | connect(add, SIGNAL(clicked()), SLOT(addbutton())); |
71 | l2->addWidget(add); | 71 | l2->addWidget(add); |
72 | l2->addStretch(1); | 72 | l2->addStretch(1); |
73 | 73 | ||
74 | remove = new QPushButton(i18n("Remove"), this); | 74 | remove = new QPushButton(i18n("Remove"), this); |
75 | connect(remove, SIGNAL(clicked()), SLOT(removebutton())); | 75 | connect(remove, SIGNAL(clicked()), SLOT(removebutton())); |
76 | l2->addWidget(remove); | 76 | l2->addWidget(remove); |
77 | 77 | ||
78 | defaults = new QPushButton(i18n("Defaults"), this); | 78 | defaults = new QPushButton(i18n("Defaults"), this); |
79 | connect(defaults, SIGNAL(clicked()), SLOT(defaultsbutton())); | 79 | connect(defaults, SIGNAL(clicked()), SLOT(defaultsbutton())); |
80 | l2->addWidget(defaults); | 80 | l2->addWidget(defaults); |
81 | 81 | ||
82 | l->addSpacing(5); | 82 | l->addSpacing(5); |
83 | 83 | ||
84 | QButtonGroup *bbox = new QButtonGroup(this); | 84 | QButtonGroup *bbox = new QButtonGroup(this); |
85 | // bbox->addStretch(1); | 85 | // bbox->addStretch(1); |
86 | closebtn = new QPushButton( bbox, i18n("OK")); | 86 | closebtn = new QPushButton( bbox, i18n("OK")); |
87 | bbox->insert(closebtn); | 87 | bbox->insert(closebtn); |
88 | connect(closebtn, SIGNAL(clicked()), SLOT(closebutton())); | 88 | connect(closebtn, SIGNAL(clicked()), SLOT(closebutton())); |
89 | QPushButton *cancel = new QPushButton( bbox, i18n("Cancel")); | 89 | QPushButton *cancel = new QPushButton( bbox, i18n("Cancel")); |
90 | bbox->insert(cancel); | 90 | bbox->insert(cancel); |
91 | connect(cancel, SIGNAL(clicked()), | 91 | connect(cancel, SIGNAL(clicked()), |
92 | this, SLOT(reject())); | 92 | this, SLOT(reject())); |
93 | bbox->layout(); | 93 | bbox->layout(); |
94 | l->addWidget(bbox); | 94 | l->addWidget(bbox); |
95 | 95 | ||
96 | setFixedSize(sizeHint()); | 96 | setFixedSize(sizeHint()); |
97 | 97 | ||
98 | //load info from gpppdata | 98 | //load info from gpppdata |
99 | init(); | 99 | init(); |
100 | 100 | ||
101 | add->setEnabled(false); | 101 | add->setEnabled(false); |
102 | remove->setEnabled(false); | 102 | remove->setEnabled(false); |
103 | argument->setFocus(); | 103 | argument->setFocus(); |
104 | } | 104 | } |
105 | 105 | ||
106 | 106 | ||
107 | void PPPdArguments::addbutton() { | 107 | void PPPdArguments::addbutton() { |
108 | if(!argument->text().isEmpty() && arguments->count() < MAX_PPPD_ARGUMENTS) { | 108 | if(!argument->text().isEmpty() && arguments->count() < MAX_PPPD_ARGUMENTS) { |
109 | arguments->insertItem(argument->text()); | 109 | arguments->insertItem(argument->text()); |
110 | argument->setText(""); | 110 | argument->setText(""); |
111 | } | 111 | } |
112 | } | 112 | } |
113 | 113 | ||
114 | 114 | ||
115 | void PPPdArguments::removebutton() { | 115 | void PPPdArguments::removebutton() { |
116 | if(arguments->currentItem() >= 0) | 116 | if(arguments->currentItem() >= 0) |
117 | arguments->removeItem(arguments->currentItem()); | 117 | arguments->removeItem(arguments->currentItem()); |
118 | } | 118 | } |
119 | 119 | ||
120 | 120 | ||
121 | void PPPdArguments::defaultsbutton() { | 121 | void PPPdArguments::defaultsbutton() { |
122 | // all of this is a hack | 122 | // all of this is a hack |
123 | // save current list | 123 | // save current list |
124 | QStringList arglist(gpppdata.pppdArgument()); | 124 | QStringList arglist(PPPData::data()->pppdArgument()); |
125 | 125 | ||
126 | // get defaults | 126 | // get defaults |
127 | gpppdata.setpppdArgumentDefaults(); | 127 | PPPData::data()->setpppdArgumentDefaults(); |
128 | init(); | 128 | init(); |
129 | 129 | ||
130 | // restore old list | 130 | // restore old list |
131 | gpppdata.setpppdArgument(arglist); | 131 | PPPData::data()->setpppdArgument(arglist); |
132 | } | 132 | } |
133 | 133 | ||
134 | 134 | ||
135 | void PPPdArguments::closebutton() { | 135 | void PPPdArguments::closebutton() { |
136 | QStringList arglist; | 136 | QStringList arglist; |
137 | for(uint i=0; i < arguments->count(); i++) | 137 | for(uint i=0; i < arguments->count(); i++) |
138 | arglist.append(arguments->text(i)); | 138 | arglist.append(arguments->text(i)); |
139 | gpppdata.setpppdArgument(arglist); | 139 | PPPData::data()->setpppdArgument(arglist); |
140 | 140 | ||
141 | done(0); | 141 | done(0); |
142 | } | 142 | } |
143 | 143 | ||
144 | 144 | ||
145 | void PPPdArguments::init() { | 145 | void PPPdArguments::init() { |
146 | while(arguments->count()) | 146 | while(arguments->count()) |
147 | arguments->removeItem(0); | 147 | arguments->removeItem(0); |
148 | 148 | ||
149 | QStringList &arglist = gpppdata.pppdArgument(); | 149 | QStringList &arglist = PPPData::data()->pppdArgument(); |
150 | for ( QStringList::Iterator it = arglist.begin(); | 150 | for ( QStringList::Iterator it = arglist.begin(); |
151 | it != arglist.end(); | 151 | it != arglist.end(); |
152 | ++it ) | 152 | ++it ) |
153 | arguments->insertItem(*it); | 153 | arguments->insertItem(*it); |
154 | } | 154 | } |
155 | 155 | ||
156 | 156 | ||
157 | void PPPdArguments::textChanged(const QString &s) { | 157 | void PPPdArguments::textChanged(const QString &s) { |
158 | add->setEnabled(s.length() > 0); | 158 | add->setEnabled(s.length() > 0); |
159 | } | 159 | } |
160 | 160 | ||
161 | 161 | ||
162 | void PPPdArguments::itemSelected(int idx) { | 162 | void PPPdArguments::itemSelected(int idx) { |
163 | remove->setEnabled(idx != -1); | 163 | remove->setEnabled(idx != -1); |
164 | } | 164 | } |
165 | 165 | ||
166 | 166 | ||
diff --git a/noncore/settings/networksettings/ppp/pppdata.cpp b/noncore/settings/networksettings/ppp/pppdata.cpp index f2386fc..646facd 100644 --- a/noncore/settings/networksettings/ppp/pppdata.cpp +++ b/noncore/settings/networksettings/ppp/pppdata.cpp | |||
@@ -1,328 +1,332 @@ | |||
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 gpppdata; | 41 | PPPData *PPPData::_data = 0; |
42 | Config *PPPData::config = 0; | ||
42 | 43 | ||
44 | PPPData* PPPData::data() | ||
45 | { | ||
46 | if (!_data){ | ||
47 | qDebug("PPPData::data() creates new Instance"); | ||
48 | _data = new PPPData(); | ||
49 | } | ||
50 | if (!_data->config){ | ||
51 | qDebug("PPPData::data() opens conffile"); | ||
52 | _data->open(); | ||
53 | } | ||
54 | return _data; | ||
55 | } | ||
43 | 56 | ||
44 | PPPData::PPPData() | 57 | PPPData::PPPData() |
45 | : config(0L), | 58 | : //config(0L), |
46 | highcount(-1), // start out with no entries | 59 | highcount(-1), // start out with no entries |
47 | caccount(-1), // set the current account index also | 60 | caccount(-1), // set the current account index also |
48 | suidprocessid(-1), // process ID of setuid child | 61 | suidprocessid(-1), // process ID of setuid child |
49 | pppdisrunning(false), | 62 | pppdisrunning(false), |
50 | pppderror(0) | 63 | pppderror(0) |
51 | { | 64 | { |
52 | } | 65 | } |
53 | 66 | ||
54 | 67 | ||
55 | // | 68 | // |
56 | // open configuration file | 69 | // open configuration file |
57 | // | 70 | // |
58 | bool PPPData::open() { | 71 | bool PPPData::open() { |
59 | 72 | qDebug("opening configfile NetworkSetupPPP"); | |
60 | config = new Config("NetworkSetup"); | 73 | if (config) return true; |
61 | /* | 74 | config = new Config("NetworkSetupPPP"); |
62 | config = kapp->config(); | ||
63 | |||
64 | if (config->getConfigState() == KConfig::NoAccess) { | ||
65 | KMessageBox::error(0L, | ||
66 | i18n("The application-specific config file could not " | ||
67 | "be opened in either read-write or read-only mode.\n" | ||
68 | "The superuser might have to change its ownership " | ||
69 | "by issuing the following command in your home directory:\n" | ||
70 | "chown {YourUsername} .kde/share/config/kppprc"), | ||
71 | kapp->name()); | ||
72 | return false; | ||
73 | } | ||
74 | |||
75 | // don't expand shell variables | ||
76 | config->setDollarExpansion(false); | ||
77 | */ | ||
78 | 75 | ||
79 | highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1; | 76 | highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1; |
80 | 77 | ||
81 | if (highcount > MAX_ACCOUNTS) | 78 | if (highcount > MAX_ACCOUNTS) |
82 | highcount = MAX_ACCOUNTS; | 79 | highcount = MAX_ACCOUNTS; |
83 | 80 | ||
84 | if(highcount >= 0 && defaultAccount().isEmpty()) { | 81 | if(highcount >= 0 && defaultAccount().isEmpty()) { |
85 | setAccountbyIndex(0); | 82 | setAccountbyIndex(0); |
86 | setDefaultAccount(accname()); | 83 | setDefaultAccount(accname()); |
87 | } else if(!setAccount(defaultAccount())) | 84 | } else if(!setAccount(defaultAccount())) |
88 | setDefaultAccount(accname()); | 85 | setDefaultAccount(accname()); |
89 | 86 | ||
90 | // start out with internal debugging disabled | 87 | // start out with internal debugging disabled |
91 | // the user is still free to specify `debug' on his own | 88 | // the user is still free to specify `debug' on his own |
92 | setPPPDebug(false); | 89 | setPPPDebug(false); |
93 | 90 | ||
94 | ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch); | 91 | ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch); |
95 | 92 | ||
96 | return true; | 93 | return true; |
97 | } | 94 | } |
98 | 95 | ||
99 | 96 | ||
100 | // | 97 | // |
101 | // save configuration | 98 | // save configuration |
102 | // | 99 | // |
103 | void PPPData::save() { | 100 | void PPPData::save() { |
104 | 101 | ||
105 | if (config) { | 102 | if (config) { |
106 | writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count()); | 103 | writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count()); |
107 | // config->sync(); | 104 | delete config; |
105 | config = 0; | ||
106 | qDebug("worte confi NetworkSetupPPP"); | ||
107 | } | ||
108 | if (_data){ | ||
109 | delete _data; | ||
110 | _data = 0; | ||
108 | } | 111 | } |
109 | 112 | ||
110 | } | 113 | } |
111 | 114 | ||
112 | 115 | ||
113 | // | 116 | // |
114 | // cancel changes | 117 | // cancel changes |
115 | // | 118 | // |
116 | void PPPData::cancel() { | 119 | void PPPData::cancel() { |
117 | 120 | ||
118 | // if (config) { | 121 | // if (config) { |
119 | // config->rollback(); | 122 | // config->rollback(); |
120 | // config->reparseConfiguration(); | 123 | // config->reparseConfiguration(); |
121 | // } | 124 | // } |
122 | 125 | ||
123 | } | 126 | } |
124 | 127 | ||
125 | 128 | ||
126 | // currently differentiates between READWRITE and NONE only | 129 | // // currently differentiates between READWRITE and NONE only |
127 | int PPPData::access() const { | 130 | // int PPPData::access() const { |
128 | 131 | ||
129 | return 0;//config->getConfigState(); | 132 | // return 1;//config->getConfigState(); |
130 | } | 133 | // } |
131 | 134 | ||
132 | 135 | ||
133 | // functions to read/write date to configuration file | 136 | // functions to read/write date to configuration file |
134 | QString PPPData::readConfig(const QString &group, const QString &key, | 137 | QString PPPData::readConfig(const QString &group, const QString &key, |
135 | const QString &defvalue = "") | 138 | const QString &defvalue = "") |
136 | { | 139 | { |
140 | // qDebug("PPPData::readConfig key >%s< group >%s<",key.latin1(), group.latin1()); | ||
137 | if (config) { | 141 | if (config) { |
138 | config->setGroup(group); | 142 | config->setGroup(group); |
139 | return config->readEntry(key, defvalue); | 143 | return config->readEntry(key, defvalue); |
140 | } else | 144 | } else |
141 | return defvalue; | 145 | return defvalue; |
142 | } | 146 | } |
143 | 147 | ||
144 | 148 | ||
145 | int PPPData::readNumConfig(const QString &group, const QString &key, | 149 | int PPPData::readNumConfig(const QString &group, const QString &key, |
146 | int defvalue) { | 150 | int defvalue) { |
147 | if (config) { | 151 | if (config) { |
148 | config->setGroup(group); | 152 | config->setGroup(group); |
149 | return config->readNumEntry(key, defvalue); | 153 | return config->readNumEntry(key, defvalue); |
150 | } else | 154 | } else |
151 | return defvalue; | 155 | return defvalue; |
152 | 156 | ||
153 | } | 157 | } |
154 | 158 | ||
155 | 159 | ||
156 | bool PPPData::readListConfig(const QString &group, const QString &key, | 160 | bool PPPData::readListConfig(const QString &group, const QString &key, |
157 | QStringList &list, char sep) { | 161 | QStringList &list, char sep) { |
158 | list.clear(); | 162 | list.clear(); |
159 | if (config) { | 163 | if (config) { |
160 | config->setGroup(group); | 164 | config->setGroup(group); |
161 | list = config->readListEntry(key, sep); | 165 | list = config->readListEntry(key, sep); |
162 | return true; | 166 | return true; |
163 | } else | 167 | } else |
164 | return false; | 168 | return false; |
165 | } | 169 | } |
166 | 170 | ||
167 | 171 | ||
168 | void PPPData::writeConfig(const QString &group, const QString &key, | 172 | void PPPData::writeConfig(const QString &group, const QString &key, |
169 | const QString &value) { | 173 | const QString &value) { |
170 | if (config) { | 174 | if (config) { |
171 | config->setGroup(group); | 175 | config->setGroup(group); |
172 | config->writeEntry(key, value); | 176 | config->writeEntry(key, value); |
173 | } | 177 | } |
174 | } | 178 | } |
175 | 179 | ||
176 | 180 | ||
177 | void PPPData::writeConfig(const QString &group, const QString &key, int value) { | 181 | void PPPData::writeConfig(const QString &group, const QString &key, int value) { |
178 | if (config) { | 182 | if (config) { |
179 | config->setGroup(group); | 183 | config->setGroup(group); |
180 | config->writeEntry(key, value); | 184 | config->writeEntry(key, value); |
181 | } | 185 | } |
182 | } | 186 | } |
183 | 187 | ||
184 | 188 | ||
185 | void PPPData::writeListConfig(const QString &group, const QString &key, | 189 | void PPPData::writeListConfig(const QString &group, const QString &key, |
186 | QStringList &list, char sep) { | 190 | QStringList &list, char sep) { |
187 | if (config) { | 191 | if (config) { |
188 | config->setGroup(group); | 192 | config->setGroup(group); |
189 | config->writeEntry(key, list, sep); | 193 | config->writeEntry(key, list, sep); |
190 | } | 194 | } |
191 | } | 195 | } |
192 | 196 | ||
193 | 197 | ||
194 | // | 198 | // |
195 | // functions to set/return general information | 199 | // functions to set/return general information |
196 | // | 200 | // |
197 | QString PPPData::password() const { | 201 | QString PPPData::password() const { |
198 | return passwd; | 202 | return passwd; |
199 | } | 203 | } |
200 | 204 | ||
201 | 205 | ||
202 | void PPPData::setPassword(const QString &pw) { | 206 | void PPPData::setPassword(const QString &pw) { |
203 | passwd = pw; | 207 | passwd = pw; |
204 | } | 208 | } |
205 | 209 | ||
206 | 210 | ||
207 | const QString PPPData::defaultAccount() { | 211 | const QString PPPData::defaultAccount() { |
208 | return readConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY); | 212 | return readConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY); |
209 | } | 213 | } |
210 | 214 | ||
211 | 215 | ||
212 | void PPPData::setDefaultAccount(const QString &n) { | 216 | void PPPData::setDefaultAccount(const QString &n) { |
213 | writeConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY, n); | 217 | writeConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY, n); |
214 | 218 | ||
215 | //now set the current account index to the default account | 219 | //now set the current account index to the default account |
216 | setAccount(defaultAccount()); | 220 | setAccount(defaultAccount()); |
217 | } | 221 | } |
218 | 222 | ||
219 | 223 | ||
220 | bool PPPData::get_show_clock_on_caption() { | 224 | bool PPPData::get_show_clock_on_caption() { |
221 | return (bool) readNumConfig(GENERAL_GRP, SHOWCLOCK_KEY, true); | 225 | return (bool) readNumConfig(GENERAL_GRP, SHOWCLOCK_KEY, true); |
222 | } | 226 | } |
223 | 227 | ||
224 | 228 | ||
225 | void PPPData::set_show_clock_on_caption(bool set) { | 229 | void PPPData::set_show_clock_on_caption(bool set) { |
226 | writeConfig(GENERAL_GRP, SHOWCLOCK_KEY, (int) set); | 230 | writeConfig(GENERAL_GRP, SHOWCLOCK_KEY, (int) set); |
227 | } | 231 | } |
228 | 232 | ||
229 | 233 | ||
230 | bool PPPData::get_xserver_exit_disconnect() { | 234 | bool PPPData::get_xserver_exit_disconnect() { |
231 | return (bool) readNumConfig(GENERAL_GRP, DISCONNECT_KEY, true); | 235 | return (bool) readNumConfig(GENERAL_GRP, DISCONNECT_KEY, true); |
232 | } | 236 | } |
233 | 237 | ||
234 | 238 | ||
235 | void PPPData::setPPPDebug(bool set) { | 239 | void PPPData::setPPPDebug(bool set) { |
236 | writeConfig(GENERAL_GRP, PPP_DEBUG_OPTION, (int)set); | 240 | writeConfig(GENERAL_GRP, PPP_DEBUG_OPTION, (int)set); |
237 | } | 241 | } |
238 | 242 | ||
239 | 243 | ||
240 | bool PPPData::getPPPDebug() { | 244 | bool PPPData::getPPPDebug() { |
241 | return (bool)readNumConfig(GENERAL_GRP, PPP_DEBUG_OPTION, false); | 245 | return (bool)readNumConfig(GENERAL_GRP, PPP_DEBUG_OPTION, false); |
242 | } | 246 | } |
243 | 247 | ||
244 | 248 | ||
245 | void PPPData::set_xserver_exit_disconnect(bool set) { | 249 | void PPPData::set_xserver_exit_disconnect(bool set) { |
246 | writeConfig(GENERAL_GRP, DISCONNECT_KEY, (int) set); | 250 | writeConfig(GENERAL_GRP, DISCONNECT_KEY, (int) set); |
247 | } | 251 | } |
248 | 252 | ||
249 | 253 | ||
250 | bool PPPData::quit_on_disconnect() { | 254 | bool PPPData::quit_on_disconnect() { |
251 | return (bool) readNumConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, false); | 255 | return (bool) readNumConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, false); |
252 | } | 256 | } |
253 | 257 | ||
254 | 258 | ||
255 | void PPPData::set_quit_on_disconnect(bool set) { | 259 | void PPPData::set_quit_on_disconnect(bool set) { |
256 | writeConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, (int) set); | 260 | writeConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, (int) set); |
257 | } | 261 | } |
258 | 262 | ||
259 | 263 | ||
260 | bool PPPData::get_show_log_window() { | 264 | bool PPPData::get_show_log_window() { |
261 | return (bool) readNumConfig (GENERAL_GRP, SHOWLOGWIN_KEY, false); | 265 | return (bool) readNumConfig (GENERAL_GRP, SHOWLOGWIN_KEY, false); |
262 | } | 266 | } |
263 | 267 | ||
264 | 268 | ||
265 | void PPPData::set_show_log_window(bool set) { | 269 | void PPPData::set_show_log_window(bool set) { |
266 | writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set); | 270 | writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set); |
267 | } | 271 | } |
268 | 272 | ||
269 | 273 | ||
270 | bool PPPData::automatic_redial() { | 274 | bool PPPData::automatic_redial() { |
271 | return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE); | 275 | return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE); |
272 | } | 276 | } |
273 | 277 | ||
274 | 278 | ||
275 | void PPPData::set_automatic_redial(bool set) { | 279 | void PPPData::set_automatic_redial(bool set) { |
276 | writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set); | 280 | writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set); |
277 | } | 281 | } |
278 | 282 | ||
279 | 283 | ||
280 | bool PPPData::get_iconify_on_connect() { | 284 | bool PPPData::get_iconify_on_connect() { |
281 | return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE); | 285 | return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE); |
282 | } | 286 | } |
283 | 287 | ||
284 | 288 | ||
285 | void PPPData::set_iconify_on_connect(bool set) { | 289 | void PPPData::set_iconify_on_connect(bool set) { |
286 | writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set); | 290 | writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set); |
287 | } | 291 | } |
288 | 292 | ||
289 | 293 | ||
290 | bool PPPData::get_dock_into_panel() { | 294 | bool PPPData::get_dock_into_panel() { |
291 | return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false); | 295 | return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false); |
292 | } | 296 | } |
293 | 297 | ||
294 | 298 | ||
295 | void PPPData::set_dock_into_panel(bool set) { | 299 | void PPPData::set_dock_into_panel(bool set) { |
296 | writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set); | 300 | writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set); |
297 | } | 301 | } |
298 | 302 | ||
299 | 303 | ||
300 | QString PPPData::pppdVersion() { | 304 | QString PPPData::pppdVersion() { |
301 | return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch); | 305 | return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch); |
302 | } | 306 | } |
303 | 307 | ||
304 | bool PPPData::pppdVersionMin(int ver, int mod, int patch) { | 308 | bool PPPData::pppdVersionMin(int ver, int mod, int patch) { |
305 | // check if pppd version fulfills minimum requirement | 309 | // check if pppd version fulfills minimum requirement |
306 | return (pppdVer > ver | 310 | return (pppdVer > ver |
307 | || (pppdVer == ver && pppdMod > mod) | 311 | || (pppdVer == ver && pppdMod > mod) |
308 | || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch)); | 312 | || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch)); |
309 | } | 313 | } |
310 | 314 | ||
311 | int PPPData::pppdTimeout() { | 315 | int PPPData::pppdTimeout() { |
312 | return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT); | 316 | return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT); |
313 | } | 317 | } |
314 | 318 | ||
315 | 319 | ||
316 | void PPPData::setpppdTimeout(int n) { | 320 | void PPPData::setpppdTimeout(int n) { |
317 | writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n); | 321 | writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n); |
318 | } | 322 | } |
319 | 323 | ||
320 | 324 | ||
321 | const QString PPPData::modemDevice() { | 325 | const QString PPPData::modemDevice() { |
322 | return readConfig (MODEM_GRP, MODEMDEV_KEY, devices[DEV_DEFAULT]); | 326 | return readConfig (MODEM_GRP, MODEMDEV_KEY, devices[DEV_DEFAULT]); |
323 | } | 327 | } |
324 | 328 | ||
325 | 329 | ||
326 | void PPPData::setModemDevice(const QString &n) { | 330 | void PPPData::setModemDevice(const QString &n) { |
327 | writeConfig(MODEM_GRP, MODEMDEV_KEY, n); | 331 | writeConfig(MODEM_GRP, MODEMDEV_KEY, n); |
328 | } | 332 | } |
@@ -529,701 +533,702 @@ const QString PPPData::modemNoCarrierResp() { | |||
529 | 533 | ||
530 | void PPPData::setModemNoCarrierResp(const QString &n) { | 534 | void PPPData::setModemNoCarrierResp(const QString &n) { |
531 | writeConfig(MODEM_GRP, NOCARRIERRESP_KEY, n); | 535 | writeConfig(MODEM_GRP, NOCARRIERRESP_KEY, n); |
532 | } | 536 | } |
533 | 537 | ||
534 | 538 | ||
535 | const QString PPPData::modemNoDialtoneResp() { | 539 | const QString PPPData::modemNoDialtoneResp() { |
536 | return readConfig(MODEM_GRP, NODIALTONERESP_KEY, "NO DIALTONE"); | 540 | return readConfig(MODEM_GRP, NODIALTONERESP_KEY, "NO DIALTONE"); |
537 | } | 541 | } |
538 | 542 | ||
539 | 543 | ||
540 | void PPPData::setModemNoDialtoneResp(const QString &n) { | 544 | void PPPData::setModemNoDialtoneResp(const QString &n) { |
541 | writeConfig(MODEM_GRP, NODIALTONERESP_KEY, n); | 545 | writeConfig(MODEM_GRP, NODIALTONERESP_KEY, n); |
542 | } | 546 | } |
543 | 547 | ||
544 | 548 | ||
545 | const QString PPPData::modemHangupStr() { | 549 | const QString PPPData::modemHangupStr() { |
546 | return readConfig(MODEM_GRP, HANGUPSTR_KEY, "+++ATH"); | 550 | return readConfig(MODEM_GRP, HANGUPSTR_KEY, "+++ATH"); |
547 | } | 551 | } |
548 | 552 | ||
549 | void PPPData::setModemHangupStr(const QString &n) { | 553 | void PPPData::setModemHangupStr(const QString &n) { |
550 | writeConfig(MODEM_GRP, HANGUPSTR_KEY, n); | 554 | writeConfig(MODEM_GRP, HANGUPSTR_KEY, n); |
551 | } | 555 | } |
552 | 556 | ||
553 | 557 | ||
554 | const QString PPPData::modemHangupResp() { | 558 | const QString PPPData::modemHangupResp() { |
555 | return readConfig(MODEM_GRP, HANGUPRESP_KEY, "OK"); | 559 | return readConfig(MODEM_GRP, HANGUPRESP_KEY, "OK"); |
556 | } | 560 | } |
557 | 561 | ||
558 | void PPPData::setModemHangupResp(const QString &n) { | 562 | void PPPData::setModemHangupResp(const QString &n) { |
559 | writeConfig(MODEM_GRP, HANGUPRESP_KEY, n); | 563 | writeConfig(MODEM_GRP, HANGUPRESP_KEY, n); |
560 | } | 564 | } |
561 | 565 | ||
562 | 566 | ||
563 | const QString PPPData::modemAnswerStr() { | 567 | const QString PPPData::modemAnswerStr() { |
564 | return readConfig(MODEM_GRP, ANSWERSTR_KEY, "ATA"); | 568 | return readConfig(MODEM_GRP, ANSWERSTR_KEY, "ATA"); |
565 | } | 569 | } |
566 | 570 | ||
567 | 571 | ||
568 | QString PPPData::volumeOff() { | 572 | QString PPPData::volumeOff() { |
569 | return readConfig(MODEM_GRP, VOLUME_OFF, "M0L0"); | 573 | return readConfig(MODEM_GRP, VOLUME_OFF, "M0L0"); |
570 | } | 574 | } |
571 | 575 | ||
572 | 576 | ||
573 | void PPPData::setVolumeOff(const QString &s) { | 577 | void PPPData::setVolumeOff(const QString &s) { |
574 | writeConfig(MODEM_GRP, VOLUME_OFF, s); | 578 | writeConfig(MODEM_GRP, VOLUME_OFF, s); |
575 | } | 579 | } |
576 | 580 | ||
577 | 581 | ||
578 | QString PPPData::volumeMedium() { | 582 | QString PPPData::volumeMedium() { |
579 | return readConfig(MODEM_GRP, VOLUME_MEDIUM, "M1L1"); | 583 | return readConfig(MODEM_GRP, VOLUME_MEDIUM, "M1L1"); |
580 | } | 584 | } |
581 | 585 | ||
582 | 586 | ||
583 | void PPPData::setVolumeMedium(const QString &s) { | 587 | void PPPData::setVolumeMedium(const QString &s) { |
584 | writeConfig(MODEM_GRP, VOLUME_MEDIUM, s); | 588 | writeConfig(MODEM_GRP, VOLUME_MEDIUM, s); |
585 | } | 589 | } |
586 | 590 | ||
587 | 591 | ||
588 | QString PPPData::volumeHigh() { | 592 | QString PPPData::volumeHigh() { |
589 | QString tmp = readConfig(MODEM_GRP, VOLUME_HIGH, "M1L3"); | 593 | QString tmp = readConfig(MODEM_GRP, VOLUME_HIGH, "M1L3"); |
590 | if(tmp == "M1L4") | 594 | if(tmp == "M1L4") |
591 | tmp = "M1L3"; | 595 | tmp = "M1L3"; |
592 | return tmp; | 596 | return tmp; |
593 | } | 597 | } |
594 | 598 | ||
595 | 599 | ||
596 | void PPPData::setVolumeHigh(const QString &s) { | 600 | void PPPData::setVolumeHigh(const QString &s) { |
597 | writeConfig(MODEM_GRP, VOLUME_HIGH, s); | 601 | writeConfig(MODEM_GRP, VOLUME_HIGH, s); |
598 | } | 602 | } |
599 | 603 | ||
600 | 604 | ||
601 | QString PPPData::volumeInitString() { | 605 | QString PPPData::volumeInitString() { |
602 | QString s; | 606 | QString s; |
603 | 607 | ||
604 | switch(volume()) { | 608 | switch(volume()) { |
605 | case 0: | 609 | case 0: |
606 | s = volumeOff(); | 610 | s = volumeOff(); |
607 | break; | 611 | break; |
608 | case 1: | 612 | case 1: |
609 | s = volumeMedium(); | 613 | s = volumeMedium(); |
610 | break; | 614 | break; |
611 | case 2: | 615 | case 2: |
612 | s = volumeHigh(); | 616 | s = volumeHigh(); |
613 | break; | 617 | break; |
614 | default: | 618 | default: |
615 | s = volumeMedium(); | 619 | s = volumeMedium(); |
616 | } | 620 | } |
617 | 621 | ||
618 | return s; | 622 | return s; |
619 | } | 623 | } |
620 | 624 | ||
621 | 625 | ||
622 | int PPPData::volume() { | 626 | int PPPData::volume() { |
623 | return readNumConfig(MODEM_GRP, VOLUME_KEY, 1); | 627 | return readNumConfig(MODEM_GRP, VOLUME_KEY, 1); |
624 | } | 628 | } |
625 | 629 | ||
626 | 630 | ||
627 | void PPPData::setVolume(int i) { | 631 | void PPPData::setVolume(int i) { |
628 | writeConfig(MODEM_GRP, VOLUME_KEY, i); | 632 | writeConfig(MODEM_GRP, VOLUME_KEY, i); |
629 | } | 633 | } |
630 | 634 | ||
631 | int PPPData::waitForDialTone() { | 635 | int PPPData::waitForDialTone() { |
632 | return readNumConfig(MODEM_GRP, DIALTONEWAIT_KEY, 1); | 636 | return readNumConfig(MODEM_GRP, DIALTONEWAIT_KEY, 1); |
633 | } | 637 | } |
634 | 638 | ||
635 | void PPPData::setWaitForDialTone(int i) { | 639 | void PPPData::setWaitForDialTone(int i) { |
636 | writeConfig(MODEM_GRP, DIALTONEWAIT_KEY, i); | 640 | writeConfig(MODEM_GRP, DIALTONEWAIT_KEY, i); |
637 | } | 641 | } |
638 | 642 | ||
639 | void PPPData::setModemAnswerStr(const QString &n) { | 643 | void PPPData::setModemAnswerStr(const QString &n) { |
640 | writeConfig(MODEM_GRP, ANSWERSTR_KEY, n); | 644 | writeConfig(MODEM_GRP, ANSWERSTR_KEY, n); |
641 | } | 645 | } |
642 | 646 | ||
643 | 647 | ||
644 | const QString PPPData::modemRingResp() { | 648 | const QString PPPData::modemRingResp() { |
645 | return readConfig(MODEM_GRP, RINGRESP_KEY, "RING"); | 649 | return readConfig(MODEM_GRP, RINGRESP_KEY, "RING"); |
646 | } | 650 | } |
647 | 651 | ||
648 | 652 | ||
649 | void PPPData::setModemRingResp(const QString &n) { | 653 | void PPPData::setModemRingResp(const QString &n) { |
650 | writeConfig(MODEM_GRP, RINGRESP_KEY, n); | 654 | writeConfig(MODEM_GRP, RINGRESP_KEY, n); |
651 | } | 655 | } |
652 | 656 | ||
653 | 657 | ||
654 | const QString PPPData::modemAnswerResp() { | 658 | const QString PPPData::modemAnswerResp() { |
655 | return readConfig(MODEM_GRP, ANSWERRESP_KEY, "CONNECT"); | 659 | return readConfig(MODEM_GRP, ANSWERRESP_KEY, "CONNECT"); |
656 | } | 660 | } |
657 | 661 | ||
658 | 662 | ||
659 | void PPPData::setModemAnswerResp(const QString &n) { | 663 | void PPPData::setModemAnswerResp(const QString &n) { |
660 | writeConfig(MODEM_GRP, ANSWERRESP_KEY, n); | 664 | writeConfig(MODEM_GRP, ANSWERRESP_KEY, n); |
661 | } | 665 | } |
662 | 666 | ||
663 | 667 | ||
664 | const QString PPPData::enter() { | 668 | const QString PPPData::enter() { |
665 | return readConfig(MODEM_GRP, ENTER_KEY, "CR"); | 669 | return readConfig(MODEM_GRP, ENTER_KEY, "CR"); |
666 | } | 670 | } |
667 | 671 | ||
668 | 672 | ||
669 | void PPPData::setEnter(const QString &n) { | 673 | void PPPData::setEnter(const QString &n) { |
670 | writeConfig(MODEM_GRP, ENTER_KEY, n); | 674 | writeConfig(MODEM_GRP, ENTER_KEY, n); |
671 | } | 675 | } |
672 | 676 | ||
673 | 677 | ||
674 | // | 678 | // |
675 | // functions to set/return account information | 679 | // functions to set/return account information |
676 | // | 680 | // |
677 | 681 | ||
678 | //returns number of accounts | 682 | //returns number of accounts |
679 | int PPPData::count() const { | 683 | int PPPData::count() const { |
680 | return highcount + 1; | 684 | return highcount + 1; |
681 | } | 685 | } |
682 | 686 | ||
683 | 687 | ||
684 | bool PPPData::setAccount(const QString &aname) { | 688 | bool PPPData::setAccount(const QString &aname) { |
685 | for(int i = 0; i <= highcount; i++) { | 689 | for(int i = 0; i <= highcount; i++) { |
686 | setAccountbyIndex(i); | 690 | setAccountbyIndex(i); |
687 | if(accname() == aname) { | 691 | if(accname() == aname) { |
688 | caccount = i; | 692 | caccount = i; |
689 | return true; | 693 | return true; |
690 | } | 694 | } |
691 | } | 695 | } |
692 | return false; | 696 | return false; |
693 | } | 697 | } |
694 | 698 | ||
695 | 699 | ||
696 | bool PPPData::setAccountbyIndex(int i) { | 700 | bool PPPData::setAccountbyIndex(int i) { |
697 | if(i >= 0 && i <= highcount) { | 701 | if(i >= 0 && i <= highcount) { |
698 | caccount = i; | 702 | caccount = i; |
699 | cgroup.sprintf("%s%i", ACCOUNT_GRP, i); | 703 | cgroup.sprintf("%s%i", ACCOUNT_GRP, i); |
700 | return true; | 704 | return true; |
701 | } | 705 | } |
702 | return false; | 706 | return false; |
703 | } | 707 | } |
704 | 708 | ||
705 | 709 | ||
706 | bool PPPData::isUniqueAccname(const QString &n) { | 710 | bool PPPData::isUniqueAccname(const QString &n) { |
707 | int current = caccount; | 711 | int current = caccount; |
708 | for(int i=0; i <= highcount; i++) { | 712 | for(int i=0; i <= highcount; i++) { |
709 | setAccountbyIndex(i); | 713 | setAccountbyIndex(i); |
710 | if(accname() == n && i != current) { | 714 | if(accname() == n && i != current) { |
711 | setAccountbyIndex(current); | 715 | setAccountbyIndex(current); |
712 | return false; | 716 | return false; |
713 | } | 717 | } |
714 | } | 718 | } |
715 | setAccountbyIndex(current); | 719 | setAccountbyIndex(current); |
716 | return true; | 720 | return true; |
717 | } | 721 | } |
718 | 722 | ||
719 | 723 | ||
720 | bool PPPData::deleteAccount() { | 724 | bool PPPData::deleteAccount() { |
721 | if(caccount < 0) | 725 | //FIXME: |
722 | return false; | 726 | // if(caccount < 0) |
727 | return false; | ||
723 | 728 | ||
724 | // QMap <QString, QString> map; | 729 | // QMap <QString, QString> map; |
725 | // QMap <QString, QString>::Iterator it; | 730 | // QMap <QString, QString>::Iterator it; |
726 | 731 | ||
727 | // set all entries of the current account to "" | 732 | // // set all entries of the current account to "" |
728 | // tille: do not handle the accounts here... (?) | ||
729 | // map = config->entryMap(cgroup); | 733 | // map = config->entryMap(cgroup); |
730 | // it = map.begin(); | 734 | // it = map.begin(); |
731 | // while (it != map.end()) { | 735 | // while (it != map.end()) { |
732 | // config->writeEntry(it.key(), ""); | 736 | // config->writeEntry(it.key(), ""); |
733 | // it++; | 737 | // it++; |
734 | // } | 738 | // } |
735 | 739 | ||
736 | // // shift the succeeding accounts | 740 | // // shift the succeeding accounts |
737 | // for(int i = caccount+1; i <= highcount; i++) { | 741 | // for(int i = caccount+1; i <= highcount; i++) { |
738 | // setAccountbyIndex(i); | 742 | // setAccountbyIndex(i); |
739 | // map = config->entryMap(cgroup); | 743 | // map = config->entryMap(cgroup); |
740 | // it = map.begin(); | 744 | // it = map.begin(); |
741 | // setAccountbyIndex(i-1); | 745 | // setAccountbyIndex(i-1); |
742 | // config->setGroup(cgroup); | 746 | // config->setGroup(cgroup); |
743 | // while (it != map.end()) { | 747 | // while (it != map.end()) { |
744 | // config->writeEntry(it.key(), *it); | 748 | // config->writeEntry(it.key(), *it); |
745 | // it++; | 749 | // it++; |
746 | // } | 750 | // } |
747 | // } | 751 | // } |
748 | 752 | ||
749 | // // make sure the top account is cleared | 753 | // // make sure the top account is cleared |
750 | // setAccountbyIndex(highcount); | 754 | // setAccountbyIndex(highcount); |
751 | // map = config->entryMap(cgroup); | 755 | // map = config->entryMap(cgroup); |
752 | // it = map.begin(); | 756 | // it = map.begin(); |
753 | // config->setGroup(cgroup); | 757 | // config->setGroup(cgroup); |
754 | // while (it.key() != QString::null) { | 758 | // while (it.key() != QString::null) { |
755 | // config->writeEntry(it.key(), ""); | 759 | // config->writeEntry(it.key(), ""); |
756 | // it++; | 760 | // it++; |
757 | // } | 761 | // } |
758 | 762 | ||
759 | highcount--; | 763 | // highcount--; |
760 | if(caccount > highcount) | 764 | // if(caccount > highcount) |
761 | caccount = highcount; | 765 | // caccount = highcount; |
762 | 766 | ||
763 | setAccountbyIndex(caccount); | 767 | // setAccountbyIndex(caccount); |
764 | 768 | ||
765 | return true; | 769 | // return true; |
766 | } | 770 | } |
767 | 771 | ||
768 | 772 | ||
769 | bool PPPData::deleteAccount(const QString &aname) { | 773 | bool PPPData::deleteAccount(const QString &aname) { |
770 | if(!setAccount(aname)) | 774 | if(!setAccount(aname)) |
771 | return false; | 775 | return false; |
772 | 776 | ||
773 | deleteAccount(); | 777 | deleteAccount(); |
774 | 778 | ||
775 | return true; | 779 | return true; |
776 | } | 780 | } |
777 | 781 | ||
778 | 782 | ||
779 | int PPPData::newaccount() { | 783 | int PPPData::newaccount() { |
780 | 784 | ||
781 | if(!config || highcount >= MAX_ACCOUNTS) | 785 | qDebug("PPPData::newaccount highcount %i/%i",highcount,MAX_ACCOUNTS); |
782 | return -1; | 786 | if(!config) open(); |
787 | if (highcount >= MAX_ACCOUNTS) return -1; | ||
783 | 788 | ||
784 | highcount++; | 789 | highcount++; |
785 | setAccountbyIndex(highcount); | 790 | setAccountbyIndex(highcount); |
786 | 791 | ||
787 | setpppdArgumentDefaults(); | 792 | setpppdArgumentDefaults(); |
788 | 793 | qDebug("PPPData::newaccount -> %i",caccount); | |
789 | return caccount; | 794 | return caccount; |
790 | } | 795 | } |
791 | 796 | ||
792 | int PPPData::copyaccount(int i) { | 797 | int PPPData::copyaccount(int i) { |
793 | 798 | ||
794 | if(highcount >= MAX_ACCOUNTS) | 799 | // if(highcount >= MAX_ACCOUNTS) |
795 | return -1; | 800 | return -1; |
796 | 801 | ||
797 | setAccountbyIndex(i); | 802 | // setAccountbyIndex(i); |
798 | 803 | ||
799 | // QMap <QString, QString> map = config->entryMap(cgroup); | 804 | // QMap <QString, QString> map = config->entryMap(cgroup); |
800 | // QMap <QString, QString>::ConstIterator it = map.begin(); | 805 | // QMap <QString, QString>::ConstIterator it = map.begin(); |
801 | 806 | ||
802 | QString newname = i18n("%1_copy").arg(accname()); | 807 | // QString newname = i18n("%1_copy").arg(accname()); |
803 | 808 | ||
804 | newaccount(); | 809 | // newaccount(); |
805 | 810 | ||
806 | // while (it != map.end()) { | 811 | // while (it != map.end()) { |
807 | // config->writeEntry(it.key(), *it); | 812 | // config->writeEntry(it.key(), *it); |
808 | // it++; | 813 | // it++; |
809 | // } | 814 | // } |
810 | 815 | ||
811 | setAccname(newname); | 816 | // setAccname(newname); |
812 | 817 | ||
813 | return caccount; | 818 | // return caccount; |
814 | } | 819 | } |
815 | 820 | ||
816 | 821 | ||
817 | const QString PPPData::accname() { | 822 | const QString PPPData::accname() { |
818 | return readConfig(cgroup, NAME_KEY); | 823 | return readConfig(cgroup, NAME_KEY); |
819 | } | 824 | } |
820 | 825 | ||
821 | void PPPData::setAccname(const QString &n) { | 826 | void PPPData::setAccname(const QString &n) { |
822 | if(!cgroup.isNull()) { | 827 | if(!cgroup.isNull()) { |
823 | // are we manipulating the default account's name ? then change it, too. | 828 | // are we manipulating the default account's name ? then change it, too. |
824 | bool def = accname() == defaultAccount(); | 829 | bool def = accname() == defaultAccount(); |
825 | writeConfig(cgroup, NAME_KEY, n); | 830 | writeConfig(cgroup, NAME_KEY, n); |
826 | if (def) | 831 | if (def) |
827 | setDefaultAccount(n); | 832 | setDefaultAccount(n); |
828 | } | 833 | } |
829 | } | 834 | } |
830 | 835 | ||
831 | 836 | ||
832 | #define SEPARATOR_CHAR ':' | 837 | #define SEPARATOR_CHAR '&' |
833 | QStringList &PPPData::phonenumbers() { | 838 | QStringList &PPPData::phonenumbers() { |
834 | 839 | ||
835 | readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR); | 840 | readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR); |
836 | return phonelist; | 841 | return phonelist; |
837 | 842 | ||
838 | } | 843 | } |
839 | 844 | ||
840 | 845 | ||
841 | const QString PPPData::phonenumber() { | 846 | const QString PPPData::phonenumber() { |
842 | return readConfig(cgroup, PHONENUMBER_KEY); | 847 | return readConfig(cgroup, PHONENUMBER_KEY); |
843 | } | 848 | } |
844 | 849 | ||
845 | 850 | ||
846 | void PPPData::setPhonenumber(const QString &n) { | 851 | void PPPData::setPhonenumber(const QString &n) { |
847 | writeConfig(cgroup, PHONENUMBER_KEY, n); | 852 | writeConfig(cgroup, PHONENUMBER_KEY, n); |
848 | } | 853 | } |
849 | 854 | ||
850 | 855 | ||
851 | const QString PPPData::dialPrefix() { | 856 | const QString PPPData::dialPrefix() { |
852 | return readConfig(cgroup, DIAL_PREFIX_KEY, ""); | 857 | return readConfig(cgroup, DIAL_PREFIX_KEY, ""); |
853 | } | 858 | } |
854 | 859 | ||
855 | 860 | ||
856 | void PPPData::setDialPrefix(const QString &s) { | 861 | void PPPData::setDialPrefix(const QString &s) { |
857 | writeConfig(cgroup, DIAL_PREFIX_KEY, s); | 862 | writeConfig(cgroup, DIAL_PREFIX_KEY, s); |
858 | } | 863 | } |
859 | 864 | ||
860 | 865 | ||
861 | int PPPData::authMethod() { | 866 | int PPPData::authMethod() { |
862 | return readNumConfig(cgroup, AUTH_KEY, 0); | 867 | return readNumConfig(cgroup, AUTH_KEY, 0); |
863 | } | 868 | } |
864 | 869 | ||
865 | 870 | ||
866 | void PPPData::setAuthMethod(int value) { | 871 | void PPPData::setAuthMethod(int value) { |
867 | writeConfig(cgroup, AUTH_KEY, value); | 872 | writeConfig(cgroup, AUTH_KEY, value); |
868 | } | 873 | } |
869 | 874 | ||
870 | 875 | ||
871 | const QString PPPData::storedUsername() { | 876 | const QString PPPData::storedUsername() { |
872 | return readConfig(cgroup, STORED_USERNAME_KEY, ""); | 877 | return readConfig(cgroup, STORED_USERNAME_KEY, ""); |
873 | } | 878 | } |
874 | 879 | ||
875 | 880 | ||
876 | void PPPData::setStoredUsername(const QString &b) { | 881 | void PPPData::setStoredUsername(const QString &b) { |
877 | writeConfig(cgroup, STORED_USERNAME_KEY, b); | 882 | writeConfig(cgroup, STORED_USERNAME_KEY, b); |
878 | } | 883 | } |
879 | 884 | ||
880 | 885 | ||
881 | const QString PPPData::storedPassword() { | 886 | const QString PPPData::storedPassword() { |
882 | return readConfig(cgroup, STORED_PASSWORD_KEY, ""); | 887 | return readConfig(cgroup, STORED_PASSWORD_KEY, ""); |
883 | } | 888 | } |
884 | 889 | ||
885 | 890 | ||
886 | void PPPData::setStoredPassword(const QString &b) { | 891 | void PPPData::setStoredPassword(const QString &b) { |
887 | writeConfig(cgroup, STORED_PASSWORD_KEY, b); | 892 | writeConfig(cgroup, STORED_PASSWORD_KEY, b); |
888 | } | 893 | } |
889 | 894 | ||
890 | 895 | ||
891 | bool PPPData::storePassword() { | 896 | bool PPPData::storePassword() { |
892 | return (bool)readNumConfig(cgroup, STORE_PASSWORD_KEY, 1); | 897 | return (bool)readNumConfig(cgroup, STORE_PASSWORD_KEY, 1); |
893 | } | 898 | } |
894 | 899 | ||
895 | 900 | ||
896 | const QString PPPData::command_before_connect() { | 901 | const QString PPPData::command_before_connect() { |
897 | return readConfig(cgroup, BEFORE_CONNECT_KEY); | 902 | return readConfig(cgroup, BEFORE_CONNECT_KEY); |
898 | } | 903 | } |
899 | 904 | ||
900 | 905 | ||
901 | void PPPData::setCommand_before_connect(const QString &n) { | 906 | void PPPData::setCommand_before_connect(const QString &n) { |
902 | writeConfig(cgroup, BEFORE_CONNECT_KEY, n); | 907 | writeConfig(cgroup, BEFORE_CONNECT_KEY, n); |
903 | } | 908 | } |
904 | 909 | ||
905 | 910 | ||
906 | void PPPData::setStorePassword(bool b) { | 911 | void PPPData::setStorePassword(bool b) { |
907 | writeConfig(cgroup, STORE_PASSWORD_KEY, (int)b); | 912 | writeConfig(cgroup, STORE_PASSWORD_KEY, (int)b); |
908 | } | 913 | } |
909 | 914 | ||
910 | 915 | ||
911 | const QString PPPData::command_on_connect() { | 916 | const QString PPPData::command_on_connect() { |
912 | return readConfig(cgroup, COMMAND_KEY); | 917 | return readConfig(cgroup, COMMAND_KEY); |
913 | } | 918 | } |
914 | 919 | ||
915 | 920 | ||
916 | void PPPData::setCommand_on_connect(const QString &n) { | 921 | void PPPData::setCommand_on_connect(const QString &n) { |
917 | writeConfig(cgroup, COMMAND_KEY, n); | 922 | writeConfig(cgroup, COMMAND_KEY, n); |
918 | } | 923 | } |
919 | 924 | ||
920 | 925 | ||
921 | const QString PPPData::command_on_disconnect() { | 926 | const QString PPPData::command_on_disconnect() { |
922 | return readConfig(cgroup, DISCONNECT_COMMAND_KEY); | 927 | return readConfig(cgroup, DISCONNECT_COMMAND_KEY); |
923 | } | 928 | } |
924 | 929 | ||
925 | 930 | ||
926 | void PPPData::setCommand_on_disconnect(const QString &n) { | 931 | void PPPData::setCommand_on_disconnect(const QString &n) { |
927 | writeConfig(cgroup, DISCONNECT_COMMAND_KEY, n); | 932 | writeConfig(cgroup, DISCONNECT_COMMAND_KEY, n); |
928 | } | 933 | } |
929 | 934 | ||
930 | 935 | ||
931 | const QString PPPData::command_before_disconnect() { | 936 | const QString PPPData::command_before_disconnect() { |
932 | return readConfig(cgroup, BEFORE_DISCONNECT_KEY); | 937 | return readConfig(cgroup, BEFORE_DISCONNECT_KEY); |
933 | } | 938 | } |
934 | 939 | ||
935 | 940 | ||
936 | void PPPData::setCommand_before_disconnect(const QString &n) { | 941 | void PPPData::setCommand_before_disconnect(const QString &n) { |
937 | writeConfig(cgroup, BEFORE_DISCONNECT_KEY, n); | 942 | writeConfig(cgroup, BEFORE_DISCONNECT_KEY, n); |
938 | } | 943 | } |
939 | 944 | ||
940 | 945 | ||
941 | const QString PPPData::ipaddr() { | 946 | const QString PPPData::ipaddr() { |
942 | return readConfig(cgroup, IPADDR_KEY); | 947 | return readConfig(cgroup, IPADDR_KEY); |
943 | } | 948 | } |
944 | 949 | ||
945 | 950 | ||
946 | void PPPData::setIpaddr(const QString &n) { | 951 | void PPPData::setIpaddr(const QString &n) { |
947 | writeConfig(cgroup, IPADDR_KEY, n); | 952 | writeConfig(cgroup, IPADDR_KEY, n); |
948 | } | 953 | } |
949 | 954 | ||
950 | 955 | ||
951 | const QString PPPData::subnetmask() { | 956 | const QString PPPData::subnetmask() { |
952 | return readConfig(cgroup, SUBNETMASK_KEY); | 957 | return readConfig(cgroup, SUBNETMASK_KEY); |
953 | } | 958 | } |
954 | 959 | ||
955 | 960 | ||
956 | void PPPData::setSubnetmask(const QString &n) { | 961 | void PPPData::setSubnetmask(const QString &n) { |
957 | writeConfig(cgroup, SUBNETMASK_KEY, n); | 962 | writeConfig(cgroup, SUBNETMASK_KEY, n); |
958 | } | 963 | } |
959 | 964 | ||
960 | 965 | ||
961 | bool PPPData::autoname() { | 966 | bool PPPData::autoname() { |
962 | return (bool) readNumConfig(cgroup, AUTONAME_KEY, false); | 967 | return (bool) readNumConfig(cgroup, AUTONAME_KEY, false); |
963 | } | 968 | } |
964 | 969 | ||
965 | 970 | ||
966 | void PPPData::setAutoname(bool set) { | 971 | void PPPData::setAutoname(bool set) { |
967 | writeConfig(cgroup, AUTONAME_KEY, (int) set); | 972 | writeConfig(cgroup, AUTONAME_KEY, (int) set); |
968 | } | 973 | } |
969 | 974 | ||
970 | 975 | ||
971 | bool PPPData::AcctEnabled() { | 976 | bool PPPData::AcctEnabled() { |
972 | return (bool) readNumConfig(cgroup, ACCTENABLED_KEY, false); | 977 | return (bool) readNumConfig(cgroup, ACCTENABLED_KEY, false); |
973 | } | 978 | } |
974 | 979 | ||
975 | 980 | ||
976 | void PPPData::setAcctEnabled(bool set) { | 981 | void PPPData::setAcctEnabled(bool set) { |
977 | writeConfig(cgroup, ACCTENABLED_KEY, (int) set); | 982 | writeConfig(cgroup, ACCTENABLED_KEY, (int) set); |
978 | } | 983 | } |
979 | 984 | ||
980 | 985 | ||
981 | int PPPData::VolAcctEnabled() { | 986 | int PPPData::VolAcctEnabled() { |
982 | return readNumConfig(cgroup, VOLACCTENABLED_KEY, 0); | 987 | return readNumConfig(cgroup, VOLACCTENABLED_KEY, 0); |
983 | } | 988 | } |
984 | 989 | ||
985 | 990 | ||
986 | void PPPData::setVolAcctEnabled(int set) { | 991 | void PPPData::setVolAcctEnabled(int set) { |
987 | writeConfig(cgroup, VOLACCTENABLED_KEY, set); | 992 | writeConfig(cgroup, VOLACCTENABLED_KEY, set); |
988 | } | 993 | } |
989 | 994 | ||
990 | 995 | ||
991 | const QString PPPData::gateway() { | 996 | const QString PPPData::gateway() { |
992 | return readConfig(cgroup, GATEWAY_KEY); | 997 | return readConfig(cgroup, GATEWAY_KEY); |
993 | } | 998 | } |
994 | 999 | ||
995 | 1000 | ||
996 | void PPPData::setGateway(const QString &n ) { | 1001 | void PPPData::setGateway(const QString &n ) { |
997 | writeConfig(cgroup, GATEWAY_KEY, n); | 1002 | writeConfig(cgroup, GATEWAY_KEY, n); |
998 | } | 1003 | } |
999 | 1004 | ||
1000 | 1005 | ||
1001 | bool PPPData::defaultroute() { | 1006 | bool PPPData::defaultroute() { |
1002 | // default route is by default 'on'. | 1007 | // default route is by default 'on'. |
1003 | return (bool) readNumConfig(cgroup, DEFAULTROUTE_KEY, true); | 1008 | return (bool) readNumConfig(cgroup, DEFAULTROUTE_KEY, true); |
1004 | } | 1009 | } |
1005 | 1010 | ||
1006 | 1011 | ||
1007 | void PPPData::setDefaultroute(bool set) { | 1012 | void PPPData::setDefaultroute(bool set) { |
1008 | writeConfig(cgroup, DEFAULTROUTE_KEY, (int) set); | 1013 | writeConfig(cgroup, DEFAULTROUTE_KEY, (int) set); |
1009 | } | 1014 | } |
1010 | 1015 | ||
1011 | 1016 | ||
1012 | bool PPPData::autoDNS() { | 1017 | bool PPPData::autoDNS() { |
1013 | bool set = (bool) readNumConfig(cgroup, AUTODNS_KEY, true); | 1018 | bool set = (bool) readNumConfig(cgroup, AUTODNS_KEY, true); |
1014 | return (set && gpppdata.pppdVersionMin(2, 3, 7)); | 1019 | return (set && PPPData::data()->pppdVersionMin(2, 3, 7)); |
1015 | } | 1020 | } |
1016 | 1021 | ||
1017 | 1022 | ||
1018 | void PPPData::setAutoDNS(bool set) { | 1023 | void PPPData::setAutoDNS(bool set) { |
1019 | writeConfig(cgroup, AUTODNS_KEY, (int) set); | 1024 | writeConfig(cgroup, AUTODNS_KEY, (int) set); |
1020 | } | 1025 | } |
1021 | 1026 | ||
1022 | 1027 | ||
1023 | void PPPData::setExDNSDisabled(bool set) { | 1028 | void PPPData::setExDNSDisabled(bool set) { |
1024 | writeConfig(cgroup, EXDNSDISABLED_KEY, (int) set); | 1029 | writeConfig(cgroup, EXDNSDISABLED_KEY, (int) set); |
1025 | } | 1030 | } |
1026 | 1031 | ||
1027 | 1032 | ||
1028 | bool PPPData::exDNSDisabled() { | 1033 | bool PPPData::exDNSDisabled() { |
1029 | return (bool) readNumConfig(cgroup, EXDNSDISABLED_KEY,0); | 1034 | return (bool) readNumConfig(cgroup, EXDNSDISABLED_KEY,0); |
1030 | } | 1035 | } |
1031 | 1036 | ||
1032 | 1037 | ||
1033 | QStringList &PPPData::dns() { | 1038 | QStringList &PPPData::dns() { |
1034 | static QStringList dnslist; | 1039 | static QStringList dnslist; |
1035 | 1040 | ||
1036 | readListConfig(cgroup, DNS_KEY, dnslist); | 1041 | readListConfig(cgroup, DNS_KEY, dnslist); |
1037 | while(dnslist.count() > MAX_DNS_ENTRIES) | 1042 | while(dnslist.count() > MAX_DNS_ENTRIES) |
1038 | dnslist.remove(dnslist.last()); | 1043 | dnslist.remove(dnslist.last()); |
1039 | 1044 | ||
1040 | return dnslist; | 1045 | return dnslist; |
1041 | } | 1046 | } |
1042 | 1047 | ||
1043 | 1048 | ||
1044 | void PPPData::setDns(QStringList &list) { | 1049 | void PPPData::setDns(QStringList &list) { |
1045 | writeListConfig(cgroup, DNS_KEY, list); | 1050 | writeListConfig(cgroup, DNS_KEY, list); |
1046 | } | 1051 | } |
1047 | 1052 | ||
1048 | 1053 | ||
1049 | const QString PPPData::domain() { | 1054 | const QString PPPData::domain() { |
1050 | return readConfig(cgroup, DOMAIN_KEY); | 1055 | return readConfig(cgroup, DOMAIN_KEY); |
1051 | } | 1056 | } |
1052 | 1057 | ||
1053 | 1058 | ||
1054 | void PPPData::setDomain(const QString &n ) { | 1059 | void PPPData::setDomain(const QString &n ) { |
1055 | writeConfig(cgroup, DOMAIN_KEY, n); | 1060 | writeConfig(cgroup, DOMAIN_KEY, n); |
1056 | } | 1061 | } |
1057 | 1062 | ||
1058 | 1063 | ||
1059 | QStringList &PPPData::scriptType() { | 1064 | QStringList &PPPData::scriptType() { |
1060 | static QStringList typelist; | 1065 | static QStringList typelist; |
1061 | 1066 | ||
1062 | readListConfig(cgroup, SCRIPTCOM_KEY, typelist); | 1067 | readListConfig(cgroup, SCRIPTCOM_KEY, typelist); |
1063 | while(typelist.count() > MAX_SCRIPT_ENTRIES) | 1068 | while(typelist.count() > MAX_SCRIPT_ENTRIES) |
1064 | typelist.remove(typelist.last()); | 1069 | typelist.remove(typelist.last()); |
1065 | 1070 | ||
1066 | return typelist; | 1071 | return typelist; |
1067 | } | 1072 | } |
1068 | 1073 | ||
1069 | 1074 | ||
1070 | void PPPData::setScriptType(QStringList &list) { | 1075 | void PPPData::setScriptType(QStringList &list) { |
1071 | writeListConfig(cgroup, SCRIPTCOM_KEY, list); | 1076 | writeListConfig(cgroup, SCRIPTCOM_KEY, list); |
1072 | } | 1077 | } |
1073 | 1078 | ||
1074 | 1079 | ||
1075 | QStringList &PPPData::script() { | 1080 | QStringList &PPPData::script() { |
1076 | static QStringList scriptlist; | 1081 | static QStringList scriptlist; |
1077 | 1082 | ||
1078 | readListConfig(cgroup, SCRIPTARG_KEY, scriptlist); | 1083 | readListConfig(cgroup, SCRIPTARG_KEY, scriptlist); |
1079 | while(scriptlist.count() > MAX_SCRIPT_ENTRIES) | 1084 | while(scriptlist.count() > MAX_SCRIPT_ENTRIES) |
1080 | scriptlist.remove(scriptlist.last()); | 1085 | scriptlist.remove(scriptlist.last()); |
1081 | 1086 | ||
1082 | return scriptlist; | 1087 | return scriptlist; |
1083 | } | 1088 | } |
1084 | 1089 | ||
1085 | 1090 | ||
1086 | void PPPData::setScript(QStringList &list) { | 1091 | void PPPData::setScript(QStringList &list) { |
1087 | writeListConfig(cgroup, SCRIPTARG_KEY, list); | 1092 | writeListConfig(cgroup, SCRIPTARG_KEY, list); |
1088 | } | 1093 | } |
1089 | 1094 | ||
1090 | 1095 | ||
1091 | const QString PPPData::accountingFile() { | 1096 | const QString PPPData::accountingFile() { |
1092 | return readConfig(cgroup, ACCTFILE_KEY); | 1097 | return readConfig(cgroup, ACCTFILE_KEY); |
1093 | } | 1098 | } |
1094 | 1099 | ||
1095 | 1100 | ||
1096 | void PPPData::setAccountingFile(const QString &n) { | 1101 | void PPPData::setAccountingFile(const QString &n) { |
1097 | writeConfig(cgroup, ACCTFILE_KEY, n); | 1102 | writeConfig(cgroup, ACCTFILE_KEY, n); |
1098 | } | 1103 | } |
1099 | 1104 | ||
1100 | 1105 | ||
1101 | const QString PPPData::totalCosts() { | 1106 | const QString PPPData::totalCosts() { |
1102 | return readConfig(cgroup, TOTALCOSTS_KEY); | 1107 | return readConfig(cgroup, TOTALCOSTS_KEY); |
1103 | } | 1108 | } |
1104 | 1109 | ||
1105 | 1110 | ||
1106 | void PPPData::setTotalCosts(const QString &n) { | 1111 | void PPPData::setTotalCosts(const QString &n) { |
1107 | writeConfig(cgroup, TOTALCOSTS_KEY, n); | 1112 | writeConfig(cgroup, TOTALCOSTS_KEY, n); |
1108 | } | 1113 | } |
1109 | 1114 | ||
1110 | 1115 | ||
1111 | int PPPData::totalBytes() { | 1116 | int PPPData::totalBytes() { |
1112 | return readNumConfig(cgroup, TOTALBYTES_KEY, 0); | 1117 | return readNumConfig(cgroup, TOTALBYTES_KEY, 0); |
1113 | } | 1118 | } |
1114 | 1119 | ||
1115 | void PPPData::setTotalBytes(int n) { | 1120 | void PPPData::setTotalBytes(int n) { |
1116 | writeConfig(cgroup, TOTALBYTES_KEY, n); | 1121 | writeConfig(cgroup, TOTALBYTES_KEY, n); |
1117 | } | 1122 | } |
1118 | 1123 | ||
1119 | 1124 | ||
1120 | QStringList &PPPData::pppdArgument() { | 1125 | QStringList &PPPData::pppdArgument() { |
1121 | static QStringList arglist; | 1126 | static QStringList arglist; |
1122 | 1127 | ||
1123 | while(arglist.count() > MAX_PPPD_ARGUMENTS) | 1128 | while(arglist.count() > MAX_PPPD_ARGUMENTS) |
1124 | arglist.remove(arglist.last()); | 1129 | arglist.remove(arglist.last()); |
1125 | readListConfig(cgroup, PPPDARG_KEY, arglist); | 1130 | readListConfig(cgroup, PPPDARG_KEY, arglist); |
1126 | 1131 | ||
1127 | return arglist; | 1132 | return arglist; |
1128 | } | 1133 | } |
1129 | 1134 | ||
1130 | 1135 | ||
1131 | void PPPData::setpppdArgument(QStringList &args) { | 1136 | void PPPData::setpppdArgument(QStringList &args) { |
1132 | writeListConfig(cgroup, PPPDARG_KEY, args); | 1137 | writeListConfig(cgroup, PPPDARG_KEY, args); |
1133 | } | 1138 | } |
1134 | 1139 | ||
1135 | 1140 | ||
1136 | void PPPData::setpppdArgumentDefaults() { | 1141 | void PPPData::setpppdArgumentDefaults() { |
1137 | QStringList arg; | 1142 | QStringList arg; |
1138 | setpppdArgument(arg); | 1143 | setpppdArgument(arg); |
1139 | } | 1144 | } |
1140 | 1145 | ||
1141 | 1146 | ||
1142 | // graphing widget | 1147 | // // graphing widget |
1143 | void PPPData::setGraphingOptions(bool enable, | 1148 | // void PPPData::setGraphingOptions(bool enable, |
1144 | QColor bg, | 1149 | // QColor bg, |
1145 | QColor text, | 1150 | // QColor text, |
1146 | QColor in, | 1151 | // QColor in, |
1147 | QColor out) | 1152 | // QColor out) |
1148 | { | 1153 | // { |
1149 | if(config) { | 1154 | // if(config) { |
1150 | config->setGroup(GRAPH_GRP); | 1155 | // config->setGroup(GRAPH_GRP); |
1151 | config->writeEntry(GENABLED, enable); | 1156 | // config->writeEntry(GENABLED, enable); |
1152 | // config->writeEntry(GCOLOR_BG, bg); | 1157 | // // config->writeEntry(GCOLOR_BG, bg); |
1153 | // config->writeEntry(GCOLOR_TEXT, text); | 1158 | // // config->writeEntry(GCOLOR_TEXT, text); |
1154 | // config->writeEntry(GCOLOR_IN, in); | 1159 | // // config->writeEntry(GCOLOR_IN, in); |
1155 | // config->writeEntry(GCOLOR_OUT, out); | 1160 | // // config->writeEntry(GCOLOR_OUT, out); |
1156 | } | 1161 | // } |
1157 | } | 1162 | // } |
1158 | 1163 | ||
1159 | void PPPData::graphingOptions(bool &enable, | 1164 | // void PPPData::graphingOptions(bool &enable, |
1160 | QColor &bg, | 1165 | // QColor &bg, |
1161 | QColor &text, | 1166 | // QColor &text, |
1162 | QColor &in, | 1167 | // QColor &in, |
1163 | QColor &out) | 1168 | // QColor &out) |
1164 | { | 1169 | // { |
1165 | QColor c; | 1170 | // QColor c; |
1166 | 1171 | ||
1167 | if(config) { | 1172 | // if(config) { |
1168 | config->setGroup(GRAPH_GRP); | 1173 | // config->setGroup(GRAPH_GRP); |
1169 | enable = config->readBoolEntry(GENABLED, true); | 1174 | // enable = config->readBoolEntry(GENABLED, true); |
1170 | bg = Qt::white; | 1175 | // bg = Qt::white; |
1171 | //bg = config->readColorEntry(GCOLOR_BG, &c); | 1176 | // //bg = config->readColorEntry(GCOLOR_BG, &c); |
1172 | text = Qt::black; | 1177 | // text = Qt::black; |
1173 | //text = config->readColorEntry(GCOLOR_TEXT, &c); | 1178 | // //text = config->readColorEntry(GCOLOR_TEXT, &c); |
1174 | in = Qt::blue; | 1179 | // in = Qt::blue; |
1175 | //in = config->readColorEntry(GCOLOR_IN, &c); | 1180 | // //in = config->readColorEntry(GCOLOR_IN, &c); |
1176 | out = Qt::red; | 1181 | // out = Qt::red; |
1177 | //out = config->readColorEntry(GCOLOR_OUT, &c); | 1182 | // //out = config->readColorEntry(GCOLOR_OUT, &c); |
1178 | } | 1183 | // } |
1179 | } | 1184 | // } |
1180 | 1185 | ||
1181 | 1186 | ||
1182 | bool PPPData::graphingEnabled() { | 1187 | // bool PPPData::graphingEnabled() { |
1183 | return (bool) readNumConfig(GRAPH_GRP, GENABLED, true); | 1188 | // return (bool) readNumConfig(GRAPH_GRP, GENABLED, true); |
1184 | } | 1189 | // } |
1185 | 1190 | ||
1186 | 1191 | ||
1187 | 1192 | ||
1188 | // | 1193 | // |
1189 | //functions to change/set the child pppd process info | 1194 | //functions to change/set the child pppd process info |
1190 | // | 1195 | // |
1191 | bool PPPData::pppdRunning() const { | 1196 | bool PPPData::pppdRunning() const { |
1192 | return pppdisrunning; | 1197 | return pppdisrunning; |
1193 | } | 1198 | } |
1194 | 1199 | ||
1195 | void PPPData::setpppdRunning(bool set) { | 1200 | void PPPData::setpppdRunning(bool set) { |
1196 | pppdisrunning = set; | 1201 | pppdisrunning = set; |
1197 | } | 1202 | } |
1198 | 1203 | ||
1199 | int PPPData::pppdError() const { | 1204 | int PPPData::pppdError() const { |
1200 | return pppderror; | 1205 | return pppderror; |
1201 | } | 1206 | } |
1202 | 1207 | ||
1203 | void PPPData::setpppdError(int err) { | 1208 | void PPPData::setpppdError(int err) { |
1204 | pppderror = err; | 1209 | pppderror = err; |
1205 | } | 1210 | } |
1206 | 1211 | ||
1207 | 1212 | ||
1208 | // | 1213 | // // |
1209 | // window position | 1214 | // // window position |
1210 | // | 1215 | // // |
1211 | void PPPData::winPosConWin(int& p_x, int& p_y) { | 1216 | // void PPPData::winPosConWin(int& p_x, int& p_y) { |
1212 | p_x = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_X, QApplication::desktop()->width()/2-160); | 1217 | // p_x = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_X, QApplication::desktop()->width()/2-160); |
1213 | p_y = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_Y, QApplication::desktop()->height()/2-55); | 1218 | // p_y = readNumConfig(WINPOS_GRP, WINPOS_CONWIN_Y, QApplication::desktop()->height()/2-55); |
1214 | } | 1219 | // } |
1215 | 1220 | ||
1216 | void PPPData::setWinPosConWin(int p_x, int p_y) { | 1221 | // void PPPData::setWinPosConWin(int p_x, int p_y) { |
1217 | writeConfig(WINPOS_GRP, WINPOS_CONWIN_X, p_x); | 1222 | // writeConfig(WINPOS_GRP, WINPOS_CONWIN_X, p_x); |
1218 | writeConfig(WINPOS_GRP, WINPOS_CONWIN_Y, p_y); | 1223 | // writeConfig(WINPOS_GRP, WINPOS_CONWIN_Y, p_y); |
1219 | } | 1224 | // } |
1220 | 1225 | ||
1221 | void PPPData::winPosStatWin(int& p_x, int& p_y) { | 1226 | // void PPPData::winPosStatWin(int& p_x, int& p_y) { |
1222 | p_x = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_X, QApplication::desktop()->width()/2-160); | 1227 | // p_x = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_X, QApplication::desktop()->width()/2-160); |
1223 | p_y = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_Y, QApplication::desktop()->height()/2-55); | 1228 | // p_y = readNumConfig(WINPOS_GRP, WINPOS_STATWIN_Y, QApplication::desktop()->height()/2-55); |
1224 | } | 1229 | // } |
1225 | 1230 | ||
1226 | void PPPData::setWinPosStatWin(int p_x, int p_y) { | 1231 | // void PPPData::setWinPosStatWin(int p_x, int p_y) { |
1227 | writeConfig(WINPOS_GRP, WINPOS_STATWIN_X, p_x); | 1232 | // writeConfig(WINPOS_GRP, WINPOS_STATWIN_X, p_x); |
1228 | writeConfig(WINPOS_GRP, WINPOS_STATWIN_Y, p_y); | 1233 | // writeConfig(WINPOS_GRP, WINPOS_STATWIN_Y, p_y); |
1229 | } | 1234 | // } |
diff --git a/noncore/settings/networksettings/ppp/pppdata.h b/noncore/settings/networksettings/ppp/pppdata.h index e286b70..57ce2fd 100644 --- a/noncore/settings/networksettings/ppp/pppdata.h +++ b/noncore/settings/networksettings/ppp/pppdata.h | |||
@@ -1,465 +1,467 @@ | |||
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 <qstring.h> | 34 | #include <qstring.h> |
35 | #include <qstringlist.h> | 35 | #include <qstringlist.h> |
36 | #include <qcolor.h> | 36 | #include <qcolor.h> |
37 | 37 | ||
38 | #include "kpppconfig.h" | 38 | #include "kpppconfig.h" |
39 | 39 | ||
40 | class Config; | 40 | class Config; |
41 | 41 | ||
42 | // string lengths | 42 | // string lengths |
43 | 43 | ||
44 | #define PATH_SIZE 120 | 44 | #define PATH_SIZE 120 |
45 | #define MODEMSTR_SIZE 80 | 45 | #define MODEMSTR_SIZE 80 |
46 | #define ACCNAME_SIZE 50 | 46 | #define ACCNAME_SIZE 50 |
47 | #define PHONENUMBER_SIZE 60 | 47 | #define PHONENUMBER_SIZE 60 |
48 | #define COMMAND_SIZE 255 | 48 | #define COMMAND_SIZE 255 |
49 | #define IPADDR_SIZE 15 | 49 | #define IPADDR_SIZE 15 |
50 | #define DOMAIN_SIZE 50 | 50 | #define DOMAIN_SIZE 50 |
51 | #define TIMEOUT_SIZE 60 | 51 | #define TIMEOUT_SIZE 60 |
52 | 52 | ||
53 | // | 53 | // |
54 | // keys for config file | 54 | // keys for config file |
55 | // | 55 | // |
56 | 56 | ||
57 | // groups | 57 | // groups |
58 | #define GENERAL_GRP "General" | 58 | #define GENERAL_GRP "PPP_General" |
59 | #define MODEM_GRP "Modem" | 59 | #define MODEM_GRP "PPP_Modem" |
60 | #define ACCOUNT_GRP "Account" | 60 | #define ACCOUNT_GRP "PPP_Account" |
61 | #define GRAPH_GRP "Graph" | 61 | //#define GRAPH_GRP "Graph" |
62 | #define WINPOS_GRP "WindowPosition" | 62 | //#define WINPOS_GRP "WindowPosition" |
63 | 63 | ||
64 | // general | 64 | // general |
65 | #define DEFAULTACCOUNT_KEY "DefaultAccount" | 65 | #define DEFAULTACCOUNT_KEY "DefaultAccount" |
66 | #define PPPDVERSION_KEY "pppdVersion" | 66 | #define PPPDVERSION_KEY "pppdVersion" |
67 | #define PPPDTIMEOUT_KEY "pppdTimeout" | 67 | #define PPPDTIMEOUT_KEY "pppdTimeout" |
68 | #define SHOWCLOCK_KEY "ShowClock" | 68 | #define SHOWCLOCK_KEY "ShowClock" |
69 | #define SHOWLOGWIN_KEY "ShowLogWindow" | 69 | #define SHOWLOGWIN_KEY "ShowLogWindow" |
70 | #define AUTOREDIAL_KEY "AutomaticRedial" | 70 | #define AUTOREDIAL_KEY "AutomaticRedial" |
71 | #define DISCONNECT_KEY "DisconnectOnXServerExit" | 71 | #define DISCONNECT_KEY "DisconnectOnXServerExit" |
72 | #define QUITONDISCONNECT_KEY "QuitOnDisconnect" | 72 | #define QUITONDISCONNECT_KEY "QuitOnDisconnect" |
73 | #define NUMACCOUNTS_KEY "NumberOfAccounts" | 73 | #define NUMACCOUNTS_KEY "NumberOfAccounts" |
74 | #define ID_KEY "ID" | 74 | #define ID_KEY "ID" |
75 | 75 | ||
76 | // modem | 76 | // modem |
77 | #define MODEMDEV_KEY "Device" | 77 | #define MODEMDEV_KEY "Device" |
78 | #define LOCKFILE_KEY "UseLockFile" | 78 | #define LOCKFILE_KEY "UseLockFile" |
79 | #define FLOWCONTROL_KEY "FlowControl" | 79 | #define FLOWCONTROL_KEY "FlowControl" |
80 | #define SPEED_KEY "Speed" | 80 | #define SPEED_KEY "Speed" |
81 | #define TIMEOUT_KEY "Timeout" | 81 | #define TIMEOUT_KEY "Timeout" |
82 | #define TONEDURATION_KEY "ToneDuration" | 82 | #define TONEDURATION_KEY "ToneDuration" |
83 | #define BUSYWAIT_KEY "BusyWait" | 83 | #define BUSYWAIT_KEY "BusyWait" |
84 | #define INITSTR_KEY "InitString" | 84 | #define INITSTR_KEY "InitString" |
85 | #define INITRESP_KEY "InitResponse" | 85 | #define INITRESP_KEY "InitResponse" |
86 | #define PREINITDELAY_KEY "PreInitDelay" | 86 | #define PREINITDELAY_KEY "PreInitDelay" |
87 | #define INITDELAY_KEY "InitDelay" | 87 | #define INITDELAY_KEY "InitDelay" |
88 | #define NODTDETECT_KEY "NoDialToneDetection" | 88 | #define NODTDETECT_KEY "NoDialToneDetection" |
89 | #define DIALTONEWAIT_KEY "WaitForDialTone" | 89 | #define DIALTONEWAIT_KEY "WaitForDialTone" |
90 | #define DIALSTR_KEY "DialString" | 90 | #define DIALSTR_KEY "DialString" |
91 | #define CONNECTRESP_KEY "ConnectResponse" | 91 | #define CONNECTRESP_KEY "ConnectResponse" |
92 | #define BUSYRESP_KEY "BusyResponse" | 92 | #define BUSYRESP_KEY "BusyResponse" |
93 | #define NOCARRIERRESP_KEY "NoCarrierResponse" | 93 | #define NOCARRIERRESP_KEY "NoCarrierResponse" |
94 | #define NODIALTONERESP_KEY "NoDialToneResp" | 94 | #define NODIALTONERESP_KEY "NoDialToneResp" |
95 | #define HANGUPSTR_KEY "HangupString" | 95 | #define HANGUPSTR_KEY "HangupString" |
96 | #define HANGUPRESP_KEY "HangUpResponse" | 96 | #define HANGUPRESP_KEY "HangUpResponse" |
97 | #define ANSWERSTR_KEY "AnswerString" | 97 | #define ANSWERSTR_KEY "AnswerString" |
98 | #define RINGRESP_KEY "RingResponse" | 98 | #define RINGRESP_KEY "RingResponse" |
99 | #define ANSWERRESP_KEY "AnswerResponse" | 99 | #define ANSWERRESP_KEY "AnswerResponse" |
100 | #define ENTER_KEY "Enter" | 100 | #define ENTER_KEY "Enter" |
101 | #define ESCAPESTR_KEY "EscapeString" | 101 | #define ESCAPESTR_KEY "EscapeString" |
102 | #define ESCAPERESP_KEY "EscapeResponse" | 102 | #define ESCAPERESP_KEY "EscapeResponse" |
103 | #define ESCAPEGUARDTIME_KEY "EscapeGuardTime" | 103 | #define ESCAPEGUARDTIME_KEY "EscapeGuardTime" |
104 | #define USECDLINE_KEY "UseCDLine" | 104 | #define USECDLINE_KEY "UseCDLine" |
105 | #define VOLUME_HIGH "VolumeHigh" | 105 | #define VOLUME_HIGH "VolumeHigh" |
106 | #define VOLUME_MEDIUM "VolumeMedium" | 106 | #define VOLUME_MEDIUM "VolumeMedium" |
107 | #define VOLUME_OFF "VolumeOff" | 107 | #define VOLUME_OFF "VolumeOff" |
108 | #define VOLUME_KEY "Volume" | 108 | #define VOLUME_KEY "Volume" |
109 | 109 | ||
110 | // account | 110 | // account |
111 | #define NAME_KEY "Name" | 111 | #define NAME_KEY "Name" |
112 | #define PHONENUMBER_KEY "Phonenumber" | 112 | #define PHONENUMBER_KEY "Phonenumber" |
113 | #define DIAL_PREFIX_KEY "DialPrefix" | 113 | #define DIAL_PREFIX_KEY "DialPrefix" |
114 | #define AUTH_KEY "Authentication" | 114 | #define AUTH_KEY "Authentication" |
115 | #define STORED_PASSWORD_KEY "Password" | 115 | #define STORED_PASSWORD_KEY "Password" |
116 | #define STORED_USERNAME_KEY "Username" | 116 | #define STORED_USERNAME_KEY "Username" |
117 | #define STORE_PASSWORD_KEY "StorePassword" | 117 | #define STORE_PASSWORD_KEY "StorePassword" |
118 | #define BEFORE_CONNECT_KEY "BeforeConnect" | 118 | #define BEFORE_CONNECT_KEY "BeforeConnect" |
119 | #define COMMAND_KEY "Command" | 119 | #define COMMAND_KEY "Command" |
120 | #define DISCONNECT_COMMAND_KEY "DisconnectCommand" | 120 | #define DISCONNECT_COMMAND_KEY "DisconnectCommand" |
121 | #define BEFORE_DISCONNECT_KEY "BeforeDisconnect" | 121 | #define BEFORE_DISCONNECT_KEY "BeforeDisconnect" |
122 | #define IPADDR_KEY "IPAddr" | 122 | #define IPADDR_KEY "IPAddr" |
123 | #define SUBNETMASK_KEY "SubnetMask" | 123 | #define SUBNETMASK_KEY "SubnetMask" |
124 | #define ACCTENABLED_KEY "AccountingEnabled" | 124 | #define ACCTENABLED_KEY "AccountingEnabled" |
125 | #define VOLACCTENABLED_KEY "VolumeAccountingEnabled" | 125 | #define VOLACCTENABLED_KEY "VolumeAccountingEnabled" |
126 | #define ACCTFILE_KEY "AccountingFile" | 126 | #define ACCTFILE_KEY "AccountingFile" |
127 | #define AUTONAME_KEY "AutoName" | 127 | #define AUTONAME_KEY "AutoName" |
128 | #define GATEWAY_KEY "Gateway" | 128 | #define GATEWAY_KEY "Gateway" |
129 | #define DEFAULTROUTE_KEY "DefaultRoute" | 129 | #define DEFAULTROUTE_KEY "DefaultRoute" |
130 | #define DOMAIN_KEY "Domain" | 130 | #define DOMAIN_KEY "Domain" |
131 | #define DNS_KEY "DNS" | 131 | #define DNS_KEY "DNS" |
132 | #define AUTODNS_KEY "AutoDNS" | 132 | #define AUTODNS_KEY "AutoDNS" |
133 | #define EXDNSDISABLED_KEY "ExDNSDisabled" | 133 | #define EXDNSDISABLED_KEY "ExDNSDisabled" |
134 | #define SCRIPTCOM_KEY "ScriptCommands" | 134 | #define SCRIPTCOM_KEY "ScriptCommands" |
135 | #define SCRIPTARG_KEY "ScriptArguments" | 135 | #define SCRIPTARG_KEY "ScriptArguments" |
136 | #define PPPDARG_KEY "pppdArguments" | 136 | #define PPPDARG_KEY "pppdArguments" |
137 | #define PPP_DEBUG_OPTION "PPPDebug" | 137 | #define PPP_DEBUG_OPTION "PPPDebug" |
138 | #define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect" | 138 | #define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect" |
139 | #define DOCKING_KEY "DockIntoPanel" | 139 | #define DOCKING_KEY "DockIntoPanel" |
140 | #define TOTALCOSTS_KEY "TotalCosts" | 140 | #define TOTALCOSTS_KEY "TotalCosts" |
141 | #define TOTALBYTES_KEY "TotalBytes" | 141 | #define TOTALBYTES_KEY "TotalBytes" |
142 | 142 | ||
143 | // graph colors | 143 | // graph colors |
144 | #define GENABLED "Enabled" | 144 | #define GENABLED "Enabled" |
145 | #define GCOLOR_BG "Background" | 145 | #define GCOLOR_BG "Background" |
146 | #define GCOLOR_TEXT "Text" | 146 | #define GCOLOR_TEXT "Text" |
147 | #define GCOLOR_IN "InBytes" | 147 | #define GCOLOR_IN "InBytes" |
148 | #define GCOLOR_OUT "OutBytes" | 148 | #define GCOLOR_OUT "OutBytes" |
149 | 149 | ||
150 | // pppd errors | 150 | // pppd errors |
151 | #define E_IF_TIMEOUT 1 | 151 | #define E_IF_TIMEOUT 1 |
152 | #define E_PPPD_DIED 2 | 152 | #define E_PPPD_DIED 2 |
153 | 153 | ||
154 | // window position | 154 | // window position |
155 | #define WINPOS_CONWIN_X "WindowPositionConWinX" | 155 | #define WINPOS_CONWIN_X "WindowPositionConWinX" |
156 | #define WINPOS_CONWIN_Y "WindowPositionConWinY" | 156 | #define WINPOS_CONWIN_Y "WindowPositionConWinY" |
157 | #define WINPOS_STATWIN_X "WindowPositionStatWinX" | 157 | #define WINPOS_STATWIN_X "WindowPositionStatWinX" |
158 | #define WINPOS_STATWIN_Y "WindowPositionStatWinY" | 158 | #define WINPOS_STATWIN_Y "WindowPositionStatWinY" |
159 | 159 | ||
160 | class PPPData { | 160 | class PPPData { |
161 | public: | 161 | public: |
162 | PPPData(); | 162 | PPPData(); |
163 | ~PPPData() {}; | 163 | ~PPPData() {}; |
164 | static PPPData* data(); | ||
164 | 165 | ||
165 | enum { NumInitStrings = 2 }; | 166 | enum { NumInitStrings = 2 }; |
166 | 167 | ||
167 | // general functions | 168 | // general functions |
168 | bool open(); | 169 | bool open(); |
169 | void save(); | 170 | void save(); |
170 | void cancel(); | 171 | void cancel(); |
171 | int access() const; // read/write access | 172 | // int access() const; // read/write access |
172 | 173 | ||
173 | // function to read/write date to configuration file | 174 | // function to read/write date to configuration file |
174 | QString readConfig(const QString &, const QString &, const QString &); | 175 | QString readConfig(const QString &, const QString &, const QString &); |
175 | int readNumConfig(const QString &, const QString &, int); | 176 | int readNumConfig(const QString &, const QString &, int); |
176 | bool readListConfig(const QString &, const QString &, | 177 | bool readListConfig(const QString &, const QString &, |
177 | QStringList &, char sep = ','); | 178 | QStringList &, char sep = ','); |
178 | void writeConfig(const QString &, const QString &, const QString &); | 179 | void writeConfig(const QString &, const QString &, const QString &); |
179 | void writeConfig(const QString &, const QString &, int); | 180 | void writeConfig(const QString &, const QString &, int); |
180 | void writeListConfig(const QString &, const QString &, | 181 | void writeListConfig(const QString &, const QString &, |
181 | QStringList &, char sep = ','); | 182 | QStringList &, char sep = ','); |
182 | 183 | ||
183 | // return the current account group | 184 | // return the current account group |
184 | QString currentGroup() { return cgroup; } | 185 | QString currentGroup() { return cgroup; } |
185 | 186 | ||
186 | // functions to set/get general kppp info | 187 | // functions to set/get general kppp info |
187 | QString password() const; | 188 | QString password() const; |
188 | void setPassword(const QString &); | 189 | void setPassword(const QString &); |
189 | 190 | ||
190 | const QString defaultAccount(); | 191 | const QString defaultAccount(); |
191 | void setDefaultAccount(const QString &); | 192 | void setDefaultAccount(const QString &); |
192 | 193 | ||
193 | void set_xserver_exit_disconnect(bool set); | 194 | void set_xserver_exit_disconnect(bool set); |
194 | bool get_xserver_exit_disconnect(); | 195 | bool get_xserver_exit_disconnect(); |
195 | 196 | ||
196 | void setPPPDebug(bool set); | 197 | void setPPPDebug(bool set); |
197 | bool getPPPDebug(); | 198 | bool getPPPDebug(); |
198 | 199 | ||
199 | void set_quit_on_disconnect(bool); | 200 | void set_quit_on_disconnect(bool); |
200 | bool quit_on_disconnect(); | 201 | bool quit_on_disconnect(); |
201 | 202 | ||
202 | void set_show_clock_on_caption(bool set); | 203 | void set_show_clock_on_caption(bool set); |
203 | bool get_show_clock_on_caption(); | 204 | bool get_show_clock_on_caption(); |
204 | 205 | ||
205 | void set_show_log_window(bool set); | 206 | void set_show_log_window(bool set); |
206 | bool get_show_log_window(); | 207 | bool get_show_log_window(); |
207 | 208 | ||
208 | void set_automatic_redial(bool set); | 209 | void set_automatic_redial(bool set); |
209 | bool automatic_redial(); | 210 | bool automatic_redial(); |
210 | 211 | ||
211 | void set_iconify_on_connect(bool set); | 212 | void set_iconify_on_connect(bool set); |
212 | bool get_iconify_on_connect(); | 213 | bool get_iconify_on_connect(); |
213 | 214 | ||
214 | void set_dock_into_panel(bool set); | 215 | void set_dock_into_panel(bool set); |
215 | bool get_dock_into_panel(); | 216 | bool get_dock_into_panel(); |
216 | 217 | ||
217 | const QString enter(); | 218 | const QString enter(); |
218 | void setEnter(const QString &); | 219 | void setEnter(const QString &); |
219 | 220 | ||
220 | QString pppdVersion(); | 221 | QString pppdVersion(); |
221 | bool pppdVersionMin(int ver, int mod, int patch); | 222 | bool pppdVersionMin(int ver, int mod, int patch); |
222 | 223 | ||
223 | int pppdTimeout(); | 224 | int pppdTimeout(); |
224 | void setpppdTimeout(int); | 225 | void setpppdTimeout(int); |
225 | 226 | ||
226 | int busyWait(); | 227 | int busyWait(); |
227 | void setbusyWait(int); | 228 | void setbusyWait(int); |
228 | 229 | ||
229 | bool modemLockFile(); | 230 | bool modemLockFile(); |
230 | void setModemLockFile(bool set); | 231 | void setModemLockFile(bool set); |
231 | 232 | ||
232 | int modemEscapeGuardTime(); | 233 | int modemEscapeGuardTime(); |
233 | void setModemEscapeGuardTime(int i); | 234 | void setModemEscapeGuardTime(int i); |
234 | 235 | ||
235 | void setModemEscapeStr(const QString &); | 236 | void setModemEscapeStr(const QString &); |
236 | const QString modemEscapeStr(); | 237 | const QString modemEscapeStr(); |
237 | 238 | ||
238 | void setModemEscapeResp(const QString &); | 239 | void setModemEscapeResp(const QString &); |
239 | const QString modemEscapeResp(); | 240 | const QString modemEscapeResp(); |
240 | 241 | ||
241 | const QString modemDevice(); | 242 | const QString modemDevice(); |
242 | void setModemDevice(const QString &); | 243 | void setModemDevice(const QString &); |
243 | 244 | ||
244 | const QString flowcontrol(); | 245 | const QString flowcontrol(); |
245 | void setFlowcontrol(const QString &); | 246 | void setFlowcontrol(const QString &); |
246 | 247 | ||
247 | int modemTimeout(); | 248 | int modemTimeout(); |
248 | void setModemTimeout(int); | 249 | void setModemTimeout(int); |
249 | 250 | ||
250 | int modemToneDuration(); | 251 | int modemToneDuration(); |
251 | void setModemToneDuration(int); | 252 | void setModemToneDuration(int); |
252 | 253 | ||
253 | QString volumeInitString(); | 254 | QString volumeInitString(); |
254 | int volume(); | 255 | int volume(); |
255 | void setVolume(int); | 256 | void setVolume(int); |
256 | 257 | ||
257 | int waitForDialTone(); | 258 | int waitForDialTone(); |
258 | void setWaitForDialTone(int i); | 259 | void setWaitForDialTone(int i); |
259 | 260 | ||
260 | // modem command strings/responses | 261 | // modem command strings/responses |
261 | const QString modemInitStr(int i); | 262 | const QString modemInitStr(int i); |
262 | void setModemInitStr(int i, const QString &); | 263 | void setModemInitStr(int i, const QString &); |
263 | 264 | ||
264 | const QString modemInitResp(); | 265 | const QString modemInitResp(); |
265 | void setModemInitResp(const QString &); | 266 | void setModemInitResp(const QString &); |
266 | 267 | ||
267 | int modemPreInitDelay(); | 268 | int modemPreInitDelay(); |
268 | void setModemPreInitDelay(int); | 269 | void setModemPreInitDelay(int); |
269 | 270 | ||
270 | int modemInitDelay(); | 271 | int modemInitDelay(); |
271 | void setModemInitDelay(int); | 272 | void setModemInitDelay(int); |
272 | 273 | ||
273 | QString modemNoDialToneDetectionStr(); | 274 | QString modemNoDialToneDetectionStr(); |
274 | void setModemNoDialToneDetectionStr(const QString &); | 275 | void setModemNoDialToneDetectionStr(const QString &); |
275 | 276 | ||
276 | const QString modemDialStr(); | 277 | const QString modemDialStr(); |
277 | void setModemDialStr(const QString &); | 278 | void setModemDialStr(const QString &); |
278 | 279 | ||
279 | const QString modemConnectResp(); | 280 | const QString modemConnectResp(); |
280 | void setModemConnectResp(const QString &); | 281 | void setModemConnectResp(const QString &); |
281 | 282 | ||
282 | const QString modemBusyResp(); | 283 | const QString modemBusyResp(); |
283 | void setModemBusyResp(const QString &); | 284 | void setModemBusyResp(const QString &); |
284 | 285 | ||
285 | const QString modemNoCarrierResp(); | 286 | const QString modemNoCarrierResp(); |
286 | void setModemNoCarrierResp(const QString &); | 287 | void setModemNoCarrierResp(const QString &); |
287 | 288 | ||
288 | const QString modemNoDialtoneResp(); | 289 | const QString modemNoDialtoneResp(); |
289 | void setModemNoDialtoneResp(const QString &); | 290 | void setModemNoDialtoneResp(const QString &); |
290 | 291 | ||
291 | const QString modemHangupStr(); | 292 | const QString modemHangupStr(); |
292 | void setModemHangupStr(const QString &); | 293 | void setModemHangupStr(const QString &); |
293 | 294 | ||
294 | const QString modemHangupResp(); | 295 | const QString modemHangupResp(); |
295 | void setModemHangupResp(const QString &); | 296 | void setModemHangupResp(const QString &); |
296 | 297 | ||
297 | const QString modemAnswerStr(); | 298 | const QString modemAnswerStr(); |
298 | void setModemAnswerStr(const QString &); | 299 | void setModemAnswerStr(const QString &); |
299 | 300 | ||
300 | const QString modemRingResp(); | 301 | const QString modemRingResp(); |
301 | void setModemRingResp(const QString &); | 302 | void setModemRingResp(const QString &); |
302 | 303 | ||
303 | const QString modemAnswerResp(); | 304 | const QString modemAnswerResp(); |
304 | void setModemAnswerResp(const QString &); | 305 | void setModemAnswerResp(const QString &); |
305 | 306 | ||
306 | QString volumeOff(); | 307 | QString volumeOff(); |
307 | void setVolumeOff(const QString &); | 308 | void setVolumeOff(const QString &); |
308 | 309 | ||
309 | QString volumeMedium(); | 310 | QString volumeMedium(); |
310 | void setVolumeMedium(const QString &); | 311 | void setVolumeMedium(const QString &); |
311 | 312 | ||
312 | QString volumeHigh(); | 313 | QString volumeHigh(); |
313 | void setVolumeHigh(const QString &); | 314 | void setVolumeHigh(const QString &); |
314 | 315 | ||
315 | #if 0 | 316 | #if 0 |
316 | void setUseCDLine(const int n); | 317 | void setUseCDLine(const int n); |
317 | int UseCDLine(); | 318 | int UseCDLine(); |
318 | #endif | 319 | #endif |
319 | 320 | ||
320 | // functions to set/get account information | 321 | // functions to set/get account information |
321 | int count() const; | 322 | int count() const; |
322 | bool setAccount(const QString &); | 323 | bool setAccount(const QString &); |
323 | bool setAccountbyIndex(int); | 324 | bool setAccountbyIndex(int); |
324 | 325 | ||
325 | bool isUniqueAccname(const QString &); | 326 | bool isUniqueAccname(const QString &); |
326 | 327 | ||
327 | bool deleteAccount(); | 328 | bool deleteAccount(); |
328 | bool deleteAccount(const QString &); | 329 | bool deleteAccount(const QString &); |
329 | int newaccount(); | 330 | int newaccount(); |
330 | int copyaccount(int i); | 331 | int copyaccount(int i); |
331 | 332 | ||
332 | const QString accname(); | 333 | const QString accname(); |
333 | void setAccname(const QString &); | 334 | void setAccname(const QString &); |
334 | 335 | ||
335 | QStringList &phonenumbers(); | 336 | QStringList &phonenumbers(); |
336 | const QString phonenumber(); | 337 | const QString phonenumber(); |
337 | void setPhonenumber(const QString &); | 338 | void setPhonenumber(const QString &); |
338 | 339 | ||
339 | const QString dialPrefix(); | 340 | const QString dialPrefix(); |
340 | void setDialPrefix(const QString &); | 341 | void setDialPrefix(const QString &); |
341 | 342 | ||
342 | int authMethod(); | 343 | int authMethod(); |
343 | void setAuthMethod(int); | 344 | void setAuthMethod(int); |
344 | 345 | ||
345 | const QString storedUsername(); | 346 | const QString storedUsername(); |
346 | void setStoredUsername(const QString &); | 347 | void setStoredUsername(const QString &); |
347 | 348 | ||
348 | const QString storedPassword(); | 349 | const QString storedPassword(); |
349 | void setStoredPassword(const QString &); | 350 | void setStoredPassword(const QString &); |
350 | 351 | ||
351 | bool storePassword(); | 352 | bool storePassword(); |
352 | void setStorePassword(bool); | 353 | void setStorePassword(bool); |
353 | 354 | ||
354 | const QString speed(); | 355 | const QString speed(); |
355 | void setSpeed(const QString &); | 356 | void setSpeed(const QString &); |
356 | 357 | ||
357 | const QString command_before_connect(); | 358 | const QString command_before_connect(); |
358 | void setCommand_before_connect(const QString &); | 359 | void setCommand_before_connect(const QString &); |
359 | 360 | ||
360 | const QString command_on_connect(); | 361 | const QString command_on_connect(); |
361 | void setCommand_on_connect(const QString &); | 362 | void setCommand_on_connect(const QString &); |
362 | 363 | ||
363 | const QString command_on_disconnect(); | 364 | const QString command_on_disconnect(); |
364 | void setCommand_on_disconnect(const QString &); | 365 | void setCommand_on_disconnect(const QString &); |
365 | 366 | ||
366 | const QString command_before_disconnect(); | 367 | const QString command_before_disconnect(); |
367 | void setCommand_before_disconnect(const QString &); | 368 | void setCommand_before_disconnect(const QString &); |
368 | 369 | ||
369 | const QString ipaddr(); | 370 | const QString ipaddr(); |
370 | void setIpaddr(const QString &); | 371 | void setIpaddr(const QString &); |
371 | 372 | ||
372 | const QString subnetmask(); | 373 | const QString subnetmask(); |
373 | void setSubnetmask(const QString &); | 374 | void setSubnetmask(const QString &); |
374 | 375 | ||
375 | bool AcctEnabled(); | 376 | bool AcctEnabled(); |
376 | void setAcctEnabled(bool set); | 377 | void setAcctEnabled(bool set); |
377 | 378 | ||
378 | int VolAcctEnabled(); | 379 | int VolAcctEnabled(); |
379 | void setVolAcctEnabled(int set); | 380 | void setVolAcctEnabled(int set); |
380 | 381 | ||
381 | bool autoDNS(); | 382 | bool autoDNS(); |
382 | void setAutoDNS(bool set); | 383 | void setAutoDNS(bool set); |
383 | 384 | ||
384 | bool exDNSDisabled(); | 385 | bool exDNSDisabled(); |
385 | void setExDNSDisabled(bool set); | 386 | void setExDNSDisabled(bool set); |
386 | 387 | ||
387 | bool autoname(); | 388 | bool autoname(); |
388 | void setAutoname(bool set); | 389 | void setAutoname(bool set); |
389 | 390 | ||
390 | const QString gateway(); | 391 | const QString gateway(); |
391 | void setGateway(const QString &); | 392 | void setGateway(const QString &); |
392 | 393 | ||
393 | bool defaultroute(); | 394 | bool defaultroute(); |
394 | void setDefaultroute(bool set); | 395 | void setDefaultroute(bool set); |
395 | 396 | ||
396 | QStringList &dns(); | 397 | QStringList &dns(); |
397 | void setDns(QStringList &); | 398 | void setDns(QStringList &); |
398 | 399 | ||
399 | const QString domain(); | 400 | const QString domain(); |
400 | void setDomain(const QString &); | 401 | void setDomain(const QString &); |
401 | 402 | ||
402 | QStringList &scriptType(); | 403 | QStringList &scriptType(); |
403 | void setScriptType(QStringList &); | 404 | void setScriptType(QStringList &); |
404 | 405 | ||
405 | QStringList &script(); | 406 | QStringList &script(); |
406 | void setScript(QStringList &); | 407 | void setScript(QStringList &); |
407 | 408 | ||
408 | QStringList &pppdArgument(); | 409 | QStringList &pppdArgument(); |
409 | void setpppdArgumentDefaults(); | 410 | void setpppdArgumentDefaults(); |
410 | void setpppdArgument(QStringList &); | 411 | void setpppdArgument(QStringList &); |
411 | 412 | ||
412 | //functions to change/set the child pppd process info | 413 | //functions to change/set the child pppd process info |
413 | bool pppdRunning() const; | 414 | bool pppdRunning() const; |
414 | void setpppdRunning(bool set); | 415 | void setpppdRunning(bool set); |
415 | 416 | ||
416 | int pppdError() const; | 417 | int pppdError() const; |
417 | void setpppdError(int err); | 418 | void setpppdError(int err); |
418 | 419 | ||
419 | // functions to set/query the accounting info | 420 | // functions to set/query the accounting info |
420 | const QString accountingFile(); | 421 | const QString accountingFile(); |
421 | void setAccountingFile(const QString &); | 422 | void setAccountingFile(const QString &); |
422 | 423 | ||
423 | const QString totalCosts(); | 424 | const QString totalCosts(); |
424 | void setTotalCosts(const QString &); | 425 | void setTotalCosts(const QString &); |
425 | 426 | ||
426 | int totalBytes(); | 427 | int totalBytes(); |
427 | void setTotalBytes(int); | 428 | void setTotalBytes(int); |
428 | 429 | ||
429 | // graphing widget | 430 | // // graphing widget |
430 | void setGraphingOptions(bool enabled, | 431 | // void setGraphingOptions(bool enabled, |
431 | QColor bg, | 432 | // QColor bg, |
432 | QColor text, | 433 | // QColor text, |
433 | QColor in, | 434 | // QColor in, |
434 | QColor out); | 435 | // QColor out); |
435 | void graphingOptions(bool &enabled, | 436 | // void graphingOptions(bool &enabled, |
436 | QColor &bg, | 437 | // QColor &bg, |
437 | QColor &text, | 438 | // QColor &text, |
438 | QColor &in, | 439 | // QColor &in, |
439 | QColor &out); | 440 | // QColor &out); |
440 | bool graphingEnabled(); | 441 | // bool graphingEnabled(); |
441 | 442 | ||
442 | // window positions | 443 | // // window positions |
443 | void winPosConWin(int &, int &); | 444 | // void winPosConWin(int &, int &); |
444 | void setWinPosConWin(int, int); | 445 | // void setWinPosConWin(int, int); |
445 | void winPosStatWin(int &, int &); | 446 | // void winPosStatWin(int &, int &); |
446 | void setWinPosStatWin(int, int); | 447 | // void setWinPosStatWin(int, int); |
447 | 448 | ||
448 | private: | 449 | private: |
449 | QString passwd; | ||
450 | Config* config; // configuration object | ||
451 | int highcount; // index of highest account | ||
452 | int caccount; // index of the current account | ||
453 | QString cgroup; // name of current config group | ||
454 | pid_t suidprocessid; // process ID of setuid child | ||
455 | bool pppdisrunning; // pppd process | ||
456 | // daemon | ||
457 | int pppderror; // error encounterd running pppd | ||
458 | int pppdVer, pppdMod, pppdPatch; // pppd version | ||
459 | |||
460 | QStringList phonelist; | ||
461 | }; | ||
462 | 450 | ||
463 | extern PPPData gpppdata; | 451 | static PPPData *_data; |
452 | |||
453 | QString passwd; | ||
454 | static Config* config; // configuration object | ||
455 | int highcount; // index of highest account | ||
456 | int caccount; // index of the current account | ||
457 | QString cgroup; // name of current config group | ||
458 | pid_t suidprocessid; // process ID of setuid child | ||
459 | bool pppdisrunning; // pppd process | ||
460 | // daemon | ||
461 | int pppderror; // error encounterd running pppd | ||
462 | int pppdVer, pppdMod, pppdPatch; // pppd version | ||
463 | |||
464 | QStringList phonelist; | ||
465 | }; | ||
464 | 466 | ||
465 | #endif | 467 | #endif |
diff --git a/noncore/settings/networksettings/ppp/pppmodule.cpp b/noncore/settings/networksettings/ppp/pppmodule.cpp index d6ca88a..da17e26 100644 --- a/noncore/settings/networksettings/ppp/pppmodule.cpp +++ b/noncore/settings/networksettings/ppp/pppmodule.cpp | |||
@@ -1,120 +1,121 @@ | |||
1 | #include "pppconfig.h" | 1 | #include "pppconfig.h" |
2 | #include "pppmodule.h" | 2 | #include "pppmodule.h" |
3 | //#include "pppimp.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 | 13 | ||
14 | /** | 14 | /** |
15 | * Delete any interfaces that we own. | 15 | * Delete any interfaces that we own. |
16 | */ | 16 | */ |
17 | PPPModule::~PPPModule(){ | 17 | PPPModule::~PPPModule(){ |
18 | Interface *i; | 18 | Interface *i; |
19 | for ( i=list.first(); i != 0; i=list.next() ) | 19 | for ( i=list.first(); i != 0; i=list.next() ) |
20 | delete i; | 20 | delete i; |
21 | } | 21 | } |
22 | 22 | ||
23 | /** | 23 | /** |
24 | * Change the current profile | 24 | * Change the current profile |
25 | */ | 25 | */ |
26 | void PPPModule::setProfile(const QString &newProfile){ | 26 | void PPPModule::setProfile(const QString &newProfile){ |
27 | profile = newProfile; | 27 | profile = newProfile; |
28 | } | 28 | } |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * get the icon name for this device. | 31 | * get the icon name for this device. |
32 | * @param Interface* can be used in determining the icon. | 32 | * @param Interface* can be used in determining the icon. |
33 | * @return QString the icon name (minus .png, .gif etc) | 33 | * @return QString the icon name (minus .png, .gif etc) |
34 | */ | 34 | */ |
35 | QString PPPModule::getPixmapName(Interface* ){ | 35 | QString PPPModule::getPixmapName(Interface* ){ |
36 | return "ppp"; | 36 | return "ppp"; |
37 | } | 37 | } |
38 | 38 | ||
39 | /** | 39 | /** |
40 | * Check to see if the interface i is owned by this module. | 40 | * Check to see if the interface i is owned by this module. |
41 | * @param Interface* interface to check against | 41 | * @param Interface* interface to check against |
42 | * @return bool true if i is owned by this module, false otherwise. | 42 | * @return bool true if i is owned by this module, false otherwise. |
43 | */ | 43 | */ |
44 | bool PPPModule::isOwner(Interface *i){ | 44 | bool PPPModule::isOwner(Interface *i){ |
45 | if(!i->getInterfaceName().upper().contains("PPP")) | 45 | if(!i->getInterfaceName().upper().contains("PPP")) |
46 | return false; | 46 | return false; |
47 | 47 | ||
48 | i->setHardwareName("PPP"); | 48 | i->setHardwareName("PPP"); |
49 | list.append(i); | 49 | list.append(i); |
50 | return true; | 50 | return true; |
51 | } | 51 | } |
52 | 52 | ||
53 | /** | 53 | /** |
54 | * Create, and return the WLANConfigure Module | 54 | * Create, and return the WLANConfigure Module |
55 | * @return QWidget* pointer to this modules configure. | 55 | * @return QWidget* pointer to this modules configure. |
56 | */ | 56 | */ |
57 | QWidget *PPPModule::configure(Interface *i){ | 57 | QWidget *PPPModule::configure(Interface *i){ |
58 | qDebug("return ModemWidget"); | 58 | qDebug("return ModemWidget"); |
59 | PPPConfigWidget *pppconfig = new PPPConfigWidget( 0, "PPPConfig", false, Qt::WDestructiveClose ); | 59 | PPPConfigWidget *pppconfig = new PPPConfigWidget( 0, "PPPConfig", false, Qt::WDestructiveClose ); |
60 | // pppconfig->setProfile(profile); | 60 | // pppconfig->setProfile(profile); |
61 | return pppconfig; | 61 | return pppconfig; |
62 | } | 62 | } |
63 | 63 | ||
64 | /** | 64 | /** |
65 | * Create, and return the Information Module | 65 | * Create, and return the Information Module |
66 | * @return QWidget* pointer to this modules info. | 66 | * @return QWidget* pointer to this modules info. |
67 | */ | 67 | */ |
68 | QWidget *PPPModule::information(Interface *i){ | 68 | QWidget *PPPModule::information(Interface *i){ |
69 | // We don't have any advanced pppd information widget yet :-D | 69 | // We don't have any advanced pppd information widget yet :-D |
70 | // TODO ^ | 70 | // TODO ^ |
71 | qDebug("return PPPModule::information"); | 71 | qDebug("return PPPModule::information"); |
72 | InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i); | 72 | InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i); |
73 | return information; | 73 | return information; |
74 | } | 74 | } |
75 | 75 | ||
76 | /** | 76 | /** |
77 | * Get all active (up or down) interfaces | 77 | * Get all active (up or down) interfaces |
78 | * @return QList<Interface> A list of interfaces that exsist that havn't | 78 | * @return QList<Interface> A list of interfaces that exsist that havn't |
79 | * been called by isOwner() | 79 | * been called by isOwner() |
80 | */ | 80 | */ |
81 | QList<Interface> PPPModule::getInterfaces(){ | 81 | QList<Interface> PPPModule::getInterfaces(){ |
82 | // List all of the files in the peer directory | 82 | // List all of the files in the peer directory |
83 | return list; | 83 | return list; |
84 | } | 84 | } |
85 | 85 | ||
86 | /** | 86 | /** |
87 | * Attempt to add a new interface as defined by name | 87 | * Attempt to add a new interface as defined by name |
88 | * @param name the name of the type of interface that should be created given | 88 | * @param name the name of the type of interface that should be created given |
89 | * by possibleNewInterfaces(); | 89 | * by possibleNewInterfaces(); |
90 | * @return Interface* NULL if it was unable to be created. | 90 | * @return Interface* NULL if it was unable to be created. |
91 | */ | 91 | */ |
92 | Interface *PPPModule::addNewInterface(const QString &newInterface){ | 92 | Interface *PPPModule::addNewInterface(const QString &newInterface){ |
93 | 93 | ||
94 | qDebug("try to add iface %s",newInterface.latin1()); | 94 | qDebug("try to add iface %s",newInterface.latin1()); |
95 | 95 | ||
96 | PPPConfigWidget imp(0, "PPPConfigImp", true); | 96 | PPPConfigWidget imp(0, "PPPConfigImp", true); |
97 | imp.showMaximized(); | 97 | imp.showMaximized(); |
98 | if(imp.exec() == QDialog::Accepted ){ | 98 | if(imp.exec() == QDialog::Accepted ){ |
99 | qDebug("ACCEPTED"); | 99 | qDebug("ACCEPTED"); |
100 | return new Interface( 0, newInterface ); | 100 | return new Interface( 0, newInterface ); |
101 | PPPData::data()->save(); | ||
101 | } | 102 | } |
102 | return NULL; | 103 | return NULL; |
103 | } | 104 | } |
104 | 105 | ||
105 | /** | 106 | /** |
106 | * Attempts to remove the interface, doesn't delete i | 107 | * Attempts to remove the interface, doesn't delete i |
107 | * @return bool true if successfull, false otherwise. | 108 | * @return bool true if successfull, false otherwise. |
108 | */ | 109 | */ |
109 | bool PPPModule::remove(Interface*){ | 110 | bool PPPModule::remove(Interface*){ |
110 | // Can't remove a hardware device, you can stop it though. | 111 | // Can't remove a hardware device, you can stop it though. |
111 | return false; | 112 | return false; |
112 | } | 113 | } |
113 | 114 | ||
114 | void PPPModule::possibleNewInterfaces(QMap<QString, QString> &newIfaces) | 115 | void PPPModule::possibleNewInterfaces(QMap<QString, QString> &newIfaces) |
115 | { | 116 | { |
116 | qDebug("here"); | 117 | qDebug("here"); |
117 | newIfaces.insert(QObject::tr("PPP") ,QObject::tr("generic ppp device")); | 118 | newIfaces.insert(QObject::tr("PPP") ,QObject::tr("generic ppp device")); |
118 | } | 119 | } |
119 | 120 | ||
120 | 121 | ||