-- PostgreSQL Database Reset Script for Rocket.Chat Import -- Run as: sudo -u postgres psql -f reset_database.sql -- Terminate all connections to the database (force disconnect users) SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE datname = 'rocketchat_converted' AND pid <> pg_backend_pid(); -- Drop the database if it exists DROP DATABASE IF EXISTS rocketchat_converted; -- Create fresh database CREATE DATABASE rocketchat_converted; -- Create user (if not exists) DO $$ BEGIN IF NOT EXISTS (SELECT FROM pg_user WHERE usename = 'rocketchat_user') THEN CREATE USER rocketchat_user WITH PASSWORD 'HKjLgt23gWuPXzEAn3rW'; END IF; END $$; -- Grant database privileges GRANT CONNECT ON DATABASE rocketchat_converted TO rocketchat_user; GRANT CREATE ON DATABASE rocketchat_converted TO rocketchat_user; -- Connect to the new database \c rocketchat_converted; -- Grant schema privileges GRANT CREATE ON SCHEMA public TO rocketchat_user; GRANT USAGE ON SCHEMA public TO rocketchat_user; -- Grant privileges on all future tables and sequences ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT, INSERT, UPDATE, DELETE ON TABLES TO rocketchat_user; ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT USAGE, SELECT ON SEQUENCES TO rocketchat_user; -- Display success message \echo 'Database reset completed successfully!' \echo 'You can now run the converter with:' \echo 'python3 mongo_to_postgres_converter.py --mongo-path db/database/62df06d44234d20001289144 --pg-database rocketchat_converted --pg-user rocketchat_user --pg-password your_password'