$plugin_data) { $plugin = array(); echo "\nPlugin: $plugin_type"; $base_rrd_name = 'munin/'.$plugin_type; d_echo("\n[$plugin_data]\n"); foreach (explode("\n", $plugin_data) as $line) { list($key, $value) = explode(' ', $line, 2); if (preg_match('/^graph_/', $key)) { list(,$key) = explode('_', $key); $plugin['graph'][$key] = $value; } else { list($metric,$key) = explode('.', $key); $plugin['values'][$metric][$key] = $value; } } if (!is_array($plugins_db[$plugin_type])) { $insert = array( 'device_id' => $device['device_id'], 'mplug_type' => $plugin_type, 'mplug_instance' => ($instance == null ? array('NULL') : $instance), 'mplug_category' => ($plugin['graph']['category'] == null ? 'general' : strtolower($plugin['graph']['category'])), 'mplug_title' => ($plugin['graph']['title'] == null ? array('NULL') : $plugin['graph']['title']), 'mplug_vlabel' => ($plugin['graph']['vlabel'] == null ? array('NULL') : $plugin['graph']['vlabel']), 'mplug_args' => ($plugin['graph']['args'] == null ? array('NULL') : $plugin['graph']['args']), 'mplug_info' => ($plugin['graph']['info'] == null ? array('NULL') : $plugin['graph']['info']), ); $mplug_id = dbInsert($insert, 'munin_plugins'); } else { $mplug_id = $plugins_db[$plugin_type]['id']; } if ($mplug_id) { echo " ID: $mplug_id"; $dbq = dbFetchRows('SELECT * FROM `munin_plugins_ds` WHERE `mplug_id` = ?', array($mplug_id)); foreach ($dbq as $v) { $vu = $v['mplug_id'].'_'.$v['ds_name']; $ds_list[$vu] = 1; } foreach ($plugin['values'] as $name => $data) { echo " $name"; if (empty($data['type'])) { $data['type'] = 'GAUGE'; } if (empty($data['graph'])) { $data['graph'] = 'yes'; } if (empty($data['label'])) { $data['label'] = $name; } if (empty($data['draw'])) { $data['draw'] = 'LINE1.5'; } $ds_uniq = $mplug_id.'_'.$name; $fields = array( 'val' => $data['value'], ); $tags = array( 'plugin' => $plugin_type, 'rrd_def' => RrdDefinition::make()->addDataset('val', $data['type']), 'rrd_name' => $base_rrd_name . '_' . $name ); data_update($device, 'munin-plugins', $tags, $fields); if (empty($ds_list[$ds_uniq])) { $insert = array( 'mplug_id' => $mplug_id, 'ds_name' => $name, 'ds_type' => $data['type'], 'ds_label' => $data['label'], 'ds_cdef' => $data['cdef'], 'ds_draw' => $data['draw'], 'ds_info' => $data['info'], 'ds_extinfo' => $data['extinfo'], 'ds_min' => $data['min'], 'ds_max' => $data['max'], 'ds_graph' => $data['graph'], 'ds_negative' => $data['negative'], 'ds_warning' => $data['warning'], 'ds_critical' => $data['critical'], 'ds_colour' => $data['colour'], 'ds_sum' => $data['sum'], 'ds_stack' => $data['stack'], 'ds_line' => $data['line'], ); $ds_id = dbInsert($insert, 'munin_plugins_ds'); }//end if }//end foreach } else { echo "No ID!\n"; }//end if }//end foreach }//end if