first commit

This commit is contained in:
Илья Макаров 2025-02-11 23:14:16 +03:00
commit 70f0eca45a
11 changed files with 167 additions and 0 deletions

11
environment/inventory.yml Normal file
View File

@ -0,0 +1,11 @@
all:
children:
srv_1:
hosts:
srv-infra:
ansible_host: 150.241.66.94
srv-services:
ansible_host: 192.109.139.92
vars:
ansible_ssh_port: 10001
ansible_ssh_private_key_file: /home/ilyamak04/.ssh/srv-key

View File

@ -0,0 +1,7 @@
---
- hosts: srv_1
vars_files:
- ../roles/preparing_machine/vault.yml
roles:
- preparing_machine

View File

@ -0,0 +1,38 @@
Role Name
=========
A brief description of the role goes here.
Requirements
------------
Any pre-requisites that may not be covered by Ansible itself or the role should be mentioned here. For instance, if the role uses the EC2 module, it may be a good idea to mention in this section that the boto package is required.
Role Variables
--------------
A description of the settable variables for this role should go here, including any variables that are in defaults/main.yml, vars/main.yml, and any variables that can/should be set via parameters to the role. Any variables that are read from other roles and/or the global scope (ie. hostvars, group vars, etc.) should be mentioned here as well.
Dependencies
------------
A list of other roles hosted on Galaxy should go here, plus any details in regards to parameters that may need to be set for other roles, or variables that are used from other roles.
Example Playbook
----------------
Including an example of how to use your role (for instance, with variables passed in as parameters) is always nice for users too:
- hosts: servers
roles:
- { role: username.rolename, x: 42 }
License
-------
BSD
Author Information
------------------
An optional section for the role authors to include contact information, or a website (HTML is not allowed).

View File

@ -0,0 +1,5 @@
---
# defaults file for preparing_machine
new_user: ilyamak04
new_user_password: "{{ vault_new_user_password }}"

View File

@ -0,0 +1,2 @@
---
# handlers file for preparing_machine

View File

@ -0,0 +1,52 @@
galaxy_info:
author: your name
description: your role description
company: your company (optional)
# If the issue tracker for your role is not on github, uncomment the
# next line and provide a value
# issue_tracker_url: http://example.com/issue/tracker
# Choose a valid license ID from https://spdx.org - some suggested licenses:
# - BSD-3-Clause (default)
# - MIT
# - GPL-2.0-or-later
# - GPL-3.0-only
# - Apache-2.0
# - CC-BY-4.0
license: license (GPL-2.0-or-later, MIT, etc)
min_ansible_version: 2.1
# If this a Container Enabled role, provide the minimum Ansible Container version.
# min_ansible_container_version:
#
# Provide a list of supported platforms, and for each platform a list of versions.
# If you don't wish to enumerate all versions for a particular platform, use 'all'.
# To view available platforms and versions (or releases), visit:
# https://galaxy.ansible.com/api/v1/platforms/
#
# platforms:
# - name: Fedora
# versions:
# - all
# - 25
# - name: SomePlatform
# versions:
# - all
# - 1.0
# - 7
# - 99.99
galaxy_tags: []
# List tags for your role here, one per line. A tag is a keyword that describes
# and categorizes the role. Users find roles by searching for tags. Be sure to
# remove the '[]' above, if you add tags to this list.
#
# NOTE: A tag is limited to a single word comprised of alphanumeric characters.
# Maximum 20 tags per role.
dependencies: []
# List your role dependencies here, one per line. Be sure to remove the '[]' above,
# if you add dependencies to this list.

View File

@ -0,0 +1,36 @@
---
# tasks file for preparing_machine
- name: Обновление списка пакетов и установка ПО
apt:
update_cache: yes
upgrade: dist
autoremove: yes
autoclean: yes
- name: Установка необходимых пакетов
apt:
name:
- net-tools
- git
- zip
- unzip
- curl
- wget
- htop
- fzf
- gcc
- build-essential
- libc6-dev
- g++-13
state: present
- name: Создание пользователя
user:
name: "{{ new_user }}"
password: "{{ new_user_password | password_hash('sha512') }}"
shell: /bin/bash
create_home: yes
groups: sudo
append: yes
when: new_user is defined

View File

@ -0,0 +1,2 @@
localhost

View File

@ -0,0 +1,5 @@
---
- hosts: localhost
remote_user: root
roles:
- preparing_machine

View File

@ -0,0 +1,2 @@
---
# vars file for preparing_machine

View File

@ -0,0 +1,7 @@
$ANSIBLE_VAULT;1.1;AES256
62353165633862323337333835313435363833323238383163623032616439346365346536656363
3630626462623635643437323831383964343964316364640a623735373431666334373862323661
65373537623038356261303537653066323463656239666663363734306234386332636235333265
3061613630393638650a383136396130646639613432616561616238353232363638366531363339
66356535653063313765643130623862646261336662343163386264303033366133356539663761
3830643831393037343430303133363762343232663561646465