/tools/rg_change_pass (6fd01780738c202e62bd13365320d38be1e45416) (2077 bytes) (mode 100755) (type blob)
#!/usr/bin/php
<?php
// Change password for any user
error_reporting(E_ALL);
ini_set("track_errors", "On");
set_time_limit(0);
$_s = microtime(TRUE);
require_once("/etc/rocketgit/config.php");
$INC = $rg_scripts . '/inc';
require_once($INC . "/init.inc.php");
require_once($INC . "/log.inc.php");
require_once($INC . "/sql.inc.php");
require_once($INC . "/struct.inc.php");
require_once($INC . "/cache.inc.php");
require_once($INC . "/repo.inc.php");
require_once($INC . "/prof.inc.php");
require_once($INC . "/mr.inc.php");
require_once($INC . "/keys.inc.php");
require_once($INC . "/user.inc.php");
require_once($INC . "/bug.inc.php");
require_once($INC . "/fixes.inc.php");
$uid = getmyuid();
if ($uid !== 0) {
echo 'This script must be run with root rights!' . "\n";
exit(1);
}
rg_log_set_file($rg_log_dir . '/rg_change_pass.log');
rg_sql_app("rg_change_pass");
$db = rg_sql_open($rg_sql);
if ($db === FALSE) {
echo 'Cannot connect to db: ' . $rg_sql_error() . "!\n";
exit(1);
}
$stdin = fopen('php://stdin', 'r');
if ($stdin === FALSE) {
echo 'Cannot open stdin!' . "\n";
exit(1);
}
if ($_SERVER['argc'] < 2)
$user = 'admin';
else
$user = trim($_SERVER['argv'][1]);
echo 'Changing password for user ' . $user . "\n";
echo "New password (will show on the screen, watch your back!): ";
$pass = fread($stdin, 128);
$pass = trim($pass);
$ui = rg_user_info($db, 0, $user, '');
if ($ui['exists'] != 1) {
echo 'User not found!' . "\n";
exit(1);
}
$r = rg_user_set_pass($db, $ui['uid'], $pass);
if ($r !== TRUE) {
echo 'Could not change pass: ' . rg_user_error() . "!\n";
exit(1);
}
echo 'Password changed with success!' . "\n";
if (rg_totp_enrolled($db, $ui['uid'])) {
echo 'Please note that user ' . $user . ' is enrolled in 2fa.' . "\n";
echo 'Do you want to remove any enrollment (yes/no) [no]: ';
$a = trim(fread($stdin, 128));
if (strcasecmp($a, 'yes') == 0) {
$r = rg_totp_unenroll($db, $ui['uid']);
if ($r !== TRUE) {
echo 'Cannot unenroll: ' . rg_totp_error() . '!' . "\n";
exit(1);
}
echo 'Done unenrolling!' . "\n";
}
}
?>
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
9 |
f3c7a7c5da68804a1bdf391127ba34aed33c3cca |
.exclude |
100644 |
blob |
95 |
3e2e24ae7f12c3618604c014e2a5cdbc7572d73d |
.gitignore |
100644 |
blob |
375 |
1f425bcd2049c526744d449511094fc045ceac74 |
AUTHORS |
100644 |
blob |
1132 |
dd65951315f3de6d52d52a82fca59889d1d95187 |
Certs.txt |
100644 |
blob |
1538 |
3f88d5ff4a2a7b3328dde912fc95c46e52da9a7d |
History.txt |
100644 |
blob |
34520 |
dba13ed2ddf783ee8118c6a581dbf75305f816a3 |
LICENSE |
100644 |
blob |
3341 |
994c8a35a81ada4c768ba38bbea6dae006a35be0 |
Makefile.in |
100644 |
blob |
5013 |
726b89f5ea8777af6099eb82110136fb1702c41b |
README |
100644 |
blob |
179703 |
3a70d08e1af14f7c82650d35086b17d82bb9cf7f |
TODO |
100644 |
blob |
1294 |
f22911eb777f0695fcf81ad686eac133eb11fcc4 |
TODO-plans |
100644 |
blob |
203 |
a2863c67c3da44126b61a15a6f09738c25e0fbe0 |
TODO.perf |
100644 |
blob |
967 |
56bbaa7c937381fb10a2907b6bbe056ef8cc824a |
TODO.vm |
040000 |
tree |
- |
21928e906ad2907a55c2e81c2a8b0502b586b8a0 |
artwork |
100644 |
blob |
5118 |
29b8b86a2eebbd5e33e7fe03c6bb8cf269601dbb |
compare.csv |
100755 |
blob |
30 |
92c4bc48245c00408cd7e1fd89bc1a03058f4ce4 |
configure |
040000 |
tree |
- |
9e126f629e04ddbf18a7ad306a0e931a281a2cea |
debian |
040000 |
tree |
- |
2e58bf5808e1f01f1e5f9fbc8764427436b6490f |
docker |
040000 |
tree |
- |
f67d3605efbd6422a8acdd953578991139266391 |
docs |
100755 |
blob |
17577 |
06fe0062db5d1135bcfa1f48a10e84b3596d8c15 |
duilder |
100644 |
blob |
536 |
e31b63f440c725a5b491489e6a4bf35ee66ff073 |
duilder.conf |
040000 |
tree |
- |
1a62427b7e1e1e78bbb0c05f5d7bc62d7306e4d3 |
hooks |
040000 |
tree |
- |
cc01aba03617920b3b5d4cbdd0fe625aa0a7b8cd |
inc |
040000 |
tree |
- |
e255ce234c3993998edc12bc7e93fff555376eda |
misc |
100644 |
blob |
5061 |
4bee32faa18d9af843d9f02f954706f4b39edcbb |
rocketgit.spec |
040000 |
tree |
- |
640da6f5683010d7b088c94b520241a19ec73122 |
root |
040000 |
tree |
- |
d12f5b07cd2a2e1e284cd9627fefa9df303048c4 |
samples |
040000 |
tree |
- |
e4f37b0cbae154e93e660665725e581a3863a4dd |
scripts |
040000 |
tree |
- |
a3cb7109a47e7dae03a78667841b986e23baa224 |
selinux |
100755 |
blob |
256 |
462ccd108c431f54e380cdac2329129875a318b5 |
spell_check.sh |
040000 |
tree |
- |
16e63d499e2c018ced3a78f3ed162d7b54b168ed |
techdocs |
040000 |
tree |
- |
4bf43340a24dd859890f3133b501bbd528389691 |
tests |
040000 |
tree |
- |
e810d7397575886ef495708d571eb3675f6928ba |
tools |
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/catalinux/rocketgit
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/catalinux/rocketgit
Clone this repository using git:
git clone git://git.rocketgit.com/user/catalinux/rocketgit
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main