-rw-r--r-- | noncore/settings/usermanager/userdialog.cpp | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/noncore/settings/usermanager/userdialog.cpp b/noncore/settings/usermanager/userdialog.cpp index c43b391..42a9144 100644 --- a/noncore/settings/usermanager/userdialog.cpp +++ b/noncore/settings/usermanager/userdialog.cpp | |||
@@ -81,66 +81,66 @@ void UserDialog::setupTab1() { | |||
81 | uidLineEdit->setEnabled(false); | 81 | uidLineEdit->setEnabled(false); |
82 | 82 | ||
83 | // Username (gecos) | 83 | // Username (gecos) |
84 | QLabel *gecosLabel=new QLabel(tabpage,"gecos"); | 84 | QLabel *gecosLabel=new QLabel(tabpage,"gecos"); |
85 | gecosLabel->setText("Username: "); | 85 | gecosLabel->setText("Username: "); |
86 | gecosLineEdit=new QLineEdit(tabpage,"gecos"); | 86 | gecosLineEdit=new QLineEdit(tabpage,"gecos"); |
87 | 87 | ||
88 | // Password | 88 | // Password |
89 | QLabel *passwordLabel=new QLabel(tabpage,"password"); | 89 | QLabel *passwordLabel=new QLabel(tabpage,"password"); |
90 | passwordLabel->setText("Password: "); | 90 | passwordLabel->setText("Password: "); |
91 | passwordLineEdit=new QLineEdit(tabpage,"password"); | 91 | passwordLineEdit=new QLineEdit(tabpage,"password"); |
92 | passwordLineEdit->setEchoMode(QLineEdit::Password); | 92 | passwordLineEdit->setEchoMode(QLineEdit::Password); |
93 | 93 | ||
94 | // Shell | 94 | // Shell |
95 | QLabel *shellLabel=new QLabel(tabpage,"shell"); | 95 | QLabel *shellLabel=new QLabel(tabpage,"shell"); |
96 | shellLabel->setText("Shell: "); | 96 | shellLabel->setText("Shell: "); |
97 | shellComboBox=new QComboBox(tabpage,"shell"); | 97 | shellComboBox=new QComboBox(tabpage,"shell"); |
98 | shellComboBox->setEditable(true); | 98 | shellComboBox->setEditable(true); |
99 | shellComboBox->insertItem("/bin/sh"); | 99 | shellComboBox->insertItem("/bin/sh"); |
100 | shellComboBox->insertItem("/bin/ash"); | 100 | shellComboBox->insertItem("/bin/ash"); |
101 | shellComboBox->insertItem("/bin/false"); | 101 | shellComboBox->insertItem("/bin/false"); |
102 | 102 | ||
103 | // Primary Group | 103 | // Primary Group |
104 | QLabel *groupLabel=new QLabel(tabpage,"group"); | 104 | QLabel *groupLabel=new QLabel(tabpage,"group"); |
105 | groupLabel->setText("Primary group: "); | 105 | groupLabel->setText("Primary group: "); |
106 | groupComboBox=new QComboBox(tabpage,"PrimaryGroup"); | 106 | groupComboBox=new QComboBox(tabpage,"PrimaryGroup"); |
107 | 107 | ||
108 | // Copy /etc/skel | 108 | // Copy /etc/skel |
109 | QLabel *skelLabel=new QLabel(tabpage,"skel"); | 109 | QLabel *skelLabel=new QLabel(tabpage,"skel"); |
110 | skelLabel->setText("Copy /etc/skel: "); | 110 | skelLabel->setText("Copy /etc/skel: "); |
111 | skelCheckBox=new QCheckBox(tabpage); | 111 | skelCheckBox=new QCheckBox(tabpage); |
112 | skelCheckBox->setChecked(true); | 112 | skelCheckBox->setChecked(true); |
113 | skelLabel->setDisabled(true); | 113 | //skelLabel->setDisabled(true); |
114 | skelCheckBox->setDisabled(true); | 114 | //skelCheckBox->setDisabled(true); |
115 | 115 | ||
116 | // Widget layout | 116 | // Widget layout |
117 | QHBoxLayout *hlayout=new QHBoxLayout(-1,"hlayout"); | 117 | QHBoxLayout *hlayout=new QHBoxLayout(-1,"hlayout"); |
118 | layout->addWidget(picturePushButton); | 118 | layout->addWidget(picturePushButton); |
119 | layout->addSpacing(5); | 119 | layout->addSpacing(5); |
120 | layout->addLayout(hlayout); | 120 | layout->addLayout(hlayout); |
121 | QVBoxLayout *vlayout1=new QVBoxLayout(-1,"vlayout1"); | 121 | QVBoxLayout *vlayout1=new QVBoxLayout(-1,"vlayout1"); |
122 | QVBoxLayout *vlayout2=new QVBoxLayout(-1,"vlayout2"); | 122 | QVBoxLayout *vlayout2=new QVBoxLayout(-1,"vlayout2"); |
123 | // First column, labels | 123 | // First column, labels |
124 | vlayout1->addWidget(loginLabel); | 124 | vlayout1->addWidget(loginLabel); |
125 | vlayout1->addSpacing(5); | 125 | vlayout1->addSpacing(5); |
126 | vlayout1->addWidget(uidLabel); | 126 | vlayout1->addWidget(uidLabel); |
127 | vlayout1->addSpacing(5); | 127 | vlayout1->addSpacing(5); |
128 | vlayout1->addWidget(gecosLabel); | 128 | vlayout1->addWidget(gecosLabel); |
129 | vlayout1->addSpacing(5); | 129 | vlayout1->addSpacing(5); |
130 | vlayout1->addWidget(passwordLabel); | 130 | vlayout1->addWidget(passwordLabel); |
131 | vlayout1->addSpacing(5); | 131 | vlayout1->addSpacing(5); |
132 | vlayout1->addWidget(shellLabel); | 132 | vlayout1->addWidget(shellLabel); |
133 | vlayout1->addSpacing(5); | 133 | vlayout1->addSpacing(5); |
134 | vlayout1->addWidget(groupLabel); | 134 | vlayout1->addWidget(groupLabel); |
135 | vlayout1->addSpacing(5); | 135 | vlayout1->addSpacing(5); |
136 | vlayout1->addWidget(skelLabel); | 136 | vlayout1->addWidget(skelLabel); |
137 | // Second column, data | 137 | // Second column, data |
138 | vlayout2->addWidget(loginLineEdit); | 138 | vlayout2->addWidget(loginLineEdit); |
139 | vlayout2->addSpacing(5); | 139 | vlayout2->addSpacing(5); |
140 | vlayout2->addWidget(uidLineEdit); | 140 | vlayout2->addWidget(uidLineEdit); |
141 | vlayout2->addSpacing(5); | 141 | vlayout2->addSpacing(5); |
142 | vlayout2->addWidget(gecosLineEdit); | 142 | vlayout2->addWidget(gecosLineEdit); |
143 | vlayout2->addSpacing(5); | 143 | vlayout2->addSpacing(5); |
144 | vlayout2->addWidget(passwordLineEdit); | 144 | vlayout2->addWidget(passwordLineEdit); |
145 | vlayout2->addSpacing(5); | 145 | vlayout2->addSpacing(5); |
146 | vlayout2->addWidget(shellComboBox); | 146 | vlayout2->addWidget(shellComboBox); |
@@ -214,64 +214,80 @@ bool UserDialog::addUser(int uid, int gid) { | |||
214 | } | 214 | } |
215 | // Show the dialog! | 215 | // Show the dialog! |
216 | if(!(adduserDialog->exec())) return false; | 216 | if(!(adduserDialog->exec())) return false; |
217 | if((adduserDialog->groupComboBox->currentItem()!=0)) { | 217 | if((adduserDialog->groupComboBox->currentItem()!=0)) { |
218 | accounts->findGroup(adduserDialog->groupComboBox->currentText()); | 218 | accounts->findGroup(adduserDialog->groupComboBox->currentText()); |
219 | adduserDialog->groupID=accounts->gr_gid; | 219 | adduserDialog->groupID=accounts->gr_gid; |
220 | qWarning(QString::number(accounts->gr_gid)); | 220 | qWarning(QString::number(accounts->gr_gid)); |
221 | } | 221 | } |
222 | if(!(accounts->addUser(adduserDialog->loginLineEdit->text(), adduserDialog->passwordLineEdit->text(), | 222 | if(!(accounts->addUser(adduserDialog->loginLineEdit->text(), adduserDialog->passwordLineEdit->text(), |
223 | adduserDialog->uidLineEdit->text().toInt(), adduserDialog->groupID, adduserDialog->gecosLineEdit->text(), | 223 | adduserDialog->uidLineEdit->text().toInt(), adduserDialog->groupID, adduserDialog->gecosLineEdit->text(), |
224 | QString("/home/")+adduserDialog->loginLineEdit->text() , adduserDialog->shellComboBox->currentText()))) { | 224 | QString("/home/")+adduserDialog->loginLineEdit->text() , adduserDialog->shellComboBox->currentText()))) { |
225 | QMessageBox::information(0,"Ooops!","Something went wrong!\nUnable to add user."); | 225 | QMessageBox::information(0,"Ooops!","Something went wrong!\nUnable to add user."); |
226 | return false; | 226 | return false; |
227 | } | 227 | } |
228 | 228 | ||
229 | // Add User to additional groups. | 229 | // Add User to additional groups. |
230 | QListViewItemIterator it( adduserDialog->groupsListView ); | 230 | QListViewItemIterator it( adduserDialog->groupsListView ); |
231 | for ( ; it.current(); ++it ) { | 231 | for ( ; it.current(); ++it ) { |
232 | temp=(QCheckListItem*)it.current(); | 232 | temp=(QCheckListItem*)it.current(); |
233 | if (temp->isOn() ) | 233 | if (temp->isOn() ) |
234 | accounts->addGroupMember(it.current()->text(0),adduserDialog->loginLineEdit->text()); | 234 | accounts->addGroupMember(it.current()->text(0),adduserDialog->loginLineEdit->text()); |
235 | } | 235 | } |
236 | // Copy image to pics/users/ | 236 | // Copy image to pics/users/ |
237 | if(!(adduserDialog->userImage.isNull())) { | 237 | if(!(adduserDialog->userImage.isNull())) { |
238 | QDir d; | 238 | QDir d; |
239 | if(!(d.exists("/opt/QtPalmtop/pics/users"))) { | 239 | if(!(d.exists("/opt/QtPalmtop/pics/users"))) { |
240 | d.mkdir("/opt/QtPalmtop/pics/users"); | 240 | d.mkdir("/opt/QtPalmtop/pics/users"); |
241 | } | 241 | } |
242 | QString filename="/opt/QtPalmtop/pics/users/"+accounts->pw_name+".png"; | 242 | QString filename="/opt/QtPalmtop/pics/users/"+accounts->pw_name+".png"; |
243 | // adduserDialog->userImage=adduserDialog->userImage.smoothScale(48,48); | 243 | // adduserDialog->userImage=adduserDialog->userImage.smoothScale(48,48); |
244 | adduserDialog->userImage.save(filename,"PNG"); | 244 | adduserDialog->userImage.save(filename,"PNG"); |
245 | } | 245 | } |
246 | |||
247 | // Should we copy the skeleton homedirectory /etc/skel to the user's homedirectory? | ||
248 | accounts->findUser(adduserDialog->loginLineEdit->text()); | ||
249 | if(adduserDialog->skelCheckBox->isChecked()) { | ||
250 | QString command_cp; | ||
251 | QString command_chown; | ||
252 | command_cp.sprintf("cp -a /etc/skel/* %s/",accounts->pw_dir.latin1()); | ||
253 | system(command_cp); | ||
254 | |||
255 | command_cp.sprintf("cp -a /etc/skel/.[!.]* %s/",accounts->pw_dir.latin1());// Bug in busybox, ".*" includes parent directory, does this work as a workaround? | ||
256 | system(command_cp); | ||
257 | |||
258 | command_chown.sprintf("chown -R %d:%d %s",accounts->pw_uid,accounts->pw_gid,accounts->pw_dir.latin1()); | ||
259 | system(command_chown); | ||
260 | } | ||
261 | |||
246 | return true; | 262 | return true; |
247 | } | 263 | } |
248 | 264 | ||
249 | /** | 265 | /** |
250 | * Deletes the user account. | 266 | * Deletes the user account. |
251 | * | 267 | * |
252 | * @param username User to be deleted. | 268 | * @param username User to be deleted. |
253 | * | 269 | * |
254 | * @return <code>true</code> if the user was successfully deleted, otherwise <code>false</code>. | 270 | * @return <code>true</code> if the user was successfully deleted, otherwise <code>false</code>. |
255 | * | 271 | * |
256 | */ | 272 | */ |
257 | bool UserDialog::delUser(const char *username) { | 273 | bool UserDialog::delUser(const char *username) { |
258 | if((accounts->findUser(username))) {// Does that user exist? | 274 | if((accounts->findUser(username))) {// Does that user exist? |
259 | if(!(accounts->delUser(username))) {// Delete the user. | 275 | if(!(accounts->delUser(username))) {// Delete the user. |
260 | QMessageBox::information(0,"Ooops!","Something went wrong\nUnable to delete user: "+QString(username)+"."); | 276 | QMessageBox::information(0,"Ooops!","Something went wrong\nUnable to delete user: "+QString(username)+"."); |
261 | } | 277 | } |
262 | } else { | 278 | } else { |
263 | QMessageBox::information(0,"Invalid Username","That username ("+QString(username)+")does not exist."); | 279 | QMessageBox::information(0,"Invalid Username","That username ("+QString(username)+")does not exist."); |
264 | return false; | 280 | return false; |
265 | } | 281 | } |
266 | return true; | 282 | return true; |
267 | } | 283 | } |
268 | 284 | ||
269 | /** | 285 | /** |
270 | * This displays a confirmation dialog wether a user should be deleted or not. | 286 | * This displays a confirmation dialog wether a user should be deleted or not. |
271 | * (And also deletes the account) | 287 | * (And also deletes the account) |
272 | * | 288 | * |
273 | * @param username User to be deleted. | 289 | * @param username User to be deleted. |
274 | * | 290 | * |
275 | * @return <code>true</code> if the user was successfully deleted, otherwise <code>false</code>. | 291 | * @return <code>true</code> if the user was successfully deleted, otherwise <code>false</code>. |
276 | * | 292 | * |
277 | */ | 293 | */ |