mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-04-03 07:44:16 +02:00
Optimized gnome for personal computers
This commit is contained in:
parent
b488ea949f
commit
663e5604fd
@ -166,6 +166,12 @@ defaults_applications:
|
||||
css_enabled: "{{css_enabled_default}}" # Enables\Disables Global CSS Style
|
||||
landingpage_iframe_enabled: "{{landingpage_iframe_enabled_default}}" # Enables\Disables the possibility to embed this on landing page via iframe
|
||||
|
||||
## Gnome
|
||||
gnome:
|
||||
plugins:
|
||||
- [enable,nasa_apod@elinvention.ovh,https://github.com/Elinvention/gnome-shell-extension-nasa-apod.git]
|
||||
- [disable,dash-to-dock@micxgx.gmail.com,'']
|
||||
|
||||
## Joomla
|
||||
joomla:
|
||||
version: "latest"
|
||||
|
@ -1,21 +0,0 @@
|
||||
# Ansible Role: caffeine_auto_start
|
||||
|
||||
An Ansible Role that installs `caffeine-ng` on Archlinux systems and sets it to start automatically when the user logs in.
|
||||
|
||||
## Requirements
|
||||
|
||||
- The target system should be Archlinux.
|
||||
- Ansible 2.4 or higher.
|
||||
- The [kewlfft.aur.aur](https://galaxy.ansible.com/kewlfft/aur) Ansible Galaxy role for managing AUR packages.
|
||||
|
||||
## Role Variables
|
||||
|
||||
None.
|
||||
|
||||
## Author
|
||||
|
||||
Kevin Veen-Birkenbach - kevin@veen.world - https://www.veen.world/
|
||||
|
||||
## Background
|
||||
|
||||
The code for this role was created in an interactive conversation with OpenAI's language model. You can view the original conversation [here](https://chat.openai.com/share/fa846dac-6068-4386-b3e7-b75f1248ec82).
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
dependencies:
|
||||
- system-aur-helper
|
||||
galaxy_info:
|
||||
author: Kevin Veen-Birkenbach
|
||||
description: Ansible role for installing caffeine-ng and setting it to start at user login.
|
||||
min_ansible_version: 2.4
|
||||
platforms:
|
||||
- name: Archlinux
|
||||
versions:
|
||||
- all
|
||||
galaxy_tags:
|
||||
- caffeine
|
||||
- autostart
|
||||
- archlinux
|
23
roles/pc-gnome-caffeine/README.md
Normal file
23
roles/pc-gnome-caffeine/README.md
Normal file
@ -0,0 +1,23 @@
|
||||
# GNOME Caffeine Setup
|
||||
|
||||
## Description
|
||||
|
||||
This role installs [caffeine-ng](https://codeberg.org/WhyNotHugo/caffeine-ng), a utility that prevents your GNOME desktop from entering sleep mode or activating the screensaver automatically. It also ensures that caffeine-ng is set to autostart at user login.
|
||||
|
||||
## Purpose
|
||||
|
||||
The purpose of this role is to ensure uninterrupted workflow by keeping the desktop active during long-running tasks or presentations. By automatically starting caffeine-ng, it prevents unwanted screen locking or sleep modes on GNOME systems.
|
||||
|
||||
## Features
|
||||
|
||||
- Installs caffeine-ng from the AUR using an AUR helper.
|
||||
- Creates the autostart directory if it does not exist.
|
||||
- Deploys a customized desktop entry to ensure caffeine-ng starts automatically.
|
||||
- Enhances user experience by maintaining an active desktop environment.
|
||||
|
||||
## Credits
|
||||
|
||||
Developed and maintained by **Kevin Veen-Birkenbach**.
|
||||
Learn more at [www.veen.world](https://www.veen.world)
|
||||
|
||||
License: [CyMaIS NonCommercial License (CNCL)](https://s.veen.world/cncl)
|
17
roles/pc-gnome-caffeine/meta/main.yml
Normal file
17
roles/pc-gnome-caffeine/meta/main.yml
Normal file
@ -0,0 +1,17 @@
|
||||
---
|
||||
galaxy_info:
|
||||
author: "Kevin Veen-Birkenbach"
|
||||
description: "Installs caffeine-ng and configures it to autostart for preventing screen sleep on GNOME."
|
||||
license: "CyMaIS NonCommercial License (CNCL)"
|
||||
license_url: "https://s.veen.world/cncl"
|
||||
min_ansible_version: "2.4"
|
||||
platforms:
|
||||
- name: Archlinux
|
||||
versions:
|
||||
- all
|
||||
galaxy_tags:
|
||||
- caffeine
|
||||
- autostart
|
||||
- archlinux
|
||||
dependencies:
|
||||
- system-aur-helper
|
25
roles/pc-gnome-extensions/README.md
Normal file
25
roles/pc-gnome-extensions/README.md
Normal file
@ -0,0 +1,25 @@
|
||||
# GNOME Extensions Manager
|
||||
|
||||
## Description
|
||||
|
||||
This role manages GNOME Shell extensions by ensuring user extensions are enabled and by installing the CLI GNOME Extension Manager. The CLI tool facilitates the configuration and control of GNOME extensions via the command line.
|
||||
|
||||
Learn more about the CLI tool on its [GitHub page](https://github.com/kevinveenbirkenbach/cli-gnome-extension-manager) and about GNOME Extensions at [GNOME Extensions](https://extensions.gnome.org).
|
||||
|
||||
## Purpose
|
||||
|
||||
The purpose of this role is to enhance and customize the GNOME desktop environment by managing shell extensions. It simplifies the process of installing and configuring extensions, thereby improving productivity and desktop functionality.
|
||||
|
||||
## Features
|
||||
|
||||
- Activates GNOME Shell extensions via gsettings.
|
||||
- Installs the CLI GNOME Extension Manager using the package manager.
|
||||
- Executes extension configuration commands for streamlined management.
|
||||
- Provides an automated method for managing and updating GNOME extensions.
|
||||
|
||||
## Credits
|
||||
|
||||
Developed and maintained by **Kevin Veen-Birkenbach**.
|
||||
Learn more at [www.veen.world](https://www.veen.world)
|
||||
|
||||
License: [CyMaIS NonCommercial License (CNCL)](https://s.veen.world/cncl)
|
21
roles/pc-gnome-extensions/meta/main.yml
Normal file
21
roles/pc-gnome-extensions/meta/main.yml
Normal file
@ -0,0 +1,21 @@
|
||||
---
|
||||
galaxy_info:
|
||||
author: "Kevin Veen-Birkenbach"
|
||||
description: "Configures GNOME Shell extensions and installs the CLI GNOME Extension Manager for managing extensions."
|
||||
license: "CyMaIS NonCommercial License (CNCL)"
|
||||
license_url: "https://s.veen.world/cncl"
|
||||
company: |
|
||||
Kevin Veen-Birkenbach
|
||||
Consulting & Coaching Solutions
|
||||
https://www.veen.world
|
||||
min_ansible_version: "2.9"
|
||||
platforms:
|
||||
- name: Archlinux
|
||||
versions:
|
||||
- rolling
|
||||
galaxy_tags:
|
||||
- gnome
|
||||
- extensions
|
||||
- automation
|
||||
dependencies:
|
||||
- package-manager
|
13
roles/pc-gnome-extensions/tasks/main.yml
Normal file
13
roles/pc-gnome-extensions/tasks/main.yml
Normal file
@ -0,0 +1,13 @@
|
||||
- name: GNOME Activate Extensions
|
||||
ansible.builtin.shell: gsettings set org.gnome.shell disable-user-extensions false
|
||||
become: false
|
||||
|
||||
- name: install cli-gnome-extension-manager
|
||||
command:
|
||||
cmd: "pkgmgr install cli-gnome-extension-manager --clone-mode https"
|
||||
become: false
|
||||
|
||||
- name: Execute CLI GNOME Extension manager script
|
||||
ansible.builtin.shell: cli-gnome-extension-manager "{{ item[0] }}" "{{ item[1] }}" "{{ item[2] }}"
|
||||
loop: "{{applications[application_id].plugins | dict2items }}"
|
||||
become: false
|
25
roles/pc-gnome-terminal/README.md
Normal file
25
roles/pc-gnome-terminal/README.md
Normal file
@ -0,0 +1,25 @@
|
||||
# GNOME Terminal Installation
|
||||
|
||||
## Description
|
||||
|
||||
This role installs **GNOME Terminal**, the official terminal emulator for the GNOME desktop environment. GNOME Terminal provides a modern, feature-rich command-line interface for users on Arch Linux.
|
||||
|
||||
Learn more about GNOME Terminal on [Wikipedia](https://en.wikipedia.org/wiki/GNOME_Terminal) and visit the [GNOME Official Website](https://www.gnome.org) for additional details.
|
||||
|
||||
## Purpose
|
||||
|
||||
The purpose of this role is to ensure that GNOME Terminal is installed and properly configured on Arch Linux systems, providing users with a robust and fully featured terminal emulator that integrates seamlessly with the GNOME desktop.
|
||||
|
||||
## Features
|
||||
|
||||
- Installs GNOME Terminal using the Pacman package manager.
|
||||
- Ensures the terminal emulator is available system-wide.
|
||||
- Supports modern features and configuration options offered by GNOME Terminal.
|
||||
- Enhances the overall usability and productivity of the GNOME desktop environment.
|
||||
|
||||
## Credits
|
||||
|
||||
Developed and maintained by **Kevin Veen-Birkenbach**.
|
||||
Learn more at [www.veen.world](https://www.veen.world)
|
||||
|
||||
License: [CyMaIS NonCommercial License (CNCL)](https://s.veen.world/cncl)
|
20
roles/pc-gnome-terminal/meta/main.yml
Normal file
20
roles/pc-gnome-terminal/meta/main.yml
Normal file
@ -0,0 +1,20 @@
|
||||
---
|
||||
galaxy_info:
|
||||
author: "Kevin Veen-Birkenbach"
|
||||
description: "Installs GNOME Terminal on Arch Linux, providing a modern terminal emulator for the GNOME desktop environment."
|
||||
license: "CyMaIS NonCommercial License (CNCL)"
|
||||
license_url: "https://s.veen.world/cncl"
|
||||
company: |
|
||||
Kevin Veen-Birkenbach
|
||||
Consulting & Coaching Solutions
|
||||
https://www.veen.world
|
||||
min_ansible_version: "2.9"
|
||||
platforms:
|
||||
- name: Archlinux
|
||||
versions:
|
||||
- rolling
|
||||
galaxy_tags:
|
||||
- gnome
|
||||
- terminal
|
||||
- automation
|
||||
dependencies: []
|
6
roles/pc-gnome-terminal/tasks/main.yml
Normal file
6
roles/pc-gnome-terminal/tasks/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
- name: Install Gnome Terminal
|
||||
# @see https://en.wikipedia.org/wiki/GNOME_Terminal
|
||||
community.general.pacman:
|
||||
name:
|
||||
- gnome-terminal
|
||||
state: present
|
@ -1,52 +1,27 @@
|
||||
# PC-Gnome Role
|
||||
# GNOME Desktop Setup
|
||||
|
||||
## Overview
|
||||
Welcome to the `pc-gnome` role, a key part of the `cymais` repository. This role is dedicated to setting up and configuring the GNOME desktop environment on personal computers.
|
||||
## Description
|
||||
|
||||
## Role Details
|
||||
The `pc-gnome` role includes several tasks for installing GNOME software, managing GNOME extensions, and customizing the GNOME desktop experience:
|
||||
This role aggregates various GNOME desktop components to ensure a cohesive and fully functional GNOME environment on Arch Linux. It includes the installation and configuration of several sub-roles:
|
||||
- **pc-gnome-caffeine:** Prevents the system from sleeping or locking automatically.
|
||||
- **pc-gnome-extensions:** Manages GNOME Shell extensions and installs the CLI GNOME Extension Manager.
|
||||
- **pc-gnome-terminal:** Installs GNOME Terminal, the official terminal emulator for GNOME.
|
||||
|
||||
1. **Install Gnome Software**:
|
||||
- Installs essential GNOME packages such as `gnome-shell-extensions`, `gnome-shell-extension-desktop-icons-ng`, and `gnome-terminal` using the `community.general.pacman` module.
|
||||
## Purpose
|
||||
|
||||
2. **GNOME Activate Extensions**:
|
||||
- Enables user extensions in GNOME using the `gsettings` command.
|
||||
The purpose of this role is to provide a complete GNOME desktop experience by orchestrating multiple sub-roles. This simplifies deployment and management by ensuring that all key components are installed and configured in a consistent, system-wide manner.
|
||||
|
||||
3. **GNOME Set Favorite Apps**:
|
||||
- Customizes the favorite applications on the GNOME shell using the `gsettings` command and the `{{favorite_apps}}` variable.
|
||||
## Features
|
||||
|
||||
4. **Pull CLI GNOME Extension Manager Script**:
|
||||
- Clones or updates the CLI GNOME Extension Manager script from a Git repository.
|
||||
- Aggregates multiple GNOME-related roles into one cohesive setup.
|
||||
- Installs and configures caffeine-ng to keep the desktop active.
|
||||
- Manages GNOME Shell extensions and integrates the CLI GNOME Extension Manager.
|
||||
- Installs GNOME Terminal for a robust command-line interface.
|
||||
- Ensures a seamless and uniform GNOME environment on Arch Linux.
|
||||
|
||||
5. **Warn if Repo is Not Reachable**:
|
||||
- Displays a warning message if the repository for the CLI GNOME Extension Manager script is not reachable.
|
||||
## Credits
|
||||
|
||||
6. **Execute CLI GNOME Extension Manager Script**:
|
||||
- Runs the CLI GNOME Extension Manager script to manage GNOME extensions based on the `{{gnome_extensions}}` variable.
|
||||
Developed and maintained by **Kevin Veen-Birkenbach**.
|
||||
Learn more at [www.veen.world](https://www.veen.world)
|
||||
|
||||
## Other Resources
|
||||
For additional details on managing GNOME extensions via command line, visit [Ask Ubuntu](https://askubuntu.com/questions/1029376/how-do-i-enable-and-disable-gnome-extensions-from-the-command-line).
|
||||
|
||||
## Dependencies
|
||||
This role depends on:
|
||||
- **pc-git**: Ensures Git is installed for cloning repositories.
|
||||
- **pc-caffeine**: A supplementary role that may include tools or configurations complementing the GNOME setup.
|
||||
|
||||
## Purpose and Usage
|
||||
The `pc-gnome` role is ideal for users who prefer the GNOME desktop environment and wish to automate its setup and customization. It's especially useful for setting up a new system or reconfiguring GNOME after a system update.
|
||||
|
||||
## Prerequisites
|
||||
- **Ansible**: Must be installed to use this role.
|
||||
- **Arch Linux-based System**: The role uses the `pacman` package manager, indicating it's designed for Arch Linux or similar distributions.
|
||||
|
||||
## Running the Role
|
||||
To use this role:
|
||||
1. Clone the `cymais` repository.
|
||||
2. Navigate to the `roles/pc-gnome` directory.
|
||||
3. Run the role using Ansible, ensuring you have the necessary permissions for installations and configurations.
|
||||
|
||||
## Customization
|
||||
You can customize this role by modifying the GNOME software packages, favorite apps, and GNOME extensions in the respective tasks.
|
||||
|
||||
## Support and Contributions
|
||||
For support, feedback, or contributions, such as adding more GNOME-related configurations or tools, open an issue or submit a pull request in the `cymais` repository. Contributions that enhance the GNOME environment setup are highly encouraged.
|
||||
License: [CyMaIS NonCommercial License (CNCL)](https://s.veen.world/cncl)
|
@ -1,3 +1,24 @@
|
||||
---
|
||||
galaxy_info:
|
||||
author: "Kevin Veen-Birkenbach"
|
||||
description: "Aggregates essential GNOME desktop roles—including caffeine, extensions, and terminal—for a complete GNOME environment on Arch Linux."
|
||||
license: "CyMaIS NonCommercial License (CNCL)"
|
||||
license_url: "https://s.veen.world/cncl"
|
||||
company: |
|
||||
Kevin Veen-Birkenbach
|
||||
Consulting & Coaching Solutions
|
||||
https://www.veen.world
|
||||
min_ansible_version: "2.9"
|
||||
platforms:
|
||||
- name: Archlinux
|
||||
versions:
|
||||
- rolling
|
||||
galaxy_tags:
|
||||
- gnome
|
||||
- desktop
|
||||
- archlinux
|
||||
- automation
|
||||
dependencies:
|
||||
- pc-git
|
||||
- pc-caffeine
|
||||
- pc-gnome-caffeine
|
||||
- pc-gnome-extensions
|
||||
- pc-gnome-terminal
|
@ -1,28 +0,0 @@
|
||||
- name: Install Gnome Software
|
||||
community.general.pacman:
|
||||
name:
|
||||
- gnome-shell-extensions
|
||||
- gnome-shell-extension-desktop-icons-ng
|
||||
- gnome-terminal
|
||||
state: present
|
||||
|
||||
- name: GNOME Activate Extensions
|
||||
ansible.builtin.shell: gsettings set org.gnome.shell disable-user-extensions false
|
||||
become: false
|
||||
|
||||
- name: GNOME Set favorite apps
|
||||
ansible.builtin.shell: gsettings set org.gnome.shell favorite-apps "{{favorite_apps}}"
|
||||
become: false
|
||||
|
||||
- name: pull CLI GNOME Extension manager script
|
||||
git:
|
||||
repo: "git@github.com:kevinveenbirkenbach/cli-gnome-extension-manager.git"
|
||||
dest: "$HOME/Repositories/github.com/kevinveenbirkenbach/cli-gnome-extension-manager"
|
||||
update: yes
|
||||
ignore_errors: true
|
||||
become: false
|
||||
|
||||
- name: Execute CLI GNOME Extension manager script
|
||||
ansible.builtin.shell: bash "/home/{{client_username}}/Repositories/github.com/kevinveenbirkenbach/cli-gnome-extension-manager/gnome-extension-manager.sh" "{{ item[0] }}" "{{ item[1] }}" "{{ item[2] }}"
|
||||
loop: "{{gnome_extensions}}"
|
||||
become: false
|
Loading…
x
Reference in New Issue
Block a user