Saltstack Official Linux Formula
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

169 line
4.5KB

  1. {%- from "linux/map.jinja" import system with context %}
  2. {%- if system.enabled %}
  3. include:
  4. - linux.system.package
  5. # global proxy setup
  6. {%- if system.proxy.get('pkg', {}).get('enabled', False) %}
  7. {%- if grains.os_family == 'Debian' %}
  8. /etc/apt/apt.conf.d/99proxies-salt:
  9. file.managed:
  10. - template: jinja
  11. - source: salt://linux/files/apt.conf.d_proxies
  12. - defaults:
  13. external_host: False
  14. https: {{ system.proxy.get('pkg', {}).get('https', None) | default(system.proxy.get('https', None), true) }}
  15. http: {{ system.proxy.get('pkg', {}).get('http', None) | default(system.proxy.get('http', None), true) }}
  16. ftp: {{ system.proxy.get('pkg', {}).get('ftp', None) | default(system.proxy.get('ftp', None), true) }}
  17. {%- else %}
  18. /etc/apt/apt.conf.d/99proxies-salt:
  19. file.absent
  20. {%- endif %}
  21. {%- endif %}
  22. {% set default_repos = {} %}
  23. {%- for name, repo in system.repo.iteritems() %}
  24. {%- if grains.os_family == 'Debian' %}
  25. # per repository proxy setup
  26. {%- if repo.get('proxy', {}).get('enabled', False) %}
  27. {%- set external_host = repo.proxy.get('host', None) or repo.source.split('/')[2] %}
  28. /etc/apt/apt.conf.d/99proxies-salt-{{ name }}:
  29. file.managed:
  30. - template: jinja
  31. - source: salt://linux/files/apt.conf.d_proxies
  32. - defaults:
  33. external_host: {{ external_host }}
  34. https: {{ repo.proxy.get('https', None) or system.proxy.get('pkg', {}).get('https', None) | default(system.proxy.get('https', None), True) }}
  35. http: {{ repo.proxy.get('http', None) or system.proxy.get('pkg', {}).get('http', None) | default(system.proxy.get('http', None), True) }}
  36. ftp: {{ repo.proxy.get('ftp', None) or system.proxy.get('pkg', {}).get('ftp', None) | default(system.proxy.get('ftp', None), True) }}
  37. {%- else %}
  38. /etc/apt/apt.conf.d/99proxies-salt-{{ name }}:
  39. file.absent
  40. {%- endif %}
  41. {%- if repo.pin is defined %}
  42. linux_repo_{{ name }}_pin:
  43. file.managed:
  44. - name: /etc/apt/preferences.d/{{ name }}
  45. - source: salt://linux/files/preferences_repo
  46. - template: jinja
  47. - defaults:
  48. repo_name: {{ name }}
  49. {%- else %}
  50. linux_repo_{{ name }}_pin:
  51. file.absent:
  52. - name: /etc/apt/preferences.d/{{ name }}
  53. {%- endif %}
  54. {%- if repo.get('default', False) %}
  55. {%- do default_repos.update({name: repo}) %}
  56. {%- if repo.key_url|default(False) %}
  57. linux_repo_{{ name }}_key:
  58. cmd.wait:
  59. - name: "curl -s {{ repo.key_url }} | apt-key add -"
  60. - watch:
  61. - file: default_repo_list
  62. {%- endif %}
  63. {%- else %}
  64. linux_repo_{{ name }}:
  65. pkgrepo.managed:
  66. - human_name: {{ name }}
  67. - name: {{ repo.source }}
  68. {%- if repo.architectures is defined %}
  69. - architectures: {{ repo.architectures }}
  70. {%- endif %}
  71. - file: /etc/apt/sources.list.d/{{ name }}.list
  72. - clean_file: {{ repo.clean|default(True) }}
  73. {%- if repo.key_id is defined %}
  74. - keyid: {{ repo.key_id }}
  75. {%- endif %}
  76. {%- if repo.key_server is defined %}
  77. - keyserver: {{ repo.key_server }}
  78. {%- endif %}
  79. {%- if repo.key_url is defined %}
  80. - key_url: {{ repo.key_url }}
  81. {%- endif %}
  82. - consolidate: {{ repo.get('consolidate', False) }}
  83. - clean_file: {{ repo.get('clean_file', False) }}
  84. - refresh_db: {{ repo.get('refresh_db', True) }}
  85. - require:
  86. - pkg: linux_packages
  87. {%- if repo.get('proxy', {}).get('enabled', False) %}
  88. - file: /etc/apt/apt.conf.d/99proxies-salt-{{ name }}
  89. {%- endif %}
  90. {%- if system.proxy.get('pkg', {}).get('enabled', False) %}
  91. - file: /etc/apt/apt.conf.d/99proxies-salt
  92. {%- endif %}
  93. {%- endif %}
  94. {%- endif %}
  95. {%- if grains.os_family == "RedHat" %}
  96. {%- if repo.get('proxy', {}).get('enabled', False) %}
  97. # PLACEHOLDER
  98. # TODO, implement per proxy configuration for Yum
  99. {%- endif %}
  100. {%- if not repo.get('default', False) %}
  101. linux_repo_{{ name }}:
  102. pkgrepo.managed:
  103. - name: {{ name }}
  104. - humanname: {{ repo.get('humanname', name) }}
  105. {%- if repo.mirrorlist is defined %}
  106. - mirrorlist: {{ repo.mirrorlist }}
  107. {%- else %}
  108. - baseurl: {{ repo.source }}
  109. {%- endif %}
  110. - gpgcheck: {% if repo.get('gpgcheck', False) %}1{% else %}0{% endif %}
  111. {%- if repo.gpgkey is defined %}
  112. - gpgkey: {{ repo.gpgkey }}
  113. {%- endif %}
  114. - require:
  115. - pkg: linux_packages
  116. {%- endif %}
  117. {%- endif %}
  118. {%- endfor %}
  119. {%- if default_repos|length > 0 and grains.os_family == 'Debian' %}
  120. default_repo_list:
  121. file.managed:
  122. - name: /etc/apt/sources.list
  123. - source: salt://linux/files/sources.list
  124. - template: jinja
  125. - user: root
  126. - group: root
  127. - mode: 0644
  128. - defaults:
  129. default_repos: {{ default_repos }}
  130. - require:
  131. - pkg: linux_packages
  132. {%- endif %}
  133. {%- endif %}