HEX
Server: LiteSpeed
System: Linux server315.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: globfdxw (6114)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/globfdxw/www/wp-content/plugins/give/src/Campaigns/Migrations/Tables/CreateCampaignsTable.php
<?php

namespace Give\Campaigns\Migrations\Tables;

use Give\Framework\Database\DB;
use Give\Framework\Database\Exceptions\DatabaseQueryException;
use Give\Framework\Migrations\Contracts\Migration;
use Give\Framework\Migrations\Exceptions\DatabaseMigrationException;

/**
 * @since 4.0.0
 * Creates give_campaigns table
 */
class CreateCampaignsTable extends Migration
{
    /**
     * @inheritdoc
     */
    public static function id(): string
    {
        return 'give-campaigns-create-give-campaigns-table';
    }

    /**
     * @inheritdoc
     */
    public static function title(): string
    {
        return 'Create give_campaigns table from core';
    }

    /**
     * @inheritdoc
     */
    public static function timestamp(): string
    {
        return strtotime('2024-08-26 00:00:00');
    }

    /**
     * @inheritDoc
     * @throws DatabaseMigrationException
     */
    public function run()
    {
        global $wpdb;

        $table = $wpdb->give_campaigns;
        $charset = DB::get_charset_collate();

        $sql = "CREATE TABLE $table (
            id INT UNSIGNED NOT NULL AUTO_INCREMENT,
            campaign_page_id INT UNSIGNED NULL,
            form_id INT NOT NULL,
            campaign_type VARCHAR(12) NOT NULL DEFAULT '',
            campaign_title TEXT NOT NULL,
            campaign_url TEXT NOT NULL,
            short_desc TEXT NOT NULL,
            long_desc TEXT NOT NULL,
            campaign_logo TEXT NOT NULL,
            campaign_image TEXT NOT NULL,
            primary_color VARCHAR(7) NOT NULL,
            secondary_color VARCHAR(7) NOT NULL,
            campaign_goal INT UNSIGNED NOT NULL,
            goal_type VARCHAR(24) NOT NULL DEFAULT 'amount',
            status VARCHAR(12) NOT NULL,
            start_date DATETIME NULL,
            end_date DATETIME NULL,
            date_created DATETIME NOT NULL,
            PRIMARY KEY  (id)
        ) $charset";

        try {
            DB::delta($sql);
        } catch (DatabaseQueryException $exception) {
            throw new DatabaseMigrationException("An error occurred while creating the $table table", 0, $exception);
        }
    }
}