设为首页 收藏本站
查看: 1117|回复: 0

[经验分享] 使用python3调用 salt-api

[复制链接]

尚未签到

发表于 2018-8-8 08:39:48 | 显示全部楼层 |阅读模式
#python3.x  import pycurl
  from io import BytesIO
  import json
  class PyCurl(object):
  def __init__(self, url, **kwargs):
  # 传入url地址
  self.url = url
  # 取出header相关信息
  self.header = kwargs.get("header", None)
  # 创建一个curl对象
  self.curl = pycurl.Curl()
  # setopt 来设置一些请求选项
  # 指定请求的URL
  self.curl.setopt(self.curl.URL, self.url)
  # 设置代理浏览器
  self.curl.setopt(self.curl.HEADER, False)
  # 设置请求方式
  self.curl.setopt(self.curl.POST, True)
  # 设置https方式
  self.curl.setopt(pycurl.SSL_VERIFYPEER, 0)
  self.curl.setopt(pycurl.SSL_VERIFYHOST, 0)
  # 判断header是否存在
  if self.header:
  # 设置模拟浏览器
  self.curl.setopt(self.curl.HTTPHEADER, self.header)
  def request(self, data=None, timeout=None):
  # 判断对象类型 是否为 str
  if isinstance(data, str):
  #将数据提交
  self.curl.setopt(pycurl.POSTFIELDS, data)
  header_buf = BytesIO()
  body_buf = BytesIO()
  # 强制获取新的连接,即替代缓存中的连接
  self.curl.setopt(self.curl.FRESH_CONNECT, True)
  # 完成交互后强制断开连接,不重用
  self.curl.setopt(self.curl.FORBID_REUSE, True)
  if str(timeout).isdigit() and timeout > 0:
  # 设置timeout超时时间
  self.curl.setopt(self.curl.TIMEOUT, timeout)
  # 将返回的HTTP HEADER定向到回调函数header_buf
  self.curl.setopt(self.curl.HEADERFUNCTION, header_buf.write)
  # 将返回的内容定向到回调函数body_buf
  self.curl.setopt(self.curl.WRITEFUNCTION, body_buf.write)
  try:
  # 服务器返回信息
  self.curl.perform()
  except pycurl.error:
  return False
  # 状态码
  http_code = self.curl.getinfo(self.curl.HTTP_CODE)
  # 关闭连接
  self.curl.close()
  # 返回状态码 header body
  return {"http_code": http_code, "header": header_buf.getvalue(), "body": body_buf.getvalue(), "url": self.url}
  class SaltApi(object):
  def __init__(self,**kwargs):
  # 设置超时时间
  self.timeout = kwargs.get("timeout", 300)
  # 设置头信息
  self.header = kwargs.get("header", ["Content-Type:application/json"])
  # 获取url
  self.__url = "https://192.168.104.76:8000"
  # 获取
  self.__username = "salt-api"
  self.__password = "salt-api"

  # token>  def token_id(self):
  obj = {'eauth': 'pam', 'username': self.__username, 'password': self.__password}
  result = self.post(prefix="/login",**obj)
  if result:
  try:
  self.__token_id = result['return'][0]['token']
  except KeyError:
  raise KeyError
  print(self.__token_id)
  return self.__token_id
  def post(self, prefix="/",token=None,**data):
  # url拼接
  url = self.__url + prefix
  print (data)
  # 实例化
  self.header.append(str(token))
  curl = PyCurl(url, header=self.header)
  # 发起请求
  result = curl.request(data=json.dumps(data), timeout=self.timeout)
  # 判断值
  if not result:
  return result
  #判断状态码是否等于200
  if result["http_code"] != 200:
  self.response = "response code %s".format(result["info"]["http_code"])
  return self.response
  result = json.loads(result["body"].decode())
  # 判断是否有error
  if "error" in result and result["error"]:
  self.response = "%s(%s)" % (result["error"]["data"], result["error"]["code"])
  return self.response
  #返回正确的数据
  return result
  def all_key(self):
  '''
  获取所有的minion_key
  '''
  token = 'X-Auth-Token:%s'%self.token_id()
  obj = {'client': 'wheel', 'fun': 'key.list_all'}
  content = self.post(token=token,**obj)
  # 取出认证已经通过的
  minions = content['return'][0]['data']['return']['minions']
  #print('已认证',minions)
  # 取出未通过认证的
  minions_pre = content['return'][0]['data']['return']['minions_pre']
  # print('未认证',minions_pre)
  return minions,minions_pre
  def accept_key(self,node_name):
  '''
  如果你想认证某个主机 那么调用此方法
  '''
  token = 'X-Auth-Token:%s' % self.token_id()
  obj = {'client': 'wheel', 'fun': 'key.accept','match':node_name}
  content = self.post(token=token,**obj)
  print (content)
  ret = content['return'][0]['data']['success']
  return ret
  # 删除认证方法
  def delete_key(self, node_name):
  obj = {'client': 'wheel', 'fun': 'key.delete', 'match': node_name}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  ret = content['return'][0]['data']['success']
  return ret
  # 针对主机远程执行模块
  def host_remote_func(self, tgt, fun):
  ''' tgt是主机 fun是模块
  写上模块名 返回 可以用来调用基本的资产
  例如 curl -k https://ip地址:8080/ \
  >      -H "Accept: application/x-yaml" \
  >      -H "X-Auth-Token:b50e90485615309de0d83132cece2906f6193e43" \
  >      -d client='local' \
  >      -d tgt='*' \
  >      -d fun='test.ping'  要执行的模块
  return:
  - iZ28r91y66hZ: true
  node2.minion: true
  '''
  obj = {'client': 'local', 'tgt': tgt, 'fun': fun}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  ret = content['return'][0]
  return ret
  def group_remote_func(self,tgt,fun):
  obj = {'client': 'local', 'tgt': tgt, 'fun': fun,'expr_form': 'nodegroup'}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  print (content)
  ret = content['return'][0]
  return ret
  def host_remote_execution_module(self,tgt,fun,arg):
  '执行fun 传入传入参数arg '
  obj = {'client': 'local', 'tgt': tgt, 'fun': fun,'arg': arg}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  ret = content['return'][0]
  return ret
  #print(salt_aa.host_remote_execution_module('*', 'cmd.run', 'ifconfig'))
  # 基于分组来执行
  def group_remote_execution_module(self, tgt, fun, arg):
  '''
  根据分组来执行
  tgt =
  '''
  obj = {'client': 'local', 'tgt': tgt, 'fun': fun, 'arg': arg, 'expr_form': 'nodegroup'}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]
  return jid
  def host_sls(self, tgt, arg):
  '''主机进行sls'''
  obj = {'client': 'local', 'tgt': tgt, 'fun': 'state.sls', 'arg': arg}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  return content
  def group_sls(self, tgt, arg):
  ''' 分组进行sls '''
  obj = {'client': 'local', 'tgt': tgt, 'fun': 'state.sls', 'arg': arg, 'expr_form': 'nodegroup'}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]['jid']
  return jid
  def host_sls_async(self, tgt, arg):
  '''主机异步sls '''
  obj = {'client': 'local_async', 'tgt': tgt, 'fun': 'state.sls', 'arg': arg}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]['jid']
  return jid
  def group_sls_async(self, tgt, arg):
  '''分组异步sls '''
  obj = {'client': 'local_async', 'tgt': tgt, 'fun': 'state.sls', 'arg': arg, 'expr_form': 'nodegroup'}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]['jid']
  return jid
  def server_group_pillar(self, tgt, arg, **kwargs):
  '''分组进行sls and pillar'''
  obj = {'client': 'local', 'tgt': tgt, 'fun': 'state.sls', 'arg': arg, 'expr_form': 'nodegroup',
  'kwarg': kwargs}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]
  print (jid)
  def server_hosts_pillar(self, tgt, arg,**kwargs):
  '''针对主机执行sls and pillar '''
  obj = {"client": "local", "tgt": tgt, "fun": "state.sls", "arg": arg,"kwarg":kwargs}
  token = 'X-Auth-Token:%s' % self.token_id()
  content = self.post(token=token, **obj)
  jid = content['return'][0]
  return jid
  def jobs_all_list(self):
  '''打印所有jid缓存'''
  token = 'X-Auth-Token:%s' % self.token_id()
  obj = {"client": "runner", "fun": "jobs.list_jobs"}
  content = self.post(token=token, **obj)
  print (content)
  def jobs_jid_status(self, jid):
  '''查看jid运行状态'''
  token = 'X-Auth-Token:%s' % self.token_id()
  obj = {"client": "runner", "fun": "jobs.lookup_jid", "jid": jid}
  content = self.post(token=token, **obj)
  print (content)
  return content
  if __name__ == '__main__':
  sa = saltapi.SaltApi()
  print (sa.host_remote_execution_module('node76','cmd.run','ifconfig'))
  print (sa.accept_key("node76"))

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-548439-1-1.html 上篇帖子: python基础:元组的使用 下篇帖子: 初窥Python(五)——python中的decorator
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表