123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311 |
- <?php
- /**
- * providers class
- *
- * @method null delete
- * @method null toggle
- * @method null copy
- * @method null setup
- */
- if (!class_exists('providers')) {
- class providers {
- /**
- * declare the variables
- */
- private $app_name;
- private $app_uuid;
- private $name;
- private $table;
- private $toggle_field;
- private $toggle_values;
- private $description_field;
- private $location;
- public $id;
- /**
- * called when the object is created
- */
- public function __construct() {
- //assign the variables
- $this->app_name = 'providers';
- $this->app_uuid = '35187839-237e-4271-b8a1-9b9c45dc8833';
- $this->name = 'provider';
- $this->table = 'providers';
- $this->toggle_field = 'provider_enabled';
- $this->toggle_values = ['true','false'];
- $this->description_field = 'provider_description';
- $this->location = 'providers.php';
- }
- /**
- * called when there are no references to a particular object
- * unset the variables used in the class
- */
- public function __destruct() {
- foreach ($this as $key => $value) {
- unset($this->$key);
- }
- }
- /**
- * delete rows from the database
- */
- public function delete($records) {
- if (permission_exists($this->name.'_delete')) {
- //add multi-lingual support
- $language = new text;
- $text = $language->get();
- //validate the token
- $token = new token;
- if (!$token->validate($_SERVER['PHP_SELF'])) {
- message::add($text['message-invalid_token'],'negative');
- header('Location: '.$this->location);
- exit;
- }
- //delete multiple records
- if (is_array($records) && @sizeof($records) != 0) {
- //build the delete array
- $x = 0;
- foreach ($records as $record) {
- //add to the array
- if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
- $array['providers'][$x]['provider_uuid'] = $record['uuid'];
- $array['provider_settings'][$x]['provider_uuid'] = $record['uuid'];
- $array['provider_addresses'][$x]['provider_uuid'] = $record['uuid'];
- }
- //increment the id
- $x++;
- }
- //delete the checked rows
- if (is_array($array) && @sizeof($array) != 0) {
- //execute delete
- $database = new database;
- $database->app_name = $this->app_name;
- $database->app_uuid = $this->app_uuid;
- $database->delete($array);
- unset($array);
- //set message
- message::add($text['message-delete']);
- }
- unset($records);
- }
- }
- }
- /**
- * toggle a field between two values
- */
- public function toggle($records) {
- if (permission_exists($this->name.'_edit')) {
- //add multi-lingual support
- $language = new text;
- $text = $language->get();
- //validate the token
- $token = new token;
- if (!$token->validate($_SERVER['PHP_SELF'])) {
- message::add($text['message-invalid_token'],'negative');
- header('Location: '.$this->location);
- exit;
- }
- //toggle the checked records
- if (is_array($records) && @sizeof($records) != 0) {
- //get current toggle state
- foreach($records as $record) {
- if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
- $uuids[] = "'".$record['uuid']."'";
- }
- }
- if (is_array($uuids) && @sizeof($uuids) != 0) {
- $sql = "select ".$this->name."_uuid as uuid, ".$this->toggle_field." as toggle from v_".$this->table." ";
- $sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
- $database = new database;
- $rows = $database->select($sql, $parameters, 'all');
- if (is_array($rows) && @sizeof($rows) != 0) {
- foreach ($rows as $row) {
- $states[$row['uuid']] = $row['toggle'];
- }
- }
- unset($sql, $parameters, $rows, $row);
- }
- //build update array
- $x = 0;
- foreach($states as $uuid => $state) {
- //create the array
- $array[$this->table][$x][$this->name.'_uuid'] = $uuid;
- $array[$this->table][$x][$this->toggle_field] = $state == $this->toggle_values[0] ? $this->toggle_values[1] : $this->toggle_values[0];
- //increment the id
- $x++;
- }
- //save the changes
- if (is_array($array) && @sizeof($array) != 0) {
- //save the array
- $database = new database;
- $database->app_name = $this->app_name;
- $database->app_uuid = $this->app_uuid;
- $database->save($array);
- unset($array);
- //set message
- message::add($text['message-toggle']);
- }
- unset($records, $states);
- }
- }
- }
- /**
- * copy rows from the database
- */
- public function copy($records) {
- if (permission_exists($this->name.'_add')) {
- //add multi-lingual support
- $language = new text;
- $text = $language->get();
- //validate the token
- $token = new token;
- if (!$token->validate($_SERVER['PHP_SELF'])) {
- message::add($text['message-invalid_token'],'negative');
- header('Location: '.$this->location);
- exit;
- }
- //copy the checked records
- if (is_array($records) && @sizeof($records) != 0) {
- //get checked records
- foreach($records as $record) {
- if ($record['checked'] == 'true' && is_uuid($record['uuid'])) {
- $uuids[] = "'".$record['uuid']."'";
- }
- }
- //create the array from existing data
- if (is_array($uuids) && @sizeof($uuids) != 0) {
- $sql = "select * from v_".$this->table." ";
- $sql .= "where ".$this->name."_uuid in (".implode(', ', $uuids).") ";
- $database = new database;
- $rows = $database->select($sql, $parameters, 'all');
- if (is_array($rows) && @sizeof($rows) != 0) {
- $x = 0;
- foreach ($rows as $row) {
- //copy data
- $array[$this->table][$x] = $row;
- //add copy to the description
- $array[$this->table][$x][$this->name.'_uuid'] = uuid();
- $array[$this->table][$x][$this->description_field] = trim($row[$this->description_field]).' ('.$text['label-copy'].')';
- //increment the id
- $x++;
- }
- }
- unset($sql, $parameters, $rows, $row);
- }
- //save the changes and set the message
- if (is_array($array) && @sizeof($array) != 0) {
- //save the array
- $database = new database;
- $database->app_name = $this->app_name;
- $database->app_uuid = $this->app_uuid;
- $database->save($array);
- unset($array);
- //set message
- message::add($text['message-copy']);
- }
- unset($records);
- }
- }
- }
- /**
- * setup the provider
- */
- public function setup() {
- //provider selection
- $provider_list = glob($_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/app/*/resources/providers/settings.php");
- foreach ($provider_list as $setting_path) {
- include($setting_path);
- }
- $providers = $array['providers'];
- unset($array);
- //get the array
- $x = 0;
- foreach ($providers as $row) {
- if (md5($row['provider_name']) == $this->id) {
- if ($row['provider_name'] == 'Add a Provider') {
- $provider_name = 'Provider';
- }
- else {
- $provider_name = $row['provider_name'];
- }
- $array['providers'][$x]['provider_uuid'] = $row['provider_uuid'];
- $array['providers'][$x]['provider_name'] = $provider_name;
- $array['providers'][$x]['provider_enabled'] = $row['provider_enabled'];
- $array['providers'][$x]['provider_description'] = '';
- $provider = $row;
- }
- }
- //add the provider settings
- $y = 0;
- foreach ($provider['provider_settings'] as $row) {
- $array['providers'][$x]['provider_settings'][$y]['provider_uuid'] = $row['provider_uuid'];
- $array['providers'][$x]['provider_settings'][$y]['application_uuid'] = $row['application_uuid'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_uuid'] = $row['provider_setting_uuid'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_category'] = $row['provider_setting_category'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_subcategory'] = $row['provider_setting_subcategory'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_type'] = $row['provider_setting_type'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_name'] = $row['provider_setting_name'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_value'] = $row['provider_setting_value'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_order'] = $row['provider_setting_order'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_enabled'] = $row['provider_setting_enabled'];
- $array['providers'][$x]['provider_settings'][$y]['provider_setting_description'] = $row['provider_setting_description'];
- $y++;
- }
- //add the provider addresses
- $y = 0;
- foreach ($provider['provider_addresses'] as $row) {
- $array['providers'][$x]['provider_addresses'][$y]['provider_uuid'] = $row['provider_uuid'];
- $array['providers'][$x]['provider_addresses'][$y]['provider_address_uuid'] = $row['provider_address_uuid'];
- $array['providers'][$x]['provider_addresses'][$y]['provider_address_cidr'] = $row['provider_address_cidr'];
- $array['providers'][$x]['provider_addresses'][$y]['provider_address_enabled'] = $row['provider_address_enabled'];
- $array['providers'][$x]['provider_addresses'][$y]['provider_address_description'] = $row['provider_address_description'];
- $y++;
- }
- //save to the data
- $database = new database;
- $database->app_name = 'providers';
- $database->app_uuid = '35187839-237e-4271-b8a1-9b9c45dc8833';
- $database->save($array);
- //$message = $database->message;
- //view_array($message);
- unset($array);
- }
- }
- }
- ?>
|