Skip to content

Presentator v2 to v3 migration tool

License

Notifications You must be signed in to change notification settings

presentator/v2tov3migrate

Repository files navigation

Presentator v2 to v3 migration tool

CLI that takes care for migrating the database and uploaded files from Presentator v2 to v3.

With that said, there are some notable and breaking changes in Presentator v3:

  • If there are multiple OAuth2 accounts from the same provider linked to a single Presentator user (eg. 2 Google accounts associated to 1 Presentator user) the migration will keep only the last one linked.

  • The "Project Guidelines" are deprecated and no longer available.

  • For superuser access you could use the PocketBase Dashboard located at https://yourPresentatorApp.com/_/.

Setup

  1. ⚠️ The migration tool is expected to be executed locally while having access to an existing Presentator v2 installation (at minimum the DB server must be running) to COPY the data from.

  2. Before starting the migration tool, you'll need to have a configured local Presentator v3.

    Presentator v3 is built on top on PocketBase and it is distributed as a single "all-in-one" portable file.

    Go to the Presentator v3 releases page and download the executable for your platform.

    Navigate to the extracted directory and start the executable with ./presentator serve.

    Go to your browser and open http://127.0.0.1:8090/_/ to configure the appropriate app settings from the PocketBase Dashboard > Settings, including the S3 file storage credentials if you are planning to use one.

    Once done, you can stop the process and will notice that it has created a pb_data directory next to the executable. This is where your Presentator v3 app data lives and when deploying on production it will be enough to just upload only the executable and the pb_data directory, but more on that later.

  3. Create a migration config.json file and place it next to your pb_data (remove the comments):

    • if your old Presentator v2 files are stored locally:
    {
        "v3DataDir":      "./pb_data", // path to the pb_data dir
        "v2DBDriver":     "mysql", // "pgx" for PostgreSQL
        "v2DBConnection": "username:password@localhost/presentator", // must be a valid DSN
        "v2LocalStorage": "/path/to/your/old/presentator/web/storage"
    }
    • if your old Presentator v2 files are stored in S3:
    {
        "v3DataDir":      "./pb_data", // path to the pb_data dir
        "v2DBDriver":     "mysql", // "pgx" for PostgreSQL
        "v2DBConnection": "username:password@address/dbname", // must be a valid DSN
        "v2S3Storage": {
            "endpoint":       "",
            "bucket":         "",
            "region":         "",
            "accessKey":      "",
            "secret":         "",
            "forcePathStyle": false
        }
    }
  4. Download the migration tool for your platform and for example place it next to your pb_data.

  5. Start the migration tool with ./v2tov3migrate and wait for the process to finish (it could take some time to complete).

  6. Verify that the content was migrated properly by starting the Presentator v3 executable - ./presentator serve and navigating to http://127.0.0.1:8090.

    Once you've confirmed that everything is OK, you can remove the old Presentator v2 data, the v2tov3migrate and config.json files, and you should be ready to deploy your new Presentator v3 installation. For more information on this, please refer to Presentator v3 - Going to production.

Tip

The migration tool is "incremental" and it could be run multiple times. It will attempt to sync new, changed or deleted records.

This also means that in case of an error (eg. lack of disk space), next time when you start it again it should be able to continue from where it left.