/tools/rg_authorize (56b5bf1ba3a435f0d5b80c11eacc359ffe5c22c4) (1893 bytes) (mode 100755) (type blob)
#!/usr/bin/php
<?php
// This is called by SSH daemon to lookup a fingerprint
// Called by AuthorizedKeysCommand in sshd_config
error_reporting(E_ALL);
ini_set('track_errors', 'On');
set_time_limit(30);
$_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 . '/prof.inc.php');
require_once($INC . '/keys.inc.php');
require_once($INC . '/user.inc.php');
require_once($INC . '/fixes.inc.php');
rg_prof_start('MAIN');
rg_log_set_file($rg_log_dir . '/authorize.log');
rg_log_set_sid('000000'); // to spread the logs
rg_sql_app('rg_authorize-' . $rg_log_sid);
$db = rg_sql_open($rg_sql);
if ($db === FALSE) {
rg_log('Cannot connect to db!');
exit(1);
}
if ($_SERVER['argc'] < 2) {
rg_log('Invalid number of parameters (' . $_SERVER['argc'] . ')!');
rg_log_ml('argv: ' . print_r($_SERVER['argv'], TRUE));
exit(1);
}
$fp = trim($_SERVER['argv'][1]);
if (strncmp($fp, 'SHA256:', 7) != 0) {
rg_log('Invalid fingerprint type: ' . $fp . '!');
exit(1);
}
$fp = substr($fp, 7);
$fp = rtrim($fp, '=');
$r = rg_keys_search_by_fingerprint($db, $fp);
if ($r['ok'] !== 1) {
rg_log('Cannot lookup by fingerprint: ' . rg_keys_error());
exit(1);
}
rg_log('DEBUG: Found ' . count($r['list']) . ' key(s)');
$global_flags = rg_keys_global_flags($db);
foreach ($r['list'] as $i) {
// Ignore invalid keys
$ki = rg_keys_info($i['key']);
if ($ki['ok'] != 1)
continue;
// Ignore weak keys
$r = rg_keys_weak($db, $ki);
if ($r['ok'] != 1)
continue;
if ($r['weak'] != 0)
continue;
rg_log('Sending key ' . $i['key_id'] . ' ' . $ki['fingerprint_sha256']);
echo rg_keys_output_line($i, $global_flags);
}
rg_prof_end('MAIN');
rg_prof_log();
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