aws.rb 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. # frozen_string_literal: true
  2. require 'accounts'
  3. require 'regions'
  4. require 'mime-types'
  5. require 'fog-aws'
  6. require 's3'
  7. require 'ipaddr'
  8. require 'neo4j'
  9. require 'rds'
  10. require 'neoinfra/config'
  11. require 'neoinfra/cloudwatch'
  12. RFC_1918 = [
  13. IPAddr.new('10.0.0.0/8'),
  14. IPAddr.new('172.16.0.0/12'),
  15. IPAddr.new('192.168.0.0/16'),
  16. ].freeze
  17. # NeoInfra Account information
  18. module NeoInfra
  19. # Provide informations about the accounts available
  20. class Aws
  21. def initialize
  22. @cfg = NeoInfra::Config.new
  23. neo4j_url = "http://#{@cfg.neo4j[:host]}:#{@cfg.neo4j[:port]}"
  24. Neo4j::Session.open(:server_db, neo4j_url)
  25. end
  26. def regions
  27. account = @cfg.accounts.first
  28. base_conf = {
  29. provider: 'AWS',
  30. aws_access_key_id: account[:key],
  31. aws_secret_access_key: account[:secret]
  32. }
  33. conn = Fog::Compute.new(base_conf)
  34. conn.describe_regions.data[:body]['regionInfo'].collect { |x| x['regionName'] }
  35. end
  36. def region_count
  37. Region.all.length
  38. end
  39. def az_count
  40. Az.all.length
  41. end
  42. def azs(region)
  43. account = @cfg.accounts.first
  44. base_conf = {
  45. provider: 'AWS',
  46. aws_access_key_id: account[:key],
  47. aws_secret_access_key: account[:secret],
  48. region: region
  49. }
  50. conn = Fog::Compute.new(base_conf)
  51. conn.describe_availability_zones.data[:body]['availabilityZoneInfo'].collect { |x| x['zoneName'] }
  52. end
  53. def load_regions
  54. regions.each do |region|
  55. next unless Region.where(region: region).empty?
  56. r = Region.new(
  57. region: region
  58. )
  59. r.save
  60. azs(region).each do |az|
  61. next unless Az.where(az: az).empty?
  62. a = Az.new(az: az)
  63. a.save
  64. AzRegion.create(from_node: a, to_node: Region.where(region: region).first)
  65. end
  66. end
  67. end
  68. def list_buckets
  69. buckets = []
  70. Bucket.all.order('n.size DESC').each do |b|
  71. buckets << {
  72. 'name' => b.name,
  73. 'size' => b.size,
  74. 'versioning' => b.versioning,
  75. 'creation' => b.creation,
  76. 'region' => b.region.region,
  77. 'owner' => b.owner.name
  78. }
  79. end
  80. return buckets
  81. end
  82. def load_buckets
  83. cw = NeoInfra::Cloudwatch.new
  84. @cfg.accounts.each do |account|
  85. base_conf = {
  86. provider: 'AWS',
  87. aws_access_key_id: account[:key],
  88. aws_secret_access_key: account[:secret]
  89. }
  90. s = Fog::Storage.new(base_conf)
  91. s.directories.each do |bucket|
  92. next unless Bucket.where(name: bucket.key).empty?
  93. begin
  94. vers = bucket.versioning?.to_s
  95. crea = bucket.creation_date.to_s
  96. rescue
  97. vers = "unknown"
  98. crea = "unknown"
  99. end
  100. b = Bucket.new(
  101. name: bucket.key,
  102. versioning: vers,
  103. creation: crea,
  104. size: cw.get_bucket_size(account[:key], account[:secret], bucket.location, bucket.key)
  105. )
  106. b.save
  107. BucketRegion.create(from_node: b, to_node: Region.where(region: bucket.location).first)
  108. BucketAccount.create(from_node: b, to_node: AwsAccount.where(name: account[:name]).first)
  109. end
  110. end
  111. end
  112. def load_security_groups
  113. @cfg.accounts.each do |account|
  114. base_conf = {
  115. provider: 'AWS',
  116. aws_access_key_id: account[:key],
  117. aws_secret_access_key: account[:secret]
  118. }
  119. self.regions.each do |region|
  120. region_conf = { region: region }
  121. conn = Fog::Compute.new(region_conf.merge(base_conf))
  122. conn.security_groups.all.each do |grp|
  123. ####
  124. grp.ip_permissions.each do |iprule|
  125. if iprule['ipProtocol'] != "-1"
  126. iprule['ipRanges'].each do |r|
  127. if iprule['toPort'] == -1
  128. to_port = 65535
  129. else
  130. to_port = iprule['toPort']
  131. end
  132. if iprule['fromPort'] == -1
  133. from_port = 0
  134. else
  135. from_port = iprule['fromPort']
  136. end
  137. if IpRules.where(
  138. cidr_block: r['cidrIp'],
  139. direction: 'ingress',
  140. proto: iprule['ipProtocol'],
  141. to_port: to_port,
  142. from_port: from_port,
  143. ).empty?
  144. rl = IpRules.new(
  145. cidr_block: r['cidrIp'],
  146. direction: 'ingress',
  147. proto: iprule['ipProtocol'],
  148. to_port: to_port,
  149. from_port: from_port,
  150. private: RFC_1918.any? { |rfc| rfc.include?(IPAddr.new(r['cidrIp']))}
  151. )
  152. rl.save
  153. end
  154. end
  155. end
  156. end
  157. next unless SecurityGroup.where(sg_id: grp.group_id).empty?
  158. g = SecurityGroup.new(
  159. sg_id: grp.group_id,
  160. name: grp.name,
  161. description: grp.description,
  162. )
  163. g.save
  164. SecurityGroupOwner.create(from_node: g, to_node: AwsAccount.where(account_id: grp.owner_id).first)
  165. SecurityGroupVpc.create(from_node: g, to_node: Vpc.where(vpc_id: grp.vpc_id).first)
  166. end
  167. end
  168. end
  169. end
  170. def load_rds
  171. @cfg.accounts.each do |account|
  172. base_conf = {
  173. aws_access_key_id: account[:key],
  174. aws_secret_access_key: account[:secret]
  175. }
  176. s = Fog::AWS::RDS.new(base_conf)
  177. s.servers.each do |rds|
  178. next unless Rds.where(name: rds.id).empty?
  179. r = Rds.new(
  180. name: rds.id,
  181. size: rds.flavor_id,
  182. engine: rds.engine,
  183. engine_version: rds.engine_version,
  184. multi_az: rds.multi_az.to_s,
  185. endpoint: rds.endpoint['Address'],
  186. port: rds.endpoint['Port'],
  187. allocated_storage: rds.allocated_storage,
  188. )
  189. r.save
  190. RdsAz.create(from_node: r, to_node: Az.where(az: rds.availability_zone).first)
  191. RdsAccount.create(from_node: r, to_node: AwsAccount.where(name: account[:name]).first)
  192. end
  193. end
  194. end
  195. end
  196. end