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/Repositories/CampaignPageRepository.php
<?php

namespace Give\Campaigns\Repositories;

use Give\Campaigns\Actions\CreateDefaultLayoutForCampaignPage;
use Give\Campaigns\Models\CampaignPage;
use Give\Campaigns\ValueObjects\CampaignPageMetaKeys;
use Give\Campaigns\ValueObjects\CampaignPageStatus;
use Give\Framework\Database\DB;
use Give\Framework\Exceptions\Primitives\Exception;
use Give\Framework\Exceptions\Primitives\InvalidArgumentException;
use Give\Framework\Models\ModelQueryBuilder;
use Give\Framework\Support\Facades\DateTime\Temporal;
use Give\Helpers\Hooks;
use Give\Log\Log;

/**
 * @since 4.0.0
 */
class CampaignPageRepository
{
    /**
     * @since 4.0.0
     */
    protected $requiredProperties = [
        'campaignId',
    ];

    /**
     * @since 4.0.0
     */
    public function getById(int $id): ?CampaignPage
    {
        return $this->prepareQuery()
            ->where('id', $id)
            ->get();
    }

    /**
     * @since 4.0.0
     */
    public function queryByCampaignId(int $campaignId): ModelQueryBuilder
    {
        return $this->prepareQuery()
            ->where('post_status', CampaignPageStatus::TRASH()->getValue(), '!=')
            ->where('postmeta_attach_meta_campaignId.meta_value', $campaignId);
    }

    /**
     * @since 4.0.0
     */
    public function findByCampaignId(int $campaignId): ?CampaignPage
    {
        return $this->queryByCampaignId($campaignId)->get();
    }

    /**
     * @since 4.0.0
     * @throws Exception
     */
    public function insert(CampaignPage $campaignPage): void
    {
        $this->validate($campaignPage);

        Hooks::doAction('givewp_campaign_page_creating', $campaignPage);

        $dateCreated = Temporal::withoutMicroseconds($campaignPage->createdAt ?: Temporal::getCurrentDateTime());
        $dateCreatedFormatted = Temporal::getFormattedDateTime($dateCreated);
        $dateUpdated = $campaignPage->updatedAt ?? $dateCreated;
        $dateUpdatedFormatted = Temporal::getFormattedDateTime($dateUpdated);
        $status = $campaignPage->status ?? CampaignPageStatus::DRAFT();
        $campaign = $campaignPage->campaign();

        if (!$campaign) {
            throw new Exception('Campaign not found');
        }

        DB::query('START TRANSACTION');

        try {
            $campaignPage->id = wp_insert_post([
                'post_title' => $campaign->title,
                'post_name' => sanitize_title($campaign->title),
                'post_date' => $dateCreatedFormatted,
                'post_modified' => $dateUpdatedFormatted,
                'post_status' => $status->getValue(),
                'post_type' => 'page',
                'post_content' => $campaignPage->content ?? give(CreateDefaultLayoutForCampaignPage::class)(
                    $campaign->id,
                    $campaign->shortDescription
                ),
            ]);

            if (!$campaignPage->id) {
                throw new Exception('Failed creating a campaign page');
            }

            $campaignPage->createdAt = $dateCreated;
            $campaignPage->updatedAt = $dateUpdated;
            $campaignPage->status = $status;

            update_post_meta($campaignPage->id, CampaignPageMetaKeys::CAMPAIGN_ID, $campaignPage->campaignId);

            if ($campaign->image && $imageId = attachment_url_to_postid($campaign->image)) {
                set_post_thumbnail($campaignPage->id, $imageId);
            }
        } catch (Exception $exception) {
            DB::query('ROLLBACK');

            Log::error('Failed creating a campaign page', [$campaignPage]);

            throw new $exception('Failed creating a campaign page');
        }

        DB::query('COMMIT');

        Hooks::doAction('givewp_campaign_page_created', $campaignPage);
    }

    /**
     * @since 4.0.0
     * @throws Exception
     */
    public function update(CampaignPage $campaignPage): void
    {
        $this->validate($campaignPage);

        Hooks::doAction('givewp_campaign_page_updating', $campaignPage);

        $now = Temporal::withoutMicroseconds(Temporal::getCurrentDateTime());
        $nowFormatted = Temporal::getFormattedDateTime($now);
        $status = $campaignPage->status ?? CampaignPageStatus::PUBLISH();

        DB::query('START TRANSACTION');

        try {
            DB::table('posts')
                ->where('ID', $campaignPage->id)
                ->update([
                    'post_modified' => $nowFormatted,
                    'post_modified_gmt' => get_gmt_from_date($nowFormatted),
                    'post_status' => $status->getValue(),
                    'post_content' => $campaignPage->content,
                ]);

            $campaignPage->updatedAt = $now;
            $campaignPage->status = $status;

            update_post_meta($campaignPage->id, CampaignPageMetaKeys::CAMPAIGN_ID, $campaignPage->campaignId);
        } catch (Exception $exception) {
            DB::query('ROLLBACK');

            Log::error('Failed updating a campaign page', [$campaignPage]);

            throw new $exception('Failed updating a campaign page');
        }

        DB::query('COMMIT');

        Hooks::doAction('givewp_campaign_page_updated', $campaignPage);
    }

    /**
     * @since 4.0.0
     * @throws Exception
     */
    public function delete(CampaignPage $campaignPage): bool
    {
        DB::query('START TRANSACTION');

        Hooks::doAction('givewp_campaign_page_deleting', $campaignPage);

        try {
            DB::table('posts')
                ->where('id', $campaignPage->id)
                ->delete();

            DB::table('postmeta')
                ->where('post_id', $campaignPage->id)
                ->delete();
        } catch (Exception $exception) {
            DB::query('ROLLBACK');

            Log::error('Failed deleting a campaign page', [$campaignPage]);

            throw new $exception('Failed deleting a campaign page');
        }

        DB::query('COMMIT');

        Hooks::doAction('givewp_campaign_page_deleted', $campaignPage);

        return true;
    }

    /**
     * @since 4.0.0
     *
     * @return ModelQueryBuilder<CampaignPage>
     */
    public function prepareQuery(): ModelQueryBuilder
    {
        $builder = new ModelQueryBuilder(CampaignPage::class);

        return $builder->from('posts')
            ->select(
                ['ID', 'id'],
                ['post_date', 'createdAt'],
                ['post_modified', 'updatedAt'],
                ['post_status', 'status'],
                ['post_content', 'content']
            )
            ->attachMeta(
                'postmeta',
                'ID',
                'post_id',
                ...CampaignPageMetaKeys::getColumnsForAttachMetaQuery()
            );
    }

    /**
     * @since 4.0.0
     */
    public function validate(CampaignPage $campaignPage)
    {
        foreach ($this->requiredProperties as $key) {
            if (!isset($campaignPage->$key)) {
                throw new InvalidArgumentException("'$key' is required.");
            }
        }
    }
}