mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-09-18 08:20:51 +00:00
[Change] 修改idc => cluster
This commit is contained in:
@@ -29,7 +29,7 @@ Options = namedtuple('Options', [
|
||||
'ssh_common_args', 'ssh_extra_args', 'sftp_extra_args',
|
||||
'scp_extra_args', 'become', 'become_method', 'become_user',
|
||||
'verbosity', 'check', 'extra_vars', 'playbook_path', 'passwords',
|
||||
'diff',
|
||||
'diff', 'gathering'
|
||||
])
|
||||
|
||||
|
||||
@@ -58,6 +58,7 @@ def get_default_options():
|
||||
playbook_path='/etc/ansible/',
|
||||
passwords=None,
|
||||
diff=False,
|
||||
gathering='implicit',
|
||||
)
|
||||
return options
|
||||
|
||||
|
@@ -6,8 +6,9 @@ import uuid
|
||||
|
||||
from django.db import models
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from common.utils import signer
|
||||
|
||||
__all__ = ["AdHoc", "History"]
|
||||
__all__ = ["AdHoc", "AdHocRunHistory"]
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
@@ -16,6 +17,8 @@ logger = logging.getLogger(__name__)
|
||||
class AdHoc(models.Model):
|
||||
id = models.UUIDField(default=uuid.uuid4, primary_key=True)
|
||||
name = models.CharField(max_length=128, blank=True, verbose_name=_('Name'))
|
||||
is_deleted = models.BooleanField(default=False)
|
||||
date_create = models.DateTimeField(auto_created=True)
|
||||
|
||||
@property
|
||||
def short_id(self):
|
||||
@@ -39,7 +42,7 @@ class AdHocData(models.Model):
|
||||
become = models.BooleanField(default=False, verbose_name=_("Become"))
|
||||
become_method = models.CharField(choices=BECOME_METHOD_CHOICES, default='sudo', max_length=4)
|
||||
become_user = models.CharField(default='root', max_length=64)
|
||||
become_pass = models.CharField(default='', max_length=128)
|
||||
_become_pass = models.CharField(default='', max_length=128)
|
||||
pattern = models.CharField(max_length=64, default='', verbose_name=_('Pattern'))
|
||||
created_by = models.CharField(max_length=64, verbose_name=_('Create by'))
|
||||
date_created = models.DateTimeField(auto_created=True)
|
||||
@@ -60,15 +63,29 @@ class AdHocData(models.Model):
|
||||
def hosts(self, item):
|
||||
self._hosts = json.dumps(item)
|
||||
|
||||
@property
|
||||
def become_pass(self):
|
||||
return signer.unsign(self._become_pass)
|
||||
|
||||
@become_pass.setter
|
||||
def become_pass(self, password):
|
||||
self._become_pass = signer.sign(password)
|
||||
|
||||
@property
|
||||
def short_version(self):
|
||||
return str(self.version).split('-')[-1]
|
||||
|
||||
def run(self):
|
||||
pass
|
||||
|
||||
def __str__(self):
|
||||
return "{} of {}".format(self.subject.name, self.short_version)
|
||||
|
||||
class Meta:
|
||||
db_table = "ops_adhoc_data"
|
||||
|
||||
class AdHocHistory(models.Model):
|
||||
|
||||
class AdHocRunHistory(models.Model):
|
||||
uuid = models.UUIDField(default=uuid.uuid4, primary_key=True)
|
||||
adhoc = models.ForeignKey(AdHocData, on_delete=models.CASCADE)
|
||||
date_start = models.DateTimeField(auto_now_add=True, verbose_name=_('Start time'))
|
||||
@@ -85,3 +102,6 @@ class AdHocHistory(models.Model):
|
||||
|
||||
def __str__(self):
|
||||
return self.short_id
|
||||
|
||||
class Meta:
|
||||
db_table = "ops_adhoc_history"
|
||||
|
@@ -9,79 +9,18 @@ import uuid
|
||||
|
||||
from django.utils import timezone
|
||||
|
||||
from assets.models import Asset
|
||||
from common.utils import get_logger
|
||||
from .ansible.runner import AdHocRunner
|
||||
from common.utils import get_logger, get_object_or_none
|
||||
from .ansible import AdHocRunner
|
||||
from assets.utils import get_assets_by_hostname_list
|
||||
|
||||
logger = get_logger(__file__)
|
||||
|
||||
|
||||
def run_AdHoc(task_tuple, assets,
|
||||
task_name='Ansible AdHoc runner',
|
||||
task_id=None, pattern='all',
|
||||
record=True, verbose=True):
|
||||
"""
|
||||
:param task_tuple: (('module_name', 'module_args'), ('module_name', 'module_args'))
|
||||
:param assets: [asset1, asset2]
|
||||
:param task_name:
|
||||
:param task_id:
|
||||
:param pattern:
|
||||
:param record:
|
||||
:param verbose:
|
||||
:return: summary: {'success': [], 'failed': [{'192.168.1.1': 'msg'}]}
|
||||
result: {'contacted': {'hostname': [{''}, {''}], 'dark': []}
|
||||
"""
|
||||
|
||||
if not assets:
|
||||
logger.warning('Empty assets, runner cancel')
|
||||
return
|
||||
if isinstance(assets[0], Asset):
|
||||
assets = [asset._to_secret_json() for asset in assets]
|
||||
if task_id is None:
|
||||
task_id = str(uuid.uuid4())
|
||||
|
||||
runner = AdHocRunner(assets)
|
||||
if record:
|
||||
from .models import Playbook
|
||||
if not Playbook.objects.filter(uuid=task_id):
|
||||
record = Playbook(uuid=task_id,
|
||||
name=task_name,
|
||||
assets=','.join(str(asset['id']) for asset in assets),
|
||||
module_args=task_tuple,
|
||||
pattern=pattern)
|
||||
record.save()
|
||||
else:
|
||||
record = Playbook.objects.get(uuid=task_id)
|
||||
record.date_start = timezone.now()
|
||||
record.date_finished = None
|
||||
record.timedelta = None
|
||||
record.is_finished = False
|
||||
record.is_success = False
|
||||
record.save()
|
||||
ts_start = time.time()
|
||||
if verbose:
|
||||
logger.debug('Start runner {}'.format(task_name))
|
||||
result = runner.run(task_tuple, pattern=pattern, task_name=task_name)
|
||||
timedelta = round(time.time() - ts_start, 2)
|
||||
summary = runner.clean_result()
|
||||
if record:
|
||||
record.date_finished = timezone.now()
|
||||
record.is_finished = True
|
||||
if verbose:
|
||||
record.result = json.dumps(result, indent=4, sort_keys=True)
|
||||
record.summary = json.dumps(summary)
|
||||
record.timedelta = timedelta
|
||||
if len(summary['failed']) == 0:
|
||||
record.is_success = True
|
||||
else:
|
||||
record.is_success = False
|
||||
record.save()
|
||||
return summary, result
|
||||
|
||||
|
||||
UUID_PATTERN = re.compile(r'[0-9a-zA-Z\-]{36}')
|
||||
|
||||
|
||||
def run_AdHoc():
|
||||
pass
|
||||
|
||||
|
||||
def is_uuid(s):
|
||||
if UUID_PATTERN.match(s):
|
||||
return True
|
||||
@@ -99,3 +38,60 @@ def asset_to_dict_with_credential(asset):
|
||||
|
||||
def system_user_to_dict_with_credential(system_user):
|
||||
return system_user._to_secret_json()
|
||||
|
||||
|
||||
def get_hosts_with_admin(hostname_list):
|
||||
assets = get_assets_by_hostname_list(hostname_list)
|
||||
return [asset._to_secret_json for asset in assets]
|
||||
|
||||
|
||||
def get_hosts(hostname_list):
|
||||
assets = get_assets_by_hostname_list(hostname_list)
|
||||
return [asset.to_json for asset in assets]
|
||||
|
||||
|
||||
def get_run_user(name):
|
||||
from assets.models import SystemUser
|
||||
system_user = get_object_or_none(SystemUser, name=name)
|
||||
if system_user is None:
|
||||
return {}
|
||||
else:
|
||||
return system_user._to_secret_json()
|
||||
|
||||
|
||||
def get_hosts_with_run_user(hostname_list, run_as):
|
||||
hosts_dict = get_hosts(hostname_list)
|
||||
system_user_dct = get_run_user(run_as)
|
||||
|
||||
for host in hosts_dict:
|
||||
host.update(system_user_dct)
|
||||
return hosts_dict
|
||||
|
||||
|
||||
def hosts_add_become(hosts, adhoc_data):
|
||||
if adhoc_data.become:
|
||||
become_data = {
|
||||
"become": {
|
||||
"method": adhoc_data.become_method,
|
||||
"user": adhoc_data.become_user,
|
||||
"pass": adhoc_data.become_pass,
|
||||
}
|
||||
}
|
||||
for host in hosts:
|
||||
host.update(become_data)
|
||||
return hosts
|
||||
|
||||
|
||||
def run_adhoc(adhoc_data, forks=10):
|
||||
tasks = adhoc_data.tasks
|
||||
hostname_list = adhoc_data.hosts
|
||||
adhoc_name = adhoc_data.subject.name
|
||||
|
||||
if adhoc_data.run_as_admin:
|
||||
hosts = get_hosts_with_admin(adhoc_data.hosts)
|
||||
else:
|
||||
hosts = get_hosts_with_run_user(hostname_list, adhoc_data.run_as)
|
||||
hosts_add_become(hosts, adhoc_data) # admin user 自带become
|
||||
|
||||
runner = AdHocRunner(hosts)
|
||||
runner.set_option('forks', forks)
|
||||
|
@@ -9,7 +9,7 @@ from django.views.generic import ListView, DetailView, View
|
||||
from django.utils import timezone
|
||||
from django.shortcuts import redirect, reverse
|
||||
|
||||
from .models import AdHoc, AdHocData, AdHocHistory
|
||||
from .models import AdHoc, AdHocData, AdHocRunHistory
|
||||
from ops.tasks import rerun_task
|
||||
|
||||
|
||||
@@ -63,7 +63,7 @@ class TaskListView(ListView):
|
||||
|
||||
|
||||
class TaskDetailView(DetailView):
|
||||
model = AdHocHistory
|
||||
model = AdHocRunHistory
|
||||
template_name = 'ops/task_detail.html'
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
|
Reference in New Issue
Block a user