Compare commits
No commits in common. "main" and "main" have entirely different histories.
|
@ -10,4 +10,4 @@ steps:
|
||||||
- pip3 install -U ansible-lint
|
- pip3 install -U ansible-lint
|
||||||
- name: lint check
|
- name: lint check
|
||||||
commands:
|
commands:
|
||||||
- "ansible-lint -w '' -x ''"
|
- "ansible-lint"
|
|
@ -13,5 +13,5 @@ drone_rpc_host: "localhost"
|
||||||
drone_server_host: "localhost"
|
drone_server_host: "localhost"
|
||||||
drone_logs_debug: "true"
|
drone_logs_debug: "true"
|
||||||
drone_user_filter: ""
|
drone_user_filter: ""
|
||||||
drone_version: "v2.1.0"
|
drone_version: "v1.10.1"
|
||||||
|
|
||||||
|
|
|
@ -1,39 +1,13 @@
|
||||||
---
|
---
|
||||||
# handlers are executed in the order they are written in the handlers file, not the order they are notified.
|
# handlers file for im
|
||||||
|
|
||||||
- name: "Build drone"
|
|
||||||
command: 'go build'
|
|
||||||
become: true
|
|
||||||
become_user : "{{ drone_user }}"
|
|
||||||
notify: "Restart drone"
|
|
||||||
args:
|
|
||||||
chdir: "{{ drone_home }}/drone/cmd/drone-server"
|
|
||||||
|
|
||||||
- name: "Unzip runner"
|
|
||||||
unarchive:
|
|
||||||
src: "{{ drone_home }}/drone_runner_exec_linux_amd64.tar.gz"
|
|
||||||
remote_src: yes
|
|
||||||
dest: /usr/local/bin/
|
|
||||||
notify:
|
|
||||||
- "Install drone runner exec"
|
|
||||||
- "Stop drone runner exec"
|
|
||||||
- "Start drone runner exec"
|
|
||||||
|
|
||||||
- name: "Stop drone runner exec"
|
|
||||||
command: "drone-runner-exec service stop"
|
|
||||||
when: ansible_service_mgr == "systemd"
|
|
||||||
|
|
||||||
- name: "Install drone runner exec"
|
|
||||||
command: "drone-runner-exec service install"
|
|
||||||
when: ansible_service_mgr == "systemd"
|
|
||||||
|
|
||||||
- name: "Start drone runner exec"
|
|
||||||
command: "drone-runner-exec service start"
|
|
||||||
when: ansible_service_mgr == "systemd"
|
|
||||||
|
|
||||||
- name: "Restart drone"
|
- name: "Restart drone"
|
||||||
ansible.builtin.systemd:
|
service:
|
||||||
state: restarted
|
name: "drone"
|
||||||
daemon_reload: yes
|
state: "restarted"
|
||||||
name: drone
|
when: ansible_service_mgr == "systemd"
|
||||||
|
|
||||||
|
|
||||||
|
- name: "Reload systemd"
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
when: ansible_service_mgr == "systemd"
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
galaxy_info:
|
galaxy_info:
|
||||||
role_name: drone
|
role_name: ansible_role_drone
|
||||||
author: jens
|
author: Jens Timmerman
|
||||||
description: This role installs drone ci p (https://github.com/drone/drone)
|
description: This role installs drone ci p (https://github.com/drone/drone)
|
||||||
|
|
||||||
issue_tracker_url: https://gitea.caret.be/jens/ansible-role-drone/issues
|
issue_tracker_url: https://gitea.caret.be/jens/ansible-role-drone/issues
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
---
|
---
|
||||||
# tasks file for drone
|
# tasks file for drone
|
||||||
- name: 'Install dependencies'
|
- name: 'install dependencies'
|
||||||
package:
|
package:
|
||||||
name:
|
name:
|
||||||
- 'git'
|
- 'git'
|
||||||
|
@ -14,7 +14,7 @@
|
||||||
home: "{{ drone_home }}"
|
home: "{{ drone_home }}"
|
||||||
shell: "/bin/false"
|
shell: "/bin/false"
|
||||||
|
|
||||||
- name: 'Download latest drone'
|
- name: 'download latest drone'
|
||||||
git:
|
git:
|
||||||
dest: "{{ drone_home }}/drone"
|
dest: "{{ drone_home }}/drone"
|
||||||
repo: https://github.com/drone/drone.git
|
repo: https://github.com/drone/drone.git
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
force: true
|
force: true
|
||||||
become: true
|
become: true
|
||||||
become_user : "{{ drone_user }}"
|
become_user : "{{ drone_user }}"
|
||||||
notify: "Build drone"
|
register: gitclone
|
||||||
|
|
||||||
- name: "Setup systemd service"
|
- name: "Setup systemd service"
|
||||||
template:
|
template:
|
||||||
|
@ -36,51 +36,60 @@
|
||||||
- "Restart drone"
|
- "Restart drone"
|
||||||
when: ansible_service_mgr == "systemd"
|
when: ansible_service_mgr == "systemd"
|
||||||
|
|
||||||
|
- name: "build drone"
|
||||||
- name: "Clone runner"
|
command: 'go build'
|
||||||
get_url:
|
|
||||||
url: https://github.com/drone-runners/drone-runner-exec/releases/latest/download/drone_runner_exec_linux_amd64.tar.gz
|
|
||||||
dest: "{{ drone_home }}"
|
|
||||||
become: true
|
become: true
|
||||||
become_user : "{{ drone_user }}"
|
become_user : "{{ drone_user }}"
|
||||||
notify: "Unzip runner"
|
notify: "Restart drone"
|
||||||
|
args:
|
||||||
|
chdir: "{{ drone_home }}/drone/cmd/drone-server"
|
||||||
|
when: gitclone.changed
|
||||||
|
|
||||||
|
- name: "clone runner"
|
||||||
- name: "Make local runner config dir"
|
git:
|
||||||
|
dest: "{{ drone_home }}/drone"
|
||||||
|
repo: https://github.com/drone-runners/drone-runner-exec.git
|
||||||
|
version: "{{ v1.0.0-beta.9}}"
|
||||||
|
become: true
|
||||||
|
become_user : "{{ drone_user }}"
|
||||||
|
register: gitclonerunner
|
||||||
|
|
||||||
|
- name: "make local runner config dir"
|
||||||
file:
|
file:
|
||||||
path: "/etc/drone-runner-exec/"
|
path: "/etc/drone-runner-exec/"
|
||||||
state: directory
|
state: directory
|
||||||
owner: drone
|
owner: drone
|
||||||
group: drone
|
group: drone
|
||||||
mode: '0700'
|
mode: '0700'
|
||||||
notify:
|
|
||||||
- "Install drone runner exec"
|
|
||||||
- "Stop drone runner exec"
|
|
||||||
- "Start drone runner exec"
|
|
||||||
|
|
||||||
- name: "Make local runner config dir"
|
- name: "make local runner config dir"
|
||||||
file:
|
file:
|
||||||
path: "/var/log/drone-runner-exec/"
|
path: "/var/log/drone-runner-exec/"
|
||||||
state: directory
|
state: directory
|
||||||
owner: drone
|
owner: drone
|
||||||
group: drone
|
group: drone
|
||||||
mode: '0700'
|
mode: '0700'
|
||||||
notify:
|
|
||||||
- "Install drone runner exec"
|
|
||||||
- "Stop drone runner exec"
|
|
||||||
- "Start drone runner exec"
|
|
||||||
|
|
||||||
- name: "Configure local runner"
|
- name: "configure local runner"
|
||||||
template:
|
template:
|
||||||
src: exec_runner_config.j2
|
src: exec_runner_config.j2
|
||||||
dest: "/etc/drone-runner-exec/config"
|
dest: "/etc/drone-runner-exec/config"
|
||||||
owner: drone
|
owner: drone
|
||||||
group: drone
|
group: drone
|
||||||
mode: '0700'
|
mode: '0700'
|
||||||
notify:
|
|
||||||
- "Install drone runner exec"
|
- name: "install local runner"
|
||||||
- "Stop drone runner exec"
|
command: 'cp drone-runner-exec/drone-runner-exec /usr/loca/bin/drone-runner-exec && drone-runner-exec service install'
|
||||||
- "Start drone runner exec"
|
when: gitclonerunner.changed
|
||||||
|
|
||||||
|
- name: "stop local runner"
|
||||||
|
command: 'drone-runner-exec service stop'
|
||||||
|
when: gitclonerunner.changed
|
||||||
|
|
||||||
|
- name: "start local runner"
|
||||||
|
command: 'drone-runner-exec service start'
|
||||||
|
when: gitclonerunner.changed
|
||||||
|
|
||||||
|
|
||||||
- name: "Configure drone"
|
- name: "Configure drone"
|
||||||
template:
|
template:
|
||||||
|
|
|
@ -0,0 +1,131 @@
|
||||||
|
"""
|
||||||
|
Django settings for im project.
|
||||||
|
|
||||||
|
Generated by 'django-admin startproject' using Django 2.1.1.
|
||||||
|
|
||||||
|
For more information on this file, see
|
||||||
|
https://docs.djangoproject.com/en/2.1/topics/settings/
|
||||||
|
|
||||||
|
For the full list of settings and their values, see
|
||||||
|
https://docs.djangoproject.com/en/2.1/ref/settings/
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
||||||
|
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
||||||
|
|
||||||
|
|
||||||
|
# Quick-start development settings - unsuitable for production
|
||||||
|
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
|
||||||
|
|
||||||
|
# SECURITY WARNING: keep the secret key used in production secret!
|
||||||
|
SECRET_KEY = '{{im_secret_key}}'
|
||||||
|
|
||||||
|
# SECURITY WARNING: don't run with debug turned on in production!
|
||||||
|
DEBUG = False
|
||||||
|
|
||||||
|
ALLOWED_HOSTS = [
|
||||||
|
'{{im_domain}}'
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
# Application definition
|
||||||
|
|
||||||
|
INSTALLED_APPS = [
|
||||||
|
'django.contrib.admin',
|
||||||
|
'django.contrib.auth',
|
||||||
|
'django.contrib.contenttypes',
|
||||||
|
'django.contrib.sessions',
|
||||||
|
'django.contrib.messages',
|
||||||
|
'django.contrib.staticfiles',
|
||||||
|
'inventory.apps.InventoryConfig',
|
||||||
|
]
|
||||||
|
|
||||||
|
MIDDLEWARE = [
|
||||||
|
'django.middleware.security.SecurityMiddleware',
|
||||||
|
'whitenoise.middleware.WhiteNoiseMiddleware',
|
||||||
|
'django.contrib.sessions.middleware.SessionMiddleware',
|
||||||
|
'django.middleware.common.CommonMiddleware',
|
||||||
|
'django.middleware.csrf.CsrfViewMiddleware',
|
||||||
|
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||||
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
|
]
|
||||||
|
|
||||||
|
ROOT_URLCONF = 'im.urls'
|
||||||
|
|
||||||
|
TEMPLATES = [
|
||||||
|
{
|
||||||
|
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
||||||
|
'DIRS': [],
|
||||||
|
'APP_DIRS': True,
|
||||||
|
'OPTIONS': {
|
||||||
|
'context_processors': [
|
||||||
|
'django.template.context_processors.debug',
|
||||||
|
'django.template.context_processors.request',
|
||||||
|
'django.contrib.auth.context_processors.auth',
|
||||||
|
'django.contrib.messages.context_processors.messages',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
WSGI_APPLICATION = 'im.wsgi.application'
|
||||||
|
|
||||||
|
|
||||||
|
# Database
|
||||||
|
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases
|
||||||
|
|
||||||
|
DATABASES = {
|
||||||
|
'default': {
|
||||||
|
'ENGINE': 'django.db.backends.postgresql_psycopg2',
|
||||||
|
'NAME': '{{im_db_name}}',
|
||||||
|
'USER': '{{im_db_user}}',
|
||||||
|
'PASSWORD': '{{im_db_password}}',
|
||||||
|
'HOST': '{{im_db_server}}',
|
||||||
|
'PORT': '{{im_db_port}}',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Password validation
|
||||||
|
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators
|
||||||
|
|
||||||
|
AUTH_PASSWORD_VALIDATORS = [
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
# Internationalization
|
||||||
|
# https://docs.djangoproject.com/en/2.1/topics/i18n/
|
||||||
|
|
||||||
|
LANGUAGE_CODE = 'en-us'
|
||||||
|
|
||||||
|
TIME_ZONE = 'UTC'
|
||||||
|
|
||||||
|
USE_I18N = True
|
||||||
|
|
||||||
|
USE_L10N = True
|
||||||
|
|
||||||
|
USE_TZ = True
|
||||||
|
|
||||||
|
|
||||||
|
# Static files (CSS, JavaScript, Images)
|
||||||
|
# https://docs.djangoproject.com/en/2.1/howto/static-files/
|
||||||
|
# http://whitenoise.evans.io/en/stable/django.html
|
||||||
|
|
||||||
|
STATIC_URL = '/static/'
|
||||||
|
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
|
||||||
|
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
|
Loading…
Reference in New Issue