/tools/rg_authorize (885dc5663030ba18457d08114c28cd1984b1cec8) (1764 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)');
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;
echo rg_keys_output_line($i);
}
rg_prof_end('MAIN');
rg_prof_log();
?>
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
9 |
f3c7a7c5da68804a1bdf391127ba34aed33c3cca |
.exclude |
100644 |
blob |
102 |
eaeb7d777062c60a55cdd4b5734902cdf6e1790c |
.gitignore |
100644 |
blob |
375 |
1f425bcd2049c526744d449511094fc045ceac74 |
AUTHORS |
100644 |
blob |
1132 |
dd65951315f3de6d52d52a82fca59889d1d95187 |
Certs.txt |
100644 |
blob |
1434 |
a05c9b5350fe6367d40c83c1da2eb95441016969 |
History.txt |
100644 |
blob |
34520 |
dba13ed2ddf783ee8118c6a581dbf75305f816a3 |
LICENSE |
100644 |
blob |
3280 |
e71cdfe4c88b5a144f35719874e72ce508b1c854 |
Makefile.in |
100644 |
blob |
5867 |
0c5899445818b82269b17da3fff4c39a89f760bb |
README |
100644 |
blob |
151025 |
a1ad6b55193784ef8dd4dca668708477b27317bb |
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 |
5596 |
c403f2d1bf9b582026a1b4d42447118acea9bdc7 |
compare.csv |
100755 |
blob |
30 |
92c4bc48245c00408cd7e1fd89bc1a03058f4ce4 |
configure |
040000 |
tree |
- |
03c8adc1d40f2218407164412524c8a59cc24542 |
debian |
040000 |
tree |
- |
e6949523536cb43048b767d7e3661ee2837f04b8 |
docker |
040000 |
tree |
- |
f67d3605efbd6422a8acdd953578991139266391 |
docs |
100755 |
blob |
16720 |
52405deef0d3708e7553022e1e9db73faa28d05c |
duilder |
100644 |
blob |
536 |
7e834f8f0a52ada786dd978522cd0f310e2438f6 |
duilder.conf |
040000 |
tree |
- |
5482f09eab630acc00f6507d9732ba657e8cadf1 |
hooks |
040000 |
tree |
- |
ea9238456a8e85c5c6283325951b268240bcd2cf |
inc |
040000 |
tree |
- |
e255ce234c3993998edc12bc7e93fff555376eda |
misc |
100644 |
blob |
4576 |
549c56428615002dd1bd0dab413c5e4c05c6d02d |
rocketgit.spec.in |
040000 |
tree |
- |
880d9d4304f1462e1f540d37b96dc5e9b49246a9 |
root |
040000 |
tree |
- |
a28d727d9d0ce55e9c742b1d23f7d9b49101bc38 |
samples |
040000 |
tree |
- |
39f88d6e9b355f8041f83660d7e9bc58ee05fff4 |
scripts |
040000 |
tree |
- |
8d287566a2deca8cb87248003f09e22604c837b4 |
selinux |
100755 |
blob |
256 |
462ccd108c431f54e380cdac2329129875a318b5 |
spell_check.sh |
040000 |
tree |
- |
3aee54193d1f2fb794cb1133433e4645b864f5a0 |
techdocs |
040000 |
tree |
- |
c2118ef4d47606a06da55738fcc10d416fddf551 |
tests |
040000 |
tree |
- |
3a262971aa172ade74d5a4930e04393918ca1911 |
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