5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2024-10-07 11:16:56 +00:00

Merge branch 'blazer' into panel.sutty.nl

This commit is contained in:
f 2022-04-30 10:29:10 -03:00
commit f807bb4891

View file

@ -21,10 +21,12 @@ class UriCollectionJob < PeriodicJob
def perform(site_id:, once: true) def perform(site_id:, once: true)
@site = Site.find site_id @site = Site.find site_id
# Obtener el principio del intervalo anterior
beginning = beginning_of_interval
# Recordar la última vez que se corrió la tarea # Recordar la última vez que se corrió la tarea
stat = site.stats.create! name: STAT_NAME stat = site.stats.create! name: STAT_NAME
beginning = beginning_of_interval # Columnas a agrupar
columns = %i[http_referer geoip2_data_country_name] columns = %i[http_referer geoip2_data_country_name].zip([nil]).to_h
# Recorremos todos los hostnames y uris posibles y luego agrupamos # Recorremos todos los hostnames y uris posibles y luego agrupamos
# recursivamente para no tener que recalcular, asumiendo que es más # recursivamente para no tener que recalcular, asumiendo que es más
@ -35,6 +37,9 @@ class UriCollectionJob < PeriodicJob
break if stop? break if stop?
host_dimensions = { host: host } host_dimensions = { host: host }
columns.each_key do |column|
columns[column] = AccessLog.where(**host_dimensions).distinct(column).pluck(column)
end
# Las URIs son la fuente de verdad de las visitas, porque son las # Las URIs son la fuente de verdad de las visitas, porque son las
# que indican las páginas y recursos descargables, el resto son # que indican las páginas y recursos descargables, el resto son
@ -49,9 +54,9 @@ class UriCollectionJob < PeriodicJob
rollup(name, beginning, **dimensions) rollup(name, beginning, **dimensions)
reduce_rollup(name, beginning, **dimensions) reduce_rollup(name, beginning, **dimensions)
columns.each do |column| columns.each_pair do |column, values|
# Obtener orígenes de visitas por host # Obtener orígenes de visitas por host
AccessLog.where(**host_dimensions).distinct(column).pluck(column).each do |value| values.each do |value|
column_name = "host|uri|#{column}" column_name = "host|uri|#{column}"
dimensions[column] = value dimensions[column] = value
@ -71,7 +76,7 @@ class UriCollectionJob < PeriodicJob
# Acumular por mes y año # Acumular por mes y año
reduce_rollup('host', beginning, **host_dimensions) reduce_rollup('host', beginning, **host_dimensions)
columns.each do |column| columns.each_key do |column|
square_rollup(name: "host|uri|#{column}", square_rollup(name: "host|uri|#{column}",
new_name: "host|#{column}", new_name: "host|#{column}",
interval: starting_interval, interval: starting_interval,