/tools/rg_authorize (7d240f3e7afbeee72e290b729453ba99a2312209) (1749 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');
$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 |
289 |
fabbff669e768c05d6cfab4d9aeb651bf623e174 |
AUTHORS |
100644 |
blob |
1132 |
dd65951315f3de6d52d52a82fca59889d1d95187 |
Certs.txt |
100644 |
blob |
549 |
41c3bdbba8ec2523fe24b84bdd46777fc13e8345 |
History.txt |
100644 |
blob |
34520 |
dba13ed2ddf783ee8118c6a581dbf75305f816a3 |
LICENSE |
100644 |
blob |
3398 |
cf75b360b8a3e6ef86bc4a42648e353bd58c2a80 |
Makefile.in |
100644 |
blob |
5774 |
4a18249bf06d04d1e27d97623f12a7a2d51f83c0 |
README |
100644 |
blob |
118238 |
d608cd4baee99ad20df682aa04c4f17cdad33694 |
TODO |
100644 |
blob |
1294 |
f22911eb777f0695fcf81ad686eac133eb11fcc4 |
TODO-plans |
100644 |
blob |
203 |
a2863c67c3da44126b61a15a6f09738c25e0fbe0 |
TODO.perf |
100644 |
blob |
994 |
76399724a83bdbf5a2b3b03d3d66e6de8598b9cd |
TODO.vm |
040000 |
tree |
- |
21928e906ad2907a55c2e81c2a8b0502b586b8a0 |
artwork |
100644 |
blob |
4650 |
548f8c18609fa92b720aebfa5433f50a2c4ced78 |
compare.csv |
100755 |
blob |
30 |
92c4bc48245c00408cd7e1fd89bc1a03058f4ce4 |
configure |
040000 |
tree |
- |
1624fa67631f0dd10772e19016ffcd9af8e44773 |
debian |
040000 |
tree |
- |
3c08a24a998b6e80be5f4af4ac3599ab6acacba3 |
docker |
040000 |
tree |
- |
f67d3605efbd6422a8acdd953578991139266391 |
docs |
100755 |
blob |
16719 |
464375221f1db42f123db3ca7eeb14ad5659b196 |
duilder |
100644 |
blob |
536 |
a19f569b20992ce32c943ec937f846e5f6275ebb |
duilder.conf |
040000 |
tree |
- |
c503cf29ce2337a771fdfdbf4225b35d8e81ab98 |
hooks |
040000 |
tree |
- |
7d7eded090374232f580fbcb004e5c0ddbe1097b |
inc |
040000 |
tree |
- |
ab5cc695f620de9abecc84af49866a45612067c6 |
misc |
100644 |
blob |
3742 |
dd0d01262f0ec9a6ac67aa549300631f6f3896b8 |
rocketgit.spec.in |
040000 |
tree |
- |
b40f50e29ed4ce18e4cfc84fc25bcf086d5b7ec8 |
root |
040000 |
tree |
- |
edfd5fcdabcb2a987269d8167dfe8d02eebe3e19 |
samples |
040000 |
tree |
- |
dadefbcdcd82cedbce7279cf8003cbc1da8112e0 |
scripts |
040000 |
tree |
- |
00c52dce99b99f5f59800512ffd8e145d5ffe2c9 |
selinux |
100755 |
blob |
256 |
462ccd108c431f54e380cdac2329129875a318b5 |
spell_check.sh |
040000 |
tree |
- |
cb54e074b3ca35943edfcda9dd9cfcd281bcd9e7 |
techdocs |
040000 |
tree |
- |
984d80c5dbd69030f7b3ac4081d83dd9ce780e72 |
tests |
040000 |
tree |
- |
63f68e921ac8d6a62ea9c3d180e072c7c4725b7d |
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