X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Flibs%2Fnetwork_functions.php;h=a1797e30ae4d8531a4925e12b7a7606858c5e5aa;hp=e173bad283bed37d2914c517f99cf0b91bee4d90;hb=72ac9f672704438aabc4f4bada7f5c3b40499f1a;hpb=039203d5428c9c6a3bed61fb3a9a16958c6fd44c diff --git a/inc/libs/network_functions.php b/inc/libs/network_functions.php index e173bad283..a1797e30ae 100644 --- a/inc/libs/network_functions.php +++ b/inc/libs/network_functions.php @@ -44,14 +44,14 @@ if (!defined('__SECURITY')) { // Handle a (maybe) sent form here function doNetworkHandleForm () { // Was the form sent? - if ((isFormSent()) || (isPostRequestElementSet('edit')) || (isPostRequestElementSet('del')) || (isPostRequestElementSet('change')) || (isPostRequestElementSet('remove'))) { + if ((isFormSent()) || (isPostRequestParameterSet('edit')) || (isPostRequestParameterSet('del')) || (isPostRequestParameterSet('change')) || (isPostRequestParameterSet('remove'))) { // Do we have a 'do'? - if (isGetRequestElementSet('do')) { + if (isGetRequestParameterSet('do')) { // Process the request doAdminNetworkProcessForm(); } else { // No 'do' found - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_DO_404')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_DO_404')); } } // END - if } @@ -59,23 +59,23 @@ function doNetworkHandleForm () { // Processes an admin form function doAdminNetworkProcessForm () { // Form really sent? - if ((!isFormSent()) && (!isPostRequestElementSet('edit')) && (!isPostRequestElementSet('del')) && (!isPostRequestElementSet('change')) && (!isPostRequestElementSet('remove'))) { + if ((!isFormSent()) && (!isPostRequestParameterSet('edit')) && (!isPostRequestParameterSet('del')) && (!isPostRequestParameterSet('change')) && (!isPostRequestParameterSet('remove'))) { // Abort here - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_FORM_NOT_SENT')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_FORM_NOT_SENT')); return; - } elseif (!isGetRequestElementSet('do')) { + } elseif (!isGetRequestParameterSet('do')) { // No 'do' found - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_DO_404')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_DO_404')); return; } // Create function name - $functionName = sprintf("doAdminNetworkProcess%sForm", ucfirst(strtolower(getRequestElement('do')))); + $functionName = sprintf("doAdminNetworkProcess%sForm", ucfirst(strtolower(getRequestParameter('do')))); // Is the function valid? if (!function_exists($functionName)) { // Invalid function name - debug_report_bug('Invalid do ' . getRequestElement('do') . ', function ' . $functionName .' does not exist.', false); + debug_report_bug('Invalid do ' . getRequestParameter('do') . ', function ' . $functionName .' does not exist.', false); } // END - if // Call-back the method handling our request @@ -98,6 +98,38 @@ function isNetworkNameValid ($name) { return $isValid; } +// Checks wether the given network type is already used (valid) +function isNetworkTypeHandleValid ($type, $networkId) { + // Query for it + $result = SQL_QUERY_ESC("SELECT `network_type_id` FROM `{?_MYSQL_PREFIX?}_network_types` WHERE `network_id`=%s AND `network_type_handle`='%s' LIMIT 1", + array($networkId, $type), __FUNCTION__, __LINE__); + + // Does it exist? + $isValid = (SQL_NUMROWS($result) == 1); + + // Free result + SQL_FREERESULT($result); + + // Return result + return $isValid; +} + +// Checks wether the given network request parameter is already used (valid) +function isNetworkRequestParameterValid ($key, $type, $networkId) { + // Query for it + $result = SQL_QUERY_ESC("SELECT `network_param_id` FROM `{?_MYSQL_PREFIX?}_network_request_params` WHERE `network_id`=%s AND `network_type_id`=%s AND `request_param_key`='%s' LIMIT 1", + array($networkId, $type, $key), __FUNCTION__, __LINE__); + + // Does it exist? + $isValid = (SQL_NUMROWS($result) == 1); + + // Free result + SQL_FREERESULT($result); + + // Return result + return $isValid; +} + // "Getter" for a network's data by provided id number function getNetworkDataById ($id) { // Ids lower one are not accepted @@ -132,6 +164,40 @@ LIMIT 1", return $networkData; } +// "Getter" for a network type data by provided id number +function getNetworkTypeDataById ($id) { + // Ids lower one are not accepted + if ($id < 1) { + // Not good, should be fixed + debug_report_bug('Network type id ' . $id . ' is smaller than 1.'); + } // END - if + + // By default we have no data + $networkTypeData = array(); + + // Query for the network data + $result = SQL_QUERY_ESC("SELECT + `network_type_id`, `network_id`, `network_type_handle`, `network_type_api_url`, `network_type_click_url`, `network_type_banner_url` +FROM + `{?_MYSQL_PREFIX?}_network_types` +WHERE + `network_type_id`=%s +LIMIT 1", + array(bigintval($id)), __FUNCTION__, __LINE__); + + // Do we have an entry? + if (SQL_NUMROWS($result) == 1) { + // Then get it + $networkTypeData = SQL_FETCHARRAY($result); + } // END - if + + // Free result + SQL_FREERESULT($result); + + // Return result + return $networkTypeData; +} + // Updates given network (id) with data from array function doNetworkUpdateDataByArray ($id, $networkData) { // Ids lower one are not accepted @@ -144,6 +210,18 @@ function doNetworkUpdateDataByArray ($id, $networkData) { return adminSaveSettings($networkData, '_network_data', sprintf("`network_id`=%s", bigintval($id)), array(), false, false); } +// Updates given network type handler (id) with data from array +function doNetworkUpdateTypeByArray ($id, $networkTypeData) { + // Ids lower one are not accepted + if ($id < 1) { + // Not good, should be fixed + debug_report_bug('Network type handler id ' . $id . ' is smaller than 1.'); + } // END - if + + // Just call our inner method + return adminSaveSettings($networkTypeData, '_network_types', sprintf("`network_type_id`=%s", bigintval($id)), array(), false, false); +} + // Removes given network entry function doAdminRemoveNetworkEntry ($table, $column, $id, $limit = 1) { // Remove the entry @@ -161,11 +239,11 @@ function generateAdminNetworkList () { // Query for all networks $result = SQL_QUERY("SELECT - `network_id`, `network_title` + `network_id`, `network_short_name`, `network_title` FROM `{?_MYSQL_PREFIX?}_network_data` ORDER BY - `network_title` ASC", __FILE__, __LINE__); + `network_short_name` ASC", __FILE__, __LINE__); // Do we have entries? if (SQL_NUMROWS($result) > 0) { @@ -177,10 +255,10 @@ ORDER BY } // END - while // Generate the selection box - $content = generateSelectionBoxFromArray($rows, 'network', 'network_id', 'network_title'); + $content = generateSelectionBoxFromArray($rows, 'network', 'network_id'); } else { // Nothing selected - $content = loadTemplate('admin_settings_saved', false, getMessage('ADMIN_ENTRIES_404')); + $content = loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_ENTRIES_404')); } // Free the result @@ -197,14 +275,14 @@ ORDER BY // Callback function to add new network function doAdminNetworkProcessAddnetworkForm () { // We can say here, the form is sent, so check if the network is already added - if (isNetworkNameValid(postRequestElement('network_short_name'))) { + if (isNetworkNameValid(postRequestParameter('network_short_name'))) { // Already there - loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_ALREADY_ADDED', postRequestElement('network_short_name'))); - return; + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_ALREADY_ADDED', postRequestParameter('network_short_name'))); + return false; } // END - if // Remove the 'ok' part - unsetPostRequestElement('ok'); + unsetPostRequestParameter('ok'); // Add the whole request to database SQL_QUERY("INSERT INTO @@ -216,7 +294,7 @@ function doAdminNetworkProcessAddnetworkForm () { )", __FUNCTION__, __LINE__); // Add the id for output only - setRequestPostElement('network_id', SQL_INSERTID()); + setPostRequestParameter('network_id', SQL_INSERTID()); // Output message if (SQL_AFFECTEDROWS() == 1) { @@ -224,7 +302,7 @@ function doAdminNetworkProcessAddnetworkForm () { loadTemplate('admin_network_added', false, postRequestArray()); } else { // Not added - loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_DATA_NOT_ADDED', postRequestElement('network_short_name'))); + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_DATA_NOT_ADDED', postRequestParameter('network_short_name'))); } } @@ -234,7 +312,7 @@ function doAdminNetworkProcessHandlenetworkForm () { if (countPostSelection() > 0) { // Something has been selected, so start displaying one by one $SW = 2; $OUT = ''; - foreach (postRequestElement('sel') as $id => $sel) { + foreach (postRequestParameter('sel') as $id => $sel) { // Is this selected? if ($sel == 1) { // Load this network's data @@ -245,18 +323,21 @@ function doAdminNetworkProcessHandlenetworkForm () { // Add color $networkData['sw'] = $SW; - if (isPostRequestElementSet('edit')) { + if (isPostRequestParameterSet('edit')) { // Make selection box for network_request_type $networkData['network_request_type'] = generateOptionList( '/ARRAY/', array('GET','POST'), - array(getMessage('ADMIN_NETWORK_REQUEST_TYPE_GET'), getMessage('ADMIN_NETWORK_REQUEST_TYPE_POST')), + array( + getMessage('ADMIN_NETWORK_REQUEST_TYPE_GET'), + getMessage('ADMIN_NETWORK_REQUEST_TYPE_POST') + ), $networkData['network_request_type'] ); // Add row template for editing $OUT .= loadTemplate('admin_edit_networks_row', true, $networkData); - } elseif (isPostRequestElementSet('del')) { + } elseif (isPostRequestParameterSet('del')) { // Translate the request type $networkData['network_request_type'] = getMessage('ADMIN_NETWORK_REQUEST_TYPE_' . $networkData['network_request_type']); @@ -276,9 +357,9 @@ function doAdminNetworkProcessHandlenetworkForm () { // If we have no rows, we don't need to display the edit form if (!empty($OUT)) { // Output main template - if (isPostRequestElementSet('edit')) { + if (isPostRequestParameterSet('edit')) { loadTemplate('admin_edit_networks', false, $OUT); - } elseif (isPostRequestElementSet('del')) { + } elseif (isPostRequestParameterSet('del')) { loadTemplate('admin_del_networks', false, $OUT); } else { // Problem! @@ -289,7 +370,74 @@ function doAdminNetworkProcessHandlenetworkForm () { $GLOBALS['network_display'] = false; } else { // Nothing selected/found - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_NOTHING_FOUND')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_NOTHING_FOUND')); + } + } // END - if +} + +// Handle network type form +function doAdminNetworkProcessHandlenetworktypeForm () { + // Do we have selections? + if (countPostSelection() > 0) { + // Load network data + $networkData = getNetworkDataById(getRequestParameter('network')); + + // Something has been selected, so start displaying one by one + $SW = 2; $OUT = ''; + foreach (postRequestParameter('sel') as $id => $sel) { + // Is this selected? + if ($sel == 1) { + // Load this network's data + $networkTypeData = getNetworkTypeDataById($id); + + // Do we have found the network? + if (count($networkTypeData) > 0) { + // Add color + $networkTypeData['sw'] = $SW; + + if (isPostRequestParameterSet('edit')) { + // Add row template for deleting + $OUT .= loadTemplate('admin_edit_network_types_row', true, $networkTypeData); + } elseif (isPostRequestParameterSet('del')) { + // Fix empty banner URL + if (trim($networkTypeData['network_type_banner_url']) == '') $networkTypeData['network_type_banner_url'] = '---'; + + // Add row template for deleting + $OUT .= loadTemplate('admin_del_network_types_row', true, $networkTypeData); + } else { + // Problem! + debug_report_bug('Cannot detect edit/del.'); + } + + // Switch colors + $SW = 3 - $SW; + } // END - if + } // END - if + } // END - foreach + + // If we have no rows, we don't need to display the edit form + if (!empty($OUT)) { + // Prepare content for template + $content = array( + 'rows' => $OUT, + 'network_data' => getNetworkDataById(getRequestParameter('network')) + ); + + // Output main template + if (isPostRequestParameterSet('edit')) { + loadTemplate('admin_edit_network_types', false, $content); + } elseif (isPostRequestParameterSet('del')) { + loadTemplate('admin_del_network_types', false, $content); + } else { + // Problem! + debug_report_bug('Cannot detect edit/del.'); + } + + // Don't display the list/add new form + $GLOBALS['network_display'] = false; + } else { + // Nothing selected/found + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_TYPES_NOTHING_FOUND')); } } // END - if } @@ -302,7 +450,7 @@ function doAdminNetworkProcessChangenetworkForm () { $updated = 0; // Something has been selected, so start updating them - foreach (postRequestElement('sel') as $id => $sel) { + foreach (postRequestParameter('sel') as $id => $sel) { // Update this entry? if ($sel == 1) { // Init data array @@ -334,7 +482,7 @@ function doAdminNetworkProcessChangenetworkForm () { loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_UPDATED', $updated)); } else { // Nothing changed - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_NOTHING_CHANGED')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_NOTHING_CHANGED')); } } // END - if } @@ -347,7 +495,7 @@ function doAdminNetworkProcessRemovenetworkForm () { $removed = 0; // Something has been selected, so start updating them - foreach (postRequestElement('sel') as $id => $sel) { + foreach (postRequestParameter('sel') as $id => $sel) { // Update this entry? if ($sel == 1) { // Remove this entry @@ -361,10 +509,166 @@ function doAdminNetworkProcessRemovenetworkForm () { loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_REMOVED', $removed)); } else { // Nothing removed - loadTemplate('admin_settings_saved', false, getMessage('ADMIN_NETWORK_NOTHING_REMOVED')); + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_NOTHING_REMOVED')); } } // END - if } +// Add a network type handler if not yet found +function doAdminNetworkProcessAddnetworktypeForm () { + // Is the network type handle already used with given network? + if (isNetworkTypeHandleValid(postRequestParameter('network_type_handle'), getRequestParameter('network'))) { + // Already added + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_TYPES_HANDLE_ALREADY_ADDED', postRequestParameter('network_type_handle'))); + + // ... so abort here + return false; + } // END - if + + // Remove the 'ok' part + unsetPostRequestParameter('ok'); + + // Add id + setPostRequestParameter('network_id', getRequestParameter('network')); + + // Is network_type_banner_url set? + if (postRequestParameter('network_type_banner_url') == '') { + // Remove empty value to get a NULL for an optional entry + unsetPostRequestParameter('network_type_banner_url'); + } // END - if + + // Add the whole request to database + SQL_QUERY("INSERT INTO + `{?_MYSQL_PREFIX?}_network_types` +( + `" . implode('`,`', array_keys(postRequestArray())) . "` +) VALUES ( + '" . implode("','", array_values(postRequestArray())) . "' +)", __FUNCTION__, __LINE__); + + // Output message + if (SQL_AFFECTEDROWS() == 1) { + // Successfully added + loadTemplate('admin_network_type_added', false, postRequestArray()); + } else { + // Not added + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_TYPES_NOT_ADDED', postRequestParameter('network_type_handle'))); + } +} + +// Changes given network type handlers +function doAdminNetworkProcessChangenetworktypeForm () { + // Do we have selections? + if (countPostSelection() > 0) { + // By default nothing is updated + $updated = 0; + + // Something has been selected, so start updating them + foreach (postRequestParameter('sel') as $id => $sel) { + // Update this entry? + if ($sel == 1) { + // Init data array + $networkTypeData = array(); + + // Transfer whole array, except 'sel' + foreach (postRequestArray() as $key => $entry) { + // Skip 'sel' and submit button + if (in_array($key, array('sel', 'change'))) continue; + + // Do we have this enty? + if (!isset($entry[$id])) { + // Not found, needs fixing + debug_report_bug('No entry in key=' . $key . ', id=' . $id . ' found.'); + } // END - if + + // Add this entry + $networkTypeData[$key] = $entry[$id]; + } // END - foreach + + // Update the network data + $updated += doNetworkUpdateTypeByArray($id, $networkTypeData); + } // END - if + } // END - foreach + + // Do we have updates? + if ($updated > 0) { + // Updates done + loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_TYPES_UPDATED', $updated)); + } else { + // Nothing changed + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_TYPES_NOTHING_CHANGED')); + } + } // END - if +} + +// Removes given network type handlers +function doAdminNetworkProcessRemovenetworktypeForm () { + // Do we have selections? + if (countPostSelection() > 0) { + // By default nothing is removed + $removed = 0; + + // Something has been selected, so start updating them + foreach (postRequestParameter('sel') as $id => $sel) { + // Update this entry? + if ($sel == 1) { + // Remove this entry + $removed += doAdminRemoveNetworkEntry('types', 'network_type_id', $id); + } // END - if + } // END - foreach + + // Do we have removes? + if ($removed > 0) { + // Removals done + loadTemplate('admin_settings_saved', false, getMaskedMessage('ADMIN_NETWORK_TYPES_REMOVED', $removed)); + } else { + // Nothing removed + loadTemplate('admin_settings_unsaved', false, getMessage('ADMIN_NETWORK_TYPES_NOTHING_REMOVED')); + } + } // END - if +} + +// Adds a request parameter to given network and type +function doAdminNetworkProcessAddnetworkparamForm () { + // Is the request parameter already used with given network? + if (isNetworkRequestParameterValid(postRequestParameter('request_param_key'), postRequestParameter('network_type_id'), getRequestParameter('network'))) { + // Already added + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_REQUEST_PARAMETER_ALREADY_ADDED', postRequestParameter('request_param_key'))); + + // ... so abort here + return false; + } // END - if + + // Remove the 'ok' part + unsetPostRequestParameter('ok'); + + // Add id + setPostRequestParameter('network_id', getRequestParameter('network')); + + // Is request_param_default set? + if (postRequestParameter('request_param_default') == '') { + // Remove empty value to get a NULL for an optional entry + unsetPostRequestParameter('request_param_default'); + } // END - if + + // Add the whole request to database + SQL_QUERY("INSERT INTO + `{?_MYSQL_PREFIX?}_network_request_params` +( + `" . implode('`,`', array_keys(postRequestArray())) . "` +) VALUES ( + '" . implode("','", array_values(postRequestArray())) . "' +)", __FUNCTION__, __LINE__); + + // Output message + if (SQL_AFFECTEDROWS() == 1) { + // Successfully added + loadTemplate('admin_network_request_param_added', false, postRequestArray()); + } else { + // Not added + loadTemplate('admin_settings_unsaved', false, getMaskedMessage('ADMIN_NETWORK_REQUEST_PARAMETER_NOT_ADDED', postRequestParameter('request_param_key'))); + } +} + // [EOF] ?>