summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/usermanager/userdialog.cpp20
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 */
257bool UserDialog::delUser(const char *username) { 273bool 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 */