+ return true;
+}
+
+function setup_admin_password(&$cfg)
+{
+ if (strlen($cfg['admin_password']) > 0) {
+ return true;
+ }
+ echo("setting up admin password\n");
+ $p = getenv('ADMIN_PASSWORD');
+ if ($p === false) {
+ $p = jirafeau_gen_random(20);
+ echo("auto-generated admin password: $p\n");
+ }
+ $cfg['admin_password'] = hash('sha256', $p);
+ return true;
+}
+
+function set_rights($path)
+{
+ $uid = getenv('USER_ID');
+ if ($uid === false) {
+ $uid = 100;
+ }
+ $gid = getenv('GROUP_ID');
+ if ($gid === false) {
+ $gid = 82;
+ }
+ if (!chown($path, $uid)) {
+ echo("setting up user $uid for $path: failed\n");
+ return false;
+ }
+ if (!chgrp($path, $gid)) {
+ echo("setting up group $gid for $path: failed\n");
+ return false;
+ }
+ if (!chmod($path, 0770)) {
+ echo("setting up permissions $path: failed\n");
+ return false;
+ }
+ return true;
+}
+
+function setup_var_folder(&$cfg)
+{
+ env_2_cfg_string($cfg, 'var_root', 'VAR_ROOT', '/data/');
+ $var_root = $cfg['var_root'];
+ if (!is_dir($var_root)) {
+ mkdir($var_root, 0770, true);
+ }
+ $err = jirafeau_check_var_dir($var_root);
+ if ($err['has_error']) {
+ echo("error: cannot create $var_root folder\n");
+ return false;
+ }
+ return set_rights($var_root) &&
+ set_rights($var_root . 'async') &&
+ set_rights($var_root . 'files') &&
+ set_rights($var_root . 'links');