\n"; wp_register_script('jquery', get_stylesheet_directory_uri() . "/scripts/jquery.min.js", false, '1.11.3'); wp_enqueue_script('jquery'); $JQUERY_LOADED = true; wp_register_script('jquerymigrate', get_stylesheet_directory_uri() . "/scripts/jquery-migrate-1.2.1.min.js", false, '1.2.1'); wp_enqueue_script('jquerymigrate'); } add_action('template_redirect', 'add_custom_scripts'); function add_mime_types($mime_types) { $mime_types['txt'] = 'text/plain'; return $mime_types; } add_filter('upload_mimes', 'add_mime_types', 1, 1); function add_search_box($items, $args) { if($args->theme_location == 'header-menu') { ob_start(); get_search_form(); $searchform = ob_get_contents(); ob_end_clean(); return $items .= '
  • ' . $searchform . '
  • '; } return $items; } add_filter('wp_nav_menu_items','add_search_box', 10, 2); function set_title($title) { $url = $_SERVER['REQUEST_URI']; $spliturl = explode('?', $url); $splituri = explode('/', $spliturl[0]); if (sizeof($splituri) > 2 && $splituri[2] == "rpms") { // Set title for distroquery-api if (sizeof($splituri) > 5) { if ($splituri[5] == "") return $splituri[4] . " (" . _r("Source RPM") . ") | "; else return $splituri[4] . " (" . $splituri[5] . ") | "; } else if (sizeof($splituri) > 4) { return _r("Repository") . " " . $splituri[3] . " | "; } return _r("Repositories") . " | "; } else if (sizeof($spliturl) > 1) { // Set title for obsolete packages pages $urlargs = $spliturl[1]; parse_str($urlargs, $args); $newtitle = $title; if (array_key_exists('arch', $args)) { if (preg_match('/^[a-zA-Z0-9._]*$/', $args['arch'])) { $newtitle = urlencode($args['arch']) . " - " . $newtitle; } else { $newtitle = " Invalid request - " . $newtitle; } } if (array_key_exists('tag', $args)) { if (preg_match('/^[a-zA-Z0-9._-]*$/', $args['tag'])) { $newtitle = urlencode($args['tag']) . " - " . $newtitle; } else { $newtitle = " Invalid request - " . $newtitle; } } if (array_key_exists('pkg', $args)) { if ($args['pkg'] == '_index') $newtitle = 'Index - ' . $newtitle; else { if (preg_match('/^[a-zA-Z0-9._+-]*$/', $args['pkg'])) { $e = explode('.', urlencode($args['pkg'])); $newtitle = $e[0] . " - " . $e[1] . " - " . $newtitle; } else { $newtitle = " Invalid request - " . $newtitle; } } } return $newtitle; } return $title; } add_filter('wp_title','set_title'); // openmamba downloads pages function openmamba_download_link($milestone, $medium, $currarch, $ext, $mlword, $lang) { $latest_file = "/var/ftp/pub/openmamba/media/".$milestone."/".$medium."/".$lang."/latest.inc.php"; if (!file_exists($latest_file)) return ""; eval(file_get_contents("/var/ftp/pub/openmamba/media/".$milestone."/".$medium."/".$lang."/latest.inc.php")); if ("$milestone" == "devel") { $displaymilestone = "rolling"; } else { $displaymilestone = "$milestone"; } $currreleasetag=$releaseTag[$medium.'-'.$milestone.'-'.$lang.'-'.$currarch]; $ret = ''; # if ($lang != "it") { $downloadmirror = 'https://cdn.openmamba.org/pub/openmamba/media'; # } else { # $downloadmirror = '/media'; # } if ("$currreleasetag" != "") { $ret .= ""; $ret .= "
    "; $ret .= "openmamba $displaymilestone $medium "; $ret .= __('for','responsive')." $currarch ($mlword) 
    "; $ret .= ""; $ret .= __('File size:','responsive').' '.$sizeMedium[$medium.'-'.$currreleasetag.'-'.$lang.'-'.$currarch].'B; '; $ret .= __('Date','responsive').': '.substr($builddateMedium[$medium.'-'.$currreleasetag.'-'.$lang.'-'.$currarch], 0, strpos($builddateMedium[$medium.'-'.$currreleasetag.'-'.$lang.'-'.$currarch], ' ')); $ret .= "; Md5: " . $md5Medium[$medium.'-'.$currreleasetag.'-'.$lang.'-'.$currarch]; $ret .= "
    "; } else { $ret .= ""; $ret .= "
    "; $ret .= "openmamba $displaymilestone $medium "; $ret .= __('for','responsive')." $currarch ($mlword) 
    "; $ret .= ""; $ret .= __('Sorry, download is temporary unavailable. If the problem persists please report the problem.','responsive'); $ret .= "
    "; } return $ret; } function openmamba_infofile($mediaprefix, $milestone, $fallbackmilestone, $medium, $outputlang, $filename) { if (file_exists("$mediaprefix/$milestone/$medium/info/$filename.$outputlang.html.inc")) { $script_file = "$mediaprefix/$milestone/$medium/info/$filename.$outputlang.html.inc"; } else if (file_exists("$mediaprefix/$fallbackmilestone/$medium/info/$filename.$outputlang.html.inc")) { $script_file = "$mediaprefix/$fallbackmilestone/$medium/info/$filename.$outputlang.html.inc"; } $ret = ''; if (isset($script_file)) { $file = fopen($script_file, "r"); while (!feof($file)) { $b=fread($file,1024); $ret .= $b; } fclose($file); } return $ret; } function openmamba_download_func( $atts ) { $a = shortcode_atts( array( 'milestone' => 'devel', 'medium' => 'livedvd', 'multilang' => '0', 'archs' => 'x86_64;i586;arm;aarch64', // bitmask: 1=x86_64 2=i586 3=arm 'ext' => '.iso' ), $atts ); $milestone = $a['milestone']; $medium = $a['medium']; $ext = $a['ext']; $fallbackmilestone = 'milestone2'; if ("$milestone" == "devel") { $displaymilestone = "rolling"; $suffixmilestone = "snapshot"; } else { $displaymilestone = "$milestone"; $suffixmilestone = "$milestone"; } $archname = array("x86_64", "aarch64", "i586", "arm"); $mediaprefix = '/var/ftp/pub/openmamba/media'; $mediafallbackprefix = '/var/ftp/pub/openmamba/media/milestone2'; $outputlang = get_bloginfo("language"); $outputlang = substr($outputlang,0,2); if ("$outputlang" != "it") { $outputlang = "en"; $mlword = "multilanguage"; } else { $mlword = "multilingue"; } $ret = "

    openmamba $medium $displaymilestone

    "; $ret .= do_shortcode( openmamba_infofile($mediaprefix,$milestone,$fallbackmilestone,$medium,$outputlang,"description")); $ret .= "

    "; if ($a['multilang']) { reset($archname); foreach($archname as $ey => $currarch) { if (strpos(";".$a['archs'].";",$currarch) == false) continue; $ret .= openmamba_download_link($milestone,$medium,$currarch,$ext,$mlword,"en"); } } else { reset($archname); $langs = array('it' => 'italiano','en' => 'english','es' => 'espaƱol'); foreach($archname as $ey => $currarch) { if (strpos(";".$a['archs'].";",$currarch) == false) continue; $ret .= openmamba_download_link($milestone,$medium,$currarch,$ext,$langs[$outputlang],$outputlang); } $out = ""; foreach ($langs as $l => $lang) { if ($l == $outputlang) continue; reset($archname); foreach($archname as $ey => $currarch) { if (strpos(";".$a['archs'].";",$currarch) == false) continue; $out .= openmamba_download_link($milestone,$medium,$currarch,$ext,$lang,$l); } } $ret .= do_shortcode("[expand title=\"". __("More languages...","responsive") . "\"]". $out ."[/expand]"); } $ret .= do_shortcode("   [expand title=\"".__("Features","responsive")."\"]". openmamba_infofile($mediaprefix,$milestone,$fallbackmilestone,$medium,$outputlang,"features"). "[/expand]"); $ret .= do_shortcode("   [expand title=\"".__("Requirements","responsive")."\"]". openmamba_infofile($mediaprefix,$milestone,$fallbackmilestone,$medium,$outputlang,"requirements"). "[/expand]"); $ret .= do_shortcode("   [expand title=\"".__("Preparation","responsive")."\"]". openmamba_infofile($mediaprefix,$milestone,$fallbackmilestone,$medium,$outputlang,"howto"). "[/expand]"); $ret .= "
    "; return $ret; } add_shortcode('openmamba_download', 'openmamba_download_func'); function openmamba_webbuild_func( $atts ) { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos); } $a = shortcode_atts( array( 'host' => 'buildvm01.openmamba.org' ), $atts ); print ''; $file = fopen(get_stylesheet_directory() . '/webbuild.html.inc', "r"); print fread($file, 20000); flush(); fclose($file); print ""; } add_shortcode('openmamba_webbuild', 'openmamba_webbuild_func'); function openmamba_webbuild_status_func() { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos); } // print "
    "; // print "

    AJAX support is not enabled in your browser. Live page updates will not be available, press Reload to update.

    "; print "
    "; print "" . __("Loading, please wait...", "responsive") . ""; print "";//
    "; } add_shortcode('openmamba_webbuild_status', 'openmamba_webbuild_status_func'); function openmamba_distroquery_func() { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos + 1); } $outputlang = get_bloginfo("language"); if (substr($outputlang, 0, 2) == "it") $outputlang = "it_IT.UTF-8"; else $outputlang = "en_US.UTF-8"; if (preg_match('/^[a-zA-Z0-9._\=\-\+\/\.\&\:]*$/', $urlargs)) { $ret = "
    "; $ret .= "Loading, please wait...
    "; $ret .= "
     "; $ret .= ""; } else { $ret = "" . __("Invalid request.", "responsive") . "
    "; } return $ret; } add_shortcode('openmamba_distroquery', 'openmamba_distroquery_func'); function openmamba_distromatic_func() { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos + 1); } $outputlang = get_bloginfo("language"); if (substr($outputlang, 0, 2) == "it") $outputlang = "it_IT.UTF-8"; else $outputlang = "en_US.UTF-8"; if (preg_match('/^[a-zA-Z0-9._\=\-\+\/\.\&\:]*$/', $urlargs)) { // Set title for obsolete packages pages $arch = ""; parse_str($urlargs, $args); if (array_key_exists('arch', $args)) { if (preg_match('/^[a-zA-Z0-9._]*$/', $args['arch'])) { $arch = urlencode($args['arch']); } } if (array_key_exists('tag', $args)) { if (preg_match('/^[a-zA-Z0-9._-]*$/', $args['tag'])) { $repo = urlencode($args['tag']); } } if (array_key_exists('pkg', $args)) { if ($args['pkg'] != '_index') { if (preg_match('/^[a-zA-Z0-9._+-]*$/', $args['pkg'])) { $pkgarr = explode('.', urlencode($args['pkg'])); $pkg = $pkgarr[0]; if (sizeof($pkgarr) > 1 && $pkgarr[1] != "source") { $arch = $pkgarr[1]; } } } } if ($repo != "base" && substr($repo, 0, 6) != "devel-") { // Old repos -> old interface $ret = "" . __("Loading, please wait...", "responsive") . "
    "; $ret .= ""; } else { // Current repos -> redirect to new interface $ret = "" . __("Redirecting to new interface, please wait...", "responsive") . "
    "; $redirect_url = "https://openmamba.org/en/rpms/" . $repo . "/"; if ($pkg != "") $redirect_url .= $pkg . "/"; if ($arch != "") $redirect_url .= $arch . "/"; $ret .= ""; } } else { $ret = "" . __("Invalid request.", "responsive") . "
    "; } return $ret; } add_shortcode('openmamba_distromatic', 'openmamba_distromatic_func'); function openmamba_showfile_func() { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos + 1); } if (preg_match('/^[a-zA-Z0-9._\=\-\+\/\.\&\:]*$/', $urlargs)) { $ret = "" . "Loading, please wait..." . "
    "; $ret .= ""; } else { $ret = "" . __("Invalid request.", "responsive") . "
    "; } return $ret; } add_shortcode('openmamba_showfile', 'openmamba_showfile_func'); function openmamba_downloadfile_func() { $urlargspos = strpos($_SERVER['REQUEST_URI'], '?'); if ($urlargspos > 0) { $urlargs = substr($_SERVER['REQUEST_URI'], $urlargspos + 1); parse_str($urlargs, $args); if ($args['file']) { $ret = "" . __("Starting download of", "responsive") . " " . basename($args['file']) . ", " . __("please wait...", "responsive") . "

    "; $ret .= ""; } } return $ret; } add_shortcode('openmamba_downloadfile', 'openmamba_downloadfile_func'); // bbpress tag cloud add_filter('widget_tag_cloud_args','set_number_tags'); function set_number_tags($args) { $args = array('number' => 10, 'largest' => 20); return $args; } // load_plugin_textdomain('user-registration' , get_site_url() . 'wp-content/themes/openmamba/languages/'); add_action('wp_head','hook_cookielaw'); function hook_cookielaw() { $outputlang = get_bloginfo("language"); $outputlang = substr($outputlang,0,2); //$message = __("This website only uses first party technical cookies necessary for the correct functioning of it.","responsive"); if ("$outputlang" == "it") { $message = "Questo sito usa esclusivamente cookie di prima parte di tipo tecnico necessari per il corretto funzionamento dello stesso."; $policyurl = "/" . $outputlang . "/info/policy/"; } else { $message = "This website only uses first party technical cookies necessary for the correct functioning of it."; $policyurl = "/" . $outputlang . "/about/policy/"; } $accepttext = __("I Understand","responsive"); $policytext = __("Cookie policy","responsive"); $policyurl = "/" . $outputlang . "/info/policy/"; $output = "\n"; $output .= "\n"; $output .= "\n"; $output .= "\n"; echo $output; } /*function responsive_get_social_icons() { $responsive_options = responsive_get_options(); $sites = array ( 'foursquare' => __( 'foursquare', 'responsive' ), 'twitter' => __( 'Twitter', 'responsive' ), 'facebook' => __( 'Facebook', 'responsive' ), 'linkedin' => __( 'LinkedIn', 'responsive' ), 'youtube' => __( 'YouTube', 'responsive' ), 'stumbleupon' => __( 'StumbleUpon', 'responsive' ), 'rss' => __( 'RSS Feed', 'responsive' ), 'googleplus' => __( 'Google+', 'responsive' ), 'instagram' => __( 'Instagram', 'responsive' ), 'pinterest' => __( 'Pinterest', 'responsive' ), 'yelp' => __( 'Yelp!', 'responsive' ), 'vimeo' => __( 'Vimeo', 'responsive' ), ); $html = ''; return $html; } */ function wpb_imagelink_setup() { $image_set = get_option( 'image_default_link_type' ); if ($image_set !== 'none') { update_option('image_default_link_type', 'none'); } } add_action('admin_init', 'wpb_imagelink_setup', 10); /* Security: restrict access to wp-json */ function restrict_rest_api_access() { $whitelist = [ '127.0.0.1', "::1", '176.9.120.93', '2a01:4f8:151:7444::1:3' ]; // Allow whitelisted ip addresses if (in_array($_SERVER['REMOTE_ADDR'], $whitelist) ){ return; } // List of allowed endpoint prefixes (adjust as needed) $allowed_prefixes = [ 'openid-connect', // Allow /wp-json/openid-connect/* // Add other prefixes here if needed ]; // Get the current REST route $request_uri = $_SERVER['REQUEST_URI']; // Check if the request URI matches any allowed prefix foreach ($allowed_prefixes as $prefix) { if (strpos($request_uri, '/it/wp-json/' . $prefix) === 0) { return; // Allow access } } die( 'REST API is disabled.' ); } add_action('rest_api_init', 'restrict_rest_api_access', 10, 3 ); /* Security: filter email domains frequently used for spam registrations */ function user_registration_filter($user_id, $email) { if ($user_id == false) { $e1 = explode("@", $email); if (in_array($e1[1], array( 'xtra.ltd','tmobile.agency','btee.online','verizonconnect.online','proton.me', 'eduonline.digital','vofadonepro.online','tasktracker.in'))) { error_log( "user_registration_filter: email=" . $email . " blacklisted domain=" . $e1[1] ); $user_id = 100; } else { //preg_match("/[0-9]{2}$/", $e1[0]) || if (preg_match("/[0-9]{3}$/", $e1[0]) || in_array($e1[0], array('astro_yoga'))) { error_log( "user_registration_filter: email=" . $email . " blacklisted ([0-9]{2}$) domain=" . $e1[1] ); $user_id = 100; } else { error_log( "user_registration_filter: email=" . $email . " whitelisted domain=" . $e1[1] ); } } } return $user_id; } add_filter('email_exists', 'user_registration_filter', 10, 2); /* Security: prevent multisite signup */ function prevent_multisite_signup() { wp_redirect( site_url() ); die(); } add_action( 'signup_header', 'prevent_multisite_signup' ); /* Fix for missing js support in bbpress editor */ add_filter ('bbp_body_class', 'rew_unset_no_js') ; function rew_unset_no_js($classes) { if (in_array ('single-forum', $classes) || in_array ('single-topic', $classes)) { if (($key = array_search('no-js', $classes)) !== false) { unset($classes[$key]); } } return $classes ; } // Distroquery API management add_filter( 'query_vars', function( $query_vars ) { $query_vars[] = 'distroquery'; $query_vars[] = 'repo'; $query_vars[] = 'package'; $query_vars[] = 'arch'; return $query_vars; } ); function distroquery_api_rewrite_rules ( ) { add_rewrite_rule ( '^rpms/([^/]*)/([^/]*)/([^/]*)/?', 'index.php?distroquery=1&repo=$matches[1]&package=$matches[2]&arch=$matches[3]','top' ); add_rewrite_rule ( '^rpms/([^/]*)/([^/]*)/?', 'index.php?distroquery=1&repo=$matches[1]&package=$matches[2]','top' ); add_rewrite_rule ( '^rpms/([^/]*)/?', 'index.php?distroquery=1&repo=$matches[1]','top' ); add_rewrite_rule ( '^rpms/?', 'index.php?distroquery=1','top' ); } add_action ( 'init', 'distroquery_api_rewrite_rules', 10, 0 ) ; add_filter( 'template_include', function( $template ) { if ( get_query_var( 'distroquery' ) == false || get_query_var( 'distroquery' ) == '' ) { return $template; } return get_theme_file_path() . '/distroquery.php'; } ); // openid-connect filters function my_oidc_clients() { if ( ! defined( 'OIDC_CLIENT_ID' ) || ! defined( 'OIDC_CLIENT_KEY' ) ) { // Please define client id and key in wp-config.php. return; } return array( OIDC_CLIENT_ID => array( 'name' => 'openmamba package sources', 'secret' => OIDC_CLIENT_KEY, 'redirect_uri' => 'https://src.openmamba.org/user/oauth2/openmamba/callback', 'grant_types' => array( 'authorization_code' ), 'scope' => 'openid profile', ), ); } add_filter( 'oidc_registered_clients', 'my_oidc_clients' ); function my_oidc_capability() { return 'read'; } add_filter( 'oidc_minimal_capability', 'my_oidc_capability' ); function my_user_claims($claims, $user) { $claims['email'] = $user->user_email; return $claims; } add_filter( 'oidc_user_claims', 'my_user_claims', 10, 2 );