first commit

This commit is contained in:
2026-02-08 21:16:11 +01:00
commit e17b7026fd
8881 changed files with 1160453 additions and 0 deletions

View File

@@ -0,0 +1,215 @@
<?php
/**
* @package Convert Forms
* @version 3.2.12 Free
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2022 Tassos Marinos All Rights Reserved
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
*/
namespace ConvertForms;
defined('_JEXEC') or die('Restricted access');
class SubmissionMeta
{
/**
* Logs table
*
* @var string
*/
private static $table = '#__convertforms_submission_meta';
/**
* Adds or updates a record in the database
*
* @param int $submission_id
* @param string $type
* @param string $key
* @param string $value
* @param array $params
*
* @return void
*/
public static function save($submission_id, $type, $key = '', $value = '', $params = [])
{
if ($record = self::getMeta($submission_id, $type, $key))
{
// Update existing record
$data = (object) [
'id' => $record['id'],
'submission_id' => $submission_id,
'meta_type' => $type,
'meta_key' => $key,
'meta_value' => $value,
'params' => json_encode($params),
'date_modified' => \JFactory::getDate()->toSql()
];
try
{
\JFactory::getDbo()->updateObject(self::$table, $data, 'id');
}
catch (Exception $e)
{
}
return;
}
// Add new record
self::add($submission_id, $type, $key, $value, $params);
}
/**
* Adds a Submission Meta.
*
* @param int $submission_id
* @param string $type
* @param string $key
* @param string $value
* @param array $params
*
* @return void
*/
public static function add($submission_id, $type, $key = '', $value = '', $params = [])
{
if (!$submission_id || !$type || !$value)
{
return;
}
// Data to save
$data = (object) [
'submission_id' => $submission_id,
'meta_type' => $type,
'meta_key' => $key,
'meta_value' => $value,
'params' => json_encode($params),
'date_created' => \JFactory::getDate()->toSql()
];
// Insert the data
try
{
\JFactory::getDbo()->insertObject(self::$table, $data);
}
catch (Exception $e)
{
}
}
/**
* Retrieves the meta row.
*
* @param int $submission_id
* @param string $type
* @param string $key
*
* @return mixed
*/
public static function getMeta($submission_id, $type, $key = '')
{
if (!$submission_id || !$type)
{
return;
}
$db = \JFactory::getDbo();
$query = $db->getQuery(true);
$query
->select('*')
->from($db->quoteName(self::$table))
->where($db->quoteName('submission_id') . ' = ' . $db->quote($submission_id))
->where($db->quoteName('meta_type') . ' = ' . $db->quote($type));
if (!empty($key))
{
$query->where($db->quoteName('meta_key') . ' = ' . $db->quote($key));
}
$db->setQuery($query);
return $db->loadAssoc();
}
/**
* Retrieves meta value.
*
* @param int $submission_id
* @param string $type
* @param string $key
*
* @return string
*/
public static function getValue($submission_id, $type, $key = '')
{
if (!$data = self::getMeta($submission_id, $type, $key))
{
return;
}
return $data['meta_value'];
}
/**
* Deletes a submission meta
*
* @param int $submission_id
* @param string $type
* @param string $key
*
* @return void
*/
public static function delete($submission_id, $type, $key = '')
{
if (!$submission_id || !$type)
{
return;
}
$db = \JFactory::getDbo();
$query = $db->getQuery(true)
->delete($db->quoteName(self::$table))
->where($db->quoteName('submission_id') . ' = ' . $db->quote($submission_id))
->where($db->quoteName('meta_type') . ' = ' . $db->quote($type));
if (!empty($key))
{
$query->where($db->quoteName('meta_key') . ' = ' . $db->quote($key));
}
$db->setQuery($query);
return $db->execute();
}
/**
* Deletes a list of submission meta by ID
*
* @param array $ids
*
* @return void
*/
public static function deleteAll($ids)
{
if (!is_array($ids))
{
return;
}
$db = \JFactory::getDbo();
$query = $db->getQuery(true)
->delete($db->quoteName(self::$table))
->where($db->quoteName('id') . ' IN (' . implode(', ', (array) $ids) . ')');
$db->setQuery($query);
return $db->execute();
}
}