HEX
Server: Apache
System: Linux sg241.singhost.net 2.6.32-896.16.1.lve1.4.51.el6.x86_64 #1 SMP Wed Jan 17 13:19:23 EST 2018 x86_64
User: honghock (909)
PHP: 8.0.30
Disabled: passthru,system,shell_exec,show_source,exec,popen,proc_open
Upload Files
File: //proc/self/root/usr/lib/python2.7/site-packages/salt/runners/mine.py
# -*- coding: utf-8 -*-
'''
A runner to access data from the salt mine
'''
from __future__ import absolute_import, print_function, unicode_literals

# Import Python Libs
import logging

# Import salt libs
import salt.daemons.masterapi

log = logging.getLevelName(__name__)


def get(tgt, fun, tgt_type='glob'):
    '''
    Gathers the data from the specified minions' mine, pass in the target,
    function to look up and the target type

    CLI Example:

    .. code-block:: bash

        salt-run mine.get '*' network.interfaces
    '''
    masterapi = salt.daemons.masterapi.RemoteFuncs(__opts__)
    load = {
        'id': __opts__['id'],
        'fun': fun,
        'tgt': tgt,
        'tgt_type': tgt_type,
    }
    ret = masterapi._mine_get(load)
    return ret


def update(tgt,
           tgt_type='glob',
           clear=False,
           mine_functions=None):
    '''
    .. versionadded:: 2017.7.0

    Update the mine data on a certain group of minions.

    tgt
        Which minions to target for the execution.

    tgt_type: ``glob``
        The type of ``tgt``.

    clear: ``False``
        Boolean flag specifying whether updating will clear the existing
        mines, or will update. Default: ``False`` (update).

    mine_functions
        Update the mine data on certain functions only.
        This feature can be used when updating the mine for functions
        that require refresh at different intervals than the rest of
        the functions specified under ``mine_functions`` in the
        minion/master config or pillar.

    CLI Example:

    .. code-block:: bash

        salt-run mine.update '*'
        salt-run mine.update 'juniper-edges' tgt_type='nodegroup'
    '''
    ret = __salt__['salt.execute'](tgt,
                                   'mine.update',
                                   tgt_type=tgt_type,
                                   clear=clear,
                                   mine_functions=mine_functions)
    return ret