# Pixelfed Docker Server Role This README details the steps to manage your Pixelfed instance running in a Docker container. This setup is part of the docker-pixelfed role within Kevin Veen-Birkenbach's cymais located at [this GitHub repository](https://github.com/kevinveenbirkenbach/cymais/tree/master/roles/docker-pixelfed). ## Accessing Services ### Application Access To gain shell access to the application container, run the following command: ```bash docker-compose exec -it application bash ``` ### Clear Cache ```bash docker compose exec -it application php artisan cache:clear ``` ### Database Access To access the MariaDB instance in the database container, run the following command: ```bash docker-compose exec -it database mariadb -u pixelfed -p ``` ### User Management via CLI in Pixelfed Docker Setup To manage users in your Pixelfed instance running in a Docker container, as configured in Kevin Veen-Birkenbach's docker-pixelfed role, you can follow these steps via the Command Line Interface (CLI): 1. **Access the Application Container:** First, gain shell access to the Pixelfed application container. Use the command provided in the README: ```bash docker-compose exec -it application bash ``` This command lets you access the bash shell inside the `application` Docker container where Pixelfed is running. 2. **Navigate to Pixelfed Directory:** Once inside the container, navigate to the Pixelfed directory. This is typically the root directory where Pixelfed is installed. 3. **Use Artisan Commands:** Pixelfed is built on Laravel, so you'll use Laravel's Artisan CLI for user management. Here are some common tasks: - **Create a New User:** ```bash php artisan user:create ``` This command will prompt you to enter the user's details like username, email, and password. - **List Users:** ```bash php artisan user:list ``` This command displays a list of all users. - **Delete a User:** ```bash php artisan user:delete {username} ``` Replace `{username}` with the actual username of the user you wish to delete. - **Reset Password:** ```bash php artisan user:reset-password {username} ``` This will initiate a password reset process for the specified user. 4. **Verify and Validate:** Depending on your Pixelfed's configuration, especially if email verification is required, you might need to perform additional steps to verify new accounts or modify user details. 5. **Exit the Container:** After completing your user management tasks, exit the Docker container shell by typing `exit`. ### Note: - **Commands Variability:** The available Artisan commands can vary based on your version of Pixelfed and Laravel. Always refer to the specific documentation for your version. - **Permissions:** Ensure you have the necessary permissions and rights within the Docker container to perform these actions. - **Environment Specifics:** The exact paths and commands may vary based on your Docker and Pixelfed setup, as defined in your `docker-compose.yml` and other configuration files. This process provides a streamlined way to manage Pixelfed users directly from the CLI in a Dockerized environment, ensuring that you can efficiently administer your Pixelfed instance without needing to access the Pixelfed web interface. ## Instagram Import Cleanup If you have imported posts from Instagram, you can clean up the imported data and files as follows: ### Database Cleanup Run these commands inside your MariaDB shell to remove import related data: ```bash DELETE from import_posts WHERE 1; DELETE from import_jobs WHERE 1; DELETE from import_datas WHERE 1; DELETE from statuses where created_at < "2022-12-01 22:15:39"; DELETE from media where deleted_at >= "2023-07-28 14:39:05"; ``` ### File System Cleanup Run these commands to remove the imported files and trigger the cleanup job: ```bash docker-compose exec -u "www-data" application rm -rv "/var/www/storage/app/imports/1" docker-compose exec -u "www-data" application php artisan schedule:run ``` ## Full Cleanup (Reset) For a hard reset, which will delete all data and stop all services, use the following commands: ```bash docker-compose down docker volume rm pixelfed_application_data pixelfed_database pixelfed_redis ``` ## Update Procedure To update your Pixelfed instance, navigate to the directory where your `docker-compose.yml` file is located and run these commands: ```bash cd {{path_docker_compose_instances}}pixelfed/ && docker-compose down && docker network prune -f && docker-compose pull && docker-compose build && docker-compose -p pixelfed up -d --force-recreate ``` ## Inspecting the Services To see the status of all services or follow the logs, use these commands: ```bash docker-compose ps -a docker-compose logs -f ``` ## Debug To debug the system set APP_DEBUG to true, like descriped [here](https://docs.pixelfed.org/technical-documentation/config/). ```bash nano config/app.php php artisan cache:clear php artisan route:cache php artisan view:clear php artisan config:cache ``` ## Modifying files ```bash apt update && apt upgrade && apt install nano ``` ## Further Reading For additional information, refer to these resources: - [Docker image on Docker Hub](https://hub.docker.com/r/zknt/pixelfed) - [Blog Post about running Pixelfed in Docker](https://blog.pixelfed.de/2020/05/29/pixelfed-in-docker/) --- Author: Kevin Veen-Birkenbach, [https://www.veen.world](https://www.veen.world), [kevin@veen.world](mailto:kevin@veen.world) This README was optimized with the help of OpenAI's ChatGPT. You can view the conversation here: - https://chat.openai.com/share/3daea33f-2e30-46e9-a709-a9c93e823ed9 - https://chat.openai.com/share/17f4cf36-feb7-4e7d-bb61-2732475f8a37