Skip to main content

Upgrading Mixpost Lite to v2 from v1

Backup database

Sometimes the upgrade can go wrong, so we recommend that you backup your database before starting the upgrade.

Upgrade Using Docker

Upgrading Mixpost using Docker is straightforward. Ensure that you preserve the mounted volume during the process. Simply follow these steps:

Navigate to your folder where you have the docker-compose.yml the file then run:

# Pull the latest version
docker compose pull

# Stop and remove the old container
docker compose down

# Start a new container
docker compose up -d
info

If something goes wrong, you can use the inovector/mixpost:v1.7.2 tag to revert. Also, you need to restore your database backup.

Upgrade in a PHP Environment

This method applies if you have installed Mixpost Lite manually or within an existing Laravel application.

1. Updating your composer.json using the require command

composer require inovector/mixpost "^2.0"

2. Migrations

Some changes were made to the database, use the migration below to update your database to the latest schema:

<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;
use Inovector\Mixpost\Models\Service;

return new class extends Migration {
public function up()
{
if (Schema::hasTable('mixpost_services')) {
if (Schema::hasColumn('mixpost_services', 'credentials') && !Schema::hasColumn('mixpost_services', 'configuration')) {
Schema::table('mixpost_services', function (Blueprint $table) {
$table->renameColumn('credentials', 'configuration');
});
}

if (!Schema::hasColumn('mixpost_services', 'active')) {
Schema::table('mixpost_services', function (Blueprint $table) {
$table->boolean('active')->default(false);
});
}

Service::query()->update(['active' => true]);
}

if (Schema::hasTable('mixpost_accounts')) {
if (!Schema::hasColumn('mixpost_accounts', 'uuid')) {
Schema::table('mixpost_accounts', function (Blueprint $table) {
$table->uuid('uuid')->nullable()->after('id');
});
}

DB::table('mixpost_accounts')->whereNull('uuid')->update(['uuid' => DB::raw('uuid()')]);

if (!Schema::hasColumn('mixpost_accounts', 'uuid')) {
Schema::table('mixpost_accounts', function (Blueprint $table) {
$table->uuid('uuid')->unique()->change();
});
}

if (!Schema::hasColumn('mixpost_accounts', 'authorized')) {
Schema::table('mixpost_accounts', function (Blueprint $table) {
$table->boolean('authorized')->default(false)->after('data');
});
}
}

if (Schema::hasTable('mixpost_posts')) {
if (!Schema::hasColumn('mixpost_posts', 'uuid')) {
Schema::table('mixpost_posts', function (Blueprint $table) {
$table->uuid('uuid')->nullable()->after('id');
});
}

DB::table('mixpost_posts')->whereNull('uuid')->update(['uuid' => DB::raw('uuid()')]);

if (!Schema::hasColumn('mixpost_posts', 'uuid')) {
Schema::table('mixpost_posts', function (Blueprint $table) {
$table->uuid('uuid')->unique()->change();
});
}
}


if (Schema::hasTable('mixpost_post_accounts')) {
if (!Schema::hasColumn('mixpost_post_accounts', 'data')) {
Schema::table('mixpost_post_accounts', function (Blueprint $table) {
$table->json('data')->nullable()->after('provider_post_id');
});
}
}

if (Schema::hasTable('mixpost_tags')) {
if (!Schema::hasColumn('mixpost_tags', 'uuid')) {
Schema::table('mixpost_tags', function (Blueprint $table) {
$table->uuid('uuid')->nullable()->after('id');
});
}

DB::table('mixpost_tags')->whereNull('uuid')->update(['uuid' => DB::raw('uuid()')]);

if (!Schema::hasColumn('mixpost_tags', 'uuid')) {
Schema::table('mixpost_tags', function (Blueprint $table) {
$table->uuid('uuid')->unique()->change();
});
}
}


if (Schema::hasTable('mixpost_media')) {
if (!Schema::hasColumn('mixpost_media', 'uuid')) {
Schema::table('mixpost_media', function (Blueprint $table) {
$table->uuid('uuid')->nullable()->after('id');
});
}

DB::table('mixpost_media')->whereNull('uuid')->update(['uuid' => DB::raw('uuid()')]);

if (!Schema::hasColumn('mixpost_media', 'uuid')) {
Schema::table('mixpost_media', function (Blueprint $table) {
$table->uuid('uuid')->unique()->change();
});
}

if (!Schema::hasColumn('mixpost_media', 'data')) {
Schema::table('mixpost_media', function (Blueprint $table) {
$table->json('data')->nullable()->after('path');
});
}
}
}
};

Don't know how to migrate?

  • Open your terminal and navigate to your project directory.
  • Generate a migration file by running: php artisan make:migration create_mixpost_v2_tables
  • Open the new migration file from database/migrations and paste the migration code into it.
  • Apply the migration with: php artisan migrate
  • Done!

3. Config changes

There have been numerous config changes. If you have published the Mixpost config file, you should update it manually.

To update easily, simply run the following command:

php artisan vendor:publish --tag=mixpost-config --force

4. Schedule the commands

Update the schedule method in app/Console/Kernel.php as shown below:

protected function schedule(Schedule $schedule)
{
// Remove these commented lines
// $schedule->command('mixpost:run-scheduled-posts')->everyMinute();
// $schedule->command('mixpost:import-account-data')->everyTwoHours();
// $schedule->command('mixpost:import-account-audience')->everyThreeHours();
// $schedule->command('mixpost:process-metrics')->everyThreeHours();
// $schedule->command('mixpost:delete-old-data')->daily();

// Register Mixpost's custom schedules
\Inovector\Mixpost\Schedule::register($schedule);

// Additional Laravel commands
$schedule->command('horizon:snapshot')->everyFiveMinutes();
$schedule->command('queue:prune-batches')->daily();
$schedule->command('queue:prune-failed')->daily();
}

5. Clear the cache

php artisan route:clear
php artisan view:clear
php artisan mixpost:clear-services-cache
php artisan mixpost:clear-settings-cache

6. Optimize application

php artisan optimize

7. Terminate the Horizon process

php artisan horizon:terminate

Conclusion

Following these steps will ensure that your Mixpost Lite installation is upgraded to v2, maintaining performance and security standards.