mirror of
https://codeberg.org/ProgramSnail/config.git
synced 2025-12-06 07:28:44 +00:00
Compare commits
5 commits
19b706da4c
...
94111b0a4b
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
94111b0a4b | ||
|
|
0605fda37e | ||
|
|
f7a6f59fc6 | ||
|
|
58966f9e4a | ||
|
|
ea4409c58b |
14 changed files with 143 additions and 12 deletions
15
defaults.yml
Normal file
15
defaults.yml
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
# containers during host setup
|
||||
container_names:
|
||||
- dev
|
||||
- txt
|
||||
- haskell
|
||||
|
||||
# containers tool groups
|
||||
container_tools:
|
||||
dev:
|
||||
- cpp
|
||||
- js
|
||||
txt:
|
||||
- txt
|
||||
haskell:
|
||||
- haskell
|
||||
|
|
@ -1 +1,30 @@
|
|||
- name: Configure distrobox dev container
|
||||
hosts: localhost
|
||||
connection: local
|
||||
vars:
|
||||
vars_prompt:
|
||||
- name: tools_in
|
||||
prompt: "Specify comma separated list of required tool packages (cpp, js, haskell, txt, lang)"
|
||||
roles:
|
||||
# link and copy dotfiles
|
||||
- role: dotfiles
|
||||
vars:
|
||||
configue:
|
||||
- bash
|
||||
- cli
|
||||
- git
|
||||
- ssh
|
||||
- scripts
|
||||
|
||||
# install apps
|
||||
- role: installs
|
||||
vars:
|
||||
apps:
|
||||
- cli
|
||||
|
||||
# install and setup dev tools
|
||||
- role: dev
|
||||
vars:
|
||||
tools: "{{ tools_in.split(',') }}"
|
||||
|
||||
# TODO: repositories
|
||||
|
|
|
|||
|
|
@ -1 +1,38 @@
|
|||
- name: Create distrobox containers on host
|
||||
hosts: localhost
|
||||
connection: local
|
||||
vars:
|
||||
tasks:
|
||||
- name: Create containers
|
||||
include_role:
|
||||
name: dev_host
|
||||
vars:
|
||||
container_name: '{{ item }}'
|
||||
loop: '{{ container_names }}'
|
||||
|
||||
- name: Setup containers
|
||||
hosts: containers
|
||||
roles:
|
||||
# link and copy dotfiles
|
||||
- role: dotfiles
|
||||
vars:
|
||||
configue:
|
||||
- bash
|
||||
- cli
|
||||
- git
|
||||
- ssh
|
||||
- scripts
|
||||
|
||||
# install apps
|
||||
- role: installs
|
||||
vars:
|
||||
apps:
|
||||
- cli
|
||||
|
||||
# install and setup dev tools
|
||||
- role: dev
|
||||
vars:
|
||||
tools: "{{ container_tools['{{item}}'] }}"
|
||||
|
||||
# TODO: repositories
|
||||
|
||||
|
|
|
|||
18
roles/dev/tasks/main.yml
Normal file
18
roles/dev/tasks/main.yml
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
- ansible.builtin.import_tasks: build.yml
|
||||
|
||||
- ansible.builtin.import_tasks: cpp.yml
|
||||
when: "'cpp' in tools"
|
||||
|
||||
- ansible.builtin.import_tasks: js.yml
|
||||
when: "'js' in tools"
|
||||
|
||||
- ansible.builtin.import_tasks: haskell.yml
|
||||
when: "'haskell' in tools"
|
||||
|
||||
- ansible.builtin.import_tasks: txt.yml
|
||||
when: "'txt' in tools"
|
||||
|
||||
- ansible.builtin.import_tasks: lang.yml
|
||||
when: "'lang' in tools"
|
||||
|
||||
# TODO: ocaml, truffle, ...
|
||||
3
roles/dev_host/defaults/main.yml
Normal file
3
roles/dev_host/defaults/main.yml
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
container_name: dev
|
||||
container_image: quay.io/fedora/fedora-toolbox
|
||||
container_image_tag: latest
|
||||
37
roles/dev_host/tasks/main.yml
Normal file
37
roles/dev_host/tasks/main.yml
Normal file
|
|
@ -0,0 +1,37 @@
|
|||
# os based on https://github.com/sandorex/config/blob/master/playbooks/container-dev.yml
|
||||
|
||||
- name: Check if container already exists
|
||||
containers.podman.podman_container_info:
|
||||
name: '{{ container_name }}'
|
||||
register: container_info
|
||||
|
||||
- name: Create container using distrobox
|
||||
ansible.builtin.command:
|
||||
# requires distrobox version 1.7
|
||||
# add python3 to allow ansible to work
|
||||
# add ansible to run local roles without host (?)
|
||||
cmd: >-
|
||||
distrobox create --yes --no-entry --pull
|
||||
--image '{{ container_image }}:{{ container_image_tag }}'
|
||||
--name '{{ container_name }}'
|
||||
--hostname '{{ ansible_hostname }}'
|
||||
--additional-packages 'python3 ansible'
|
||||
when: container_info.containers | length == 0
|
||||
|
||||
- name: Start the container
|
||||
ansible.builtin.command:
|
||||
cmd: 'distrobox enter --name {{ container_name }} -- sh -c ''exit'''
|
||||
# start if not running or if not defined
|
||||
when: not (container_info.containers[0].State.Running | default(false))
|
||||
|
||||
- name: Add container to host
|
||||
changed_when: no
|
||||
ansible.builtin.add_host:
|
||||
name: '{{ container_name }}' # ??
|
||||
groups: containers
|
||||
ansible_connection: distrobox
|
||||
ansible_host: '{{ container_name }}'
|
||||
ansible_user: '{{ ansible_user_id }}'
|
||||
fedora_version: '{{ container_image_tag }}' # ??
|
||||
|
||||
# container setup is done outside (?)
|
||||
|
|
@ -5,12 +5,16 @@
|
|||
- bash
|
||||
- fish
|
||||
- trash-cli
|
||||
|
||||
# dev utils
|
||||
- just
|
||||
- jsonnet
|
||||
- shellcheck
|
||||
|
||||
# edit utils
|
||||
- helix
|
||||
- micro
|
||||
- nano
|
||||
- tmux
|
||||
- tmate
|
||||
- ripgrep
|
||||
|
|
|
|||
|
|
@ -1,18 +1,6 @@
|
|||
- ansible.builtin.import_tasks: build.yml
|
||||
when: "'build' in apps"
|
||||
|
||||
- ansible.builtin.import_tasks: cli.yml
|
||||
when: "'cli' in apps"
|
||||
|
||||
- ansible.builtin.import_tasks: cpp.yml
|
||||
when: "'cpp' in apps"
|
||||
|
||||
- ansible.builtin.import_tasks: lang.yml
|
||||
when: "'lang' in apps"
|
||||
|
||||
- ansible.builtin.import_tasks: javascript.yml
|
||||
when: "'javascript' in apps"
|
||||
|
||||
- ansible.builtin.import_tasks: gui.yml
|
||||
when: "'gui' in apps"
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue