Skip to content

Instantly share code, notes, and snippets.

@bdombro
Created November 6, 2016 21:13
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save bdombro/e312641d3663978fee215500a9a0b006 to your computer and use it in GitHub Desktop.
Save bdombro/e312641d3663978fee215500a9a0b006 to your computer and use it in GitHub Desktop.
ubuntu@ip-172-31-56-171:~$ wget -qO- https://get.docker.com/ | sh
modprobe: FATAL: Module aufs not found.
+ sudo -E sh -c sleep 3; apt-get update
Ign http://us-east-1.ec2.archive.ubuntu.com trusty InRelease
Get:1 http://us-east-1.ec2.archive.ubuntu.com trusty-updates InRelease [65.9 kB]
Get:2 http://us-east-1.ec2.archive.ubuntu.com trusty-backports InRelease [65.9 kB]
Hit http://us-east-1.ec2.archive.ubuntu.com trusty Release.gpg
Hit http://us-east-1.ec2.archive.ubuntu.com trusty Release
Get:3 http://security.ubuntu.com trusty-security InRelease [65.9 kB]
Get:4 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main Sources [384 kB]
Get:5 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted Sources [5,888 B]
Get:6 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe Sources [169 kB]
Get:7 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse Sources [7,531 B]
Get:8 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main amd64 Packages [913 kB]
Get:9 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted amd64 Packages [16.4 kB]
Get:10 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe amd64 Packages [388 kB]
Get:11 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse amd64 Packages [14.0 kB]
Get:12 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main Translation-en [443 kB]
Get:13 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse Translation-en [7,340 B]
Get:14 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted Translation-en [3,842 B]
Get:15 http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe Translation-en [205 kB]
Get:16 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main Sources [9,646 B]
Get:17 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted Sources [28 B]
Get:18 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe Sources [35.2 kB]
Get:19 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse Sources [1,898 B]
Get:20 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main amd64 Packages [13.3 kB]
Get:21 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted amd64 Packages [28 B]
Get:22 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe amd64 Packages [43.2 kB]
Get:23 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse amd64 Packages [1,571 B]
Get:24 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main Translation-en [7,493 B]
Get:25 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse Translation-en [1,215 B]
Get:26 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted Translation-en [28 B]
Get:27 http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe Translation-en [36.8 kB]
Get:28 http://us-east-1.ec2.archive.ubuntu.com trusty/main Sources [1,064 kB]
Get:29 http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Sources [5,433 B]
Get:30 http://us-east-1.ec2.archive.ubuntu.com trusty/universe Sources [6,399 kB]
Get:31 http://security.ubuntu.com trusty-security/main Sources [120 kB]
Get:32 http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Sources [174 kB]
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/main amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/restricted amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/universe amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/main Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/universe Translation-en
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/main Translation-en_US
Get:33 http://security.ubuntu.com trusty-security/universe Sources [45.1 kB]
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Translation-en_US
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Translation-en_US
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/universe Translation-en_US
Get:34 http://security.ubuntu.com trusty-security/main amd64 Packages [542 kB]
Get:35 http://security.ubuntu.com trusty-security/universe amd64 Packages [142 kB]
Get:36 http://security.ubuntu.com trusty-security/main Translation-en [298 kB]
Get:37 http://security.ubuntu.com trusty-security/universe Translation-en [84.5 kB]
Fetched 11.8 MB in 3s (3,616 kB/s)
Reading package lists... Done
+ sudo -E sh -c sleep 3; apt-get install -y -q linux-image-extra-3.13.0-100-generic linux-image-extra-virtual
Reading package lists...
Building dependency tree...
Reading state information...
The following extra packages will be installed:
crda iw libnl-3-200 libnl-genl-3-200 linux-firmware linux-image-generic
wireless-regdb
The following NEW packages will be installed:
crda iw libnl-3-200 libnl-genl-3-200 linux-firmware
linux-image-extra-3.13.0-100-generic linux-image-extra-virtual
linux-image-generic wireless-regdb
0 upgraded, 9 newly installed, 0 to remove and 15 not upgraded.
Need to get 70.1 MB of archives.
After this operation, 275 MB of additional disk space will be used.
Get:1 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main libnl-3-200 amd64 3.2.21-1ubuntu4 [45.6 kB]
Get:2 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main libnl-genl-3-200 amd64 3.2.21-1ubuntu4 [10.2 kB]
Get:3 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main wireless-regdb all 2013.02.13-1ubuntu1 [6,456 B]
Get:4 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main crda amd64 1.1.2-1ubuntu2 [15.2 kB]
Get:5 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main iw amd64 3.4-1 [51.7 kB]
Get:6 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main linux-firmware all 1.127.22 [33.2 MB]
Get:7 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main linux-image-extra-3.13.0-100-generic amd64 3.13.0-100.147 [36.7 MB]
Get:8 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main linux-image-generic amd64 3.13.0.100.108 [2,346 B]
Get:9 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main linux-image-extra-virtual amd64 3.13.0.100.108 [1,764 B]
Fetched 70.1 MB in 1s (48.5 MB/s)
Selecting previously unselected package libnl-3-200:amd64.
(Reading database ... 51177 files and directories currently installed.)
Preparing to unpack .../libnl-3-200_3.2.21-1ubuntu4_amd64.deb ...
Unpacking libnl-3-200:amd64 (3.2.21-1ubuntu4) ...
Selecting previously unselected package libnl-genl-3-200:amd64.
Preparing to unpack .../libnl-genl-3-200_3.2.21-1ubuntu4_amd64.deb ...
Unpacking libnl-genl-3-200:amd64 (3.2.21-1ubuntu4) ...
Selecting previously unselected package wireless-regdb.
Preparing to unpack .../wireless-regdb_2013.02.13-1ubuntu1_all.deb ...
Unpacking wireless-regdb (2013.02.13-1ubuntu1) ...
Selecting previously unselected package crda.
Preparing to unpack .../crda_1.1.2-1ubuntu2_amd64.deb ...
Unpacking crda (1.1.2-1ubuntu2) ...
Selecting previously unselected package iw.
Preparing to unpack .../archives/iw_3.4-1_amd64.deb ...
Unpacking iw (3.4-1) ...
Selecting previously unselected package linux-firmware.
Preparing to unpack .../linux-firmware_1.127.22_all.deb ...
Unpacking linux-firmware (1.127.22) ...
Selecting previously unselected package linux-image-extra-3.13.0-100-generic.
Preparing to unpack .../linux-image-extra-3.13.0-100-generic_3.13.0-100.147_amd64.deb ...
Unpacking linux-image-extra-3.13.0-100-generic (3.13.0-100.147) ...
Selecting previously unselected package linux-image-generic.
Preparing to unpack .../linux-image-generic_3.13.0.100.108_amd64.deb ...
Unpacking linux-image-generic (3.13.0.100.108) ...
Selecting previously unselected package linux-image-extra-virtual.
Preparing to unpack .../linux-image-extra-virtual_3.13.0.100.108_amd64.deb ...
Unpacking linux-image-extra-virtual (3.13.0.100.108) ...
Processing triggers for man-db (2.6.7.1-1ubuntu1) ...
Setting up libnl-3-200:amd64 (3.2.21-1ubuntu4) ...
Setting up libnl-genl-3-200:amd64 (3.2.21-1ubuntu4) ...
Setting up wireless-regdb (2013.02.13-1ubuntu1) ...
Setting up crda (1.1.2-1ubuntu2) ...
Setting up iw (3.4-1) ...
Setting up linux-firmware (1.127.22) ...
Setting up linux-image-extra-3.13.0-100-generic (3.13.0-100.147) ...
run-parts: executing /etc/kernel/postinst.d/apt-auto-removal 3.13.0-100-generic /boot/vmlinuz-3.13.0-100-generic
run-parts: executing /etc/kernel/postinst.d/initramfs-tools 3.13.0-100-generic /boot/vmlinuz-3.13.0-100-generic
update-initramfs: Generating /boot/initrd.img-3.13.0-100-generic
run-parts: executing /etc/kernel/postinst.d/update-notifier 3.13.0-100-generic /boot/vmlinuz-3.13.0-100-generic
run-parts: executing /etc/kernel/postinst.d/x-grub-legacy-ec2 3.13.0-100-generic /boot/vmlinuz-3.13.0-100-generic
Searching for GRUB installation directory ... found: /boot/grub
Searching for default file ... found: /boot/grub/default
Testing for an existing GRUB menu.lst file ... found: /boot/grub/menu.lst
Searching for splash image ... none found, skipping ...
Found kernel: /boot/vmlinuz-3.13.0-100-generic
Found kernel: /boot/vmlinuz-3.13.0-100-generic
Updating /boot/grub/menu.lst ... done
run-parts: executing /etc/kernel/postinst.d/zz-update-grub 3.13.0-100-generic /boot/vmlinuz-3.13.0-100-generic
Generating grub configuration file ...
Found linux image: /boot/vmlinuz-3.13.0-100-generic
Found initrd image: /boot/initrd.img-3.13.0-100-generic
done
Setting up linux-image-generic (3.13.0.100.108) ...
Setting up linux-image-extra-virtual (3.13.0.100.108) ...
Processing triggers for libc-bin (2.19-0ubuntu6.9) ...
apparmor is enabled in the kernel and apparmor utils were already installed
+ sudo -E sh -c apt-key adv --keyserver hkp://ha.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
Executing: gpg --ignore-time-conflict --no-options --no-default-keyring --homedir /tmp/tmp.RxPjC5dCza --no-auto-check-trustdb --trust-model always --keyring /etc/apt/trusted.gpg --primary-keyring /etc/apt/trusted.gpg --keyserver hkp://ha.pool.sks-keyservers.net:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
gpg: requesting key 2C52609D from hkp server ha.pool.sks-keyservers.net
gpg: key 2C52609D: public key "Docker Release Tool (releasedocker) <docker@docker.com>" imported
gpg: Total number processed: 1
gpg: imported: 1 (RSA: 1)
+ break
+ sudo -E sh -c apt-key adv -k 58118E89F3A912897C070ADBF76221572C52609D >/dev/null
+ sudo -E sh -c mkdir -p /etc/apt/sources.list.d
+ dpkg --print-architecture
+ sudo -E sh -c echo deb \[arch=amd64\] https://apt.dockerproject.org/repo ubuntu-trusty main > /etc/apt/sources.list.d/docker.list
+ sudo -E sh -c sleep 3; apt-get update; apt-get install -y -q docker-engine
Ign http://us-east-1.ec2.archive.ubuntu.com trusty InRelease
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates InRelease
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports InRelease
Hit http://us-east-1.ec2.archive.ubuntu.com trusty Release.gpg
Hit http://us-east-1.ec2.archive.ubuntu.com trusty Release
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/main Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/multiverse Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/restricted Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-updates/universe Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/main Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/multiverse Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/restricted Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty-backports/universe Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/main Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/universe Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Sources
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/main amd64 Packages
Hit http://security.ubuntu.com trusty-security InRelease
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/restricted amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/universe amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse amd64 Packages
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/main Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Translation-en
Hit http://us-east-1.ec2.archive.ubuntu.com trusty/universe Translation-en
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/main Translation-en_US
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/multiverse Translation-en_US
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/restricted Translation-en_US
Ign http://us-east-1.ec2.archive.ubuntu.com trusty/universe Translation-en_US
Hit http://security.ubuntu.com trusty-security/main Sources
Get:1 https://apt.dockerproject.org ubuntu-trusty InRelease
Get:2 https://apt.dockerproject.org ubuntu-trusty/main amd64 Packages
Get:3 https://apt.dockerproject.org ubuntu-trusty/main Translation-en_US
Hit http://security.ubuntu.com trusty-security/universe Sources
Ign https://apt.dockerproject.org ubuntu-trusty/main Translation-en_US
Ign https://apt.dockerproject.org ubuntu-trusty/main Translation-en
Hit http://security.ubuntu.com trusty-security/main amd64 Packages
Hit http://security.ubuntu.com trusty-security/universe amd64 Packages
Hit http://security.ubuntu.com trusty-security/main Translation-en
Hit http://security.ubuntu.com trusty-security/universe Translation-en
Fetched 35.9 kB in 2s (16.7 kB/s)
Reading package lists... Done
Reading package lists...
Building dependency tree...
Reading state information...
The following extra packages will be installed:
aufs-tools cgroup-lite git git-man liberror-perl libltdl7
libsystemd-journal0
Suggested packages:
git-daemon-run git-daemon-sysvinit git-doc git-el git-email git-gui gitk
gitweb git-arch git-bzr git-cvs git-mediawiki git-svn
The following NEW packages will be installed:
aufs-tools cgroup-lite docker-engine git git-man liberror-perl libltdl7
libsystemd-journal0
0 upgraded, 8 newly installed, 0 to remove and 15 not upgraded.
Need to get 22.7 MB of archives.
After this operation, 124 MB of additional disk space will be used.
Get:1 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main libltdl7 amd64 2.4.2-1.7ubuntu1 [35.0 kB]
Get:2 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main libsystemd-journal0 amd64 204-5ubuntu20.19 [50.1 kB]
Get:3 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/universe aufs-tools amd64 1:3.2+20130722-1.1 [92.3 kB]
Get:4 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main liberror-perl all 0.17-1.1 [21.1 kB]
Get:5 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main git-man all 1:1.9.1-1ubuntu0.3 [699 kB]
Get:6 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty-updates/main git amd64 1:1.9.1-1ubuntu0.3 [2,586 kB]
Get:7 http://us-east-1.ec2.archive.ubuntu.com/ubuntu/ trusty/main cgroup-lite all 1.9 [3,918 B]
Fetched 22.7 MB in 0s (24.8 MB/s)
Selecting previously unselected package libltdl7:amd64.
(Reading database ... 56339 files and directories currently installed.)
Preparing to unpack .../libltdl7_2.4.2-1.7ubuntu1_amd64.deb ...
Unpacking libltdl7:amd64 (2.4.2-1.7ubuntu1) ...
Selecting previously unselected package libsystemd-journal0:amd64.
Preparing to unpack .../libsystemd-journal0_204-5ubuntu20.19_amd64.deb ...
Unpacking libsystemd-journal0:amd64 (204-5ubuntu20.19) ...
Selecting previously unselected package aufs-tools.
Preparing to unpack .../aufs-tools_1%3a3.2+20130722-1.1_amd64.deb ...
Unpacking aufs-tools (1:3.2+20130722-1.1) ...
Selecting previously unselected package docker-engine.
Preparing to unpack .../docker-engine_1.12.3-0~trusty_amd64.deb ...
Unpacking docker-engine (1.12.3-0~trusty) ...
Selecting previously unselected package liberror-perl.
Preparing to unpack .../liberror-perl_0.17-1.1_all.deb ...
Unpacking liberror-perl (0.17-1.1) ...
Selecting previously unselected package git-man.
Preparing to unpack .../git-man_1%3a1.9.1-1ubuntu0.3_all.deb ...
Unpacking git-man (1:1.9.1-1ubuntu0.3) ...
Selecting previously unselected package git.
Preparing to unpack .../git_1%3a1.9.1-1ubuntu0.3_amd64.deb ...
Unpacking git (1:1.9.1-1ubuntu0.3) ...
Selecting previously unselected package cgroup-lite.
Preparing to unpack .../cgroup-lite_1.9_all.deb ...
Unpacking cgroup-lite (1.9) ...
Processing triggers for man-db (2.6.7.1-1ubuntu1) ...
Processing triggers for ureadahead (0.100.0-16) ...
Setting up libltdl7:amd64 (2.4.2-1.7ubuntu1) ...
Setting up libsystemd-journal0:amd64 (204-5ubuntu20.19) ...
Setting up aufs-tools (1:3.2+20130722-1.1) ...
Setting up docker-engine (1.12.3-0~trusty) ...
docker start/running, process 12012
Setting up liberror-perl (0.17-1.1) ...
Setting up git-man (1:1.9.1-1ubuntu0.3) ...
Setting up git (1:1.9.1-1ubuntu0.3) ...
Setting up cgroup-lite (1.9) ...
cgroup-lite start/running
Processing triggers for libc-bin (2.19-0ubuntu6.9) ...
Processing triggers for ureadahead (0.100.0-16) ...
+ sudo -E sh -c docker version
Client:
Version: 1.12.3
API version: 1.24
Go version: go1.6.3
Git commit: 6b644ec
Built: Wed Oct 26 21:44:32 2016
OS/Arch: linux/amd64
Server:
Version: 1.12.3
API version: 1.24
Go version: go1.6.3
Git commit: 6b644ec
Built: Wed Oct 26 21:44:32 2016
OS/Arch: linux/amd64
If you would like to use Docker as a non-root user, you should now consider
adding your user to the "docker" group with something like:
sudo usermod -aG docker ubuntu
Remember that you will have to log out and back in for this to take effect!
ubuntu@ip-172-31-56-171:~$ sudo usermod -aG docker ubuntu
ubuntu@ip-172-31-56-171:~$ sudo -s
root@ip-172-31-56-171:~# mkdir /var/discourse
root@ip-172-31-56-171:~# git clone https://github.com/discourse/discourse_docker.git /var/discourse
Cloning into '/var/discourse'...
remote: Counting objects: 2987, done.
remote: Total 2987 (delta 0), reused 0 (delta 0), pack-reused 2987
Receiving objects: 100% (2987/2987), 660.13 KiB | 0 bytes/s, done.
Resolving deltas: 100% (1819/1819), done.
Checking connectivity... done.
root@ip-172-31-56-171:~# cd /var/discourse
root@ip-172-31-56-171:/var/discourse# ./discourse-setup
Ports 80 and 443 are free for use
Found 4GB of memory and 2 physical CPU cores
setting db_shared_buffers = 1024MB
setting UNICORN_WORKERS = 4
Hostname for your Discourse? [discourse.example.com]: edgewoodcoop.com
Email address for admin account? [me@example.com,you@example.com]: admin@edgewoodcoop.com
SMTP server address? [smtp.example.com]: smtp.sparkpostmail.com
SMTP port? [587]:
SMTP user name? [SMTP_Injection]:
SMTP password? []: 623be434ffe94ae86da55b47d9838ee4869d67ee
Let's Encrypt account email? (ENTER to skip) [me@example.com]: admin@edgewoodcoop.com
Does this look right?
Hostname : edgewoodcoop.com
Email : admin@edgewoodcoop.com
SMTP address : smtp.sparkpostmail.com
SMTP port : 587
SMTP username : SMTP_Injection
SMTP password : 623be434ffe94ae86da55b47d9838ee4869d67ee
Let's Encrypt : admin@edgewoodcoop.com
ENTER to continue, 'n' to try again, Ctrl+C to exit:
web.ssl.template.yml enabled
letsencrypt.ssl.template.yml enabled
Configuration file at containers/app.yml updated successfully!
WARNING: We are about to start downloading the Discourse base image
This process may take anywhere between a few minutes to an hour, depending on your network speed
Please be patient
Unable to find image 'discourse/discourse:1.3.7' locally
1.3.7: Pulling from discourse/discourse
7f3a89592205: Pulling fs layer
ec4a109d9ed7: Pulling fs layer
ec4a109d9ed7: Verifying Checksum
ec4a109d9ed7: Download complete
7f3a89592205: Verifying Checksum
7f3a89592205: Download complete
7f3a89592205: Pull complete
ec4a109d9ed7: Pull complete
Digest: sha256:b91429363371b897bdf68e45ae79ef7627cb7c8edf2e7df180188e055d5aae5d
Status: Downloaded newer image for discourse/discourse:1.3.7
cd /pups && git pull && /pups/bin/pups --stdin
Already up-to-date.
I, [2016-11-06T20:00:06.912016 #13] INFO -- : Loading --stdin
I, [2016-11-06T20:00:06.917276 #13] INFO -- : > mkdir -p /shared/postgres_run
I, [2016-11-06T20:00:06.919236 #13] INFO -- :
I, [2016-11-06T20:00:06.919464 #13] INFO -- : > chown postgres:postgres /shared/postgres_run
I, [2016-11-06T20:00:06.921195 #13] INFO -- :
I, [2016-11-06T20:00:06.921355 #13] INFO -- : > chmod 775 /shared/postgres_run
I, [2016-11-06T20:00:06.922549 #13] INFO -- :
I, [2016-11-06T20:00:06.922662 #13] INFO -- : > rm -fr /var/run/postgresql
I, [2016-11-06T20:00:06.923992 #13] INFO -- :
I, [2016-11-06T20:00:06.924105 #13] INFO -- : > ln -s /shared/postgres_run /var/run/postgresql
I, [2016-11-06T20:00:06.925300 #13] INFO -- :
I, [2016-11-06T20:00:06.925416 #13] INFO -- : > socat /dev/null UNIX-CONNECT:/shared/postgres_run/.s.PGSQL.5432 || exit 0 && echo postgres already running stop container ; exit 1
2016/11/06 20:00:06 socat[21] E connect(6, AF=1 "/shared/postgres_run/.s.PGSQL.5432", 36): No such file or directory
I, [2016-11-06T20:00:06.928015 #13] INFO -- :
I, [2016-11-06T20:00:06.928168 #13] INFO -- : > rm -fr /shared/postgres_run/.s*
I, [2016-11-06T20:00:06.929946 #13] INFO -- :
I, [2016-11-06T20:00:06.930072 #13] INFO -- : > rm -fr /shared/postgres_run/*.pid
I, [2016-11-06T20:00:06.931843 #13] INFO -- :
I, [2016-11-06T20:00:06.931965 #13] INFO -- : > mkdir -p /shared/postgres_run/9.5-main.pg_stat_tmp
I, [2016-11-06T20:00:06.933362 #13] INFO -- :
I, [2016-11-06T20:00:06.933482 #13] INFO -- : > chown postgres:postgres /shared/postgres_run/9.5-main.pg_stat_tmp
I, [2016-11-06T20:00:06.934979 #13] INFO -- :
I, [2016-11-06T20:00:06.937843 #13] INFO -- : File > /etc/service/postgres/run chmod: +x
I, [2016-11-06T20:00:06.940626 #13] INFO -- : File > /etc/runit/3.d/99-postgres chmod: +x
I, [2016-11-06T20:00:06.943360 #13] INFO -- : File > /root/upgrade_postgres chmod: +x
I, [2016-11-06T20:00:06.943578 #13] INFO -- : > chown -R root /var/lib/postgresql/9.5/main
I, [2016-11-06T20:00:07.015529 #13] INFO -- :
I, [2016-11-06T20:00:07.015657 #13] INFO -- : > [ ! -e /shared/postgres_data ] && install -d -m 0755 -o postgres -g postgres /shared/postgres_data && sudo -E -u postgres /usr/lib/postgresql/9.5/bin/initdb -D /shared/postgres_data || exit 0
WARNING: enabling "trust" authentication for local connections
You can change this by editing pg_hba.conf or using the option -A, or
--auth-local and --auth-host, the next time you run initdb.
I, [2016-11-06T20:00:10.183211 #13] INFO -- : The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.
The database cluster will be initialized with locale "en_US.UTF-8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".
Data page checksums are disabled.
fixing permissions on existing directory /shared/postgres_data ... ok
creating subdirectories ... ok
selecting default max_connections ... 100
selecting default shared_buffers ... 128MB
selecting dynamic shared memory implementation ... posix
creating configuration files ... ok
creating template1 database in /shared/postgres_data/base/1 ... ok
initializing pg_authid ... ok
initializing dependencies ... ok
creating system views ... ok
loading system objects' descriptions ... ok
creating collations ... ok
creating conversions ... ok
creating dictionaries ... ok
setting privileges on built-in objects ... ok
creating information schema ... ok
loading PL/pgSQL server-side language ... ok
vacuuming database template1 ... ok
copying template1 to template0 ... ok
copying template1 to postgres ... ok
syncing data to disk ... ok
Success. You can now start the database server using:
/usr/lib/postgresql/9.5/bin/pg_ctl -D /shared/postgres_data -l logfile start
I, [2016-11-06T20:00:10.183341 #13] INFO -- : > chown -R postgres:postgres /shared/postgres_data
I, [2016-11-06T20:00:10.187664 #13] INFO -- :
I, [2016-11-06T20:00:10.187745 #13] INFO -- : > chown -R postgres:postgres /var/run/postgresql
I, [2016-11-06T20:00:10.189417 #13] INFO -- :
I, [2016-11-06T20:00:10.189639 #13] INFO -- : > /root/upgrade_postgres
I, [2016-11-06T20:00:10.192830 #13] INFO -- :
I, [2016-11-06T20:00:10.192970 #13] INFO -- : > rm /root/upgrade_postgres
I, [2016-11-06T20:00:10.194196 #13] INFO -- :
I, [2016-11-06T20:00:10.194449 #13] INFO -- : Replacing data_directory = '/var/lib/postgresql/9.5/main' with data_directory = '/shared/postgres_data' in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.194954 #13] INFO -- : Replacing (?-mix:#?listen_addresses *=.*) with listen_addresses = '*' in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.195861 #13] INFO -- : Replacing (?-mix:#?synchronous_commit *=.*) with synchronous_commit = $db_synchronous_commit in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.196775 #13] INFO -- : Replacing (?-mix:#?shared_buffers *=.*) with shared_buffers = $db_shared_buffers in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.197590 #13] INFO -- : Replacing (?-mix:#?work_mem *=.*) with work_mem = $db_work_mem in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.198462 #13] INFO -- : Replacing (?-mix:#?default_text_search_config *=.*) with default_text_search_config = '$db_default_text_search_config' in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.199395 #13] INFO -- : > install -d -m 0755 -o postgres -g postgres /shared/postgres_backup
I, [2016-11-06T20:00:10.201482 #13] INFO -- :
I, [2016-11-06T20:00:10.201723 #13] INFO -- : Replacing (?-mix:#?max_wal_senders *=.*) with max_wal_senders = $db_max_wal_senders in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.202049 #13] INFO -- : Replacing (?-mix:#?wal_level *=.*) with wal_level = $db_wal_level in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.202964 #13] INFO -- : Replacing (?-mix:#?checkpoint_segments *=.*) with checkpoint_segments = $db_checkpoint_segments in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.203825 #13] INFO -- : Replacing (?-mix:#?logging_collector *=.*) with logging_collector = $db_logging_collector in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.204730 #13] INFO -- : Replacing (?-mix:#?log_min_duration_statement *=.*) with log_min_duration_statement = $db_log_min_duration_statement in /etc/postgresql/9.5/main/postgresql.conf
I, [2016-11-06T20:00:10.205878 #13] INFO -- : Replacing (?-mix:^#local +replication +postgres +peer$) with local replication postgres peer in /etc/postgresql/9.5/main/pg_hba.conf
I, [2016-11-06T20:00:10.206135 #13] INFO -- : Replacing (?-mix:^host.*all.*all.*127.*$) with host all all 0.0.0.0/0 md5 in /etc/postgresql/9.5/main/pg_hba.conf
I, [2016-11-06T20:00:10.206768 #13] INFO -- : > HOME=/var/lib/postgresql USER=postgres exec chpst -u postgres:postgres:ssl-cert -U postgres:postgres:ssl-cert /usr/lib/postgresql/9.5/bin/postmaster -D /etc/postgresql/9.5/main
I, [2016-11-06T20:00:10.207835 #13] INFO -- : > sleep 5
2016-11-06 20:00:10 UTC [86-1] LOG: database system was shut down at 2016-11-06 20:00:08 UTC
2016-11-06 20:00:10 UTC [86-2] LOG: MultiXact member wraparound protections are now enabled
2016-11-06 20:00:10 UTC [83-1] LOG: database system is ready to accept connections
2016-11-06 20:00:10 UTC [90-1] LOG: autovacuum launcher started
I, [2016-11-06T20:00:15.209401 #13] INFO -- :
I, [2016-11-06T20:00:15.209629 #13] INFO -- : > su postgres -c 'createdb discourse' || true
2016-11-06 20:00:15 UTC [95-1] postgres@postgres LOG: duration: 370.297 ms statement: CREATE DATABASE discourse;
I, [2016-11-06T20:00:15.626208 #13] INFO -- :
I, [2016-11-06T20:00:15.626446 #13] INFO -- : > su postgres -c 'psql discourse -c "create user discourse;"' || true
I, [2016-11-06T20:00:15.678309 #13] INFO -- : CREATE ROLE
I, [2016-11-06T20:00:15.678768 #13] INFO -- : > su postgres -c 'psql discourse -c "grant all privileges on database discourse to discourse;"' || true
I, [2016-11-06T20:00:15.728213 #13] INFO -- : GRANT
I, [2016-11-06T20:00:15.728787 #13] INFO -- : > su postgres -c 'psql discourse -c "alter schema public owner to discourse;"'
I, [2016-11-06T20:00:15.784568 #13] INFO -- : ALTER SCHEMA
I, [2016-11-06T20:00:15.784747 #13] INFO -- : > su postgres -c 'psql template1 -c "create extension if not exists hstore;"'
I, [2016-11-06T20:00:15.849271 #13] INFO -- : CREATE EXTENSION
I, [2016-11-06T20:00:15.849601 #13] INFO -- : > su postgres -c 'psql template1 -c "create extension if not exists pg_trgm;"'
I, [2016-11-06T20:00:15.904133 #13] INFO -- : CREATE EXTENSION
I, [2016-11-06T20:00:15.904494 #13] INFO -- : > su postgres -c 'psql discourse -c "create extension if not exists hstore;"'
I, [2016-11-06T20:00:15.966664 #13] INFO -- : CREATE EXTENSION
I, [2016-11-06T20:00:15.967004 #13] INFO -- : > su postgres -c 'psql discourse -c "create extension if not exists pg_trgm;"'
I, [2016-11-06T20:00:16.021111 #13] INFO -- : CREATE EXTENSION
I, [2016-11-06T20:00:16.021494 #13] INFO -- : > sudo -u postgres psql discourse
I, [2016-11-06T20:00:16.022780 #13] INFO -- : update pg_database set encoding = pg_char_to_encoding('UTF8') where datname = 'discourse' AND encoding = pg_char_to_encoding('SQL_ASCII');
I, [2016-11-06T20:00:16.073768 #13] INFO -- : File > /var/lib/postgresql/take-database-backup chmod: +x
I, [2016-11-06T20:00:16.075625 #13] INFO -- : File > /var/spool/cron/crontabs/postgres chmod:
I, [2016-11-06T20:00:16.075736 #13] INFO -- : > echo postgres installed!
I, [2016-11-06T20:00:16.076933 #13] INFO -- : postgres installed!
I, [2016-11-06T20:00:16.079709 #13] INFO -- : File > /etc/service/redis/run chmod: +x
I, [2016-11-06T20:00:16.082524 #13] INFO -- : File > /etc/runit/3.d/10-redis chmod: +x
I, [2016-11-06T20:00:16.082695 #13] INFO -- : Replacing daemonize yes with in /etc/redis/redis.conf
I, [2016-11-06T20:00:16.083152 #13] INFO -- : Replacing (?-mix:^pidfile.*$) with in /etc/redis/redis.conf
I, [2016-11-06T20:00:16.087275 #13] INFO -- : > install -d -m 0755 -o redis -g redis /shared/redis_data
I, [2016-11-06T20:00:16.089218 #13] INFO -- :
I, [2016-11-06T20:00:16.089441 #13] INFO -- : Replacing (?-mix:^logfile.*$) with logfile "" in /etc/redis/redis.conf
I, [2016-11-06T20:00:16.089865 #13] INFO -- : Replacing (?-mix:^bind .*$) with in /etc/redis/redis.conf
I, [2016-11-06T20:00:16.090839 #13] INFO -- : Replacing (?-mix:^dir .*$) with dir /shared/redis_data in /etc/redis/redis.conf
I, [2016-11-06T20:00:16.092084 #13] INFO -- : > echo redis installed
I, [2016-11-06T20:00:16.093507 #13] INFO -- : redis installed
I, [2016-11-06T20:00:16.093628 #13] INFO -- : > cat /etc/redis/redis.conf | grep logfile
I, [2016-11-06T20:00:16.096364 #13] INFO -- : logfile ""
I, [2016-11-06T20:00:16.096494 #13] INFO -- : > exec chpst -u redis -U redis /usr/bin/redis-server /etc/redis/redis.conf
I, [2016-11-06T20:00:16.097482 #13] INFO -- : > sleep 10
_._
_.-``__ ''-._
_.-`` `. `_. ''-._ Redis 3.0.6 (00000000/0) 64 bit
.-`` .-```. ```\/ _.,_ ''-._
( ' , .-` | `, ) Running in standalone mode
|`-._`-...-` __...-.``-._|'` _.-'| Port: 6379
| `-._ `._ / _.-' | PID: 196
`-._ `-._ `-./ _.-' _.-'
|`-._`-._ `-.__.-' _.-'_.-'|
| `-._`-._ _.-'_.-' | http://redis.io
`-._ `-._`-.__.-'_.-' _.-'
|`-._`-._ `-.__.-' _.-'_.-'|
| `-._`-._ _.-'_.-' |
`-._ `-._`-.__.-'_.-' _.-'
`-._ `-.__.-' _.-'
`-._ _.-'
`-.__.-'
196:M 06 Nov 20:00:16.101 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
196:M 06 Nov 20:00:16.101 # Server started, Redis version 3.0.6
196:M 06 Nov 20:00:16.101 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
196:M 06 Nov 20:00:16.101 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
196:M 06 Nov 20:00:16.101 * The server is now ready to accept connections on port 6379
I, [2016-11-06T20:00:26.098895 #13] INFO -- :
I, [2016-11-06T20:00:26.099165 #13] INFO -- : Replacing <policymap> with <policymap>
<policy domain="coder" rights="none" pattern="EPHEMERAL" />
<policy domain="coder" rights="none" pattern="URL" />
<policy domain="coder" rights="none" pattern="HTTPS" />
<policy domain="coder" rights="none" pattern="MVG" />
<policy domain="coder" rights="none" pattern="MSL" />
<policy domain="coder" rights="none" pattern="TEXT" />
<policy domain="coder" rights="none" pattern="SHOW" />
<policy domain="coder" rights="none" pattern="WIN" />
<policy domain="coder" rights="none" pattern="PLT" />
in /usr/local/etc/ImageMagick-6/policy.xml
I, [2016-11-06T20:00:26.099572 #13] INFO -- : > /usr/local/bin/ruby -e 'if ENV["DISCOURSE_SMTP_ADDRESS"] == "smtp.example.com"; puts "Aborting! Mail is not configured!"; exit 1; end'
I, [2016-11-06T20:00:26.145655 #13] INFO -- :
I, [2016-11-06T20:00:26.145839 #13] INFO -- : > /usr/local/bin/ruby -e 'if ENV["DISCOURSE_HOSTNAME"] == "discourse.example.com"; puts "Aborting! Domain is not configured!"; exit 1; end'
I, [2016-11-06T20:00:26.191430 #13] INFO -- :
I, [2016-11-06T20:00:26.191602 #13] INFO -- : > chown -R discourse /home/discourse
I, [2016-11-06T20:00:26.193683 #13] INFO -- :
I, [2016-11-06T20:00:26.193818 #13] INFO -- : > rm -f /etc/cron.d/anacron
I, [2016-11-06T20:00:26.195189 #13] INFO -- :
I, [2016-11-06T20:00:26.196868 #13] INFO -- : File > /etc/cron.d/anacron chmod:
I, [2016-11-06T20:00:26.199752 #13] INFO -- : File > /etc/runit/1.d/copy-env chmod: +x
I, [2016-11-06T20:00:26.202523 #13] INFO -- : File > /etc/runit/1.d/00-fix-log-permissions chmod: +x
I, [2016-11-06T20:00:26.205283 #13] INFO -- : File > /etc/runit/1.d/enable-brotli chmod: +x
I, [2016-11-06T20:00:26.208064 #13] INFO -- : File > /etc/service/unicorn/run chmod: +x
I, [2016-11-06T20:00:26.210861 #13] INFO -- : File > /etc/service/nginx/run chmod: +x
I, [2016-11-06T20:00:26.213566 #13] INFO -- : File > /etc/runit/3.d/01-nginx chmod: +x
I, [2016-11-06T20:00:26.216363 #13] INFO -- : File > /etc/runit/3.d/02-unicorn chmod: +x
I, [2016-11-06T20:00:26.216467 #13] INFO -- : Replacing # postgres with sv start postgres || exit 1 in /etc/service/unicorn/run
I, [2016-11-06T20:00:26.216747 #13] INFO -- : > exec chpst -u redis -U redis /usr/bin/redis-server /etc/redis/redis.conf
I, [2016-11-06T20:00:26.218090 #13] INFO -- : > cd /var/www/discourse && git reset --hard
224:M 06 Nov 20:00:26.221 # Creating Server TCP listening socket *:6379: bind: Address already in use
Checking out files: 100% (10773/10773), done.
I, [2016-11-06T20:00:27.861801 #13] INFO -- : HEAD is now at 407cda1 FIX: Scrolling on backup logs
I, [2016-11-06T20:00:27.861915 #13] INFO -- : > cd /var/www/discourse && git clean -f
I, [2016-11-06T20:00:27.893036 #13] INFO -- :
I, [2016-11-06T20:00:27.893153 #13] INFO -- : > cd /var/www/discourse && git remote set-branches --add origin master
I, [2016-11-06T20:00:27.896015 #13] INFO -- :
I, [2016-11-06T20:00:27.896085 #13] INFO -- : > cd /var/www/discourse && git pull
From https://github.com/discourse/discourse
407cda1..b032ed4 master -> origin/master
e6047f2..ad7dbae beta -> origin/beta
2bce183..d5ba32a stable -> origin/stable
407cda1..b032ed4 tests-passed -> origin/tests-passed
* [new tag] v1.6.6 -> v1.6.6
* [new tag] v1.6.5 -> v1.6.5
* [new tag] v1.7.0.beta7 -> v1.7.0.beta7
I, [2016-11-06T20:00:33.649908 #13] INFO -- : Updating 407cda1..b032ed4
Fast-forward
.gitignore | 4 +-
Gemfile | 3 +-
Gemfile.lock | 21 +-
.../admin/controllers/admin-site-text-index.js.es6 | 35 +-
.../admin/routes/admin-route-map.js.es6 | 50 +-
app/assets/javascripts/deprecated.js | 24 -
.../discourse-common/components/combo-box.js.es6 | 6 +-
.../discourse-common/lib/helpers.js.es6 | 6 +-
.../javascripts/discourse-common/resolver.js.es6 | 11 +-
app/assets/javascripts/discourse.js.es6 | 22 +-
.../components/color-picker-choice.js.es6 | 27 +
.../discourse/components/color-picker.js.es6 | 33 +-
.../discourse/components/composer-messages.js.es6 | 2 +-
.../discourse/components/d-button.js.es6 | 3 +
.../discourse/components/d-checkbox.js.es6 | 15 +-
.../discourse/components/d-editor.js.es6 | 23 +-
.../components/edit-category-settings.js.es6 | 18 +
.../discourse/components/edit-category-tab.js.es6 | 7 +-
.../discourse/components/image-uploader.js.es6 | 2 +-
.../discourse/components/login-reply-button.js.es6 | 7 +
.../components/search-advanced-options.js.es6 | 29 +-
.../discourse/components/toggle-deleted.js.es6 | 12 -
.../components/topic-footer-buttons.js.es6 | 50 +-
.../components/topic-footer-mobile-dropdown.js.es6 | 2 +-
.../discourse/components/topic-navigation.js.es6 | 12 +-
.../javascripts/discourse/controllers/topic.js.es6 | 95 ++--
.../discourse/controllers/user-card.js.es6 | 4 +-
.../javascripts/discourse/controllers/user.js.es6 | 5 +
.../javascripts/discourse/helpers/as-hash.js.es6 | 12 +-
.../discourse/helpers/custom-html.js.es6 | 4 +-
.../discourse/helpers/inline-date.js.es6 | 8 +-
.../discourse/helpers/plugin-outlet.js.es6 | 39 +-
.../discourse/initializers/mobile.js.es6 | 6 +-
.../javascripts/discourse/lib/computed.js.es6 | 31 +-
.../javascripts/discourse/mapping-router.js.es6 | 4 +-
.../discourse/mixins/delegated-actions.js.es6 | 16 +
.../javascripts/discourse/models/admin-post.js.es6 | 2 +-
.../javascripts/discourse/models/category.js.es6 | 4 +-
.../javascripts/discourse/models/composer.js.es6 | 3 +-
.../discourse/models/post-stream.js.es6 | 12 +-
.../javascripts/discourse/models/topic.js.es6 | 1 -
.../discourse/models/user-action.js.es6 | 6 +-
.../javascripts/discourse/models/user.js.es6 | 6 +-
.../inject-discourse-objects.js.es6 | 8 -
.../discourse/routes/app-route-map.js.es6 | 32 +-
.../javascripts/discourse/routes/tags-show.js.es6 | 10 -
.../javascripts/discourse/routes/topic.js.es6 | 5 +-
.../discourse/templates/application.hbs | 2 +
.../templates/components/color-picker.hbs | 1 +
.../discourse/templates/components/d-button.hbs | 5 +-
.../discourse/templates/components/d-checkbox.hbs | 2 +-
.../components/edit-category-settings.hbs | 10 +
.../components/search-advanced-options.hbs | 2 +-
.../templates/components/toggle-deleted.hbs | 7 -
.../templates/components/topic-footer-buttons.hbs | 60 +++
.../templates/mobile/discovery/categories.hbs | 2 +-
.../javascripts/discourse/templates/topic.hbs | 6 +-
.../javascripts/discourse/templates/user.hbs | 3 +-
.../discourse/views/archive-button.js.es6 | 35 --
.../discourse/views/bookmark-button.js.es6 | 28 --
.../javascripts/discourse/views/container.js.es6 | 16 -
.../discourse/views/flag-topic-button.js.es6 | 16 -
.../discourse/views/invite-reply-button.js.es6 | 18 -
.../discourse/views/login-reply-button.js.es6 | 12 -
.../javascripts/discourse/views/modal-body.js.es6 | 6 +-
.../discourse/views/reply-button.js.es6 | 23 -
.../discourse/views/share-button.js.es6 | 14 -
.../views/topic-footer-main-buttons.js.es6 | 47 +-
app/assets/javascripts/discourse/views/user.js.es6 | 3 +-
.../discourse/widgets/search-menu.js.es6 | 2 +-
.../discourse/widgets/topic-timeline.js.es6 | 53 +-
.../javascripts/discourse/widgets/widget.js.es6 | 9 +-
app/assets/javascripts/ember-addons/fmt.js.es6 | 24 +
app/assets/javascripts/main_include.js | 3 +-
.../pretty-text/engines/discourse-markdown.js.es6 | 2 +-
.../wizard/test/helpers/component-test.js.es6 | 2 +-
.../wizard/test/helpers/start-app.js.es6 | 2 +-
app/assets/javascripts/wizard/wizard.js.es6 | 2 +-
app/assets/stylesheets/common/topic-timeline.scss | 90 +++-
app/assets/stylesheets/desktop/topic-post.scss | 5 +
app/assets/stylesheets/mobile/topic.scss | 6 +
app/assets/stylesheets/wizard.scss | 10 +
app/controllers/categories_controller.rb | 2 +
app/controllers/posts_controller.rb | 2 +-
app/controllers/tags_controller.rb | 18 +-
app/controllers/webhooks_controller.rb | 2 +-
app/jobs/regular/emit_web_hook_event.rb | 1 +
app/jobs/scheduled/clean_up_uploads.rb | 30 +-
app/models/category.rb | 2 +
app/models/color_scheme.rb | 2 +
app/models/directory_item.rb | 7 +
app/models/embeddable_host.rb | 11 +-
app/models/facebook_user_info.rb | 4 +
app/models/group.rb | 3 +
app/models/invite.rb | 1 +
app/models/post.rb | 1 +
app/models/single_sign_on_record.rb | 2 +-
app/models/tag.rb | 13 +-
app/models/user_api_key.rb | 7 +-
app/models/web_hook.rb | 1 +
app/models/web_hook_event.rb | 2 +-
app/serializers/basic_category_serializer.rb | 4 +-
config/locales/client.de.yml | 2 +-
config/locales/client.en.yml | 13 +
config/locales/client.et.yml | 63 ++-
config/locales/client.fi.yml | 7 +-
config/locales/client.fr.yml | 14 +
config/locales/client.he.yml | 16 +-
config/locales/client.pt.yml | 550 +++++++++++++++++----
config/locales/client.ro.yml | 16 +-
config/locales/client.ru.yml | 221 +++++++--
config/locales/server.ar.yml | 2 -
config/locales/server.bs_BA.yml | 5 -
config/locales/server.cs.yml | 1 -
config/locales/server.da.yml | 10 +-
config/locales/server.de.yml | 5 -
config/locales/server.en.yml | 2 +-
config/locales/server.es.yml | 2 -
config/locales/server.et.yml | 37 +-
config/locales/server.fa_IR.yml | 2 -
config/locales/server.fi.yml | 16 +-
config/locales/server.fr.yml | 11 +-
config/locales/server.he.yml | 17 +-
config/locales/server.it.yml | 2 -
config/locales/server.ja.yml | 2 -
config/locales/server.ko.yml | 2 -
config/locales/server.nl.yml | 2 -
config/locales/server.pl_PL.yml | 2 -
config/locales/server.pt.yml | 83 ++--
config/locales/server.pt_BR.yml | 2 -
config/locales/server.ro.yml | 152 +++++-
config/locales/server.ru.yml | 2 -
config/locales/server.sk.yml | 2 -
config/locales/server.sq.yml | 4 +-
config/locales/server.sv.yml | 2 -
config/locales/server.tr_TR.yml | 11 +-
config/locales/server.uk.yml | 1 -
config/locales/server.vi.yml | 2 -
config/locales/server.zh_CN.yml | 2 -
config/locales/server.zh_TW.yml | 2 -
.../20161029181306_add_image_url_to_posts.rb | 5 +
...20161031183811_add_sort_fields_to_categories.rb | 6 +
.../20161102024700_add_post_uploads_indexes.rb | 6 +
...024818_add_uploaded_avatar_id_index_to_users.rb | 5 +
.../20161102024838_add_user_avatars_indexes.rb | 6 +
.../20161102024900_add_user_profiles_indexes.rb | 6 +
.../20161102024920_add_categories_indexes.rb | 6 +
lib/composer_messages_finder.rb | 4 +-
lib/cooked_post_processor.rb | 17 +-
lib/discourse.rb | 3 +
lib/email/sender.rb | 19 +-
.../tilt/es6_module_transpiler_template.rb | 4 +
lib/js_locale_helper.rb | 4 +
lib/onebox/engine/discourse_local_onebox.rb | 134 ++---
lib/onebox/templates/discourse_topic_onebox.hbs | 6 +-
lib/oneboxer.rb | 4 +-
lib/topic_query.rb | 9 +
lib/topic_view.rb | 8 +-
lib/version.rb | 2 +-
lib/wizard.rb | 8 +-
.../config/locales/server.ar.yml | 2 +-
.../assets/javascripts/initializers/lazyYT.js.es6 | 33 +-
.../assets/javascripts/jquery.iframetracker.js | 165 +++++++
plugins/lazyYT/plugin.rb | 1 +
.../poll/assets/javascripts/lib/even-round.js.es6 | 28 +-
plugins/poll/config/locales/client.pt.yml | 22 +-
plugins/poll/config/locales/server.pt.yml | 47 +-
script/check_forking.rb | 31 ++
script/import_scripts/mylittleforum.rb | 453 +++++++++++++++++
spec/components/composer_messages_finder_spec.rb | 20 +
spec/components/cooked_post_processor_spec.rb | 15 +-
spec/components/email/sender_spec.rb | 20 +
.../onebox/engine/discourse_local_onebox_spec.rb | 78 +--
spec/components/topic_query_spec.rb | 20 +
spec/controllers/tags_controller_spec.rb | 13 +
spec/controllers/webhooks_controller_spec.rb | 4 +-
spec/jobs/clean_up_uploads_spec.rb | 10 +
spec/models/tag_spec.rb | 12 +-
.../javascripts/acceptance/search-full-test.js.es6 | 10 +-
test/javascripts/ember/resolver-test.js.es6 | 4 +-
test/javascripts/helpers/component-test.js.es6 | 2 +-
test/javascripts/lib/pretty-text-test.js.es6 | 9 +
test/javascripts/models/post-stream-test.js.es6 | 15 +-
test/javascripts/views/container-view-test.js.es6 | 83 ----
184 files changed, 2763 insertions(+), 1263 deletions(-)
create mode 100644 app/assets/javascripts/discourse/components/color-picker-choice.js.es6
create mode 100644 app/assets/javascripts/discourse/components/login-reply-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/components/toggle-deleted.js.es6
create mode 100644 app/assets/javascripts/discourse/mixins/delegated-actions.js.es6
create mode 100644 app/assets/javascripts/discourse/templates/components/color-picker.hbs
delete mode 100644 app/assets/javascripts/discourse/templates/components/toggle-deleted.hbs
create mode 100644 app/assets/javascripts/discourse/templates/components/topic-footer-buttons.hbs
delete mode 100644 app/assets/javascripts/discourse/views/archive-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/bookmark-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/container.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/flag-topic-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/invite-reply-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/login-reply-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/reply-button.js.es6
delete mode 100644 app/assets/javascripts/discourse/views/share-button.js.es6
create mode 100644 app/assets/javascripts/ember-addons/fmt.js.es6
create mode 100644 db/migrate/20161029181306_add_image_url_to_posts.rb
create mode 100644 db/migrate/20161031183811_add_sort_fields_to_categories.rb
create mode 100644 db/migrate/20161102024700_add_post_uploads_indexes.rb
create mode 100644 db/migrate/20161102024818_add_uploaded_avatar_id_index_to_users.rb
create mode 100644 db/migrate/20161102024838_add_user_avatars_indexes.rb
create mode 100644 db/migrate/20161102024900_add_user_profiles_indexes.rb
create mode 100644 db/migrate/20161102024920_add_categories_indexes.rb
create mode 100644 plugins/lazyYT/assets/javascripts/jquery.iframetracker.js
create mode 100644 script/check_forking.rb
create mode 100644 script/import_scripts/mylittleforum.rb
delete mode 100644 test/javascripts/views/container-view-test.js.es6
I, [2016-11-06T20:00:33.650040 #13] INFO -- : > cd /var/www/discourse && git fetch origin tests-passed
From https://github.com/discourse/discourse
* branch tests-passed -> FETCH_HEAD
I, [2016-11-06T20:00:33.852093 #13] INFO -- :
I, [2016-11-06T20:00:33.852205 #13] INFO -- : > cd /var/www/discourse && git checkout tests-passed
Switched to a new branch 'tests-passed'
I, [2016-11-06T20:00:33.978313 #13] INFO -- : Branch tests-passed set up to track remote branch tests-passed from origin.
I, [2016-11-06T20:00:33.978423 #13] INFO -- : > cd /var/www/discourse && mkdir -p tmp/pids
I, [2016-11-06T20:00:33.980785 #13] INFO -- :
I, [2016-11-06T20:00:33.980854 #13] INFO -- : > cd /var/www/discourse && mkdir -p tmp/sockets
I, [2016-11-06T20:00:33.982930 #13] INFO -- :
I, [2016-11-06T20:00:33.982998 #13] INFO -- : > cd /var/www/discourse && touch tmp/.gitkeep
I, [2016-11-06T20:00:33.984871 #13] INFO -- :
I, [2016-11-06T20:00:33.984937 #13] INFO -- : > cd /var/www/discourse && mkdir -p /shared/log/rails
I, [2016-11-06T20:00:33.986883 #13] INFO -- :
I, [2016-11-06T20:00:33.986971 #13] INFO -- : > cd /var/www/discourse && bash -c "touch -a /shared/log/rails/{production,production_errors,unicorn.stdout,unicorn.stderr}.log"
I, [2016-11-06T20:00:33.989921 #13] INFO -- :
I, [2016-11-06T20:00:33.989996 #13] INFO -- : > cd /var/www/discourse && bash -c "ln -s /shared/log/rails/{production,production_errors,unicorn.stdout,unicorn.stderr}.log /var/www/discourse/log"
I, [2016-11-06T20:00:33.993147 #13] INFO -- :
I, [2016-11-06T20:00:33.993218 #13] INFO -- : > cd /var/www/discourse && bash -c "mkdir -p /shared/{uploads,backups}"
I, [2016-11-06T20:00:33.996427 #13] INFO -- :
I, [2016-11-06T20:00:33.996500 #13] INFO -- : > cd /var/www/discourse && bash -c "ln -s /shared/{uploads,backups} /var/www/discourse/public"
I, [2016-11-06T20:00:33.999595 #13] INFO -- :
I, [2016-11-06T20:00:33.999669 #13] INFO -- : > cd /var/www/discourse && chown -R discourse:www-data /shared/log/rails /shared/uploads /shared/backups
I, [2016-11-06T20:00:34.002235 #13] INFO -- :
I, [2016-11-06T20:00:34.002358 #13] INFO -- : Replacing # redis with sv start redis || exit 1 in /etc/service/unicorn/run
I, [2016-11-06T20:00:34.002741 #13] INFO -- : > cd /var/www/discourse/plugins && git clone https://github.com/discourse/docker_manager.git
Cloning into 'docker_manager'...
I, [2016-11-06T20:00:35.050016 #13] INFO -- :
I, [2016-11-06T20:00:35.050278 #13] INFO -- : > cp /var/www/discourse/config/nginx.sample.conf /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:00:35.052409 #13] INFO -- :
I, [2016-11-06T20:00:35.052559 #13] INFO -- : > rm /etc/nginx/sites-enabled/default
I, [2016-11-06T20:00:35.053866 #13] INFO -- :
I, [2016-11-06T20:00:35.053961 #13] INFO -- : > mkdir -p /var/nginx/cache
I, [2016-11-06T20:00:35.055708 #13] INFO -- :
I, [2016-11-06T20:00:35.055927 #13] INFO -- : Replacing pid /run/nginx.pid; with daemon off; in /etc/nginx/nginx.conf
I, [2016-11-06T20:00:35.056250 #13] INFO -- : Replacing (?m-ix:upstream[^\}]+\}) with upstream discourse { server 127.0.0.1:3000; } in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:00:35.056525 #13] INFO -- : Replacing (?-mix:server_name.+$) with server_name _ ; in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:00:35.057304 #13] INFO -- : Replacing (?-mix:client_max_body_size.+$) with client_max_body_size $upload_size ; in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:00:35.058126 #13] INFO -- : > echo "done configuring web"
I, [2016-11-06T20:00:35.059470 #13] INFO -- : done configuring web
I, [2016-11-06T20:00:35.059705 #13] INFO -- : > cd /var/www/discourse && gem update bundler
I, [2016-11-06T20:00:37.801797 #13] INFO -- : Updating installed gems
Nothing to update
I, [2016-11-06T20:00:37.801921 #13] INFO -- : > cd /var/www/discourse && chown -R discourse /var/www/discourse
I, [2016-11-06T20:00:39.024204 #13] INFO -- :
I, [2016-11-06T20:00:39.024491 #13] INFO -- : > cd /var/www/discourse && su discourse -c 'bundle install --deployment --verbose --without test --without development'
I, [2016-11-06T20:01:17.293181 #13] INFO -- : Running `bundle install --deployment --verbose --without "development"` with bundler 1.13.6
Found no changes, using resolution from the lockfile
HTTP GET https://index.rubygems.org/versions
HTTP 200 OK https://index.rubygems.org/versions
Fetching gem metadata from https://rubygems.org/
Looking up gems ["rake", "i18n", "json", "minitest", "thread_safe", "tzinfo", "activesupport", "builder", "erubis", "mini_portile2", "nokogiri", "rails-deprecated_sanitizer", "rails-dom-testing", "loofah", "rails-html-sanitizer", "actionview", "rack", "rack-test", "actionpack", "globalid", "activejob", "mime-types", "mail", "actionmailer", "activemodel", "active_model_serializers", "arel", "activerecord", "jmespath", "aws-sdk-core", "aws-sdk-resources", "aws-sdk", "babel-source", "execjs", "babel-transpiler", "ember-source", "barber", "byebug", "certified", "coderay", "concurrent-ruby", "connection_pool", "crass", "daemons", "diff-lcs", "thor", "railties", "discourse-qunit-rails", "discourse_fastimage", "docile", "unf_ext", "unf", "domain_name", "email_reply_trimmer", "ember-data-source", "sprockets", "ember-handlebars-template", "jquery-rails", "ember-rails", "eventmachine", "excon", "exifr", "fabrication", "fakeweb", "multipart-post", "faraday", "fast_blank", "rake-compiler", "fast_xor", "fast_xs", "ffi", "flamegraph", "fspath", "sorcerer", "given_core", "guess_html_encoding", "hashie", "highline", "hiredis", "htmlentities", "http-cookie", "http_accept_language", "image_size", "in_threads", "progress", "image_optim", "jwt", "kgio", "libv8", "listen", "logster", "lru_redux", "memory_profiler", "message_bus", "metaclass", "method_source", "mini_racer", "mocha", "mock_redis", "moneta", "msgpack", "multi_json", "multi_xml", "mustache", "netrc", "nokogumbo", "oauth", "oauth2", "oj", "omniauth", "omniauth-oauth2", "omniauth-facebook", "omniauth-github-discourse", "omniauth-google-oauth2", "omniauth-instagram", "omniauth-oauth", "ruby-openid", "rack-openid", "omniauth-openid", "omniauth-twitter", "onebox", "redis", "openid-redis-store", "pg", "slop", "pry", "pry-nav", "pry-rails", "puma", "r2", "rack-mini-profiler", "rack-protection", "sprockets-rails", "rails", "rails-observers", "rails_multisite", "raindrops", "rb-fsevent", "rb-inotify", "trollop", "rbtrace", "redis-namespace", "rest-client", "rinku", "rmmseg-cpp", "rspec-support", "rspec-core", "rspec-expectations", "rspec-mocks", "rspec", "rspec-given", "rspec-html-matchers", "rspec-rails", "rtlit", "ruby-readability", "sanitize", "sass", "tilt", "sass-rails", "seed-fu", "shoulda-context", "shoulda-matchers", "shoulda", "sidekiq", "sidekiq-statistic", "simple-rss", "simplecov-html", "simplecov", "sinatra", "spork", "spork-rails", "stackprof", "thin", "timecop", "uglifier", "unicorn"]
HTTP GET https://index.rubygems.org/info/rake
HTTP GET https://index.rubygems.org/info/json
HTTP GET https://index.rubygems.org/info/minitest
HTTP GET https://index.rubygems.org/info/thread_safe
HTTP GET https://index.rubygems.org/info/tzinfo
HTTP GET https://index.rubygems.org/info/activesupport
HTTP GET https://index.rubygems.org/info/builder
HTTP GET https://index.rubygems.org/info/erubis
HTTP GET https://index.rubygems.org/info/mini_portile2
HTTP GET https://index.rubygems.org/info/nokogiri
HTTP GET https://index.rubygems.org/info/rails-deprecated_sanitizer
HTTP GET https://index.rubygems.org/info/rails-dom-testing
HTTP GET https://index.rubygems.org/info/loofah
HTTP GET https://index.rubygems.org/info/rails-html-sanitizer
HTTP GET https://index.rubygems.org/info/actionview
HTTP GET https://index.rubygems.org/info/rack
HTTP GET https://index.rubygems.org/info/rack-test
HTTP GET https://index.rubygems.org/info/actionpack
HTTP GET https://index.rubygems.org/info/globalid
HTTP GET https://index.rubygems.org/info/activejob
HTTP GET https://index.rubygems.org/info/mime-types
HTTP GET https://index.rubygems.org/info/mail
HTTP GET https://index.rubygems.org/info/actionmailer
HTTP GET https://index.rubygems.org/info/activemodel
HTTP GET https://index.rubygems.org/info/i18n
HTTP 200 OK https://index.rubygems.org/info/rake
HTTP 200 OK https://index.rubygems.org/info/builder
HTTP 200 OK https://index.rubygems.org/info/activesupport
HTTP 200 OK https://index.rubygems.org/info/thread_safe
HTTP 200 OK https://index.rubygems.org/info/json
HTTP 200 OK https://index.rubygems.org/info/erubis
HTTP 200 OK https://index.rubygems.org/info/minitest
HTTP 200 OK https://index.rubygems.org/info/tzinfo
HTTP 200 OK https://index.rubygems.org/info/mini_portile2
HTTP 200 OK https://index.rubygems.org/info/nokogiri
HTTP 200 OK https://index.rubygems.org/info/rails-deprecated_sanitizer
HTTP 200 OK https://index.rubygems.org/info/rails-html-sanitizer
HTTP 200 OK https://index.rubygems.org/info/actionview
HTTP 200 OK https://index.rubygems.org/info/rack-test
HTTP 200 OK https://index.rubygems.org/info/loofah
HTTP 200 OK https://index.rubygems.org/info/rack
HTTP 200 OK https://index.rubygems.org/info/rails-dom-testing
HTTP GET https://index.rubygems.org/info/active_model_serializers
HTTP 200 OK https://index.rubygems.org/info/actionpack
HTTP 200 OK https://index.rubygems.org/info/activejob
HTTP 200 OK https://index.rubygems.org/info/mime-types
HTTP GET https://index.rubygems.org/info/arel
HTTP 200 OK https://index.rubygems.org/info/mail
HTTP GET https://index.rubygems.org/info/activerecord
HTTP 200 OK https://index.rubygems.org/info/i18n
HTTP GET https://index.rubygems.org/info/jmespath
HTTP 200 OK https://index.rubygems.org/info/globalid
HTTP GET https://index.rubygems.org/info/aws-sdk-core
HTTP GET https://index.rubygems.org/info/aws-sdk-resources
HTTP 200 OK https://index.rubygems.org/info/activemodel
HTTP GET https://index.rubygems.org/info/aws-sdk
HTTP 200 OK https://index.rubygems.org/info/actionmailer
HTTP GET https://index.rubygems.org/info/babel-source
HTTP GET https://index.rubygems.org/info/execjs
HTTP GET https://index.rubygems.org/info/babel-transpiler
HTTP GET https://index.rubygems.org/info/ember-source
HTTP GET https://index.rubygems.org/info/barber
HTTP GET https://index.rubygems.org/info/byebug
HTTP GET https://index.rubygems.org/info/certified
HTTP 200 OK https://index.rubygems.org/info/active_model_serializers
HTTP GET https://index.rubygems.org/info/coderay
HTTP GET https://index.rubygems.org/info/concurrent-ruby
HTTP GET https://index.rubygems.org/info/connection_pool
HTTP 200 OK https://index.rubygems.org/info/coderay
HTTP 200 OK https://index.rubygems.org/info/arel
HTTP GET https://index.rubygems.org/info/crass
HTTP GET https://index.rubygems.org/info/daemons
HTTP 200 OK https://index.rubygems.org/info/activerecord
HTTP GET https://index.rubygems.org/info/diff-lcs
HTTP GET https://index.rubygems.org/info/thor
HTTP GET https://index.rubygems.org/info/railties
HTTP 200 OK https://index.rubygems.org/info/aws-sdk-core
HTTP 200 OK https://index.rubygems.org/info/aws-sdk-resources
HTTP 200 OK https://index.rubygems.org/info/jmespath
HTTP GET https://index.rubygems.org/info/discourse-qunit-rails
HTTP 200 OK https://index.rubygems.org/info/aws-sdk
HTTP 200 OK https://index.rubygems.org/info/babel-source
HTTP 200 OK https://index.rubygems.org/info/execjs
HTTP 200 OK https://index.rubygems.org/info/babel-transpiler
HTTP GET https://index.rubygems.org/info/discourse_fastimage
HTTP 200 OK https://index.rubygems.org/info/barber
HTTP 200 OK https://index.rubygems.org/info/byebug
HTTP GET https://index.rubygems.org/info/docile
HTTP 200 OK https://index.rubygems.org/info/ember-source
HTTP 200 OK https://index.rubygems.org/info/certified
HTTP GET https://index.rubygems.org/info/unf_ext
HTTP GET https://index.rubygems.org/info/unf
HTTP 200 OK https://index.rubygems.org/info/concurrent-ruby
HTTP 200 OK https://index.rubygems.org/info/docile
HTTP GET https://index.rubygems.org/info/domain_name
HTTP 200 OK https://index.rubygems.org/info/crass
HTTP GET https://index.rubygems.org/info/email_reply_trimmer
HTTP 200 OK https://index.rubygems.org/info/diff-lcs
HTTP 200 OK https://index.rubygems.org/info/daemons
HTTP 200 OK https://index.rubygems.org/info/thor
HTTP GET https://index.rubygems.org/info/ember-data-source
HTTP 200 OK https://index.rubygems.org/info/railties
HTTP GET https://index.rubygems.org/info/sprockets
HTTP GET https://index.rubygems.org/info/ember-handlebars-template
HTTP GET https://index.rubygems.org/info/jquery-rails
HTTP 200 OK https://index.rubygems.org/info/discourse-qunit-rails
HTTP GET https://index.rubygems.org/info/ember-rails
HTTP GET https://index.rubygems.org/info/eventmachine
HTTP GET https://index.rubygems.org/info/excon
HTTP 200 OK https://index.rubygems.org/info/discourse_fastimage
HTTP GET https://index.rubygems.org/info/exifr
HTTP GET https://index.rubygems.org/info/fabrication
HTTP 200 OK https://index.rubygems.org/info/connection_pool
HTTP GET https://index.rubygems.org/info/fakeweb
HTTP GET https://index.rubygems.org/info/multipart-post
HTTP 200 OK https://index.rubygems.org/info/unf
HTTP 200 OK https://index.rubygems.org/info/unf_ext
HTTP GET https://index.rubygems.org/info/faraday
HTTP 200 OK https://index.rubygems.org/info/domain_name
HTTP 200 OK https://index.rubygems.org/info/email_reply_trimmer
HTTP GET https://index.rubygems.org/info/fast_blank
HTTP GET https://index.rubygems.org/info/rake-compiler
HTTP GET https://index.rubygems.org/info/fast_xor
HTTP GET https://index.rubygems.org/info/fast_xs
HTTP GET https://index.rubygems.org/info/ffi
HTTP GET https://index.rubygems.org/info/flamegraph
HTTP 200 OK https://index.rubygems.org/info/ember-data-source
HTTP 200 OK https://index.rubygems.org/info/ember-handlebars-template
HTTP 200 OK https://index.rubygems.org/info/jquery-rails
HTTP 200 OK https://index.rubygems.org/info/sprockets
HTTP 200 OK https://index.rubygems.org/info/ember-rails
HTTP GET https://index.rubygems.org/info/fspath
HTTP 200 OK https://index.rubygems.org/info/eventmachine
HTTP 200 OK https://index.rubygems.org/info/exifr
HTTP 200 OK https://index.rubygems.org/info/fabrication
HTTP GET https://index.rubygems.org/info/sorcerer
HTTP 200 OK https://index.rubygems.org/info/excon
HTTP GET https://index.rubygems.org/info/given_core
HTTP GET https://index.rubygems.org/info/guess_html_encoding
HTTP 200 OK https://index.rubygems.org/info/multipart-post
HTTP 200 OK https://index.rubygems.org/info/fakeweb
HTTP GET https://index.rubygems.org/info/hashie
HTTP GET https://index.rubygems.org/info/highline
HTTP 200 OK https://index.rubygems.org/info/faraday
HTTP GET https://index.rubygems.org/info/hiredis
HTTP 200 OK https://index.rubygems.org/info/fast_blank
HTTP 200 OK https://index.rubygems.org/info/fast_xor
HTTP GET https://index.rubygems.org/info/htmlentities
HTTP 200 OK https://index.rubygems.org/info/flamegraph
HTTP 200 OK https://index.rubygems.org/info/ffi
HTTP 200 OK https://index.rubygems.org/info/fast_xs
HTTP 200 OK https://index.rubygems.org/info/rake-compiler
HTTP GET https://index.rubygems.org/info/http-cookie
HTTP GET https://index.rubygems.org/info/http_accept_language
HTTP GET https://index.rubygems.org/info/image_size
HTTP 200 OK https://index.rubygems.org/info/fspath
HTTP GET https://index.rubygems.org/info/in_threads
HTTP GET https://index.rubygems.org/info/progress
HTTP GET https://index.rubygems.org/info/image_optim
HTTP 200 OK https://index.rubygems.org/info/progress
HTTP 200 OK https://index.rubygems.org/info/sorcerer
HTTP 200 OK https://index.rubygems.org/info/given_core
HTTP 200 OK https://index.rubygems.org/info/guess_html_encoding
HTTP GET https://index.rubygems.org/info/jwt
HTTP 200 OK https://index.rubygems.org/info/hashie
HTTP 200 OK https://index.rubygems.org/info/highline
HTTP 200 OK https://index.rubygems.org/info/hiredis
HTTP GET https://index.rubygems.org/info/kgio
HTTP GET https://index.rubygems.org/info/libv8
HTTP GET https://index.rubygems.org/info/listen
HTTP GET https://index.rubygems.org/info/logster
HTTP 200 OK https://index.rubygems.org/info/htmlentities
HTTP GET https://index.rubygems.org/info/lru_redux
HTTP 200 OK https://index.rubygems.org/info/http-cookie
HTTP 200 OK https://index.rubygems.org/info/http_accept_language
HTTP GET https://index.rubygems.org/info/memory_profiler
HTTP GET https://index.rubygems.org/info/message_bus
HTTP 200 OK https://index.rubygems.org/info/image_size
HTTP GET https://index.rubygems.org/info/metaclass
HTTP 200 OK https://index.rubygems.org/info/in_threads
HTTP GET https://index.rubygems.org/info/method_source
HTTP GET https://index.rubygems.org/info/mini_racer
HTTP 200 OK https://index.rubygems.org/info/image_optim
HTTP GET https://index.rubygems.org/info/mocha
HTTP GET https://index.rubygems.org/info/mock_redis
HTTP GET https://index.rubygems.org/info/moneta
HTTP GET https://index.rubygems.org/info/msgpack
HTTP GET https://index.rubygems.org/info/multi_json
HTTP 200 OK https://index.rubygems.org/info/jwt
HTTP GET https://index.rubygems.org/info/multi_xml
HTTP GET https://index.rubygems.org/info/mustache
HTTP GET https://index.rubygems.org/info/netrc
HTTP 200 OK https://index.rubygems.org/info/listen
HTTP 200 OK https://index.rubygems.org/info/kgio
HTTP 200 OK https://index.rubygems.org/info/libv8
HTTP GET https://index.rubygems.org/info/nokogumbo
HTTP 200 OK https://index.rubygems.org/info/lru_redux
HTTP GET https://index.rubygems.org/info/oauth
HTTP GET https://index.rubygems.org/info/oauth2
HTTP GET https://index.rubygems.org/info/oj
HTTP 200 OK https://index.rubygems.org/info/memory_profiler
HTTP GET https://index.rubygems.org/info/omniauth
HTTP 200 OK https://index.rubygems.org/info/metaclass
HTTP 200 OK https://index.rubygems.org/info/mini_racer
HTTP 200 OK https://index.rubygems.org/info/oj
HTTP 200 OK https://index.rubygems.org/info/moneta
HTTP 200 OK https://index.rubygems.org/info/mock_redis
HTTP GET https://index.rubygems.org/info/omniauth-oauth2
HTTP 200 OK https://index.rubygems.org/info/mocha
HTTP 200 OK https://index.rubygems.org/info/msgpack
HTTP 200 OK https://index.rubygems.org/info/multi_json
HTTP GET https://index.rubygems.org/info/omniauth-facebook
HTTP GET https://index.rubygems.org/info/omniauth-github-discourse
HTTP 200 OK https://index.rubygems.org/info/netrc
HTTP 200 OK https://index.rubygems.org/info/multi_xml
HTTP 200 OK https://index.rubygems.org/info/mustache
HTTP 200 OK https://index.rubygems.org/info/nokogumbo
HTTP GET https://index.rubygems.org/info/omniauth-google-oauth2
HTTP GET https://index.rubygems.org/info/omniauth-instagram
HTTP GET https://index.rubygems.org/info/omniauth-oauth
HTTP 200 OK https://index.rubygems.org/info/oauth
HTTP 200 OK https://index.rubygems.org/info/method_source
HTTP 200 OK https://index.rubygems.org/info/oauth2
HTTP 200 OK https://index.rubygems.org/info/omniauth
HTTP GET https://index.rubygems.org/info/ruby-openid
HTTP GET https://index.rubygems.org/info/rack-openid
HTTP 200 OK https://index.rubygems.org/info/omniauth-oauth
HTTP GET https://index.rubygems.org/info/omniauth-openid
HTTP GET https://index.rubygems.org/info/omniauth-twitter
HTTP GET https://index.rubygems.org/info/onebox
HTTP GET https://index.rubygems.org/info/redis
HTTP 200 OK https://index.rubygems.org/info/omniauth-oauth2
HTTP GET https://index.rubygems.org/info/openid-redis-store
HTTP 200 OK https://index.rubygems.org/info/omniauth-github-discourse
HTTP GET https://index.rubygems.org/info/pg
HTTP GET https://index.rubygems.org/info/slop
HTTP 200 OK https://index.rubygems.org/info/omniauth-facebook
HTTP GET https://index.rubygems.org/info/pry
HTTP GET https://index.rubygems.org/info/pry-nav
HTTP GET https://index.rubygems.org/info/pry-rails
HTTP 200 OK https://index.rubygems.org/info/omniauth-google-oauth2
HTTP GET https://index.rubygems.org/info/puma
HTTP GET https://index.rubygems.org/info/r2
HTTP GET https://index.rubygems.org/info/rack-mini-profiler
HTTP 200 OK https://index.rubygems.org/info/omniauth-instagram
HTTP 200 OK https://index.rubygems.org/info/rack-openid
HTTP GET https://index.rubygems.org/info/rack-protection
HTTP GET https://index.rubygems.org/info/sprockets-rails
HTTP 200 OK https://index.rubygems.org/info/ruby-openid
HTTP GET https://index.rubygems.org/info/rails
HTTP 200 OK https://index.rubygems.org/info/redis
HTTP 200 OK https://index.rubygems.org/info/openid-redis-store
HTTP 200 OK https://index.rubygems.org/info/omniauth-twitter
HTTP GET https://index.rubygems.org/info/rails-observers
HTTP 200 OK https://index.rubygems.org/info/pg
HTTP GET https://index.rubygems.org/info/rails_multisite
HTTP 200 OK https://index.rubygems.org/info/slop
HTTP 200 OK https://index.rubygems.org/info/pry-nav
HTTP 200 OK https://index.rubygems.org/info/pry-rails
HTTP GET https://index.rubygems.org/info/raindrops
HTTP GET https://index.rubygems.org/info/rb-fsevent
HTTP 200 OK https://index.rubygems.org/info/pry
HTTP GET https://index.rubygems.org/info/rb-inotify
HTTP 200 OK https://index.rubygems.org/info/puma
HTTP 200 OK https://index.rubygems.org/info/rack-protection
HTTP GET https://index.rubygems.org/info/trollop
HTTP 200 OK https://index.rubygems.org/info/rack-mini-profiler
HTTP GET https://index.rubygems.org/info/rbtrace
HTTP 200 OK https://index.rubygems.org/info/sprockets-rails
HTTP GET https://index.rubygems.org/info/redis-namespace
HTTP GET https://index.rubygems.org/info/rest-client
HTTP GET https://index.rubygems.org/info/rinku
HTTP 200 OK https://index.rubygems.org/info/rails_multisite
HTTP 200 OK https://index.rubygems.org/info/rails-observers
HTTP GET https://index.rubygems.org/info/rmmseg-cpp
HTTP 200 OK https://index.rubygems.org/info/rails
HTTP GET https://index.rubygems.org/info/rspec-support
HTTP 200 OK https://index.rubygems.org/info/raindrops
HTTP 200 OK https://index.rubygems.org/info/rb-fsevent
HTTP GET https://index.rubygems.org/info/rspec-core
HTTP 200 OK https://index.rubygems.org/info/rb-inotify
HTTP GET https://index.rubygems.org/info/rspec-expectations
HTTP GET https://index.rubygems.org/info/rspec-mocks
HTTP GET https://index.rubygems.org/info/rspec
HTTP GET https://index.rubygems.org/info/rspec-given
HTTP 200 OK https://index.rubygems.org/info/trollop
HTTP GET https://index.rubygems.org/info/rspec-html-matchers
HTTP 200 OK https://index.rubygems.org/info/redis-namespace
HTTP 200 OK https://index.rubygems.org/info/rest-client
HTTP 200 OK https://index.rubygems.org/info/rinku
HTTP 200 OK https://index.rubygems.org/info/rbtrace
HTTP GET https://index.rubygems.org/info/rspec-rails
HTTP GET https://index.rubygems.org/info/rtlit
HTTP GET https://index.rubygems.org/info/ruby-readability
HTTP 200 OK https://index.rubygems.org/info/rmmseg-cpp
HTTP GET https://index.rubygems.org/info/sanitize
HTTP 200 OK https://index.rubygems.org/info/rspec-support
HTTP GET https://index.rubygems.org/info/sass
HTTP 200 OK https://index.rubygems.org/info/rspec-expectations
HTTP 200 OK https://index.rubygems.org/info/rspec-mocks
HTTP 200 OK https://index.rubygems.org/info/rspec
HTTP 200 OK https://index.rubygems.org/info/rspec-core
HTTP GET https://index.rubygems.org/info/tilt
HTTP GET https://index.rubygems.org/info/sass-rails
HTTP 200 OK https://index.rubygems.org/info/rspec-given
HTTP GET https://index.rubygems.org/info/seed-fu
HTTP 200 OK https://index.rubygems.org/info/logster
HTTP 200 OK https://index.rubygems.org/info/rspec-html-matchers
HTTP GET https://index.rubygems.org/info/shoulda-context
HTTP GET https://index.rubygems.org/info/shoulda-matchers
HTTP 200 OK https://index.rubygems.org/info/ruby-readability
HTTP GET https://index.rubygems.org/info/shoulda
HTTP GET https://index.rubygems.org/info/sidekiq
HTTP 200 OK https://index.rubygems.org/info/sanitize
HTTP 200 OK https://index.rubygems.org/info/rspec-rails
HTTP GET https://index.rubygems.org/info/sidekiq-statistic
HTTP GET https://index.rubygems.org/info/simple-rss
HTTP GET https://index.rubygems.org/info/simplecov-html
HTTP GET https://index.rubygems.org/info/simplecov
HTTP 200 OK https://index.rubygems.org/info/sass
HTTP 200 OK https://index.rubygems.org/info/tilt
HTTP GET https://index.rubygems.org/info/sinatra
HTTP GET https://index.rubygems.org/info/spork
HTTP 200 OK https://index.rubygems.org/info/sass-rails
HTTP GET https://index.rubygems.org/info/spork-rails
HTTP GET https://index.rubygems.org/info/stackprof
HTTP GET https://index.rubygems.org/info/thin
HTTP 200 OK https://index.rubygems.org/info/shoulda-matchers
HTTP GET https://index.rubygems.org/info/timecop
HTTP 200 OK https://index.rubygems.org/info/shoulda-context
HTTP GET https://index.rubygems.org/info/uglifier
HTTP 200 OK https://index.rubygems.org/info/sidekiq
HTTP 200 OK https://index.rubygems.org/info/shoulda
HTTP GET https://index.rubygems.org/info/unicorn
HTTP 200 OK https://index.rubygems.org/info/simplecov
HTTP 200 OK https://index.rubygems.org/info/sidekiq-statistic
HTTP 200 OK https://index.rubygems.org/info/sinatra
HTTP 200 OK https://index.rubygems.org/info/spork
HTTP 200 OK https://index.rubygems.org/info/stackprof
HTTP 200 OK https://index.rubygems.org/info/thin
HTTP 200 OK https://index.rubygems.org/info/timecop
HTTP 200 OK https://index.rubygems.org/info/uglifier
HTTP 200 OK https://index.rubygems.org/info/simplecov-html
HTTP 200 OK https://index.rubygems.org/info/unicorn
HTTP 200 OK https://index.rubygems.org/info/message_bus
HTTP 200 OK https://index.rubygems.org/info/omniauth-openid
HTTP 200 OK https://index.rubygems.org/info/onebox
HTTP 200 OK https://index.rubygems.org/info/r2
HTTP 200 OK https://index.rubygems.org/info/seed-fu
HTTP 200 OK https://index.rubygems.org/info/rtlit
HTTP 200 OK https://index.rubygems.org/info/simple-rss
HTTP 200 OK https://index.rubygems.org/info/spork-rails
Looking up gems ["atomic", "abstract", "hoe", "memcache-client", "racc", "rexical", "tenderlove-frex", "weakling", "mini_portile", "pkg-config", "camping", "fcgi", "mongrel", "test-spec", "activemodel-globalid", "rack-mount", "rack-cache", "journey", "treetop", "tlsmail", "bcrypt-ruby", "text-format", "archive-tar-minitar", "rcov", "mime-types-data", "jsonapi", "json_pure", "activerecord-deprecated_finders", "jamespath", "httparty", "uuidtools", "aws-sdk-v1", "ember-template-compiler-source", "handlebars-source", "columnize", "debugger-linecache", "rb-readline", "functional-ruby", "ref", "rack-ssl", "rdoc", "hike", "active-model-adapter-source", "ember-cli-assets", "ember-es6_template", "addressable", "bones", "fast_stack", "rb-appscript", "xattr", "ffi-xattr", "newgem", "termios", "sqlite3", "rb-fchange", "rb-kqueue", "celluloid", "celluloid-io", "ruby_dep", "ruby_parser", "faraday-middleware", "httpauth", "oa-core", "oa-oauth", "oa-openid", "oa-basic", "oa-enterprise", "oa-more", "ruby-hmac", "ruby-yadis", "pry-doc", "escape_utils", "win32console", "yard", "spoon", "activeresource", "actionwebservice", "bundler", "actioncable", "curses", "cucumber", "spicycode-rcov", "syntax", "hpricot", "webrat", "rspec-collection_matchers", "sass-listen", "bourne", "compass", "sprockets-sass", "slim", "lockfile", "shotgun", "backports", "mustermann", "win32-process", "eventmachine-le", "http_parser.rb", "preforker", "therubyracer", "opengraph_parser", "verbal_expressions", "hexpress"]
HTTP GET https://index.rubygems.org/info/atomic
HTTP GET https://index.rubygems.org/info/abstract
HTTP GET https://index.rubygems.org/info/hoe
HTTP GET https://index.rubygems.org/info/memcache-client
HTTP GET https://index.rubygems.org/info/racc
HTTP GET https://index.rubygems.org/info/rexical
HTTP GET https://index.rubygems.org/info/tenderlove-frex
HTTP GET https://index.rubygems.org/info/weakling
HTTP GET https://index.rubygems.org/info/mini_portile
HTTP GET https://index.rubygems.org/info/pkg-config
HTTP GET https://index.rubygems.org/info/camping
HTTP GET https://index.rubygems.org/info/fcgi
HTTP GET https://index.rubygems.org/info/mongrel
HTTP GET https://index.rubygems.org/info/test-spec
HTTP GET https://index.rubygems.org/info/activemodel-globalid
HTTP GET https://index.rubygems.org/info/rack-mount
HTTP GET https://index.rubygems.org/info/rack-cache
HTTP GET https://index.rubygems.org/info/journey
HTTP GET https://index.rubygems.org/info/treetop
HTTP GET https://index.rubygems.org/info/tlsmail
HTTP GET https://index.rubygems.org/info/bcrypt-ruby
HTTP GET https://index.rubygems.org/info/text-format
HTTP GET https://index.rubygems.org/info/archive-tar-minitar
HTTP GET https://index.rubygems.org/info/rcov
HTTP GET https://index.rubygems.org/info/mime-types-data
HTTP 200 OK https://index.rubygems.org/info/atomic
HTTP 200 OK https://index.rubygems.org/info/racc
HTTP 200 OK https://index.rubygems.org/info/tenderlove-frex
HTTP GET https://index.rubygems.org/info/jsonapi
HTTP 200 OK https://index.rubygems.org/info/rexical
HTTP 200 OK https://index.rubygems.org/info/pkg-config
HTTP 200 OK https://index.rubygems.org/info/camping
HTTP 200 OK https://index.rubygems.org/info/mini_portile
HTTP 200 OK https://index.rubygems.org/info/memcache-client
HTTP 200 OK https://index.rubygems.org/info/fcgi
HTTP 200 OK https://index.rubygems.org/info/mongrel
HTTP 200 OK https://index.rubygems.org/info/weakling
HTTP 200 OK https://index.rubygems.org/info/test-spec
HTTP 200 OK https://index.rubygems.org/info/rack-mount
HTTP 200 OK https://index.rubygems.org/info/journey
HTTP 200 OK https://index.rubygems.org/info/tlsmail
HTTP 200 OK https://index.rubygems.org/info/activemodel-globalid
HTTP 200 OK https://index.rubygems.org/info/rack-cache
HTTP 200 OK https://index.rubygems.org/info/bcrypt-ruby
HTTP 200 OK https://index.rubygems.org/info/abstract
HTTP 200 OK https://index.rubygems.org/info/text-format
HTTP 200 OK https://index.rubygems.org/info/archive-tar-minitar
HTTP 200 OK https://index.rubygems.org/info/rcov
HTTP 200 OK https://index.rubygems.org/info/treetop
HTTP GET https://index.rubygems.org/info/json_pure
HTTP GET https://index.rubygems.org/info/activerecord-deprecated_finders
HTTP GET https://index.rubygems.org/info/jamespath
HTTP GET https://index.rubygems.org/info/httparty
HTTP 200 OK https://index.rubygems.org/info/jsonapi
HTTP GET https://index.rubygems.org/info/uuidtools
HTTP 200 OK https://index.rubygems.org/info/hoe
HTTP 200 OK https://index.rubygems.org/info/httparty
HTTP GET https://index.rubygems.org/info/aws-sdk-v1
HTTP 200 OK https://index.rubygems.org/info/uuidtools
HTTP GET https://index.rubygems.org/info/ember-template-compiler-source
HTTP GET https://index.rubygems.org/info/handlebars-source
HTTP GET https://index.rubygems.org/info/columnize
HTTP GET https://index.rubygems.org/info/debugger-linecache
HTTP GET https://index.rubygems.org/info/rb-readline
HTTP GET https://index.rubygems.org/info/functional-ruby
HTTP GET https://index.rubygems.org/info/ref
HTTP GET https://index.rubygems.org/info/rack-ssl
HTTP GET https://index.rubygems.org/info/rdoc
HTTP 200 OK https://index.rubygems.org/info/mime-types-data
HTTP GET https://index.rubygems.org/info/hike
HTTP GET https://index.rubygems.org/info/active-model-adapter-source
HTTP GET https://index.rubygems.org/info/ember-cli-assets
HTTP GET https://index.rubygems.org/info/ember-es6_template
HTTP GET https://index.rubygems.org/info/addressable
HTTP 200 OK https://index.rubygems.org/info/active-model-adapter-source
HTTP 200 OK https://index.rubygems.org/info/ember-cli-assets
HTTP GET https://index.rubygems.org/info/bones
HTTP 200 OK https://index.rubygems.org/info/ember-es6_template
HTTP GET https://index.rubygems.org/info/fast_stack
HTTP GET https://index.rubygems.org/info/rb-appscript
HTTP 200 OK https://index.rubygems.org/info/aws-sdk-v1
HTTP GET https://index.rubygems.org/info/xattr
HTTP GET https://index.rubygems.org/info/ffi-xattr
HTTP 200 OK https://index.rubygems.org/info/ember-template-compiler-source
HTTP 200 OK https://index.rubygems.org/info/handlebars-source
HTTP 200 OK https://index.rubygems.org/info/columnize
HTTP 200 OK https://index.rubygems.org/info/rb-readline
HTTP GET https://index.rubygems.org/info/newgem
HTTP 200 OK https://index.rubygems.org/info/functional-ruby
HTTP 200 OK https://index.rubygems.org/info/debugger-linecache
HTTP 200 OK https://index.rubygems.org/info/ref
HTTP 200 OK https://index.rubygems.org/info/rack-ssl
HTTP 200 OK https://index.rubygems.org/info/rdoc
HTTP 200 OK https://index.rubygems.org/info/activerecord-deprecated_finders
HTTP GET https://index.rubygems.org/info/termios
HTTP 200 OK https://index.rubygems.org/info/hike
HTTP 200 OK https://index.rubygems.org/info/json_pure
HTTP 200 OK https://index.rubygems.org/info/addressable
HTTP 200 OK https://index.rubygems.org/info/jamespath
HTTP GET https://index.rubygems.org/info/sqlite3
HTTP GET https://index.rubygems.org/info/rb-fchange
HTTP 200 OK https://index.rubygems.org/info/bones
HTTP GET https://index.rubygems.org/info/rb-kqueue
HTTP GET https://index.rubygems.org/info/celluloid
HTTP 200 OK https://index.rubygems.org/info/fast_stack
HTTP 200 OK https://index.rubygems.org/info/xattr
HTTP GET https://index.rubygems.org/info/celluloid-io
HTTP 200 OK https://index.rubygems.org/info/rb-appscript
HTTP 200 OK https://index.rubygems.org/info/ffi-xattr
HTTP GET https://index.rubygems.org/info/ruby_dep
HTTP GET https://index.rubygems.org/info/ruby_parser
HTTP GET https://index.rubygems.org/info/httpauth
HTTP 200 OK https://index.rubygems.org/info/ruby_dep
HTTP GET https://index.rubygems.org/info/oa-core
HTTP GET https://index.rubygems.org/info/oa-oauth
HTTP GET https://index.rubygems.org/info/oa-openid
HTTP GET https://index.rubygems.org/info/oa-basic
HTTP 200 OK https://index.rubygems.org/info/termios
HTTP GET https://index.rubygems.org/info/oa-enterprise
HTTP GET https://index.rubygems.org/info/oa-more
HTTP GET https://index.rubygems.org/info/ruby-hmac
HTTP GET https://index.rubygems.org/info/ruby-yadis
HTTP GET https://index.rubygems.org/info/pry-doc
HTTP 200 OK https://index.rubygems.org/info/sqlite3
HTTP 200 OK https://index.rubygems.org/info/rb-fchange
HTTP GET https://index.rubygems.org/info/escape_utils
HTTP GET https://index.rubygems.org/info/win32console
HTTP 200 OK https://index.rubygems.org/info/celluloid
HTTP GET https://index.rubygems.org/info/yard
HTTP 200 OK https://index.rubygems.org/info/celluloid-io
HTTP 200 OK https://index.rubygems.org/info/rb-kqueue
HTTP GET https://index.rubygems.org/info/spoon
HTTP GET https://index.rubygems.org/info/activeresource
HTTP GET https://index.rubygems.org/info/actionwebservice
HTTP GET https://index.rubygems.org/info/bundler
HTTP 200 OK https://index.rubygems.org/info/newgem
HTTP 200 OK https://index.rubygems.org/info/httpauth
HTTP 200 OK https://index.rubygems.org/info/ruby_parser
HTTP GET https://index.rubygems.org/info/actioncable
HTTP 200 OK https://index.rubygems.org/info/oa-oauth
HTTP 200 OK https://index.rubygems.org/info/oa-enterprise
HTTP 200 OK https://index.rubygems.org/info/oa-openid
HTTP 200 OK https://index.rubygems.org/info/oa-basic
HTTP 200 OK https://index.rubygems.org/info/bundler
HTTP 200 OK https://index.rubygems.org/info/ruby-hmac
HTTP 200 OK https://index.rubygems.org/info/oa-more
HTTP GET https://index.rubygems.org/info/curses
HTTP 200 OK https://index.rubygems.org/info/ruby-yadis
HTTP 200 OK https://index.rubygems.org/info/pry-doc
HTTP GET https://index.rubygems.org/info/cucumber
HTTP 200 OK https://index.rubygems.org/info/win32console
HTTP 200 OK https://index.rubygems.org/info/escape_utils
HTTP GET https://index.rubygems.org/info/spicycode-rcov
HTTP GET https://index.rubygems.org/info/syntax
HTTP GET https://index.rubygems.org/info/hpricot
HTTP 200 OK https://index.rubygems.org/info/yard
HTTP GET https://index.rubygems.org/info/webrat
HTTP GET https://index.rubygems.org/info/rspec-collection_matchers
HTTP 200 OK https://index.rubygems.org/info/actionwebservice
HTTP 200 OK https://index.rubygems.org/info/spoon
HTTP 200 OK https://index.rubygems.org/info/oa-core
HTTP 200 OK https://index.rubygems.org/info/activeresource
HTTP GET https://index.rubygems.org/info/sass-listen
HTTP GET https://index.rubygems.org/info/bourne
HTTP 200 OK https://index.rubygems.org/info/actioncable
HTTP GET https://index.rubygems.org/info/compass
HTTP GET https://index.rubygems.org/info/sprockets-sass
HTTP GET https://index.rubygems.org/info/slim
HTTP GET https://index.rubygems.org/info/lockfile
HTTP GET https://index.rubygems.org/info/shotgun
HTTP 200 OK https://index.rubygems.org/info/curses
HTTP GET https://index.rubygems.org/info/backports
HTTP GET https://index.rubygems.org/info/mustermann
HTTP GET https://index.rubygems.org/info/win32-process
HTTP GET https://index.rubygems.org/info/eventmachine-le
HTTP 200 OK https://index.rubygems.org/info/syntax
HTTP 200 OK https://index.rubygems.org/info/spicycode-rcov
HTTP 200 OK https://index.rubygems.org/info/cucumber
HTTP 200 OK https://index.rubygems.org/info/hpricot
HTTP GET https://index.rubygems.org/info/http_parser.rb
HTTP 200 OK https://index.rubygems.org/info/webrat
HTTP GET https://index.rubygems.org/info/preforker
HTTP GET https://index.rubygems.org/info/therubyracer
HTTP GET https://index.rubygems.org/info/opengraph_parser
HTTP 200 OK https://index.rubygems.org/info/rspec-collection_matchers
HTTP GET https://index.rubygems.org/info/verbal_expressions
HTTP 200 OK https://index.rubygems.org/info/sass-listen
HTTP 200 OK https://index.rubygems.org/info/bourne
HTTP GET https://index.rubygems.org/info/hexpress
HTTP 200 OK https://index.rubygems.org/info/sprockets-sass
HTTP 200 OK https://index.rubygems.org/info/compass
HTTP 200 OK https://index.rubygems.org/info/slim
HTTP 200 OK https://index.rubygems.org/info/lockfile
HTTP 200 OK https://index.rubygems.org/info/shotgun
HTTP 200 OK https://index.rubygems.org/info/eventmachine-le
HTTP 200 OK https://index.rubygems.org/info/mustermann
HTTP 200 OK https://index.rubygems.org/info/backports
HTTP 200 OK https://index.rubygems.org/info/win32-process
HTTP 200 OK https://index.rubygems.org/info/http_parser.rb
HTTP 200 OK https://index.rubygems.org/info/preforker
HTTP 200 OK https://index.rubygems.org/info/therubyracer
HTTP 200 OK https://index.rubygems.org/info/opengraph_parser
HTTP 200 OK https://index.rubygems.org/info/verbal_expressions
HTTP 200 OK https://index.rubygems.org/info/hexpress
Looking up gems ["markaby", "metaid", "mab", "jsonapi-parser", "jsonapi-renderer", "multimap", "rubyforge", "RubyInline", "gemcutter", "bcrypt", "text-hyphen", "facets", "polyglot", "ZenTest", "flexmock", "cgi_multipart_eof_fix", "fastthread", "gem_plugin", "echoe", "jnunemaker-crack", "crack", "launchy", "ruby_core_source", "debugger-ruby_core_source", "spruz", "public_suffix", "little-plugger", "loquacious", "bones-extras", "bones-git", "win32-api", "timers", "facter", "celluloid-essentials", "celluloid-extras", "celluloid-fsm", "celluloid-pool", "celluloid-supervision", "dotenv", "nenv", "rspec-logsplit", "nio4r", "RedCloth", "rubigen", "ParseTree", "sexp_processor", "ruby-openid-apps-discovery", "net-ldap", "rubyntlm", "pyu-ruby-sasl", "uuid", "XMLCanonicalizer", "restclient", "coffee-rails", "em-hiredis", "faye-websocket", "websocket-driver", "term-ansicolor", "gherkin", "multi_test", "cucumber-core", "gherkin3", "cucumber-wire", "event-bus", "temple", "sprockets-helpers", "tool", "haml", "chunky_png", "fssm", "compass-core", "compass-import-once", "windows-pr"]
HTTP GET https://index.rubygems.org/info/markaby
HTTP GET https://index.rubygems.org/info/metaid
HTTP GET https://index.rubygems.org/info/mab
HTTP GET https://index.rubygems.org/info/jsonapi-parser
HTTP GET https://index.rubygems.org/info/jsonapi-renderer
HTTP GET https://index.rubygems.org/info/multimap
HTTP GET https://index.rubygems.org/info/rubyforge
HTTP GET https://index.rubygems.org/info/RubyInline
HTTP GET https://index.rubygems.org/info/gemcutter
HTTP GET https://index.rubygems.org/info/bcrypt
HTTP GET https://index.rubygems.org/info/text-hyphen
HTTP GET https://index.rubygems.org/info/facets
HTTP GET https://index.rubygems.org/info/polyglot
HTTP GET https://index.rubygems.org/info/ZenTest
HTTP GET https://index.rubygems.org/info/flexmock
HTTP GET https://index.rubygems.org/info/cgi_multipart_eof_fix
HTTP GET https://index.rubygems.org/info/fastthread
HTTP GET https://index.rubygems.org/info/gem_plugin
HTTP GET https://index.rubygems.org/info/echoe
HTTP GET https://index.rubygems.org/info/jnunemaker-crack
HTTP GET https://index.rubygems.org/info/crack
HTTP GET https://index.rubygems.org/info/launchy
HTTP GET https://index.rubygems.org/info/ruby_core_source
HTTP GET https://index.rubygems.org/info/debugger-ruby_core_source
HTTP GET https://index.rubygems.org/info/spruz
HTTP 200 OK https://index.rubygems.org/info/mab
HTTP 200 OK https://index.rubygems.org/info/metaid
HTTP 200 OK https://index.rubygems.org/info/jsonapi-parser
HTTP 200 OK https://index.rubygems.org/info/markaby
HTTP 200 OK https://index.rubygems.org/info/jsonapi-renderer
HTTP 200 OK https://index.rubygems.org/info/RubyInline
HTTP 200 OK https://index.rubygems.org/info/rubyforge
HTTP 200 OK https://index.rubygems.org/info/multimap
HTTP 200 OK https://index.rubygems.org/info/gemcutter
HTTP 200 OK https://index.rubygems.org/info/text-hyphen
HTTP 200 OK https://index.rubygems.org/info/facets
HTTP 200 OK https://index.rubygems.org/info/polyglot
HTTP 200 OK https://index.rubygems.org/info/bcrypt
HTTP 200 OK https://index.rubygems.org/info/flexmock
HTTP 200 OK https://index.rubygems.org/info/ZenTest
HTTP 200 OK https://index.rubygems.org/info/cgi_multipart_eof_fix
HTTP 200 OK https://index.rubygems.org/info/fastthread
HTTP 200 OK https://index.rubygems.org/info/crack
HTTP 200 OK https://index.rubygems.org/info/ruby_core_source
HTTP 200 OK https://index.rubygems.org/info/debugger-ruby_core_source
HTTP 200 OK https://index.rubygems.org/info/spruz
HTTP 200 OK https://index.rubygems.org/info/gem_plugin
HTTP GET https://index.rubygems.org/info/public_suffix
HTTP 200 OK https://index.rubygems.org/info/launchy
HTTP 200 OK https://index.rubygems.org/info/echoe
HTTP 200 OK https://index.rubygems.org/info/jnunemaker-crack
HTTP GET https://index.rubygems.org/info/little-plugger
HTTP GET https://index.rubygems.org/info/loquacious
HTTP GET https://index.rubygems.org/info/bones-extras
HTTP GET https://index.rubygems.org/info/bones-git
HTTP GET https://index.rubygems.org/info/win32-api
HTTP GET https://index.rubygems.org/info/timers
HTTP GET https://index.rubygems.org/info/facter
HTTP GET https://index.rubygems.org/info/celluloid-essentials
HTTP GET https://index.rubygems.org/info/celluloid-extras
HTTP GET https://index.rubygems.org/info/celluloid-fsm
HTTP GET https://index.rubygems.org/info/celluloid-pool
HTTP GET https://index.rubygems.org/info/celluloid-supervision
HTTP GET https://index.rubygems.org/info/dotenv
HTTP GET https://index.rubygems.org/info/nenv
HTTP GET https://index.rubygems.org/info/rspec-logsplit
HTTP GET https://index.rubygems.org/info/nio4r
HTTP GET https://index.rubygems.org/info/RedCloth
HTTP GET https://index.rubygems.org/info/rubigen
HTTP GET https://index.rubygems.org/info/ParseTree
HTTP 200 OK https://index.rubygems.org/info/public_suffix
HTTP GET https://index.rubygems.org/info/sexp_processor
HTTP GET https://index.rubygems.org/info/ruby-openid-apps-discovery
HTTP 200 OK https://index.rubygems.org/info/loquacious
HTTP 200 OK https://index.rubygems.org/info/little-plugger
HTTP GET https://index.rubygems.org/info/net-ldap
HTTP 200 OK https://index.rubygems.org/info/bones-extras
HTTP 200 OK https://index.rubygems.org/info/bones-git
HTTP 200 OK https://index.rubygems.org/info/win32-api
HTTP GET https://index.rubygems.org/info/rubyntlm
HTTP 200 OK https://index.rubygems.org/info/timers
HTTP GET https://index.rubygems.org/info/pyu-ruby-sasl
HTTP 200 OK https://index.rubygems.org/info/facter
HTTP 200 OK https://index.rubygems.org/info/celluloid-pool
HTTP 200 OK https://index.rubygems.org/info/celluloid-extras
HTTP 200 OK https://index.rubygems.org/info/nenv
HTTP 200 OK https://index.rubygems.org/info/celluloid-supervision
HTTP 200 OK https://index.rubygems.org/info/celluloid-essentials
HTTP 200 OK https://index.rubygems.org/info/RedCloth
HTTP GET https://index.rubygems.org/info/uuid
HTTP 200 OK https://index.rubygems.org/info/rubigen
HTTP 200 OK https://index.rubygems.org/info/nio4r
HTTP 200 OK https://index.rubygems.org/info/dotenv
HTTP 200 OK https://index.rubygems.org/info/rspec-logsplit
HTTP 200 OK https://index.rubygems.org/info/celluloid-fsm
HTTP 200 OK https://index.rubygems.org/info/sexp_processor
HTTP 200 OK https://index.rubygems.org/info/ruby-openid-apps-discovery
HTTP GET https://index.rubygems.org/info/XMLCanonicalizer
HTTP GET https://index.rubygems.org/info/restclient
HTTP 200 OK https://index.rubygems.org/info/ParseTree
HTTP 200 OK https://index.rubygems.org/info/net-ldap
HTTP GET https://index.rubygems.org/info/coffee-rails
HTTP GET https://index.rubygems.org/info/em-hiredis
HTTP GET https://index.rubygems.org/info/faye-websocket
HTTP GET https://index.rubygems.org/info/websocket-driver
HTTP 200 OK https://index.rubygems.org/info/faye-websocket
HTTP 200 OK https://index.rubygems.org/info/pyu-ruby-sasl
HTTP GET https://index.rubygems.org/info/term-ansicolor
HTTP GET https://index.rubygems.org/info/gherkin
HTTP GET https://index.rubygems.org/info/multi_test
HTTP GET https://index.rubygems.org/info/cucumber-core
HTTP GET https://index.rubygems.org/info/gherkin3
HTTP GET https://index.rubygems.org/info/cucumber-wire
HTTP GET https://index.rubygems.org/info/event-bus
HTTP GET https://index.rubygems.org/info/temple
HTTP 200 OK https://index.rubygems.org/info/uuid
HTTP GET https://index.rubygems.org/info/sprockets-helpers
HTTP GET https://index.rubygems.org/info/tool
HTTP GET https://index.rubygems.org/info/haml
HTTP GET https://index.rubygems.org/info/chunky_png
HTTP GET https://index.rubygems.org/info/fssm
HTTP GET https://index.rubygems.org/info/compass-core
HTTP 200 OK https://index.rubygems.org/info/XMLCanonicalizer
HTTP GET https://index.rubygems.org/info/compass-import-once
HTTP 200 OK https://index.rubygems.org/info/restclient
HTTP 200 OK https://index.rubygems.org/info/rubyntlm
HTTP 200 OK https://index.rubygems.org/info/em-hiredis
HTTP 200 OK https://index.rubygems.org/info/coffee-rails
HTTP 200 OK https://index.rubygems.org/info/websocket-driver
HTTP GET https://index.rubygems.org/info/windows-pr
HTTP 200 OK https://index.rubygems.org/info/term-ansicolor
HTTP 200 OK https://index.rubygems.org/info/multi_test
HTTP 200 OK https://index.rubygems.org/info/cucumber-core
HTTP 200 OK https://index.rubygems.org/info/gherkin3
HTTP 200 OK https://index.rubygems.org/info/gherkin
HTTP 200 OK https://index.rubygems.org/info/cucumber-wire
HTTP 200 OK https://index.rubygems.org/info/temple
HTTP 200 OK https://index.rubygems.org/info/sprockets-helpers
HTTP 200 OK https://index.rubygems.org/info/event-bus
HTTP 200 OK https://index.rubygems.org/info/tool
HTTP 200 OK https://index.rubygems.org/info/haml
HTTP 200 OK https://index.rubygems.org/info/compass-import-once
HTTP 200 OK https://index.rubygems.org/info/chunky_png
HTTP 200 OK https://index.rubygems.org/info/fssm
HTTP 200 OK https://index.rubygems.org/info/windows-pr
HTTP 200 OK https://index.rubygems.org/info/compass-core
Looking up gems ["net-scp", "safe_yaml", "configuration", "allison", "bones-rcov", "bones-rspec", "bones-rubyforge", "bones-zentest", "git", "test-unit", "coveralls", "rubocop", "CFPropertyList", "sys-admin", "win32-dir", "windows-api", "win32-security", "hitimes", "celluloid-gems", "thoughtbot-shoulda", "dotenv-deployment", "SexpProcessor", "macaddr", "log4r", "coffee-script", "colored", "paint", "websocket-extensions", "tins", "maruku"]
HTTP GET https://index.rubygems.org/info/net-scp
HTTP GET https://index.rubygems.org/info/safe_yaml
HTTP GET https://index.rubygems.org/info/configuration
HTTP GET https://index.rubygems.org/info/allison
HTTP GET https://index.rubygems.org/info/bones-rcov
HTTP 200 OK https://index.rubygems.org/info/safe_yaml
HTTP GET https://index.rubygems.org/info/bones-rspec
HTTP GET https://index.rubygems.org/info/bones-rubyforge
HTTP GET https://index.rubygems.org/info/bones-zentest
HTTP GET https://index.rubygems.org/info/git
HTTP GET https://index.rubygems.org/info/test-unit
HTTP GET https://index.rubygems.org/info/coveralls
HTTP GET https://index.rubygems.org/info/rubocop
HTTP GET https://index.rubygems.org/info/CFPropertyList
HTTP GET https://index.rubygems.org/info/sys-admin
HTTP GET https://index.rubygems.org/info/win32-dir
HTTP GET https://index.rubygems.org/info/windows-api
HTTP GET https://index.rubygems.org/info/win32-security
HTTP GET https://index.rubygems.org/info/hitimes
HTTP GET https://index.rubygems.org/info/thoughtbot-shoulda
HTTP GET https://index.rubygems.org/info/dotenv-deployment
HTTP GET https://index.rubygems.org/info/SexpProcessor
HTTP GET https://index.rubygems.org/info/macaddr
HTTP GET https://index.rubygems.org/info/log4r
HTTP 200 OK https://index.rubygems.org/info/net-scp
HTTP GET https://index.rubygems.org/info/coffee-script
HTTP 200 OK https://index.rubygems.org/info/configuration
HTTP 200 OK https://index.rubygems.org/info/allison
HTTP GET https://index.rubygems.org/info/colored
HTTP 200 OK https://index.rubygems.org/info/bones-rcov
HTTP GET https://index.rubygems.org/info/paint
HTTP 200 OK https://index.rubygems.org/info/bones-rubyforge
HTTP 200 OK https://index.rubygems.org/info/bones-rspec
HTTP 200 OK https://index.rubygems.org/info/bones-zentest
HTTP 200 OK https://index.rubygems.org/info/git
HTTP 200 OK https://index.rubygems.org/info/coveralls
HTTP 200 OK https://index.rubygems.org/info/test-unit
HTTP 200 OK https://index.rubygems.org/info/CFPropertyList
HTTP 200 OK https://index.rubygems.org/info/sys-admin
HTTP 200 OK https://index.rubygems.org/info/rubocop
HTTP 200 OK https://index.rubygems.org/info/win32-dir
HTTP 200 OK https://index.rubygems.org/info/windows-api
HTTP 200 OK https://index.rubygems.org/info/win32-security
HTTP 200 OK https://index.rubygems.org/info/dotenv-deployment
HTTP 200 OK https://index.rubygems.org/info/thoughtbot-shoulda
HTTP 200 OK https://index.rubygems.org/info/hitimes
HTTP 200 OK https://index.rubygems.org/info/macaddr
HTTP GET https://index.rubygems.org/info/websocket-extensions
HTTP 200 OK https://index.rubygems.org/info/coffee-script
HTTP GET https://index.rubygems.org/info/tins
HTTP 200 OK https://index.rubygems.org/info/SexpProcessor
HTTP 200 OK https://index.rubygems.org/info/colored
HTTP 200 OK https://index.rubygems.org/info/log4r
HTTP GET https://index.rubygems.org/info/maruku
HTTP 200 OK https://index.rubygems.org/info/paint
HTTP 200 OK https://index.rubygems.org/info/websocket-extensions
HTTP 200 OK https://index.rubygems.org/info/maruku
HTTP 200 OK https://index.rubygems.org/info/tins
Looking up gems ["psych", "net-ssh", "power_assert", "libxml-ruby", "colorize", "rainbow", "parser", "powerpack", "ruby-progressbar", "astrolabe", "unicode-display_width", "systemu", "ffi-win32-extensions", "mkrf", "coffee-script-source"]
HTTP GET https://index.rubygems.org/info/psych
HTTP GET https://index.rubygems.org/info/net-ssh
HTTP GET https://index.rubygems.org/info/power_assert
HTTP GET https://index.rubygems.org/info/libxml-ruby
HTTP GET https://index.rubygems.org/info/colorize
HTTP GET https://index.rubygems.org/info/rainbow
HTTP GET https://index.rubygems.org/info/parser
HTTP GET https://index.rubygems.org/info/powerpack
HTTP GET https://index.rubygems.org/info/ruby-progressbar
HTTP GET https://index.rubygems.org/info/astrolabe
HTTP GET https://index.rubygems.org/info/unicode-display_width
HTTP GET https://index.rubygems.org/info/systemu
HTTP GET https://index.rubygems.org/info/ffi-win32-extensions
HTTP GET https://index.rubygems.org/info/mkrf
HTTP GET https://index.rubygems.org/info/coffee-script-source
HTTP 200 OK https://index.rubygems.org/info/net-ssh
HTTP 200 OK https://index.rubygems.org/info/psych
HTTP 200 OK https://index.rubygems.org/info/power_assert
HTTP 200 OK https://index.rubygems.org/info/colorize
HTTP 200 OK https://index.rubygems.org/info/libxml-ruby
HTTP 200 OK https://index.rubygems.org/info/rainbow
HTTP 200 OK https://index.rubygems.org/info/parser
HTTP 200 OK https://index.rubygems.org/info/astrolabe
HTTP 200 OK https://index.rubygems.org/info/unicode-display_width
HTTP 200 OK https://index.rubygems.org/info/systemu
HTTP 200 OK https://index.rubygems.org/info/powerpack
HTTP 200 OK https://index.rubygems.org/info/ruby-progressbar
HTTP 200 OK https://index.rubygems.org/info/ffi-win32-extensions
HTTP 200 OK https://index.rubygems.org/info/mkrf
HTTP 200 OK https://index.rubygems.org/info/coffee-script-source
Looking up gems ["jar-dependencies", "needle", "jruby-pageant", "bcrypt_pbkdf", "rbnacl", "rbnacl-libsodium", "pattern-match", "ast"]
HTTP GET https://index.rubygems.org/info/jar-dependencies
HTTP GET https://index.rubygems.org/info/needle
HTTP GET https://index.rubygems.org/info/jruby-pageant
HTTP GET https://index.rubygems.org/info/bcrypt_pbkdf
HTTP GET https://index.rubygems.org/info/rbnacl
HTTP GET https://index.rubygems.org/info/rbnacl-libsodium
HTTP GET https://index.rubygems.org/info/pattern-match
HTTP 200 OK https://index.rubygems.org/info/needle
HTTP GET https://index.rubygems.org/info/ast
HTTP 200 OK https://index.rubygems.org/info/jar-dependencies
HTTP 200 OK https://index.rubygems.org/info/jruby-pageant
HTTP 200 OK https://index.rubygems.org/info/bcrypt_pbkdf
HTTP 200 OK https://index.rubygems.org/info/rbnacl-libsodium
HTTP 200 OK https://index.rubygems.org/info/pattern-match
HTTP 200 OK https://index.rubygems.org/info/ast
HTTP 200 OK https://index.rubygems.org/info/rbnacl
Looking up gems ["ruby-maven"]
HTTP GET https://index.rubygems.org/info/ruby-maven
HTTP 200 OK https://index.rubygems.org/info/ruby-maven
Looking up gems ["maven-tools", "ruby-maven-libs"]
HTTP GET https://index.rubygems.org/info/maven-tools
HTTP GET https://index.rubygems.org/info/ruby-maven-libs
HTTP 200 OK https://index.rubygems.org/info/maven-tools
HTTP 200 OK https://index.rubygems.org/info/ruby-maven-libs
Looking up gems ["virtus"]
HTTP GET https://index.rubygems.org/info/virtus
HTTP 200 OK https://index.rubygems.org/info/virtus
Looking up gems ["descendants_tracker", "axiom-types", "coercible", "equalizer"]
HTTP GET https://index.rubygems.org/info/descendants_tracker
HTTP GET https://index.rubygems.org/info/axiom-types
HTTP GET https://index.rubygems.org/info/coercible
HTTP GET https://index.rubygems.org/info/equalizer
HTTP 200 OK https://index.rubygems.org/info/descendants_tracker
HTTP 200 OK https://index.rubygems.org/info/coercible
HTTP 200 OK https://index.rubygems.org/info/axiom-types
HTTP 200 OK https://index.rubygems.org/info/equalizer
Looking up gems ["ice_nine", "adamantium"]
HTTP GET https://index.rubygems.org/info/ice_nine
HTTP GET https://index.rubygems.org/info/adamantium
HTTP 200 OK https://index.rubygems.org/info/ice_nine
HTTP 200 OK https://index.rubygems.org/info/adamantium
Looking up gems ["memoizable"]
HTTP GET https://index.rubygems.org/info/memoizable
HTTP 200 OK https://index.rubygems.org/info/memoizable
Fetching version metadata from https://rubygems.org/
Looking up gems ["atomic", "abstract", "hoe", "builder", "i18n", "memcache-client", "tzinfo", "multi_json", "minitest", "thread_safe", "json", "concurrent-ruby", "method_source", "loofah", "activesupport", "nokogiri", "rails-deprecated_sanitizer", "rack", "racc", "rake-compiler", "rexical", "tenderlove-frex", "weakling", "mini_portile", "mini_portile2", "pkg-config", "camping", "fcgi", "mongrel", "ruby-openid", "test-spec", "thin", "crass", "activemodel-globalid", "globalid", "erubis", "rails-dom-testing", "rails-html-sanitizer", "activemodel", "rack-mount", "rack-test", "rack-cache", "sprockets", "journey", "actionview", "mime-types", "treetop", "tlsmail", "bcrypt-ruby", "actionpack", "mail", "text-format", "activejob", "archive-tar-minitar", "rcov", "mime-types-data", "railties", "jsonapi", "json_pure", "arel", "activerecord-deprecated_finders", "multi_xml", "jamespath", "jmespath", "aws-sdk-core", "httparty", "uuidtools", "aws-sdk-v1", "aws-sdk-resources", "babel-source", "execjs", "ember-template-compiler-source", "handlebars-source", "ember-source", "columnize", "debugger-linecache", "slop", "rb-readline", "functional-ruby", "ref", "rake", "thor", "rack-ssl", "rdoc", "unf_ext", "unf", "barber", "tilt", "rails", "hike", "active_model_serializers", "ember-data-source", "jquery-rails", "ember-handlebars-template", "active-model-adapter-source", "ember-cli-assets", "ember-es6_template", "mocha", "addressable", "multipart-post", "bones", "fast_stack", "sorcerer", "rb-appscript", "xattr", "ffi-xattr", "newgem", "termios", "redis", "domain_name", "sqlite3", "fspath", "image_size", "in_threads", "progress", "exifr", "rb-fchange", "rb-fsevent", "rb-inotify", "rb-kqueue", "celluloid", "celluloid-io", "ruby_dep", "libv8", "metaclass", "ruby_parser", "faraday", "faraday-middleware", "httpauth", "jwt", "oa-core", "oa-oauth", "oa-openid", "oa-basic", "oa-enterprise", "oa-more", "hashie", "ruby-hmac", "oauth", "omniauth", "omniauth-oauth2", "oauth2", "ruby-yadis", "rspec", "omniauth-oauth", "pry", "pry-doc", "escape_utils", "coderay", "win32console", "yard", "spoon", "ffi", "actionmailer", "activerecord", "activeresource", "actionwebservice", "bundler", "sprockets-rails", "actioncable", "curses", "trollop", "msgpack", "diff-lcs", "rspec-support", "rspec-core", "rspec-expectations", "cucumber", "spicycode-rcov", "syntax", "rspec-mocks", "netrc", "http-cookie", "given_core", "guess_html_encoding", "hpricot", "htmlentities", "nokogumbo", "webrat", "rspec-collection_matchers", "shoulda-context", "shoulda-matchers", "sass", "listen", "sass-listen", "bourne", "connection_pool", "redis-namespace", "compass", "sprockets-sass", "sinatra", "slim", "rack-protection", "simplecov-html", "docile", "lockfile", "sidekiq", "shotgun", "backports", "mustermann", "win32-process", "daemons", "eventmachine", "eventmachine-le", "http_parser.rb", "preforker", "simplecov", "therubyracer", "kgio", "raindrops", "rack-openid", "moneta", "mustache", "opengraph_parser", "verbal_expressions", "hexpress", "spork", "markaby", "metaid", "mab", "jsonapi-parser", "jsonapi-renderer", "multimap", "rubyforge", "RubyInline", "gemcutter", "bcrypt", "text-hyphen", "facets", "polyglot", "ZenTest", "flexmock", "cgi_multipart_eof_fix", "fastthread", "gem_plugin", "echoe", "jnunemaker-crack", "crack", "launchy", "babel-transpiler", "ruby_core_source", "debugger-ruby_core_source", "spruz", "public_suffix", "little-plugger", "loquacious", "bones-extras", "bones-git", "win32-api", "timers", "facter", "celluloid-essentials", "celluloid-extras", "celluloid-fsm", "celluloid-pool", "celluloid-supervision", "dotenv", "nenv", "rspec-logsplit", "nio4r", "RedCloth", "rubigen", "ParseTree", "sexp_processor", "ruby-openid-apps-discovery", "net-ldap", "rubyntlm", "pyu-ruby-sasl", "uuid", "XMLCanonicalizer", "restclient", "rest-client", "coffee-rails", "em-hiredis", "faye-websocket", "websocket-driver", "rails-observers", "term-ansicolor", "gherkin", "multi_test", "cucumber-core", "gherkin3", "cucumber-wire", "event-bus", "temple", "sprockets-helpers", "tool", "haml", "chunky_png", "fssm", "compass-core", "compass-import-once", "windows-pr", "net-scp", "safe_yaml", "configuration", "highline", "allison", "bones-rcov", "bones-rspec", "bones-rubyforge", "bones-zentest", "git", "test-unit", "coveralls", "rubocop", "CFPropertyList", "sys-admin", "win32-dir", "windows-api", "win32-security", "hitimes", "celluloid-gems", "thoughtbot-shoulda", "dotenv-deployment", "SexpProcessor", "macaddr", "log4r", "hiredis", "coffee-script", "colored", "paint", "websocket-extensions", "tins", "maruku", "psych", "net-ssh", "power_assert", "libxml-ruby", "colorize", "rainbow", "parser", "powerpack", "ruby-progressbar", "astrolabe", "unicode-display_width", "systemu", "ffi-win32-extensions", "mkrf", "coffee-script-source", "jar-dependencies", "needle", "jruby-pageant", "bcrypt_pbkdf", "rbnacl", "rbnacl-libsodium", "pattern-match", "ast", "ruby-maven", "maven-tools", "ruby-maven-libs", "virtus", "descendants_tracker", "axiom-types", "coercible", "equalizer", "ice_nine", "adamantium", "memoizable"]
Looking up gems ["faraday-middleware", "celluloid-gems"]
Fetching dependency metadata from https://rubygems.org/
Looking up gems ["faraday-middleware", "celluloid-gems"]
Using rake 11.2.2
0: rake (11.2.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rake-11.2.2.gemspec
Using i18n 0.7.0
0: i18n (0.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/i18n-0.7.0.gemspec
Using json 1.8.3
0: json (1.8.3) from /usr/local/lib/ruby/gems/2.3.0/specifications/default/json-1.8.3.gemspec
Using minitest 5.9.1
0: minitest (5.9.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/minitest-5.9.1.gemspec
Using thread_safe 0.3.5
0: thread_safe (0.3.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/thread_safe-0.3.5.gemspec
Using builder 3.2.2
0: builder (3.2.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/builder-3.2.2.gemspec
Using erubis 2.7.0
0: erubis (2.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/erubis-2.7.0.gemspec
Using mini_portile2 2.1.0
0: mini_portile2 (2.1.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mini_portile2-2.1.0.gemspec
Using rack 1.6.4
0: rack (1.6.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rack-1.6.4.gemspec
Using mime-types 2.99.2
0: mime-types (2.99.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mime-types-2.99.2.gemspec
Using arel 6.0.3
0: arel (6.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/arel-6.0.3.gemspec
Using jmespath 1.3.1
0: jmespath (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/jmespath-1.3.1.gemspec
Using babel-source 5.8.34
0: babel-source (5.8.34) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/babel-source-5.8.34.gemspec
Using execjs 2.7.0
0: execjs (2.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/execjs-2.7.0.gemspec
Using ember-source 1.12.2
0: ember-source (1.12.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ember-source-1.12.2.gemspec
Using byebug 9.0.6
0: byebug (9.0.6) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/byebug-9.0.6.gemspec
Using certified 1.0.0
0: certified (1.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/certified-1.0.0.gemspec
Using coderay 1.1.1
0: coderay (1.1.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/coderay-1.1.1.gemspec
Using concurrent-ruby 1.0.2
0: concurrent-ruby (1.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/concurrent-ruby-1.0.2.gemspec
Using connection_pool 2.2.0
0: connection_pool (2.2.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/connection_pool-2.2.0.gemspec
Using crass 1.0.2
0: crass (1.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/crass-1.0.2.gemspec
Using daemons 1.2.4
0: daemons (1.2.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/daemons-1.2.4.gemspec
Using diff-lcs 1.2.5
0: diff-lcs (1.2.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/diff-lcs-1.2.5.gemspec
Using thor 0.19.1
0: thor (0.19.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/thor-0.19.1.gemspec
Using discourse_fastimage 2.0.3
0: discourse_fastimage (2.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/discourse_fastimage-2.0.3.gemspec
Using docile 1.1.5
0: docile (1.1.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/docile-1.1.5.gemspec
Using unf_ext 0.0.7.1
0: unf_ext (0.0.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/unf_ext-0.0.7.1.gemspec
Using email_reply_trimmer 0.1.4
0: email_reply_trimmer (0.1.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/email_reply_trimmer-0.1.4.gemspec
Using eventmachine 1.2.0.1
0: eventmachine (1.2.0.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/eventmachine-1.2.0.1.gemspec
Using excon 0.53.0
0: excon (0.53.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/excon-0.53.0.gemspec
Using exifr 1.2.4
0: exifr (1.2.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/exifr-1.2.4.gemspec
Using fabrication 2.9.8
0: fabrication (2.9.8) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fabrication-2.9.8.gemspec
Using fakeweb 1.3.0
0: fakeweb (1.3.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fakeweb-1.3.0.gemspec
Using multipart-post 2.0.0
0: multipart-post (2.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/multipart-post-2.0.0.gemspec
Using fast_blank 1.0.0
0: fast_blank (1.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fast_blank-1.0.0.gemspec
Using fast_xs 0.8.0
0: fast_xs (0.8.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fast_xs-0.8.0.gemspec
Using ffi 1.9.10
0: ffi (1.9.10) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ffi-1.9.10.gemspec
Using flamegraph 0.9.5
0: flamegraph (0.9.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/flamegraph-0.9.5.gemspec
Using fspath 2.1.1
0: fspath (2.1.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fspath-2.1.1.gemspec
Using sorcerer 1.0.2
0: sorcerer (1.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sorcerer-1.0.2.gemspec
Using guess_html_encoding 0.0.11
0: guess_html_encoding (0.0.11) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/guess_html_encoding-0.0.11.gemspec
Using hashie 3.4.4
0: hashie (3.4.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/hashie-3.4.4.gemspec
Using highline 1.7.8
0: highline (1.7.8) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/highline-1.7.8.gemspec
Using hiredis 0.6.1
0: hiredis (0.6.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/hiredis-0.6.1.gemspec
Using htmlentities 4.3.4
0: htmlentities (4.3.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/htmlentities-4.3.4.gemspec
Using http_accept_language 2.0.5
0: http_accept_language (2.0.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/http_accept_language-2.0.5.gemspec
Using image_size 1.4.1
0: image_size (1.4.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/image_size-1.4.1.gemspec
Using in_threads 1.3.1
0: in_threads (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/in_threads-1.3.1.gemspec
Using progress 3.1.1
0: progress (3.1.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/progress-3.1.1.gemspec
Using jwt 1.5.2
0: jwt (1.5.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/jwt-1.5.2.gemspec
Using kgio 2.10.0
0: kgio (2.10.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/kgio-2.10.0.gemspec
Using libv8 5.3.332.38.1
0: libv8 (5.3.332.38.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/libv8-5.3.332.38.1-x86_64-linux.gemspec
Using listen 0.7.3
0: listen (0.7.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/listen-0.7.3.gemspec
Using logster 1.2.5
0: logster (1.2.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/logster-1.2.5.gemspec
Using lru_redux 1.1.0
0: lru_redux (1.1.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/lru_redux-1.1.0.gemspec
Using memory_profiler 0.9.6
0: memory_profiler (0.9.6) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/memory_profiler-0.9.6.gemspec
Using metaclass 0.0.4
0: metaclass (0.0.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/metaclass-0.0.4.gemspec
Using method_source 0.8.2
0: method_source (0.8.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/method_source-0.8.2.gemspec
Using mock_redis 0.15.4
0: mock_redis (0.15.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mock_redis-0.15.4.gemspec
Using moneta 0.8.0
0: moneta (0.8.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/moneta-0.8.0.gemspec
Using msgpack 0.7.6
0: msgpack (0.7.6) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/msgpack-0.7.6.gemspec
Using multi_json 1.12.1
0: multi_json (1.12.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/multi_json-1.12.1.gemspec
Using multi_xml 0.5.5
0: multi_xml (0.5.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/multi_xml-0.5.5.gemspec
Using mustache 1.0.3
0: mustache (1.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mustache-1.0.3.gemspec
Using netrc 0.11.0
0: netrc (0.11.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/netrc-0.11.0.gemspec
Using oauth 0.4.7
0: oauth (0.4.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/oauth-0.4.7.gemspec
Installing oj 2.17.5 with native extensions
Building native extensions. This could take a while...
0: oj (2.17.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/oj-2.17.5.gemspec
Using ruby-openid 2.7.0
0: ruby-openid (2.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ruby-openid-2.7.0.gemspec
Installing redis 3.3.1
0: redis (3.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/redis-3.3.1.gemspec
Installing pg 0.19.0 with native extensions
Building native extensions. This could take a while...
0: pg (0.19.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/pg-0.19.0.gemspec
Using slop 3.6.0
0: slop (3.6.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/slop-3.6.0.gemspec
Using puma 3.6.0
0: puma (3.6.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/puma-3.6.0.gemspec
Using r2 0.2.6
0: r2 (0.2.6) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/r2-0.2.6.gemspec
Using bundler 1.13.6
0: bundler (1.13.6) from /usr/local/lib/ruby/gems/2.3.0/gems/bundler-1.13.6/lib/bundler/source
Using rails_multisite 1.0.4
0: rails_multisite (1.0.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails_multisite-1.0.4.gemspec
Installing raindrops 0.17.0 with native extensions
Building native extensions. This could take a while...
0: raindrops (0.17.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/raindrops-0.17.0.gemspec
Using rb-fsevent 0.9.7
0: rb-fsevent (0.9.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rb-fsevent-0.9.7.gemspec
Using trollop 2.1.2
0: trollop (2.1.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/trollop-2.1.2.gemspec
Using rinku 2.0.0
0: rinku (2.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rinku-2.0.0.gemspec
Using rmmseg-cpp 0.2.9
0: rmmseg-cpp (0.2.9) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rmmseg-cpp-0.2.9.gemspec
Using rspec-support 3.4.1
0: rspec-support (3.4.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-support-3.4.1.gemspec
Using rtlit 0.0.5
0: rtlit (0.0.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rtlit-0.0.5.gemspec
Using sass 3.2.19
0: sass (3.2.19) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sass-3.2.19.gemspec
Using tilt 2.0.5
0: tilt (2.0.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/tilt-2.0.5.gemspec
Using shoulda-context 1.2.1
0: shoulda-context (1.2.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/shoulda-context-1.2.1.gemspec
Using simple-rss 1.3.1
0: simple-rss (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/simple-rss-1.3.1.gemspec
Using simplecov-html 0.10.0
0: simplecov-html (0.10.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/simplecov-html-0.10.0.gemspec
Using spork 1.0.0rc4
0: spork (1.0.0rc4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/spork-1.0.0rc4.gemspec
Using stackprof 0.2.10
0: stackprof (0.2.10) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/stackprof-0.2.10.gemspec
Using timecop 0.8.1
0: timecop (0.8.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/timecop-0.8.1.gemspec
Using rake-compiler 0.9.9
0: rake-compiler (0.9.9) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rake-compiler-0.9.9.gemspec
Using tzinfo 1.2.2
0: tzinfo (1.2.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/tzinfo-1.2.2.gemspec
Using nokogiri 1.6.8.1
0: nokogiri (1.6.8.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/nokogiri-1.6.8.1.gemspec
Using rack-test 0.6.3
0: rack-test (0.6.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rack-test-0.6.3.gemspec
Using message_bus 2.0.2
0: message_bus (2.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/message_bus-2.0.2.gemspec
Using rack-mini-profiler 0.10.1
0: rack-mini-profiler (0.10.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rack-mini-profiler-0.10.1.gemspec
Using rack-protection 1.5.3
0: rack-protection (1.5.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rack-protection-1.5.3.gemspec
Using mail 2.6.4
0: mail (2.6.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mail-2.6.4.gemspec
Using aws-sdk-core 2.5.3
0: aws-sdk-core (2.5.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/aws-sdk-core-2.5.3.gemspec
Using babel-transpiler 0.7.0
0: babel-transpiler (0.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/babel-transpiler-0.7.0.gemspec
Using uglifier 3.0.2
0: uglifier (3.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/uglifier-3.0.2.gemspec
Using barber 0.11.1
0: barber (0.11.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/barber-0.11.1.gemspec
Using ember-data-source 1.0.0.beta.16.1
0: ember-data-source (1.0.0.beta.16.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ember-data-source-1.0.0.beta.16.1.gemspec
Using sprockets 3.6.3
0: sprockets (3.6.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sprockets-3.6.3.gemspec
Using unf 0.1.4
0: unf (0.1.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/unf-0.1.4.gemspec
Using thin 1.7.0
0: thin (1.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/thin-1.7.0.gemspec
Using faraday 0.9.2
0: faraday (0.9.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/faraday-0.9.2.gemspec
Using rb-inotify 0.9.7
0: rb-inotify (0.9.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rb-inotify-0.9.7.gemspec
Using given_core 3.7.1
0: given_core (3.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/given_core-3.7.1.gemspec
Using omniauth 1.3.1
0: omniauth (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-1.3.1.gemspec
Using image_optim 0.20.2
0: image_optim (0.20.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/image_optim-0.20.2.gemspec
Installing mini_racer 0.1.7 with native extensions
Building native extensions. This could take a while...
0: mini_racer (0.1.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mini_racer-0.1.7.gemspec
Using mocha 1.1.0
0: mocha (1.1.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/mocha-1.1.0.gemspec
Using rack-openid 1.3.1
0: rack-openid (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rack-openid-1.3.1.gemspec
Using openid-redis-store 0.0.2
0: openid-redis-store (0.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/openid-redis-store-0.0.2.gemspec
Using redis-namespace 1.5.2
0: redis-namespace (1.5.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/redis-namespace-1.5.2.gemspec
Using pry 0.10.4
0: pry (0.10.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/pry-0.10.4.gemspec
Installing unicorn 5.2.0 with native extensions
Building native extensions. This could take a while...
0: unicorn (5.2.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/unicorn-5.2.0.gemspec
Using rbtrace 0.4.8
0: rbtrace (0.4.8) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rbtrace-0.4.8.gemspec
Using rspec-core 3.4.4
0: rspec-core (3.4.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-core-3.4.4.gemspec
Using rspec-expectations 3.4.0
0: rspec-expectations (3.4.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-expectations-3.4.0.gemspec
Using rspec-mocks 3.4.1
0: rspec-mocks (3.4.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-mocks-3.4.1.gemspec
Using simplecov 0.11.1
0: simplecov (0.11.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/simplecov-0.11.1.gemspec
Using fast_xor 1.1.3
0: fast_xor (1.1.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/fast_xor-1.1.3.gemspec
Using activesupport 4.2.7.1
0: activesupport (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/activesupport-4.2.7.1.gemspec
Using loofah 2.0.3
0: loofah (2.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/loofah-2.0.3.gemspec
Using nokogumbo 1.4.7
0: nokogumbo (1.4.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/nokogumbo-1.4.7.gemspec
Installing onebox 1.5.61
0: onebox (1.5.61) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/onebox-1.5.61.gemspec
Using ruby-readability 0.7.0
0: ruby-readability (0.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ruby-readability-0.7.0.gemspec
Installing sidekiq 4.2.4
0: sidekiq (4.2.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sidekiq-4.2.4.gemspec
Using sinatra 1.4.6
0: sinatra (1.4.6) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sinatra-1.4.6.gemspec
Using aws-sdk-resources 2.5.3
0: aws-sdk-resources (2.5.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/aws-sdk-resources-2.5.3.gemspec
Using ember-handlebars-template 0.7.3
0: ember-handlebars-template (0.7.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ember-handlebars-template-0.7.3.gemspec
Using domain_name 0.5.25
0: domain_name (0.5.25) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/domain_name-0.5.25.gemspec
Using oauth2 1.0.0
0: oauth2 (1.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/oauth2-1.0.0.gemspec
Using omniauth-oauth 1.1.0
0: omniauth-oauth (1.1.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-oauth-1.1.0.gemspec
Using omniauth-openid 1.0.1
0: omniauth-openid (1.0.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-openid-1.0.1.gemspec
Using pry-nav 0.2.4
0: pry-nav (0.2.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/pry-nav-0.2.4.gemspec
Using pry-rails 0.3.4
0: pry-rails (0.3.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/pry-rails-0.3.4.gemspec
Using rspec 3.4.0
0: rspec (3.4.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-3.4.0.gemspec
Using rails-deprecated_sanitizer 1.0.3
0: rails-deprecated_sanitizer (1.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails-deprecated_sanitizer-1.0.3.gemspec
Using globalid 0.3.7
0: globalid (0.3.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/globalid-0.3.7.gemspec
Using activemodel 4.2.7.1
0: activemodel (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/activemodel-4.2.7.1.gemspec
Using shoulda-matchers 2.8.0
0: shoulda-matchers (2.8.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/shoulda-matchers-2.8.0.gemspec
Using rails-html-sanitizer 1.0.3
0: rails-html-sanitizer (1.0.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails-html-sanitizer-1.0.3.gemspec
Using sanitize 4.0.1
0: sanitize (4.0.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sanitize-4.0.1.gemspec
Using sidekiq-statistic 1.2.0
0: sidekiq-statistic (1.2.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sidekiq-statistic-1.2.0.gemspec
Using aws-sdk 2.5.3
0: aws-sdk (2.5.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/aws-sdk-2.5.3.gemspec
Using http-cookie 1.0.2
0: http-cookie (1.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/http-cookie-1.0.2.gemspec
Using omniauth-oauth2 1.3.1
0: omniauth-oauth2 (1.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-oauth2-1.3.1.gemspec
Using omniauth-twitter 1.2.1
0: omniauth-twitter (1.2.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-twitter-1.2.1.gemspec
Using rspec-given 3.7.1
0: rspec-given (3.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-given-3.7.1.gemspec
Using rspec-html-matchers 0.7.0
0: rspec-html-matchers (0.7.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-html-matchers-0.7.0.gemspec
Using rails-dom-testing 1.0.7
0: rails-dom-testing (1.0.7) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails-dom-testing-1.0.7.gemspec
Using activejob 4.2.7.1
0: activejob (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/activejob-4.2.7.1.gemspec
Using active_model_serializers 0.8.3
0: active_model_serializers (0.8.3) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/active_model_serializers-0.8.3.gemspec
Using activerecord 4.2.7.1
0: activerecord (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/activerecord-4.2.7.1.gemspec
Using rails-observers 0.1.2
0: rails-observers (0.1.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails-observers-0.1.2.gemspec
Using shoulda 3.5.0
0: shoulda (3.5.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/shoulda-3.5.0.gemspec
Using rest-client 1.8.0
0: rest-client (1.8.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rest-client-1.8.0.gemspec
Using omniauth-facebook 3.0.0
0: omniauth-facebook (3.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-facebook-3.0.0.gemspec
Using omniauth-github-discourse 1.1.2
0: omniauth-github-discourse (1.1.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-github-discourse-1.1.2.gemspec
Using omniauth-google-oauth2 0.3.1
0: omniauth-google-oauth2 (0.3.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-google-oauth2-0.3.1.gemspec
Using omniauth-instagram 1.0.2
0: omniauth-instagram (1.0.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/omniauth-instagram-1.0.2.gemspec
Using actionview 4.2.7.1
0: actionview (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/actionview-4.2.7.1.gemspec
Using seed-fu 2.3.5
0: seed-fu (2.3.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/seed-fu-2.3.5.gemspec
Using actionpack 4.2.7.1
0: actionpack (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/actionpack-4.2.7.1.gemspec
Using actionmailer 4.2.7.1
0: actionmailer (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/actionmailer-4.2.7.1.gemspec
Using railties 4.2.7.1
0: railties (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/railties-4.2.7.1.gemspec
Using sprockets-rails 3.1.1
0: sprockets-rails (3.1.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sprockets-rails-3.1.1.gemspec
Using discourse-qunit-rails 0.0.9
0: discourse-qunit-rails (0.0.9) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/discourse-qunit-rails-0.0.9.gemspec
Using jquery-rails 4.0.5
0: jquery-rails (4.0.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/jquery-rails-4.0.5.gemspec
Using rspec-rails 3.4.2
0: rspec-rails (3.4.2) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rspec-rails-3.4.2.gemspec
Using rails 4.2.7.1
0: rails (4.2.7.1) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/rails-4.2.7.1.gemspec
Using sass-rails 5.0.4
0: sass-rails (5.0.4) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/sass-rails-5.0.4.gemspec
Using ember-rails 0.18.5
0: ember-rails (0.18.5) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/ember-rails-0.18.5.gemspec
Using spork-rails 4.0.0
0: spork-rails (4.0.0) from /var/www/discourse/vendor/bundle/ruby/2.3.0/specifications/spork-rails-4.0.0.gemspec
Bundle complete! 98 Gemfile dependencies, 177 gems now installed.
Gems in the group development were not installed.
Bundled gems are installed into ./vendor/bundle.
I, [2016-11-06T20:01:17.293382 #13] INFO -- : > cd /var/www/discourse && su discourse -c 'bundle exec rake db:migrate'
2016-11-06 20:01:21 UTC [1037-1] discourse@discourse ERROR: relation "users" does not exist at character 323
2016-11-06 20:01:21 UTC [1037-2] discourse@discourse STATEMENT: SELECT a.attname, format_type(a.atttypid, a.atttypmod),
pg_get_expr(d.adbin, d.adrelid), a.attnotnull, a.atttypid, a.atttypmod
FROM pg_attribute a LEFT JOIN pg_attrdef d
ON a.attrelid = d.adrelid AND a.attnum = d.adnum
WHERE a.attrelid = '"users"'::regclass
AND a.attnum > 0 AND NOT a.attisdropped
ORDER BY a.attnum
I, [2016-11-06T20:01:37.140147 #13] INFO -- : == 20000225050318 AddSchemaMigrationDetails: migrating ========================
-- create_table(:schema_migration_details)
-> 0.0080s
-- add_index(:schema_migration_details, [:version])
-> 0.0038s
-- execute("INSERT INTO schema_migration_details(version, created_at)\n SELECT version, current_timestamp\n FROM schema_migrations\n ORDER BY version\n ")
-> 0.0004s
== 20000225050318 AddSchemaMigrationDetails: migrated (0.0168s) ===============
== 20120311163914 CreateForumThreads: migrating ===============================
-- create_table(:forum_threads)
-> 0.0063s
== 20120311163914 CreateForumThreads: migrated (0.0076s) ======================
== 20120311164326 CreatePosts: migrating ======================================
-- create_table(:posts)
-> 0.0059s
-- add_index(:posts, [:forum_thread_id, :created_at])
-> 0.0038s
== 20120311164326 CreatePosts: migrated (0.0111s) =============================
== 20120311170118 CreateUsers: migrating ======================================
-- create_table(:users)
-> 0.0154s
== 20120311170118 CreateUsers: migrated (0.0167s) =============================
== 20120311201341 CreateForums: migrating =====================================
-- create_table(:forums)
-> 0.0039s
== 20120311201341 CreateForums: migrated (0.0050s) ============================
== 20120311210245 CreateSites: migrating ======================================
-- create_table(:sites)
-> 0.0038s
== 20120311210245 CreateSites: migrated (0.0049s) =============================
== 20120416201606 AddReplyToToPosts: migrating ================================
-- add_column(:posts, :reply_to_post_number, :integer, {:null=>true})
-> 0.0003s
-- add_index(:posts, :reply_to_post_number)
-> 0.0038s
== 20120416201606 AddReplyToToPosts: migrated (0.0052s) =======================
== 20120420183447 AddViewsToForumThreads: migrating ===========================
-- add_column(:forum_threads, :views, :integer, {:default=>0, :null=>false})
-> 0.0186s
== 20120420183447 AddViewsToForumThreads: migrated (0.0199s) ==================
== 20120423140906 AddPostsCountToForumThreads: migrating ======================
-- add_column(:forum_threads, :posts_count, :integer, {:default=>0, :null=>false})
-> 0.0075s
-- execute("UPDATE forum_threads SET posts_count = (SELECT count(*) FROM posts WHERE posts.forum_thread_id = forum_threads.id)")
-> 0.0006s
== 20120423140906 AddPostsCountToForumThreads: migrated (0.0094s) =============
== 20120423142820 FixPostIndices: migrating ===================================
-- remove_index(:posts, [:forum_thread_id, :created_at])
-> 0.0010s
-- add_index(:posts, [:forum_thread_id, :post_number])
-> 0.0037s
== 20120423142820 FixPostIndices: migrated (0.0059s) ==========================
== 20120423151548 RemoveLastPostId: migrating =================================
-- remove_column(:forum_threads, :last_post_id)
-> 0.0004s
== 20120423151548 RemoveLastPostId: migrated (0.0016s) ========================
== 20120425145456 AddDisplayUsernameToUsers: migrating ========================
-- add_column(:users, :display_username, :string)
-> 0.0004s
-- execute("UPDATE users SET display_username = username")
-> 0.0002s
-- execute("UPDATE users SET username = REPLACE(username, ' ', '')")
-> 0.0002s
-- add_index(:users, :username, {:unique=>true})
-> 0.0039s
== 20120425145456 AddDisplayUsernameToUsers: migrated (0.0060s) ===============
== 20120427150624 AddUserIdIndexToPosts: migrating ============================
-- add_index(:posts, :user_id)
-> 0.0037s
== 20120427150624 AddUserIdIndexToPosts: migrated (0.0048s) ===================
== 20120427151452 CookedMigration: migrating ==================================
-- rename_column(:posts, :content, :raw)
-> 0.0024s
-- rename_column(:posts, :formatted_content, :cooked)
-> 0.0015s
== 20120427151452 CookedMigration: migrated (0.0050s) =========================
== 20120427154330 CreateVestalVersions: migrating =============================
-- create_table(:versions)
-> 0.0141s
-- change_table(:versions)
-> 0.0213s
== 20120427154330 CreateVestalVersions: migrated (0.0368s) ====================
== 20120427172031 AddVersionToPosts: migrating ================================
-- add_column(:posts, :cached_version, :integer, {:null=>false, :default=>1})
-> 0.0232s
== 20120427172031 AddVersionToPosts: migrated (0.0246s) =======================
== 20120502183240 AddCreatedByToForumThreads: migrating =======================
-- add_column(:forum_threads, :user_id, :integer)
-> 0.0004s
-- execute("update forum_threads t\n set user_id = (select user_id from posts where forum_thread_id = t.Id order by post_number asc limit 1)")
-> 0.0006s
-- change_column(:forum_threads, :user_id, :integer, {:null=>false})
-> 0.0004s
== 20120502183240 AddCreatedByToForumThreads: migrated (0.0026s) ==============
== 20120502192121 AddLastPostUserIdToForumThreads: migrating ==================
-- add_column(:forum_threads, :last_post_user_id, :integer)
-> 0.0004s
-- execute("update forum_threads t\n set last_post_user_id = (select user_id from posts where forum_thread_id = t.Id order by post_number desc limit 1)")
-> 0.0003s
-- change_column(:forum_threads, :last_post_user_id, :integer, {:null=>false})
-> 0.0003s
== 20120502192121 AddLastPostUserIdToForumThreads: migrated (0.0020s) =========
== 20120503205521 AddSiteIdToUsers: migrating =================================
-- add_column(:users, :site_id, :integer)
-> 0.0003s
-- add_column(:users, :bio, :text)
-> 0.0002s
-- add_index(:users, :site_id)
-> 0.0040s
-- execute("UPDATE users SET site_id = 1")
-> 0.0002s
== 20120503205521 AddSiteIdToUsers: migrated (0.0058s) ========================
== 20120507144132 CreateExpressions: migrating ================================
-- create_table(:expressions, {:id=>false, :force=>true})
-> 0.0013s
-- add_index(:expressions, [:parent_id, :parent_type, :expression_type_id, :user_id], {:unique=>true, :name=>"expressions_pk"})
-> 0.0038s
== 20120507144132 CreateExpressions: migrated (0.0061s) =======================
== 20120507144222 CreateExpressionTypes: migrating ============================
-- create_table(:expression_types)
-> 0.0037s
-- add_index(:expression_types, [:site_id, :name], {:unique=>true})
-> 0.0034s
== 20120507144222 CreateExpressionTypes: migrated (0.0083s) ===================
== 20120514144549 AddReplyCountToPosts: migrating =============================
-- add_column(:posts, :reply_count, :integer, {:null=>false, :default=>0})
-> 0.0234s
-- execute("UPDATE posts\n SET reply_count = (SELECT count(*) FROM posts AS p2 WHERE p2.reply_to_post_number = posts.post_number)")
-> 0.0005s
== 20120514144549 AddReplyCountToPosts: migrated (0.0252s) ====================
== 20120514173920 AddFlagToExpressionTypes: migrating =========================
-- add_column(:expression_types, :flag, :boolean, {:default=>false})
-> 0.0077s
== 20120514173920 AddFlagToExpressionTypes: migrated (0.0089s) ================
== 20120514204934 AddDescriptionToExpressionTypes: migrating ==================
-- add_column(:expression_types, :description, :text, {:null=>true})
-> 0.0031s
== 20120514204934 AddDescriptionToExpressionTypes: migrated (0.0042s) =========
== 20120517200130 AddQuotelessToPost: migrating ===============================
-- add_column(:posts, :quoteless, :boolean, {:default=>false})
-> 0.0239s
== 20120517200130 AddQuotelessToPost: migrated (0.0253s) ======================
== 20120518200115 CreateReadPosts: migrating ==================================
-- create_table(:read_posts, {:id=>false})
-> 0.0007s
-- add_index(:read_posts, [:forum_thread_id, :user_id, :page], {:unique=>true})
-> 0.0040s
== 20120518200115 CreateReadPosts: migrated (0.0059s) =========================
== 20120519182212 CreateLastReadPosts: migrating ==============================
-- create_table(:last_read_posts)
-> 0.0037s
-- add_index(:last_read_posts, [:user_id, :forum_thread_id], {:unique=>true})
-> 0.0037s
== 20120519182212 CreateLastReadPosts: migrated (0.0087s) =====================
== 20120523180723 CreateViews: migrating ======================================
-- create_table(:views, {:id=>false})
-> 0.0006s
-- add_index(:views, [:parent_id, :parent_type])
-> 0.0036s
-- add_index(:views, [:parent_id, :parent_type, :ip, :viewed_at], {:unique=>true, :name=>"unique_views"})
-> 0.0036s
== 20120523180723 CreateViews: migrated (0.0091s) =============================
== 20120523184307 AddRepliesToForumThreads: migrating =========================
-- add_column(:forum_threads, :reply_count, :integer, {:default=>0, :null=>false})
-> 0.0075s
-- execute("UPDATE forum_threads SET reply_count = (SELECT COUNT(*) FROM posts WHERE posts.reply_to_post_number IS NOT NULL AND posts.forum_thread_id = forum_threads.id)")
-> 0.0006s
== 20120523184307 AddRepliesToForumThreads: migrated (0.0094s) ================
== 20120523201329 AddFeaturedToForumThreads: migrating ========================
-- add_column(:forum_threads, :featured_user1_id, :integer, {:null=>true})
-> 0.0005s
-- add_column(:forum_threads, :featured_user2_id, :integer, {:null=>true})
-> 0.0003s
-- add_column(:forum_threads, :featured_user3_id, :integer, {:null=>true})
-> 0.0002s
== 20120523201329 AddFeaturedToForumThreads: migrated (0.0023s) ===============
== 20120525194845 AddAvgTimeToForumThreads: migrating =========================
-- add_column(:forum_threads, :avg_time, :integer)
-> 0.0003s
-- execute("update forum_threads SET avg_time = abs(random() * 1200)")
-> 0.0004s
== 20120525194845 AddAvgTimeToForumThreads: migrated (0.0017s) ================
== 20120529175956 CreateUploads: migrating ====================================
-- create_table(:uploads)
-> 0.0061s
-- add_index(:uploads, :forum_thread_id)
-> 0.0038s
-- add_index(:uploads, :user_id)
-> 0.0035s
== 20120529175956 CreateUploads: migrated (0.0147s) ===========================
== 20120529202707 CreateStars: migrating ======================================
-- create_table(:stars, {:id=>false})
-> 0.0008s
-- add_index(:stars, [:parent_id, :parent_type, :user_id])
-> 0.0154s
== 20120529202707 CreateStars: migrated (0.0176s) =============================
== 20120530150726 CreateForumThreadUser: migrating ============================
-- create_table(:forum_thread_users, {:id=>false})
-> 0.0017s
-- execute("DELETE FROM read_posts")
-> 0.0002s
-- add_index(:forum_thread_users, [:forum_thread_id, :user_id], {:unique=>true})
-> 0.0041s
-- drop_table(:stars)
-> 0.0004s
-- drop_table(:last_read_posts)
-> 0.0006s
== 20120530150726 CreateForumThreadUser: migrated (0.0083s) ===================
== 20120530160745 MigratePosted: migrating ====================================
== 20120530160745 MigratePosted: migrated (0.0013s) ===========================
== 20120530200724 AddIndexToForumThreads: migrating ===========================
-- add_index(:forum_threads, :last_posted_at)
-> 0.0039s
== 20120530200724 AddIndexToForumThreads: migrated (0.0050s) ==================
== 20120530212912 CreateForumThreadLinks: migrating ===========================
-- create_table(:forum_thread_links)
-> 0.0065s
-- add_index(:forum_thread_links, :forum_thread_id)
-> 0.0035s
== 20120530212912 CreateForumThreadLinks: migrated (0.0112s) ==================
== 20120614190726 AddTagsToForumThreads: migrating ============================
-- add_column(:forum_threads, :tag, :string, {:null=>true, :limit=>25})
-> 0.0004s
== 20120614190726 AddTagsToForumThreads: migrated (0.0013s) ===================
== 20120614202024 AddQuoteCountToPosts: migrating =============================
-- add_column(:posts, :quote_count, :integer, {:default=>0, :null=>false})
-> 0.0135s
-- execute("UPDATE posts SET quote_count = 1 WHERE quoteless = 'f'")
-> 0.0003s
-- remove_column(:posts, :quoteless)
-> 0.0003s
== 20120614202024 AddQuoteCountToPosts: migrated (0.0154s) ====================
== 20120615180517 CreateBookmarks: migrating ==================================
-- create_table(:bookmarks)
-> 0.0041s
-- add_index(:bookmarks, [:user_id, :post_id], {:unique=>true})
-> 0.0037s
== 20120615180517 CreateBookmarks: migrated (0.0091s) =========================
== 20120618152946 AddReplyBelowToPosts: migrating =============================
-- add_column(:posts, :reply_below_post_number, :integer, {:null=>true})
-> 0.0004s
== 20120618152946 AddReplyBelowToPosts: migrated (0.0014s) ====================
== 20120618212349 CreatePostTimings: migrating ================================
-- create_table(:post_timings)
-> 0.0041s
-- add_index(:post_timings, [:thread_id, :post_number])
-> 0.0038s
-- add_index(:post_timings, [:thread_id, :post_number, :user_id], {:unique=>true})
-> 0.0036s
== 20120618212349 CreatePostTimings: migrated (0.0129s) =======================
== 20120618214856 CreateMessageBus: migrating =================================
-- create_table(:message_bus)
-> 0.0160s
-- add_index(:message_bus, [:created_at])
-> 0.0038s
== 20120618214856 CreateMessageBus: migrated (0.0211s) ========================
== 20120619150807 FixPostTimings: migrating ===================================
-- remove_index(:post_timings, [:thread_id, :post_number])
-> 0.0010s
-- remove_index(:post_timings, [:thread_id, :post_number, :user_id])
-> 0.0009s
-- rename_column(:post_timings, :thread_id, :forum_thread_id)
-> 0.0007s
-- add_index(:post_timings, [:forum_thread_id, :post_number], {:name=>"post_timings_summary"})
-> 0.0035s
-- add_index(:post_timings, [:forum_thread_id, :post_number, :user_id], {:unique=>true, :name=>"post_timings_unique"})
-> 0.0035s
== 20120619150807 FixPostTimings: migrated (0.0109s) ==========================
== 20120619153349 DropReadPosts: migrating ====================================
-- drop_table(:read_posts)
-> 0.0004s
== 20120619153349 DropReadPosts: migrated (0.0016s) ===========================
== 20120619172714 AddPostNumberToBookmarks: migrating =========================
-- drop_table(:bookmarks)
-> 0.0006s
-- create_table(:bookmarks)
-> 0.0038s
-- add_index(:bookmarks, [:user_id, :forum_thread_id, :post_number], {:unique=>true})
-> 0.0065s
== 20120619172714 AddPostNumberToBookmarks: migrated (0.0124s) ================
== 20120621155351 AddSeenPostCountToForumThreadUsers: migrating ===============
-- remove_column(:post_timings, :id)
-> 0.0006s
-- remove_column(:forum_thread_users, :created_at)
-> 0.0003s
-- remove_column(:forum_thread_users, :updated_at)
-> 0.0002s
-- add_column(:forum_thread_users, :seen_post_count, :integer)
-> 0.0003s
== 20120621155351 AddSeenPostCountToForumThreadUsers: migrated (0.0026s) ======
== 20120621190310 AddDeletedAtToForumThreads: migrating =======================
-- add_column(:forum_threads, :deleted_at, :datetime)
-> 0.0004s
== 20120621190310 AddDeletedAtToForumThreads: migrated (0.0015s) ==============
== 20120622200242 CreateNotifications: migrating ==============================
-- create_table(:notifications)
-> 0.0136s
-- add_index(:notifications, [:user_id, :created_at])
-> 0.0040s
== 20120622200242 CreateNotifications: migrated (0.0188s) =====================
== 20120625145714 AddSeenNotificationIdToUsers: migrating =====================
-- execute("TRUNCATE TABLE notifications")
-> 0.0069s
-- add_column(:users, :seen_notificaiton_id, :integer, {:default=>0, :null=>false})
-> 0.0114s
-- add_column(:notifications, :forum_thread_id, :integer, {:null=>true})
-> 0.0004s
-- add_column(:notifications, :post_number, :integer, {:null=>true})
-> 0.0003s
== 20120625145714 AddSeenNotificationIdToUsers: migrated (0.0204s) ============
== 20120625162318 AddDeletedAtToPosts: migrating ==============================
-- add_column(:posts, :deleted_at, :datetime)
-> 0.0004s
== 20120625162318 AddDeletedAtToPosts: migrated (0.0017s) =====================
== 20120625174544 AddHighestPostNumberToForumThreads: migrating ===============
-- add_column(:forum_threads, :highest_post_number, :integer, {:default=>0, :null=>false})
-> 0.0100s
-- execute("UPDATE forum_threads SET highest_post_number = (SELECT MAX(post_number) FROM posts WHERE posts.forum_thread_id = forum_threads.id)")
-> 0.0006s
== 20120625174544 AddHighestPostNumberToForumThreads: migrated (0.0118s) ======
== 20120625195326 AddImageUrlToForumThreads: migrating ========================
-- add_column(:forum_threads, :image_url, :string)
-> 0.0004s
== 20120625195326 AddImageUrlToForumThreads: migrated (0.0015s) ===============
== 20120629143908 RenameExpressionTypeId: migrating ===========================
-- add_column(:expression_types, :expression_index, :integer)
-> 0.0003s
-- execute("UPDATE expression_types SET expression_index = id")
-> 0.0003s
-- remove_column(:expression_types, :id)
-> 0.0005s
-- add_index(:expression_types, [:site_id, :expression_index], {:unique=>true})
-> 0.0037s
== 20120629143908 RenameExpressionTypeId: migrated (0.0060s) ==================
== 20120629150253 DenormalizeExpressions: migrating ===========================
-- add_column(:posts, :expression1_count, :integer, {:null=>false, :default=>0})
-> 0.0141s
-- add_column(:posts, :expression2_count, :integer, {:null=>false, :default=>0})
-> 0.0243s
-- add_column(:posts, :expression3_count, :integer, {:null=>false, :default=>0})
-> 0.0132s
-- add_column(:posts, :expression4_count, :integer, {:null=>false, :default=>0})
-> 0.0242s
-- add_column(:posts, :expression5_count, :integer, {:null=>false, :default=>0})
-> 0.0151s
-- add_column(:forum_threads, :expression1_count, :integer, {:null=>false, :default=>0})
-> 0.0093s
-- add_column(:forum_threads, :expression2_count, :integer, {:null=>false, :default=>0})
-> 0.0099s
-- add_column(:forum_threads, :expression3_count, :integer, {:null=>false, :default=>0})
-> 0.0095s
-- add_column(:forum_threads, :expression4_count, :integer, {:null=>false, :default=>0})
-> 0.0096s
-- add_column(:forum_threads, :expression5_count, :integer, {:null=>false, :default=>0})
-> 0.0204s
-- execute("update posts set expression1_count = (select count(*) from expressions where parent_id = posts.id and expression_type_id = 1)")
-> 0.0006s
-- execute("update forum_threads set expression1_count = (select sum(expression1_count) from posts where forum_thread_id = forum_threads.id)")
-> 0.0004s
-- execute("update posts set expression2_count = (select count(*) from expressions where parent_id = posts.id and expression_type_id = 2)")
-> 0.0002s
-- execute("update forum_threads set expression2_count = (select sum(expression2_count) from posts where forum_thread_id = forum_threads.id)")
-> 0.0003s
-- execute("update posts set expression3_count = (select count(*) from expressions where parent_id = posts.id and expression_type_id = 3)")
-> 0.0002s
-- execute("update forum_threads set expression3_count = (select sum(expression3_count) from posts where forum_thread_id = forum_threads.id)")
-> 0.0002s
-- execute("update posts set expression4_count = (select count(*) from expressions where parent_id = posts.id and expression_type_id = 4)")
-> 0.0002s
-- execute("update forum_threads set expression4_count = (select sum(expression4_count) from posts where forum_thread_id = forum_threads.id)")
-> 0.0002s
-- execute("update posts set expression5_count = (select count(*) from expressions where parent_id = posts.id and expression_type_id = 5)")
-> 0.0003s
-- execute("update forum_threads set expression5_count = (select sum(expression5_count) from posts where forum_thread_id = forum_threads.id)")
-> 0.0003s
== 20120629150253 DenormalizeExpressions: migrated (0.1548s) ==================
== 20120629151243 MakeExpressionsLessGeneric: migrating =======================
-- rename_column(:expressions, :parent_id, :post_id)
-> 0.0013s
-- rename_column(:expressions, :expression_type_id, :expression_index)
-> 0.0011s
-- remove_column(:expressions, :parent_type)
-> 0.0003s
-- add_index(:expressions, [:post_id, :expression_index, :user_id], {:unique=>true, :name=>"unique_by_user"})
-> 0.0045s
== 20120629151243 MakeExpressionsLessGeneric: migrated (0.0084s) ==============
== 20120629182637 CreateIncomingLinks: migrating ==============================
-- create_table(:incoming_links)
-> 0.0163s
-- add_index(:incoming_links, [:site_id, :forum_thread_id, :post_number], {:name=>"incoming_index"})
-> 0.0042s
== 20120629182637 CreateIncomingLinks: migrated (0.0218s) =====================
== 20120702211427 CreateReplies: migrating ====================================
-- create_table(:post_replies, {:id=>false})
-> 0.0008s
-- add_index(:post_replies, [:post_id, :reply_id], {:unique=>true})
-> 0.0034s
-- execute("INSERT INTO post_replies (post_id, reply_id, created_at, updated_at)\n SELECT p2.id, p.id, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP\n FROM posts AS p\n INNER JOIN posts AS p2 on p2.post_number = p.reply_to_post_number AND p2.forum_thread_id = P.forum_thread_id\n WHERE p.forum_thread_id IS NOT NULL")
-> 0.0005s
== 20120702211427 CreateReplies: migrated (0.0058s) ===========================
== 20120703184734 AddReflectionToForumThreadLinks: migrating ==================
-- add_column(:forum_thread_links, :reflection, :boolean, {:default=>false})
-> 0.0092s
-- change_column(:forum_thread_links, :post_id, :integer, {:null=>true})
-> 0.0004s
== 20120703184734 AddReflectionToForumThreadLinks: migrated (0.0108s) =========
== 20120703201312 AddIncomingLinkCountToPosts: migrating ======================
-- add_column(:posts, :incoming_link_count, :integer, {:default=>0, :null=>false})
-> 0.0138s
== 20120703201312 AddIncomingLinkCountToPosts: migrated (0.0151s) =============
== 20120703203623 AddIncomingLinkCountToForumThreads: migrating ===============
-- add_column(:forum_threads, :incoming_link_count, :integer, {:default=>0, :null=>false})
-> 0.0188s
== 20120703203623 AddIncomingLinkCountToForumThreads: migrated (0.0201s) ======
== 20120703210004 AddBookmarkCountToPosts: migrating ==========================
-- add_column(:posts, :bookmark_count, :integer, {:default=>0, :null=>false})
-> 0.0143s
-- add_column(:forum_threads, :bookmark_count, :integer, {:default=>0, :null=>false})
-> 0.0213s
-- add_column(:forum_threads, :star_count, :integer, {:default=>0, :null=>false})
-> 0.0100s
-- execute("UPDATE posts SET bookmark_count = (SELECT COUNT(*)\n FROM bookmarks\n WHERE post_number = posts.post_number AND forum_thread_id = posts.forum_thread_id)")
-> 0.0006s
-- execute("UPDATE forum_threads SET bookmark_count = (SELECT COUNT(*)\n FROM bookmarks\n WHERE forum_thread_id = forum_threads.id)")
-> 0.0004s
-- execute("UPDATE forum_threads SET star_count = (SELECT COUNT(*)\n FROM forum_thread_users\n WHERE forum_thread_id = forum_threads.id AND starred = true)")
-> 0.0004s
== 20120703210004 AddBookmarkCountToPosts: migrated (0.0485s) =================
== 20120704160659 AddAvgTimeToPosts: migrating ================================
-- add_column(:posts, :avg_time, :integer, {:null=>true})
-> 0.0004s
-- add_column(:posts, :score, :float, {:null=>true})
-> 0.0003s
== 20120704160659 AddAvgTimeToPosts: migrated (0.0020s) =======================
== 20120704201743 AddViewCountToPosts: migrating ==============================
-- add_column(:posts, :views, :integer, {:default=>0, :null=>false})
-> 0.0144s
-- execute("UPDATE posts SET views =\n (SELECT COUNT(*) FROM post_timings WHERE forum_thread_id = posts.forum_thread_id AND post_number = posts.post_number)")
-> 0.0006s
== 20120704201743 AddViewCountToPosts: migrated (0.0164s) =====================
== 20120705181724 AddUserToVersions: migrating ================================
-- execute("UPDATE versions SET user_type = 'User', user_id = posts.user_id\n FROM posts\n WHERE posts.id = versions.versioned_id")
-> 0.0007s
== 20120705181724 AddUserToVersions: migrated (0.0019s) =======================
== 20120708210305 AddLastPostedAtToUsers: migrating ===========================
-- add_column(:users, :last_posted_at, :datetime, {:null=>true})
-> 0.0003s
-- add_index(:users, :last_posted_at)
-> 0.0036s
-- execute("UPDATE users\n SET last_posted_at = (SELECT MAX(posts.created_at)\n FROM posts\n WHERE posts.user_id = users.id)")
-> 0.0005s
== 20120708210305 AddLastPostedAtToUsers: migrated (0.0055s) ==================
== 20120712150500 CreateCategories: migrating =================================
-- create_table(:categories)
-> 0.0085s
-- add_index(:categories, :name, {:unique=>true})
-> 0.0037s
-- add_index(:categories, :forum_thread_count)
-> 0.0035s
-- execute("INSERT INTO categories (name, forum_thread_count, created_at, updated_At)\n SELECT tag, count(*), CURRENT_TIMESTAMP, CURRENT_TIMESTAMP from forum_threads\n WHERE tag IS NOT NULL AND tag <> 'null'\n GROUP BY tag")
-> 0.0006s
== 20120712150500 CreateCategories: migrated (0.0176s) ========================
== 20120712151934 AddCategoryIdToForumThreads: migrating ======================
-- add_column(:forum_threads, :category_id, :integer)
-> 0.0004s
-- execute("UPDATE forum_threads SET category_id =\n (SELECT id\n FROM categories\n WHERE name = forum_threads.tag)")
-> 0.0006s
-- remove_column(:forum_threads, :tag)
-> 0.0003s
== 20120712151934 AddCategoryIdToForumThreads: migrated (0.0024s) =============
== 20120713201324 CreateCategoryFeaturedThreads: migrating ====================
-- create_table(:category_featured_threads, {:id=>false})
-> 0.0009s
-- add_index(:category_featured_threads, [:category_id, :forum_thread_id], {:unique=>true, :name=>"cat_featured_threads"})
-> 0.0036s
== 20120713201324 CreateCategoryFeaturedThreads: migrated (0.0056s) ===========
== 20120716020835 CreateSiteSettings: migrating ===============================
-- create_table(:site_settings)
-> 0.0060s
== 20120716020835 CreateSiteSettings: migrated (0.0071s) ======================
== 20120716173544 AddStatsToCategories: migrating =============================
-- add_column(:categories, :posts_year, :integer)
-> 0.0003s
-- add_column(:categories, :posts_month, :integer)
-> 0.0003s
-- add_column(:categories, :posts_week, :integer)
-> 0.0002s
== 20120716173544 AddStatsToCategories: migrated (0.0019s) ====================
== 20120718044955 CreateUserOpenIds: migrating ================================
-- create_table(:user_open_ids)
-> 0.0102s
-- add_index(:user_open_ids, [:url])
-> 0.0038s
== 20120718044955 CreateUserOpenIds: migrated (0.0152s) =======================
== 20120719004636 AddEmailHashedPasswordNameSaltToUsers: migrating ============
-- add_column(:users, :email, :string, {:limit=>256})
-> 0.0004s
-- execute("update users set email= md5(random()::text) || 'domain.com'")
-> 0.0003s
-- change_column(:users, :email, :string, {:limit=>256, :null=>false})
-> 0.0004s
-- add_index(:users, [:email], {:unique=>true})
-> 0.0036s
-- rename_column(:users, :display_username, :name)
-> 0.0018s
-- add_column(:users, :password_hash, :string, {:limit=>64})
-> 0.0003s
-- add_column(:users, :salt, :string, {:limit=>32})
-> 0.0003s
-- add_column(:users, :active, :boolean)
-> 0.0002s
-- add_column(:users, :activation_key, :string, {:limit=>32})
-> 0.0002s
-- add_column(:user_open_ids, :active, :boolean, {:null=>false})
-> 0.0003s
== 20120719004636 AddEmailHashedPasswordNameSaltToUsers: migrated (0.0091s) ===
== 20120720013733 AddUsernameLowerToUsers: migrating ==========================
-- add_column(:users, :username_lower, :string, {:limit=>20})
-> 0.0003s
-- execute("update users set username_lower = lower(username)")
-> 0.0003s
-- add_index(:users, [:username_lower], {:unique=>true})
-> 0.0034s
-- change_column(:users, :username_lower, :string, {:limit=>20, :null=>false})
-> 0.0006s
== 20120720013733 AddUsernameLowerToUsers: migrated (0.0058s) =================
== 20120720044246 AddAuthTokenToUsers: migrating ==============================
-- add_column(:users, :auth_token, :string, {:limit=>32})
-> 0.0004s
-- add_index(:users, [:auth_token])
-> 0.0036s
== 20120720044246 AddAuthTokenToUsers: migrated (0.0052s) =====================
== 20120720162422 AddForumIdToCategories: migrating ===========================
-- add_column(:categories, :forum_id, :integer)
-> 0.0004s
-- execute("UPDATE categories SET forum_id = (SELECT MIN(id) FROM forums)")
-> 0.0004s
-- change_column(:categories, :forum_id, :integer, {:null=>false})
-> 0.0004s
== 20120720162422 AddForumIdToCategories: migrated (0.0023s) ==================
== 20120723051512 AddNotNullsToUserOpenIds: migrating =========================
-- change_column(:user_open_ids, :user_id, :integer, {:null=>false})
-> 0.0004s
-- change_column(:user_open_ids, :email, :string, {:null=>false})
-> 0.0003s
-- change_column(:user_open_ids, :url, :string, {:null=>false})
-> 0.0007s
== 20120723051512 AddNotNullsToUserOpenIds: migrated (0.0025s) ================
== 20120724234502 AddLastSeenAtToUsers: migrating =============================
-- add_column(:users, :last_seen_at, :datetime)
-> 0.0004s
== 20120724234502 AddLastSeenAtToUsers: migrated (0.0014s) ====================
== 20120724234711 AddWebsiteToUsers: migrating ================================
-- add_column(:users, :website, :string)
-> 0.0003s
== 20120724234711 AddWebsiteToUsers: migrated (0.0013s) =======================
== 20120725183347 AddExcerptToCategories: migrating ===========================
-- add_column(:categories, :excerpt, :string, {:limit=>250})
-> 0.0003s
== 20120725183347 AddExcerptToCategories: migrated (0.0014s) ==================
== 20120726201830 AddInvisibleToForumThread: migrating ========================
-- add_column(:forum_threads, :invisible, :boolean, {:default=>false, :null=>false})
-> 0.0188s
-- change_column(:categories, :excerpt, :text, {:null=>true})
-> 0.0028s
== 20120726201830 AddInvisibleToForumThread: migrated (0.0230s) ===============
== 20120726235129 AddUserIdToCategories: migrating ============================
-- add_column(:categories, :user_id, :integer)
-> 0.0004s
-- execute("UPDATE categories SET user_id = 1186")
-> 0.0003s
-- change_column(:categories, :user_id, :integer, {:null=>false})
-> 0.0004s
== 20120726235129 AddUserIdToCategories: migrated (0.0023s) ===================
== 20120727005556 RemoveExcerptFromCategories: migrating ======================
-- remove_column(:categories, :excerpt)
-> 0.0003s
== 20120727005556 RemoveExcerptFromCategories: migrated (0.0012s) =============
== 20120727150428 RenameInvisible: migrating ==================================
-- add_column(:forum_threads, :visible, :boolean, {:default=>true, :null=>false})
-> 0.0103s
-- execute("UPDATE forum_threads SET visible = CASE WHEN invisible THEN false ELSE true END")
-> 0.0004s
-- remove_column(:forum_threads, :invisible)
-> 0.0003s
== 20120727150428 RenameInvisible: migrated (0.0124s) =========================
== 20120727213543 AddThreadCountsToCategories: migrating ======================
-- add_column(:categories, :threads_year, :integer)
-> 0.0004s
-- add_column(:categories, :threads_month, :integer)
-> 0.0002s
-- add_column(:categories, :threads_week, :integer)
-> 0.0002s
-- remove_column(:categories, :posts_year)
-> 0.0002s
-- remove_column(:categories, :posts_month)
-> 0.0002s
-- remove_column(:categories, :posts_week)
-> 0.0002s
== 20120727213543 AddThreadCountsToCategories: migrated (0.0029s) =============
== 20120802151210 AddIconToExpressionTypes: migrating =========================
-- add_column(:expression_types, :icon, :string, {:limit=>20})
-> 0.0004s
-- execute("UPDATE expression_types SET icon = 'heart' WHERE expression_index = 1")
-> 0.0003s
== 20120802151210 AddIconToExpressionTypes: migrated (0.0017s) ================
== 20120803191426 AddAdminFlagToUsers: migrating ==============================
-- add_column(:users, :admin, :boolean, {:default=>false, :null=>false})
-> 0.0215s
-- add_column(:users, :moderator, :boolean, {:default=>false, :null=>false})
-> 0.0198s
-- execute("UPDATE users SET admin = TRUE where lower(username) in ('eviltrout', 'codinghorror', 'sam', 'hanzo')")
-> 0.0005s
== 20120803191426 AddAdminFlagToUsers: migrated (0.0433s) =====================
== 20120806030641 AddNewPasswordNewSaltEmailTokenToUsers: migrating ===========
-- add_column(:users, :new_salt, :string, {:limit=>32})
-> 0.0004s
-- add_column(:users, :new_password_hash, :string, {:limit=>64})
-> 0.0003s
-- add_column(:users, :email_token, :string, {:limit=>32})
-> 0.0003s
-- remove_column(:users, :activation_key)
-> 0.0002s
== 20120806030641 AddNewPasswordNewSaltEmailTokenToUsers: migrated (0.0025s) ==
== 20120806062617 RemoveNewPasswordStuffFromUser: migrating ===================
-- remove_column(:users, :new_password_hash)
-> 0.0002s
-- remove_column(:users, :new_salt)
-> 0.0002s
== 20120806062617 RemoveNewPasswordStuffFromUser: migrated (0.0014s) ==========
== 20120807223020 CreateActions: migrating ====================================
-- create_table(:actions)
-> 0.0045s
-- add_index(:actions, [:user_id, :action_type])
-> 0.0038s
-- add_index(:actions, [:acting_user_id])
-> 0.0034s
== 20120807223020 CreateActions: migrated (0.0132s) ===========================
== 20120809020415 RemoveSiteId: migrating =====================================
-- drop_table("sites")
-> 0.0006s
-- remove_index("incoming_links", {:name=>"incoming_index"})
-> 0.0010s
-- add_index("incoming_links", ["forum_thread_id", "post_number"], {:name=>"incoming_index"})
-> 0.0039s
-- remove_column("incoming_links", "site_id")
-> 0.0002s
-- remove_index("users", {:name=>"index_users_on_site_id"})
-> 0.0010s
-- remove_column("users", "site_id")
-> 0.0002s
-- remove_index("expression_types", {:name=>"index_expression_types_on_site_id_and_expression_index"})
-> 0.0008s
-- remove_index("expression_types", {:name=>"index_expression_types_on_site_id_and_name"})
-> 0.0008s
-- remove_column("expression_types", "site_id")
-> 0.0002s
-- add_index("expression_types", ["expression_index"], {:unique=>true})
-> 0.0129s
-- add_index("expression_types", ["name"], {:unique=>true})
-> 0.0040s
-- drop_table("forums")
-> 0.0005s
== 20120809020415 RemoveSiteId: migrated (0.0279s) ============================
== 20120809030647 RemoveForumId: migrating ====================================
-- remove_column("forum_threads", "forum_id")
-> 0.0003s
-- remove_column("categories", "forum_id")
-> 0.0002s
== 20120809030647 RemoveForumId: migrated (0.0017s) ===========================
== 20120809053414 CorrectIndexingOnPosts: migrating ===========================
-- execute("update posts pp\nset post_number = c.real_number\nfrom\n(\n\tselect p1.id, count(*) real_number from posts p1\n\tjoin posts p2 on p1.forum_thread_id = p2.forum_thread_id\n\twhere p2.id <= p1.id and p1.forum_thread_id = p2.forum_thread_id\n group by p1.id\n) as c\nwhere pp.id = c.id and pp.post_number <> c.real_number")
-> 0.0006s
-- remove_index("posts", ["forum_thread_id", "post_number"])
-> 0.0010s
-- add_index("posts", ["forum_thread_id", "post_number"], {:unique=>true})
-> 0.0038s
== 20120809053414 CorrectIndexingOnPosts: migrated (0.0067s) ==================
== 20120809154750 RemoveIndexForNow: migrating ================================
-- remove_index("posts", ["forum_thread_id", "post_number"])
-> 0.0011s
-- add_index("posts", ["forum_thread_id", "post_number"], {:unique=>false})
-> 0.0038s
== 20120809154750 RemoveIndexForNow: migrated (0.0062s) =======================
== 20120809174649 CreatePostActions: migrating ================================
-- create_table(:post_actions)
-> 0.0041s
-- add_index(:post_actions, ["post_id"])
-> 0.0036s
-- execute("create unique index idx_unique_actions on\n post_actions(user_id, post_action_type_id, post_id) where deleted_at is null")
-> 0.0025s
== 20120809174649 CreatePostActions: migrated (0.0114s) =======================
== 20120809175110 CreatePostActionTypes: migrating ============================
-- create_table(:post_action_types, {:id=>false})
-> 0.0137s
== 20120809175110 CreatePostActionTypes: migrated (0.0149s) ===================
== 20120809201855 MigrateBookmarksToPostActions: migrating ====================
-- drop_table("bookmarks")
-> 0.0006s
== 20120809201855 MigrateBookmarksToPostActions: migrated (0.0016s) ===========
== 20120810064839 RenameActionsToUserActions: migrating =======================
-- rename_table("actions", "user_actions")
-> 0.0034s
== 20120810064839 RenameActionsToUserActions: migrated (0.0046s) ==============
== 20120812235417 RetireExpressions: migrating ================================
-- execute("insert into post_actions (post_action_type_id, user_id, post_id, created_at, updated_at)\nselect\n\tcase\n\t when expression_index=1 then 3\n\t when expression_index=2 then 4\n\t when expression_index=3 then 2\n\tend\n\n\t, user_id, post_id, created_at, updated_at from expressions")
-> 0.0004s
-- drop_table("expressions")
-> 0.0004s
-- drop_table("expression_types")
-> 0.0006s
== 20120812235417 RetireExpressions: migrated (0.0027s) =======================
== 20120813004347 RenameExpressionColumnsInForumThread: migrating =============
-- rename_column("forum_threads", "expression1_count", "off_topic_count")
-> 0.0014s
-- rename_column("forum_threads", "expression2_count", "offensive_count")
-> 0.0010s
-- rename_column("forum_threads", "expression3_count", "like_count")
-> 0.0010s
-- remove_column("forum_threads", "expression4_count")
-> 0.0004s
-- remove_column("forum_threads", "expression5_count")
-> 0.0003s
== 20120813004347 RenameExpressionColumnsInForumThread: migrated (0.0054s) ====
== 20120813042912 RenameExpressionColumnsInPosts: migrating ===================
-- rename_column("posts", "expression1_count", "off_topic_count")
-> 0.0016s
-- rename_column("posts", "expression2_count", "offensive_count")
-> 0.0016s
-- rename_column("posts", "expression3_count", "like_count")
-> 0.0015s
-- remove_column("posts", "expression4_count")
-> 0.0003s
-- remove_column("posts", "expression5_count")
-> 0.0002s
== 20120813042912 RenameExpressionColumnsInPosts: migrated (0.0065s) ==========
== 20120813201426 CreateForumThreadLinkClicks: migrating ======================
-- create_table(:forum_thread_link_clicks)
-> 0.0126s
-- add_column(:forum_thread_links, :clicks, :integer, {:default=>0, :null=>false})
-> 0.0095s
-- add_index(:forum_thread_link_clicks, :forum_thread_link_id, {:name=>:by_link})
-> 0.0038s
== 20120813201426 CreateForumThreadLinkClicks: migrated (0.0272s) =============
== 20120815004411 AddUniqueIndexToForumThreadLinks: migrating =================
-- execute("DELETE FROM forum_thread_links USING forum_thread_links ftl2\n WHERE ftl2.forum_thread_id = forum_thread_links.forum_thread_id\n AND ftl2.post_id = forum_thread_links.post_id\n AND ftl2.url = forum_thread_links.url\n AND ftl2.id < forum_thread_links.id")
-> 0.0005s
-- add_index(:forum_thread_links, [:forum_thread_id, :post_id, :url], {:unique=>true, :name=>"unique_post_links"})
-> 0.0036s
== 20120815004411 AddUniqueIndexToForumThreadLinks: migrated (0.0053s) ========
== 20120815180106 AddPostTypeToPosts: migrating ===============================
-- add_column(:posts, :post_type, :integer, {:default=>1, :null=>false})
-> 0.0139s
== 20120815180106 AddPostTypeToPosts: migrated (0.0152s) ======================
== 20120815204733 AddModeratorPostsCountToForumThreads: migrating =============
-- add_column(:forum_threads, :moderator_posts_count, :integer, {:default=>0, :null=>false})
-> 0.0202s
-- execute("UPDATE forum_threads\n SET moderator_posts_count = (SELECT COUNT(*)\n FROM posts WHERE posts.forum_thread_id = forum_threads.id\n AND posts.post_type = 2)")
-> 0.0006s
== 20120815204733 AddModeratorPostsCountToForumThreads: migrated (0.0222s) ====
== 20120816050526 AddUniqueConstraintToUserActions: migrating =================
-- add_index(:user_actions, ["action_type", "user_id", "target_forum_thread_id", "target_post_id", "acting_user_id"], {:name=>"idx_unique_rows", :unique=>true})
-> 0.0040s
== 20120816050526 AddUniqueConstraintToUserActions: migrated (0.0052s) ========
== 20120816205537 AddForumThreadStates: migrating =============================
-- add_column(:forum_threads, :closed, :boolean, {:default=>false, :null=>false})
-> 0.0103s
-- add_column(:forum_threads, :sticky, :boolean, {:default=>false, :null=>false})
-> 0.0202s
-- add_column(:forum_threads, :archived, :boolean, {:default=>false, :null=>false})
-> 0.0107s
== 20120816205537 AddForumThreadStates: migrated (0.0427s) ====================
== 20120816205538 AddStarredAtToForumThreadUser: migrating ====================
-- add_column(:forum_thread_users, :starred_at, :datetime)
-> 0.0003s
-- execute("alter table forum_thread_users add constraint test_starred_at check(starred = false or starred_at is not null)")
-> 0.0004s
== 20120816205538 AddStarredAtToForumThreadUser: migrated (0.0026s) ===========
== 20120820191804 AddSearchIndices: migrating =================================
-- execute("CREATE INDEX idx_search_user ON users USING GIN(to_tsvector('english', username))")
-> 0.0008s
-- execute("CREATE INDEX idx_search_thread ON forum_threads USING GIN(to_tsvector('english', title))")
-> 0.0005s
== 20120820191804 AddSearchIndices: migrated (0.0024s) ========================
== 20120821191616 AddBumpedAtToForumThreads: migrating ========================
-- add_column(:forum_threads, :bumped_at, :datetime)
-> 0.0004s
-- execute("UPDATE forum_threads SET bumped_at = last_posted_at")
-> 0.0003s
-- change_column(:forum_threads, :bumped_at, :datetime, {:null=>false})
-> 0.0004s
-- remove_index(:forum_threads, :last_posted_at)
-> 0.0009s
-- add_index(:forum_threads, :bumped_at, {:order=>{:bumped_at=>:desc}})
-> 0.0041s
== 20120821191616 AddBumpedAtToForumThreads: migrated (0.0073s) ===============
== 20120823205956 AddSlugToCategories: migrating ==============================
-- add_column(:categories, :slug, :string)
-> 0.0004s
-- execute("UPDATE categories SET slug = REPLACE(LOWER(name), ' ', '-')")
-> 0.0002s
-- change_column(:categories, :slug, :string, {:null=>false})
-> 0.0004s
== 20120823205956 AddSlugToCategories: migrated (0.0021s) =====================
== 20120824171908 CreateCategoryFeaturedUsers: migrating ======================
-- create_table(:category_featured_users)
-> 0.0038s
-- add_index(:category_featured_users, [:category_id, :user_id], {:unique=>true})
-> 0.0132s
== 20120824171908 CreateCategoryFeaturedUsers: migrated (0.0184s) =============
== 20120828204209 CreateOneboxRenders: migrating ==============================
-- create_table(:onebox_renders)
-> 0.0067s
-- add_index(:onebox_renders, :url, {:unique=>true})
-> 0.0034s
== 20120828204209 CreateOneboxRenders: migrated (0.0113s) =====================
== 20120828204624 CreatePostOneboxRenders: migrating ==========================
-- create_table(:post_onebox_renders, {:id=>false})
-> 0.0008s
-- add_index(:post_onebox_renders, [:post_id, :onebox_render_id], {:unique=>true})
-> 0.0035s
== 20120828204624 CreatePostOneboxRenders: migrated (0.0054s) =================
== 20120830182736 AddPreviewToOneboxRenders: migrating ========================
-- add_column(:onebox_renders, :preview, :text, {:null=>true})
-> 0.0003s
-- execute("DELETE FROM onebox_renders")
-> 0.0003s
-- execute("DELETE FROM post_onebox_renders")
-> 0.0003s
== 20120830182736 AddPreviewToOneboxRenders: migrated (0.0021s) ===============
== 20120910171504 RemoveDescriptionFromSiteSettings: migrating ================
-- remove_column(:site_settings, :description)
-> 0.0003s
== 20120910171504 RemoveDescriptionFromSiteSettings: migrated (0.0013s) =======
== 20120918152319 RenameViewsToReads: migrating ===============================
-- rename_column(:posts, :views, :reads)
-> 0.0016s
== 20120918152319 RenameViewsToReads: migrated (0.0026s) ======================
== 20120918205931 AddSubTagToForumThreads: migrating ==========================
-- add_column(:forum_threads, :sub_tag, :string)
-> 0.0004s
-- add_index(:forum_threads, [:category_id, :sub_tag, :bumped_at])
-> 0.0138s
== 20120918205931 AddSubTagToForumThreads: migrated (0.0156s) =================
== 20120919152846 AddHasBestOfToForumThreads: migrating =======================
-- add_column(:forum_threads, :has_best_of, :boolean, {:default=>false, :null=>false})
-> 0.0124s
-- change_column(:posts, :score, :float)
-> 0.0004s
== 20120919152846 AddHasBestOfToForumThreads: migrated (0.0142s) ==============
== 20120921055428 AddTwitterUserInfo: migrating ===============================
-- create_table(:twitter_user_infos)
-> 0.0067s
-- add_index(:twitter_user_infos, [:twitter_user_id], {:unique=>true})
-> 0.0036s
-- add_index(:twitter_user_infos, [:user_id], {:unique=>true})
-> 0.0038s
== 20120921055428 AddTwitterUserInfo: migrated (0.0154s) ======================
== 20120921155050 CreateArchetypes: migrating =================================
-- create_table(:archetypes)
-> 0.0063s
-- add_index(:archetypes, :name_key, {:unique=>true})
-> 0.0035s
-- execute("INSERT INTO archetypes (name_key, created_at, updated_at) VALUES ('regular', CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)")
-> 0.0003s
-- execute("INSERT INTO archetypes (name_key, created_at, updated_at) VALUES ('poll', CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)")
-> 0.0002s
-- add_column(:forum_threads, :archetype_id, :integer, {:default=>1, :null=>false})
-> 0.0200s
== 20120921155050 CreateArchetypes: migrated (0.0316s) ========================
== 20120921162512 AddMetaDataToForumThreads: migrating ========================
-- execute("CREATE EXTENSION IF NOT EXISTS hstore")
-> 0.0002s
-- add_column(:forum_threads, :meta_data, :hstore)
-> 0.0004s
== 20120921162512 AddMetaDataToForumThreads: migrated (0.0017s) ===============
== 20120921163606 CreateArchetypeOptions: migrating ===========================
-- create_table(:archetype_options)
-> 0.0072s
-- add_index(:archetype_options, :archetype_id)
-> 0.0040s
-- execute("INSERT INTO archetype_options (archetype_id, key, option_type, created_at, updated_at)\n VALUES (2, 'private_poll', 1, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)")
-> 0.0003s
-- execute("INSERT INTO archetype_options (archetype_id, key, option_type, created_at, updated_at)\n VALUES (2, 'single_vote', 1, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)")
-> 0.0002s
== 20120921163606 CreateArchetypeOptions: migrated (0.0129s) ==================
== 20120924182000 AddHstoreExtension: migrating ===============================
-- execute("CREATE EXTENSION IF NOT EXISTS hstore")
-> 0.0001s
== 20120924182000 AddHstoreExtension: migrated (0.0012s) ======================
== 20120924182031 AddVoteCountToPosts: migrating ==============================
-- add_column(:forum_threads, :vote_count, :integer, {:default=>0, :null=>false})
-> 0.0224s
-- add_column(:posts, :vote_count, :integer, {:default=>0, :null=>false})
-> 0.0135s
== 20120924182031 AddVoteCountToPosts: migrated (0.0373s) =====================
== 20120925171620 RemoveEnglishFromPostActionTypes: migrating =================
-- rename_column(:post_action_types, :name, :name_key)
-> 0.0010s
-- execute("UPDATE post_action_types SET name_key = regexp_replace(lower(name_key), '[^a-z]', '_')")
-> 0.0002s
-- remove_column(:post_action_types, :long_form)
-> 0.0002s
-- remove_column(:post_action_types, :description)
-> 0.0002s
== 20120925171620 RemoveEnglishFromPostActionTypes: migrated (0.0028s) ========
== 20120925190802 AddSequenceToPostActionTypes: migrating =====================
-- remove_column(:post_action_types, :id)
-> 0.0002s
-- add_column(:post_action_types, :id, :primary_key)
-> 0.0069s
== 20120925190802 AddSequenceToPostActionTypes: migrated (0.0084s) ============
== 20120928170023 AddSortOrderToPosts: migrating ==============================
-- add_column(:posts, :sort_order, :integer)
-> 0.0004s
-- remove_index(:posts, :user_id)
-> 0.0010s
-- execute("UPDATE posts AS p SET sort_order = post_number FROM forum_threads AS ft WHERE ft.id = p.forum_thread_id AND ft.archetype_id = 1")
-> 0.0006s
-- execute("UPDATE posts AS p SET sort_order =\n CASE WHEN post_number = 1 THEN 1\n ELSE 2147483647 - p.vote_count\n END\n FROM forum_threads AS ft\n WHERE ft.id = p.forum_thread_id AND ft.archetype_id = 2")
-> 0.0004s
== 20120928170023 AddSortOrderToPosts: migrated (0.0038s) =====================
== 20121009161116 AddEmailStuffToUsers: migrating =============================
-- add_column(:users, :last_emailed_at, :datetime, {:null=>true})
-> 0.0004s
-- add_column(:users, :email_digests, :boolean, {:null=>false, :default=>true})
-> 0.0190s
== 20121009161116 AddEmailStuffToUsers: migrated (0.0207s) ====================
== 20121011155904 CreateEmailLogs: migrating ==================================
-- create_table(:email_logs)
-> 0.0066s
-- add_index(:email_logs, :created_at, {:order=>{:created_at=>:desc}})
-> 0.0037s
-- add_index(:email_logs, [:user_id, :created_at], {:order=>{:created_at=>:desc}})
-> 0.0146s
== 20121011155904 CreateEmailLogs: migrated (0.0264s) =========================
== 20121017162924 ConvertArchetypes: migrating ================================
-- add_column(:forum_threads, :archetype, :string, {:default=>"regular", :null=>false})
-> 0.0129s
-- execute("UPDATE forum_threads SET archetype = a.name_key FROM archetypes AS a WHERE a.id = forum_threads.archetype_id")
-> 0.0006s
-- remove_column(:forum_threads, :archetype_id)
-> 0.0003s
-- drop_table(:archetypes)
-> 0.0007s
-- drop_table(:archetype_options)
-> 0.0007s
== 20121017162924 ConvertArchetypes: migrated (0.0166s) =======================
== 20121018103721 RenameForumThreadTables: migrating ==========================
-- rename_table("forum_threads", "topics")
-> 0.0038s
-- rename_table("forum_thread_link_clicks", "topic_link_clicks")
-> 0.0024s
-- rename_table("forum_thread_links", "topic_links")
-> 0.0027s
-- rename_table("forum_thread_users", "topic_users")
-> 0.0033s
-- rename_table("category_featured_threads", "category_featured_topics")
-> 0.0027s
-- rename_column("categories", "forum_thread_id", "topic_id")
-> 0.0012s
-- rename_column("categories", "top1_forum_thread_id", "top1_topic_id")
-> 0.0012s
-- rename_column("categories", "top2_forum_thread_id", "top2_topic_id")
-> 0.0013s
-- rename_column("categories", "forum_thread_count", "topic_count")
-> 0.0015s
-- rename_column("categories", "threads_year", "topics_year")
-> 0.0012s
-- rename_column("categories", "threads_month", "topics_month")
-> 0.0013s
-- rename_column("categories", "threads_week", "topics_week")
-> 0.0012s
-- rename_column("category_featured_topics", "forum_thread_id", "topic_id")
-> 0.0010s
-- rename_column("topic_link_clicks", "forum_thread_link_id", "topic_link_id")
-> 0.0010s
-- rename_column("topic_links", "forum_thread_id", "topic_id")
-> 0.0015s
-- rename_column("topic_links", "link_forum_thread_id", "link_topic_id")
-> 0.0013s
-- rename_column("topic_users", "forum_thread_id", "topic_id")
-> 0.0013s
-- rename_column("incoming_links", "forum_thread_id", "topic_id")
-> 0.0010s
-- rename_column("notifications", "forum_thread_id", "topic_id")
-> 0.0010s
-- rename_column("post_timings", "forum_thread_id", "topic_id")
-> 0.0014s
-- rename_column("posts", "forum_thread_id", "topic_id")
-> 0.0016s
-- rename_column("user_actions", "target_forum_thread_id", "target_topic_id")
-> 0.0018s
-- rename_column("uploads", "forum_thread_id", "topic_id")
-> 0.0015s
== 20121018103721 RenameForumThreadTables: migrated (0.0400s) =================
== 20121018133039 CreateTopicAllowedUsers: migrating ==========================
-- create_table(:topic_allowed_users)
-> 0.0040s
-- add_index(:topic_allowed_users, [:topic_id, :user_id], {:unique=>true})
-> 0.0036s
-- add_index(:topic_allowed_users, [:user_id, :topic_id], {:unique=>true})
-> 0.0035s
== 20121018133039 CreateTopicAllowedUsers: migrated (0.0126s) =================
== 20121018182709 FixNotificationData: migrating ==============================
-- execute("UPDATE notifications SET data = replace(data, 'thread_title', 'topic_title')")
-> 0.0003s
== 20121018182709 FixNotificationData: migrated (0.0013s) =====================
== 20121106015500 DropAvatarUrlFromUsers: migrating ===========================
-- remove_column(:users, :avatar_url)
-> 0.0003s
== 20121106015500 DropAvatarUrlFromUsers: migrated (0.0013s) ==================
== 20121108193516 AddPostActionIdToNotifications: migrating ===================
-- add_column(:notifications, :post_action_id, :integer, {:null=>true})
-> 0.0004s
-- add_index(:notifications, :post_action_id)
-> 0.0037s
== 20121108193516 AddPostActionIdToNotifications: migrated (0.0053s) ==========
== 20121109164630 CreateTrustLevels: migrating ================================
-- create_table(:trust_levels)
-> 0.0167s
-- add_column(:users, :trust_level_id, :integer, {:default=>1, :null=>false})
-> 0.0185s
== 20121109164630 CreateTrustLevels: migrated (0.0366s) =======================
== 20121113200844 BioMarkdownSupport: migrating ===============================
-- rename_column(:users, :bio, :bio_raw)
-> 0.0024s
-- add_column(:users, :bio_cooked, :text, {:null=>true})
-> 0.0003s
== 20121113200844 BioMarkdownSupport: migrated (0.0064s) ======================
== 20121113200845 CreateFacebookUserInfos: migrating ==========================
-- create_table(:facebook_user_infos)
-> 0.0064s
-- add_index(:facebook_user_infos, :user_id, {:unique=>true})
-> 0.0035s
-- add_index(:facebook_user_infos, :facebook_user_id, {:unique=>true})
-> 0.0119s
== 20121113200845 CreateFacebookUserInfos: migrated (0.0233s) =================
== 20121115172544 RenameStickyToPinned: migrating =============================
-- rename_column(:topics, :sticky, :pinned)
-> 0.0018s
== 20121115172544 RenameStickyToPinned: migrated (0.0030s) ====================
== 20121116212424 AddMoreEmailSettingsToUser: migrating =======================
-- add_column(:users, :email_private_messages, :boolean, {:default=>true})
-> 0.0189s
-- add_column(:users, :email_mentions, :boolean, {:default=>true})
-> 0.0293s
== 20121116212424 AddMoreEmailSettingsToUser: migrated (0.0497s) ==============
== 20121119190529 AddEmailSettingsToUsers: migrating ==========================
-- add_column(:users, :email_replied, :boolean, {:default=>true})
-> 0.0198s
-- add_column(:users, :email_quoted, :boolean, {:default=>true})
-> 0.0280s
== 20121119190529 AddEmailSettingsToUsers: migrated (0.0491s) =================
== 20121119200843 AddEmailDirectToUsers: migrating ============================
-- add_column(:users, :email_direct, :boolean, {:default=>true, :null=>false})
-> 0.0202s
-- remove_column(:users, :email_mentions)
-> 0.0004s
-- remove_column(:users, :email_replied)
-> 0.0003s
-- remove_column(:users, :email_quoted)
-> 0.0003s
== 20121119200843 AddEmailDirectToUsers: migrated (0.0225s) ===================
== 20121121202035 CreateInvites: migrating ====================================
-- create_table(:invites)
-> 0.0167s
-- add_index(:invites, :invite_key, {:unique=>true})
-> 0.0037s
-- add_index(:invites, [:email, :invited_by_id], {:unique=>true})
-> 0.0115s
== 20121121202035 CreateInvites: migrated (0.0334s) ===========================
== 20121121205215 CreateTopicInvites: migrating ===============================
-- create_table(:topic_invites)
-> 0.0037s
-- add_index(:topic_invites, [:topic_id, :invite_id], {:unique=>true})
-> 0.0038s
-- add_index(:topic_invites, :invite_id)
-> 0.0034s
== 20121121205215 CreateTopicInvites: migrated (0.0122s) ======================
== 20121122033316 AddMutedAtToTopicUser: migrating ============================
-- add_column(:topic_users, :muted_at, :datetime)
-> 0.0004s
-- change_column(:topic_users, :last_read_post_number, :integer, {:null=>true})
-> 0.0005s
-- change_column_default(:topic_users, :last_read_post_number, nil)
-> 0.0008s
== 20121122033316 AddMutedAtToTopicUser: migrated (0.0028s) ===================
== 20121123054127 MakePostNumberDistinct: migrating ===========================
== 20121123054127 MakePostNumberDistinct: migrated (0.0017s) ==================
== 20121123063630 CreateUserVisits: migrating =================================
-- create_table(:user_visits)
-> 0.0117s
-- add_index(:user_visits, [:user_id, :visited_at], {:unique=>true})
-> 0.0038s
== 20121123063630 CreateUserVisits: migrated (0.0169s) ========================
== 20121129160035 CreateEmailTokens: migrating ================================
-- create_table(:email_tokens)
-> 0.0069s
-- add_index(:email_tokens, :token, {:unique=>true})
-> 0.0037s
== 20121129160035 CreateEmailTokens: migrated (0.0118s) =======================
== 20121129184948 RemoveEmailTokenFromUsers: migrating ========================
-- execute("INSERT INTO email_tokens (user_id, email, token, created_at, updated_at)\n SELECT id, email, email_token, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP\n FROM users WHERE email_token IS NOT NULL")
-> 0.0006s
-- remove_column(:users, :email_token)
-> 0.0003s
== 20121129184948 RemoveEmailTokenFromUsers: migrated (0.0020s) ===============
== 20121130010400 CreateDrafts: migrating =====================================
-- create_table(:drafts)
-> 0.0069s
-- add_index(:drafts, [:user_id, :draft_key])
-> 0.0037s
== 20121130010400 CreateDrafts: migrated (0.0119s) ============================
== 20121130191818 AddLinkPostIdToTopicLinks: migrating ========================
-- add_column(:topic_links, :link_post_id, :integer)
-> 0.0004s
== 20121130191818 AddLinkPostIdToTopicLinks: migrated (0.0015s) ===============
== 20121202225421 AddVisitedAtToTopicUser: migrating ==========================
-- add_column(:topic_users, :last_visited_at, :datetime)
-> 0.0003s
-- add_column(:topic_users, :first_visited_at, :datetime)
-> 0.0002s
== 20121202225421 AddVisitedAtToTopicUser: migrated (0.0017s) =================
== 20121203181719 RenameSeenNotificaitonId: migrating =========================
-- rename_column(:users, :seen_notificaiton_id, :seen_notification_id)
-> 0.0023s
== 20121203181719 RenameSeenNotificaitonId: migrated (0.0033s) ================
== 20121204183855 FixLinkPostId: migrating ====================================
== 20121204183855 FixLinkPostId: migrated (0.0081s) ===========================
== 20121204193747 AddAnotherFeaturedUserToTopics: migrating ===================
-- add_column(:topics, :featured_user4_id, :integer, {:null=>true})
-> 0.0004s
== 20121204193747 AddAnotherFeaturedUserToTopics: migrated (0.0015s) ==========
== 20121205162143 AddApprovedToUsers: migrating ===============================
-- add_column(:users, :approved, :boolean, {:null=>false, :default=>false})
-> 0.0190s
-- add_column(:users, :approved_by_id, :integer, {:null=>true})
-> 0.0004s
-- add_column(:users, :approved_at, :timestamp, {:null=>true})
-> 0.0002s
== 20121205162143 AddApprovedToUsers: migrated (0.0211s) ======================
== 20121207000741 AddNotificationsToTopicUsers: migrating =====================
-- add_column(:topic_users, :notifications, :integer, {:default=>2})
-> 0.0057s
-- add_column(:topic_users, :notifications_changed_at, :datetime)
-> 0.0004s
-- add_column(:topic_users, :notifications_reason_id, :integer)
-> 0.0003s
== 20121207000741 AddNotificationsToTopicUsers: migrated (0.0077s) ============
== 20121211233131 CreateSiteCustomizations: migrating =========================
-- create_table(:site_customizations)
-> 0.0071s
-- add_index(:site_customizations, [:key])
-> 0.0036s
== 20121211233131 CreateSiteCustomizations: migrated (0.0119s) ================
== 20121216230719 AddOverrideDefaultStyleToSiteCustomization: migrating =======
-- add_column(:site_customizations, :override_default_style, :boolean, {:default=>false, :null=>false})
-> 0.0099s
-- add_column(:site_customizations, :stylesheet_baked, :text, {:default=>"", :null=>false})
-> 0.0099s
== 20121216230719 AddOverrideDefaultStyleToSiteCustomization: migrated (0.0211s)
== 20121218205642 AddTopicsEnteredToUsers: migrating ==========================
-- add_column(:users, :topics_entered, :integer, {:default=>0, :null=>false})
-> 0.0294s
-- add_column(:users, :posts_read_count, :integer, {:default=>0, :null=>false})
-> 0.0189s
== 20121218205642 AddTopicsEnteredToUsers: migrated (0.0497s) =================
== 20121224072204 AddLastEditorIdToPosts: migrating ===========================
-- add_column(:posts, :last_editor_id, :integer)
-> 0.0004s
== 20121224072204 AddLastEditorIdToPosts: migrated (0.0016s) ==================
== 20121224095139 CreateDraftSequence: migrating ==============================
-- create_table(:draft_sequences)
-> 0.0114s
-- add_index(:draft_sequences, [:user_id, :draft_key], {:unique=>true})
-> 0.0037s
== 20121224095139 CreateDraftSequence: migrated (0.0165s) =====================
== 20121224100650 AddSequenceToDrafts: migrating ==============================
-- add_column(:drafts, :sequence, :integer, {:null=>false, :default=>0})
-> 0.0101s
== 20121224100650 AddSequenceToDrafts: migrated (0.0114s) =====================
== 20121228192219 AddDeletedAtToInvites: migrating ============================
-- add_column(:invites, :deleted_at, :datetime)
-> 0.0004s
== 20121228192219 AddDeletedAtToInvites: migrated (0.0016s) ===================
== 20130107165207 AddDigestAfterDaysToUsers: migrating ========================
-- add_column(:users, :digest_after_days, :integer, {:default=>7, :null=>false})
-> 0.0306s
== 20130107165207 AddDigestAfterDaysToUsers: migrated (0.0320s) ===============
== 20130108195847 AddPreviousVisitAtToUsers: migrating ========================
-- add_column(:users, :previous_visit_at, :timestamp)
-> 0.0005s
== 20130108195847 AddPreviousVisitAtToUsers: migrated (0.0018s) ===============
== 20130115012140 MergeMuteOptionsOnTopicUsers: migrating =====================
-- execute("update topic_users set notifications = 0 where notifications = 3")
-> 0.0003s
-- execute("update topic_users set notifications = 1 where notifications = 2")
-> 0.0002s
-- execute("update topic_users set notifications = 2 where notifications = 1")
-> 0.0002s
-- execute("update topic_users set notifications = 0 where muted_at is not null")
-> 0.0002s
-- rename_column(:topic_users, :notifications, :notification_level)
-> 0.0012s
-- remove_column(:topic_users, :muted_at)
-> 0.0002s
== 20130115012140 MergeMuteOptionsOnTopicUsers: migrated (0.0034s) ============
== 20130115021937 CorrectDefaultOnNotificationLevel: migrating ================
-- change_column(:topic_users, :notification_level, :integer, {:default=>1, :null=>false})
-> 0.0024s
== 20130115021937 CorrectDefaultOnNotificationLevel: migrated (0.0034s) =======
== 20130115043603 OopsUnwatchABoatOfWatchedStuff: migrating ===================
-- execute("update topic_users set notification_level = 1 where notifications_reason_id is null and notification_level = 2")
-> 0.0003s
== 20130115043603 OopsUnwatchABoatOfWatchedStuff: migrated (0.0014s) ==========
== 20130116151829 RemoveSubTagFromTopics: migrating ===========================
-- remove_column(:topics, :sub_tag)
-> 0.0005s
== 20130116151829 RemoveSubTagFromTopics: migrated (0.0017s) ==================
== 20130120222728 FixSearch: migrating ========================================
-- execute("drop index idx_search_thread")
-> 0.0003s
-- execute("drop index idx_search_user")
-> 0.0002s
-- execute("create table posts_search (id integer not null primary key, search_data tsvector)")
-> 0.0055s
-- execute("create table users_search (id integer not null primary key, search_data tsvector)")
-> 0.0142s
-- execute("create table categories_search (id integer not null primary key, search_data tsvector)")
-> 0.0063s
-- execute("create index idx_search_post on posts_search using gin(search_data) ")
-> 0.0004s
-- execute("create index idx_search_user on users_search using gin(search_data) ")
-> 0.0004s
-- execute("create index idx_search_category on categories_search using gin(search_data) ")
-> 0.0003s
== 20130120222728 FixSearch: migrated (0.0291s) ===============================
== 20130121231352 AddTrackingToTopicUsers: migrating ==========================
-- execute("update topic_users set notification_level = 3 where notification_level = 2")
-> 0.0002s
== 20130121231352 AddTrackingToTopicUsers: migrated (0.0015s) =================
== 20130122051134 AddAutoTrackTopicsToUser: migrating =========================
-- add_column(:users, :auto_track_topics, :boolean, {:null=>false, :default=>false})
-> 0.0188s
== 20130122051134 AddAutoTrackTopicsToUser: migrated (0.0201s) ================
== 20130122232825 AddAutoTrackAfterSecondsAndBanningAndDobToUser: migrating ===
-- add_column(:users, :banned_at, :datetime)
-> 0.0004s
-- add_column(:users, :banned_till, :datetime)
-> 0.0002s
-- add_column(:users, :date_of_birth, :date)
-> 0.0002s
-- add_column(:users, :auto_track_topics_after_msecs, :integer)
-> 0.0003s
-- add_column(:users, :views, :integer, {:null=>false, :default=>0})
-> 0.0287s
-- remove_column(:users, :auto_track_topics)
-> 0.0004s
-- add_column(:topic_users, :total_msecs_viewed, :integer, {:null=>false, :default=>0})
-> 0.0059s
-- execute("update topic_users set total_msecs_viewed =\n (\n select coalesce(sum(msecs) ,0)\n from post_timings t\n where topic_users.topic_id = t.topic_id and topic_users.user_id = t.user_id\n )")
-> 0.0005s
== 20130122232825 AddAutoTrackAfterSecondsAndBanningAndDobToUser: migrated (0.0381s)
== 20130123070909 AutoTrackAllTopicsRepliedTo: migrating ======================
-- execute("update topic_users set notification_level = 2, notifications_reason_id = 4\n from posts p\n where\n notification_level = 1 and\n notifications_reason_id is null and\n p.topic_id = topic_users.topic_id and\n p.user_id = topic_users.user_id\n ")
-> 0.0006s
== 20130123070909 AutoTrackAllTopicsRepliedTo: migrated (0.0019s) =============
== 20130125002652 AddHiddenToPosts: migrating =================================
-- add_column(:posts, :hidden, :boolean, {:null=>false, :default=>false})
-> 0.0224s
-- add_column(:posts, :hidden_reason_id, :integer)
-> 0.0004s
== 20130125002652 AddHiddenToPosts: migrated (0.0241s) ========================
== 20130125030305 AddFieldsToPostAction: migrating ============================
-- add_column(:post_actions, :deleted_by, :integer)
-> 0.0004s
-- add_column(:post_actions, :message, :text)
-> 0.0028s
== 20130125030305 AddFieldsToPostAction: migrated (0.0045s) ===================
== 20130125031122 CorrectIndexOnPostAction: migrating =========================
-- remove_index("post_actions", {:name=>"idx_unique_actions"})
-> 0.0010s
-- add_index("post_actions", ["user_id", "post_action_type_id", "post_id", "deleted_at"], {:name=>"idx_unique_actions", :unique=>true})
-> 0.0037s
== 20130125031122 CorrectIndexOnPostAction: migrated (0.0060s) ================
== 20130127213646 RemoveTrustLevels: migrating ================================
-- drop_table(:trust_levels)
-> 0.0008s
-- change_column_default(:users, :trust_level_id, 0)
-> 0.0016s
-- rename_column(:users, :trust_level_id, :trust_level)
-> 0.0021s
-- update("UPDATE users set trust_level = 1")
-> 0.0005s
-> 0 rows
-- remove_column(:users, :moderator)
-> 0.0003s
-- add_column(:users, :flag_level, :integer, {:null=>false, :default=>0})
-> 0.0300s
== 20130127213646 RemoveTrustLevels: migrated (0.0369s) =======================
== 20130128182013 TrustLevelDefaultNull: migrating ============================
-- change_column_default(:users, :trust_level, nil)
-> 0.0016s
== 20130128182013 TrustLevelDefaultNull: migrated (0.0029s) ===================
== 20130129010625 RemovePmReflections: migrating ==============================
-- execute("delete from topic_links where link_topic_id in (select id from topics where archetype = 'private_message') ")
-> 0.0005s
== 20130129010625 RemovePmReflections: migrated (0.0015s) =====================
== 20130129163244 AddTimeReadToUsers: migrating ===============================
-- add_column(:users, :time_read, :integer, {:default=>0, :null=>false})
-> 0.0191s
-- execute("UPDATE users SET time_read = posts_read_count * 20")
-> 0.0004s
== 20130129163244 AddTimeReadToUsers: migrated (0.0209s) ======================
== 20130129174845 AddDaysVisitedToUsers: migrating ============================
-- add_column(:users, :days_visited, :integer, {:null=>false, :default=>0})
-> 0.0196s
-- execute("UPDATE users AS u SET days_visited = (SELECT COUNT(*) FROM user_visits AS uv WHERE uv.user_id = u.id)")
-> 0.0007s
== 20130129174845 AddDaysVisitedToUsers: migrated (0.0217s) ===================
== 20130130154611 RemoveIndexFromViews: migrating =============================
-- remove_index("views", {:name=>"unique_views"})
-> 0.0012s
-- change_column(:views, :viewed_at, :date)
-> 0.0114s
== 20130130154611 RemoveIndexFromViews: migrated (0.0141s) ====================
== 20130131055710 AddCustomFlagCountToTopics: migrating =======================
-- add_column(:topics, :custom_flag_count, :integer, {:null=>false, :default=>0})
-> 0.0168s
-- add_column(:posts, :custom_flag_count, :integer, {:null=>false, :default=>0})
-> 0.0122s
== 20130131055710 AddCustomFlagCountToTopics: migrated (0.0304s) ==============
== 20130201000828 AddColumnSummariesToPostsAndTopics: migrating ===============
-- add_column(:posts, :spam_count, :integer, {:default=>0, :null=>false})
-> 0.0117s
-- add_column(:topics, :spam_count, :integer, {:default=>0, :null=>false})
-> 0.0185s
-- add_column(:posts, :illegal_count, :integer, {:default=>0, :null=>false})
-> 0.0122s
-- add_column(:topics, :illegal_count, :integer, {:default=>0, :null=>false})
-> 0.0104s
-- add_column(:posts, :inappropriate_count, :integer, {:default=>0, :null=>false})
-> 0.0125s
-- add_column(:topics, :inappropriate_count, :integer, {:default=>0, :null=>false})
-> 0.0207s
-- remove_column(:posts, :offensive_count)
-> 0.0004s
-- remove_column(:topics, :offensive_count)
-> 0.0004s
== 20130201000828 AddColumnSummariesToPostsAndTopics: migrated (0.0884s) ======
== 20130201023409 AddPositionToPostActionType: migrating ======================
-- add_column(:post_action_types, :position, :integer, {:default=>0, :null=>false})
-> 0.0063s
== 20130201023409 AddPositionToPostActionType: migrated (0.0077s) =============
== 20130203204338 AddLastVersionAtToPosts: migrating ==========================
-- add_column(:posts, :last_version_at, :timestamp)
-> 0.0004s
-- execute("UPDATE posts SET last_version_at = COALESCE((SELECT max(created_at)\n FROM versions WHERE versions.versioned_id = posts.id\n AND versions.versioned_type = 'Post'), posts.created_at)")
-> 0.0005s
-- change_column(:posts, :last_version_at, :timestamp, {:null=>false})
-> 0.0004s
== 20130203204338 AddLastVersionAtToPosts: migrated (0.0025s) =================
== 20130204000159 AddIpAddressToUsers: migrating ==============================
-- execute("alter table users add column ip_address inet")
-> 0.0003s
== 20130204000159 AddIpAddressToUsers: migrated (0.0013s) =====================
== 20130205021905 AlterFacebookUserId: migrating ==============================
-- change_column(:facebook_user_infos, :facebook_user_id, :integer, {:limit=>8, :null=>false})
-> 0.0222s
== 20130205021905 AlterFacebookUserId: migrated (0.0235s) =====================
== 20130207200019 AddUserDeletedToPosts: migrating ============================
-- add_column(:posts, :user_deleted, :boolean, {:null=>false, :default=>false})
-> 0.0119s
== 20130207200019 AddUserDeletedToPosts: migrated (0.0133s) ===================
== 20130208220635 RemoveReplyBelowPostNumberFromPosts: migrating ==============
-- remove_column(:posts, :reply_below_post_number)
-> 0.0005s
== 20130208220635 RemoveReplyBelowPostNumberFromPosts: migrated (0.0019s) =====
== 20130213021450 RemoveTopicResponseActions: migrating =======================
-- execute("delete from user_actions where action_type = 8")
-> 0.0004s
== 20130213021450 RemoveTopicResponseActions: migrated (0.0015s) ==============
== 20130213203300 AddNewTopicDurationMinutesToUsers: migrating ================
-- add_column(:users, :new_topic_duration_minutes, :integer)
-> 0.0004s
== 20130213203300 AddNewTopicDurationMinutesToUsers: migrated (0.0014s) =======
== 20130221215017 AddDescriptionToCategories: migrating =======================
-- add_column(:categories, :description, :text, {:null=>true})
-> 0.0003s
-- remove_column(:categories, :top1_topic_id)
-> 0.0002s
-- remove_column(:categories, :top2_topic_id)
-> 0.0002s
-- remove_column(:categories, :top1_user_id)
-> 0.0002s
-- remove_column(:categories, :top2_user_id)
-> 0.0002s
== 20130221215017 AddDescriptionToCategories: migrated (0.0040s) ==============
== 20130226015336 AddGithubUserInfo: migrating ================================
-- create_table(:github_user_infos)
-> 0.0066s
-- add_index(:github_user_infos, [:github_user_id], {:unique=>true})
-> 0.0133s
-- add_index(:github_user_infos, [:user_id], {:unique=>true})
-> 0.0036s
== 20130226015336 AddGithubUserInfo: migrated (0.0249s) =======================
== 20130306180148 AddClearedPinnedToTopicUsers: migrating =====================
-- add_column(:topic_users, :cleared_pinned_at, :datetime, {:null=>true})
-> 0.0003s
-- add_column(:topics, :pinned_at, :datetime, {:null=>true})
-> 0.0003s
-- execute("UPDATE topics SET pinned_at = created_at WHERE pinned")
-> 0.0003s
-- remove_column(:topics, :pinned)
-> 0.0004s
== 20130306180148 AddClearedPinnedToTopicUsers: migrated (0.0024s) ============
== 20130311181327 RemoveExtraSpamRecord: migrating ============================
-- execute("UPDATE post_actions SET post_action_type_id = 7 where post_action_type_id = 8")
-> 0.0003s
-- execute("DELETE FROM post_action_types WHERE id = 8")
-> 0.0002s
== 20130311181327 RemoveExtraSpamRecord: migrated (0.0015s) ===================
== 20130313004922 AddExternalLinksInNewTabAnDisableQuotingToUser: migrating ===
-- add_column(:users, :external_links_in_new_tab, :boolean, {:default=>false, :null=>false})
-> 0.0191s
-- add_column(:users, :enable_quoting, :boolean, {:default=>true, :null=>false})
-> 0.0285s
== 20130313004922 AddExternalLinksInNewTabAnDisableQuotingToUser: migrated (0.0490s)
== 20130314093434 AddForegroundColorToCategories: migrating ===================
-- add_column(:categories, :text_color, :string, {:limit=>6, :null=>false, :default=>"FFFFFF"})
-> 0.0125s
== 20130314093434 AddForegroundColorToCategories: migrated (0.0138s) ==========
== 20130315180637 EnableTrigramSupport: migrating =============================
-- execute("CREATE EXTENSION IF NOT EXISTS pg_trgm")
-> 0.0001s
== 20130315180637 EnableTrigramSupport: migrated (0.0013s) ====================
== 20130319122248 AddReplyToUserIdToPost: migrating ===========================
-- add_column(:posts, :reply_to_user_id, :integer)
-> 0.0004s
-- execute("UPDATE posts p SET reply_to_user_id = (\n SELECT u.id from users u \n JOIN posts p2 ON p2.user_id = u.id AND \n p2.post_number = p.reply_to_post_number AND\n p2.topic_id = p.topic_id\n )")
-> 0.0007s
== 20130319122248 AddReplyToUserIdToPost: migrated (0.0021s) ==================
== 20130320012100 AddUserIndexesToPostsAndTopics: migrating ===================
-- execute("CREATE INDEX idx_posts_user_id_deleted_at \n ON posts(user_id) WHERE deleted_at IS NULL")
-> 0.0025s
-- execute("CREATE INDEX idx_topics_user_id_deleted_at \n ON topics(user_id) WHERE deleted_at IS NULL")
-> 0.0125s
== 20130320012100 AddUserIndexesToPostsAndTopics: migrated (0.0163s) ==========
== 20130320024345 AddModeratorToUser: migrating ===============================
-- add_column(:users, :moderator, :boolean, {:default=>false})
-> 0.0188s
-- execute("UPDATE users SET trust_level = 1, moderator = 't' where trust_level = 5")
-> 0.0004s
== 20130320024345 AddModeratorToUser: migrated (0.0206s) ======================
== 20130321154905 RemoveOneboxesFromDb: migrating =============================
-- drop_table(:post_onebox_renders)
-> 0.0004s
-- drop_table(:onebox_renders)
-> 0.0007s
== 20130321154905 RemoveOneboxesFromDb: migrated (0.0025s) ====================
== 20130322183614 AddPercentRankToPosts: migrating ============================
-- add_column(:posts, :percent_rank, :float, {:default=>1.0})
-> 0.0249s
-- execute("UPDATE posts SET percent_rank = x.percent_rank\n FROM (SELECT id, percent_rank()\n OVER (PARTITION BY topic_id ORDER BY SCORE DESC)\n FROM posts) AS x\n WHERE x.id = posts.id")
-> 0.0007s
== 20130322183614 AddPercentRankToPosts: migrated (0.0270s) ===================
== 20130326210101 AddHotnessToCategory: migrating =============================
-- add_column(:categories, :hotness, :float, {:default=>5.0, :null=>false})
-> 0.0118s
== 20130326210101 AddHotnessToCategory: migrated (0.0132s) ====================
== 20130327185852 UpdateSiteSettingsForHot: migrating =========================
-- execute("UPDATE site_settings SET value = REPLACE(value, 'popular|', 'latest|hot|') where name = 'top_menu'")
-> 0.0003s
== 20130327185852 UpdateSiteSettingsForHot: migrated (0.0014s) ================
== 20130328162943 CreateHotTopics: migrating ==================================
-- create_table(:hot_topics, {:force=>true})
-> 0.0042s
-- add_index(:hot_topics, :topic_id, {:unique=>true})
-> 0.0033s
-- add_index(:hot_topics, :score, {:order=>"desc"})
-> 0.0144s
== 20130328162943 CreateHotTopics: migrated (0.0234s) =========================
== 20130328182433 AddScoreToTopics: migrating =================================
-- add_column(:topics, :score, :float)
-> 0.0005s
-- add_column(:topics, :percent_rank, :float, {:null=>false, :default=>1.0})
-> 0.0180s
== 20130328182433 AddScoreToTopics: migrated (0.0199s) ========================
== 20130402210723 AddValuesToHotTopics: migrating =============================
-- add_column(:hot_topics, :random_bias, :float)
-> 0.0004s
-- add_column(:hot_topics, :random_multiplier, :float)
-> 0.0002s
-- add_column(:hot_topics, :days_ago_bias, :float)
-> 0.0002s
-- add_column(:hot_topics, :days_ago_multiplier, :float)
-> 0.0002s
-- add_column(:hot_topics, :hot_topic_type, :integer)
-> 0.0003s
== 20130402210723 AddValuesToHotTopics: migrated (0.0025s) ====================
== 20130404143437 CreateSiteContents: migrating ===============================
-- create_table(:site_contents, {:force=>true, :id=>false})
-> 0.0039s
-- add_index(:site_contents, :content_type, {:unique=>true})
-> 0.0128s
== 20130404143437 CreateSiteContents: migrated (0.0181s) ======================
== 20130404232558 AddUserExtras: migrating ====================================
-- add_column(:users, :likes_given, :integer, {:null=>false, :default=>0})
-> 0.0196s
-- add_column(:users, :likes_received, :integer, {:null=>false, :default=>0})
-> 0.0196s
-- add_column(:users, :topic_reply_count, :integer, {:null=>false, :default=>0})
-> 0.0298s
-- execute("UPDATE users u\nSET\n likes_given = X.likes_given\nFROM (\n SELECT\n a.user_id,\n COUNT(*) likes_given\n FROM user_actions a\n JOIN posts p ON p.id = a.target_post_id\n WHERE p.deleted_at IS NULL AND a.action_type = 1\n GROUP BY a.user_id\n) as X\nWHERE X.user_id = u.id\n")
-> 0.0010s
-- execute("UPDATE users u\nSET\n likes_received = Y.likes_received\nFROM (\n SELECT\n a.user_id,\n COUNT(*) likes_received\n FROM user_actions a\n JOIN posts p ON p.id = a.target_post_id\n WHERE p.deleted_at IS NULL AND a.action_type = 2\n GROUP BY a.user_id\n) as Y\nWHERE Y.user_id = u.id\n")
-> 0.0005s
-- execute("UPDATE users u\nSET\n topic_reply_count = Z.topic_reply_count\nFROM (\n SELECT\n p.user_id,\n COUNT(DISTINCT topic_id) topic_reply_count\n FROM posts p\n JOIN topics t on t.id = p.topic_id\n WHERE t.user_id <> p.user_id AND\n p.deleted_at IS NULL AND t.deleted_at IS NULL\n GROUP BY p.user_id\n) Z\nWHERE\n Z.user_id = u.id\n")
-> 0.0008s
== 20130404232558 AddUserExtras: migrated (0.0728s) ===========================
== 20130411205132 CreateAdminLogs: migrating ==================================
-- create_table(:admin_logs, {:force=>true})
-> 0.0085s
== 20130411205132 CreateAdminLogs: migrated (0.0098s) =========================
== 20130412015502 CorrectCountsOnPosts: migrating =============================
-- rename_column(:posts, :custom_flag_count, :notify_moderators_count)
-> 0.0017s
-- add_column(:posts, :notify_user_count, :integer, {:default=>0, :null=>false})
-> 0.0236s
== 20130412015502 CorrectCountsOnPosts: migrated (0.0268s) ====================
== 20130412020156 CorrectCountsOnTopics: migrating ============================
-- rename_column(:topics, :custom_flag_count, :notify_moderators_count)
-> 0.0015s
-- add_column(:topics, :notify_user_count, :integer, {:default=>0, :null=>false})
-> 0.0130s
== 20130412020156 CorrectCountsOnTopics: migrated (0.0158s) ===================
== 20130416004607 CreateGroups: migrating =====================================
-- create_table(:groups, {:force=>true})
-> 0.0069s
== 20130416004607 CreateGroups: migrated (0.0081s) ============================
== 20130416004933 GroupUsers: migrating =======================================
-- create_table(:group_users, {:force=>true})
-> 0.0152s
-- add_index(:group_users, [:group_id, :user_id], {:unique=>true})
-> 0.0039s
== 20130416004933 GroupUsers: migrated (0.0204s) ==============================
== 20130416170855 AddSubtypeToTopics: migrating ===============================
-- add_column(:topics, :subtype, :string)
-> 0.0004s
-- execute("update topics set subtype = 'user_to_user' where archetype = 'private_message'")
-> 0.0003s
== 20130416170855 AddSubtypeToTopics: migrated (0.0017s) ======================
== 20130419195746 IncreaseDataLengthOnNotifications: migrating ================
-- execute("ALTER TABLE notifications ALTER COLUMN data TYPE VARCHAR(1000)")
-> 0.0113s
== 20130419195746 IncreaseDataLengthOnNotifications: migrated (0.0126s) =======
== 20130422050626 AddRelatedPostIdToPostActions: migrating ====================
-- add_column(:post_actions, :related_post_id, :integer)
-> 0.0003s
== 20130422050626 AddRelatedPostIdToPostActions: migrated (0.0015s) ===========
== 20130424015746 AddSlugToTopics: migrating ==================================
-- add_column(:topics, :slug, :string)
-> 0.0004s
== 20130424015746 AddSlugToTopics: migrated (0.0016s) =========================
== 20130424055025 AddUserIdToIncomingLinks: migrating =========================
-- add_column(:incoming_links, :user_id, :integer)
-> 0.0004s
== 20130424055025 AddUserIdToIncomingLinks: migrated (0.0015s) ================
== 20130426044914 AllowNullsInIncomingLinks: migrating ========================
-- change_column(:incoming_links, :referer, :string, {:limit=>1000, :null=>true})
-> 0.0005s
-- change_column(:incoming_links, :domain, :string, {:limit=>100, :null=>true})
-> 0.0003s
== 20130426044914 AllowNullsInIncomingLinks: migrated (0.0020s) ===============
== 20130426052257 AddIncomingIpCurrentUserIdToIncomingLinks: migrating ========
-- add_column(:incoming_links, :ip_address, :inet)
-> 0.0003s
-- add_column(:incoming_links, :current_user_id, :int)
-> 0.0003s
== 20130426052257 AddIncomingIpCurrentUserIdToIncomingLinks: migrated (0.0017s)
== 20130428194335 AddUnstarredAtToTopicUsers: migrating =======================
-- add_column(:topic_users, :unstarred_at, :datetime)
-> 0.0003s
== 20130428194335 AddUnstarredAtToTopicUsers: migrated (0.0014s) ==============
== 20130429000101 AddSecurityToCategories: migrating ==========================
-- add_column(:categories, :secure, :boolean, {:default=>false, :null=>false})
-> 0.0121s
-- create_table(:category_groups, {:force=>true})
-> 0.0044s
== 20130429000101 AddSecurityToCategories: migrated (0.0177s) =================
== 20130430052751 AddTopicAllowedGroups: migrating ============================
-- create_table(:topic_allowed_groups, {:force=>true})
-> 0.0043s
-- add_index(:topic_allowed_groups, [:group_id, :topic_id], {:unique=>true})
-> 0.0039s
-- add_index(:topic_allowed_groups, [:topic_id, :group_id], {:unique=>true})
-> 0.0034s
== 20130430052751 AddTopicAllowedGroups: migrated (0.0129s) ===================
== 20130501105651 FixTopicAllowedGroups: migrating ============================
-- remove_column(:topic_allowed_groups, :integer)
-> 0.0003s
== 20130501105651 FixTopicAllowedGroups: migrated (0.0012s) ===================
== 20130506020935 AddAutomaticToGroups: migrating =============================
-- add_column(:groups, :automatic, :boolean, {:default=>false, :null=>false})
-> 0.0072s
-- execute(" ALTER SEQUENCE groups_id_seq START WITH 100\n")
-> 0.0002s
== 20130506020935 AddAutomaticToGroups: migrated (0.0088s) ====================
== 20130506185042 AddAutoCloseAtToTopics: migrating ===========================
-- add_column(:topics, :auto_close_at, :datetime)
-> 0.0005s
-- add_column(:topics, :auto_close_user_id, :integer)
-> 0.0003s
== 20130506185042 AddAutoCloseAtToTopics: migrated (0.0021s) ==================
== 20130508040235 AddUserCountToGroups: migrating =============================
-- add_column(:groups, :user_count, :integer, {:null=>false, :default=>0})
-> 0.0073s
== 20130508040235 AddUserCountToGroups: migrated (0.0086s) ====================
== 20130509040248 UpdateSequenceForGroups: migrating ==========================
-- execute(" SELECT setval('groups_id_seq', 40)\n")
-> 0.0002s
== 20130509040248 UpdateSequenceForGroups: migrated (0.0013s) =================
== 20130509041351 AddUniqueNameToGroups: migrating ============================
-- add_index(:groups, [:name], {:unique=>true})
-> 0.0038s
== 20130509041351 AddUniqueNameToGroups: migrated (0.0047s) ===================
== 20130515193551 AddAutoCloseDaysToCategories: migrating =====================
-- add_column(:categories, :auto_close_days, :float)
-> 0.0003s
== 20130515193551 AddAutoCloseDaysToCategories: migrated (0.0013s) ============
== 20130521210140 CreateCasUserInfos: migrating ===============================
-- create_table(:cas_user_infos)
-> 0.0066s
-- add_index(:cas_user_infos, :user_id, {:unique=>true})
-> 0.0145s
-- add_index(:cas_user_infos, :cas_user_id, {:unique=>true})
-> 0.0039s
== 20130521210140 CreateCasUserInfos: migrated (0.0264s) ======================
== 20130522193615 RenameSearchTables: migrating ===============================
-- rename_table(:users_search, :user_search_data)
-> 0.0031s
-- rename_column(:user_search_data, :id, :user_id)
-> 0.0010s
-- rename_table(:categories_search, :category_search_data)
-> 0.0028s
-- rename_column(:category_search_data, :id, :category_id)
-> 0.0010s
-- rename_table(:posts_search, :post_search_data)
-> 0.0027s
-- rename_column(:post_search_data, :id, :post_id)
-> 0.0009s
== 20130522193615 RenameSearchTables: migrated (0.0128s) ======================
== 20130527152648 AddLikeScoreToPosts: migrating ==============================
-- add_column(:posts, :like_score, :integer, {:default=>0, :null=>false})
-> 0.0146s
-- execute("UPDATE posts p\n set like_score = x.like_score\n FROM (SELECT pa.post_id,\n SUM(CASE\n WHEN u.admin OR u.moderator THEN 3\n ELSE 1\n END) AS like_score\n FROM post_actions AS pa\n INNER JOIN users AS u ON u.id = pa.user_id\n GROUP BY pa.post_id) AS x\n WHERE x.post_id = p.id")
-> 0.0010s
== 20130527152648 AddLikeScoreToPosts: migrated (0.0169s) =====================
== 20130528174147 AddRankToCategoryFeaturedTopics: migrating ==================
-- add_column(:category_featured_topics, :rank, :integer, {:default=>0, :null=>false})
-> 0.0167s
-- add_index(:category_featured_topics, [:category_id, :rank])
-> 0.0038s
== 20130528174147 AddRankToCategoryFeaturedTopics: migrated (0.0218s) =========
== 20130531210816 AddStaffTookActionToPostActions: migrating ==================
-- add_column(:post_actions, :staff_took_action, :boolean, {:default=>false, :null=>false})
-> 0.0122s
== 20130531210816 AddStaffTookActionToPostActions: migrated (0.0135s) =========
== 20130603192412 AddBlockedToUsers: migrating ================================
-- add_column(:users, :blocked, :boolean, {:default=>false})
-> 0.0291s
== 20130603192412 AddBlockedToUsers: migrated (0.0304s) =======================
== 20130606190601 AddAutoCloseStartedAtToTopics: migrating ====================
-- add_column(:topics, :auto_close_started_at, :datetime)
-> 0.0004s
== 20130606190601 AddAutoCloseStartedAtToTopics: migrated (0.0015s) ===========
== 20130610201033 AddReplyKeyToEmailLogs: migrating ===========================
-- add_column(:email_logs, :reply_key, :string, {:limit=>32})
-> 0.0003s
-- add_index(:email_logs, :reply_key)
-> 0.0037s
== 20130610201033 AddReplyKeyToEmailLogs: migrated (0.0051s) ==================
== 20130612200846 CreatePostUploadJoinTable: migrating ========================
-- create_table(:posts_uploads, {:force=>true, :id=>false})
-> 0.0010s
-- add_index(:posts_uploads, :post_id)
-> 0.0035s
-- add_index(:posts_uploads, :upload_id)
-> 0.0034s
-- add_index(:posts_uploads, [:post_id, :upload_id], {:unique=>true})
-> 0.0036s
== 20130612200846 CreatePostUploadJoinTable: migrated (0.0127s) ===============
== 20130613211700 DropPostsUploads: migrating =================================
-- drop_table(:posts_uploads)
-> 0.0005s
== 20130613211700 DropPostsUploads: migrated (0.0014s) ========================
== 20130613212230 CreatePostUploads: migrating ================================
-- create_table(:post_uploads)
-> 0.0035s
-- execute("create unique index idx_unique_post_uploads on post_uploads(post_id, upload_id)")
-> 0.0025s
== 20130613212230 CreatePostUploads: migrated (0.0073s) =======================
== 20130615064344 AddDynamicFaviconPreferenceToUser: migrating ================
-- add_column(:users, :dynamic_favicon, :boolean, {:default=>false, :null=>false})
-> 0.0269s
== 20130615064344 AddDynamicFaviconPreferenceToUser: migrated (0.0282s) =======
== 20130615073305 RemoveTopicIdFromUploads: migrating =========================
-- remove_column(:uploads, :topic_id)
-> 0.0004s
== 20130615073305 RemoveTopicIdFromUploads: migrated (0.0015s) ================
== 20130615075557 AddShaToUploads: migrating ==================================
-- add_column(:uploads, :sha, :string, {:null=>true})
-> 0.0003s
-- add_index(:uploads, :sha, {:unique=>true})
-> 0.0037s
== 20130615075557 AddShaToUploads: migrated (0.0051s) =========================
== 20130616082327 CreateOptimizedImages: migrating ============================
-- create_table(:optimized_images)
-> 0.0163s
-- add_index(:optimized_images, :upload_id)
-> 0.0037s
-- add_index(:optimized_images, [:upload_id, :width, :height], {:unique=>true})
-> 0.0037s
== 20130616082327 CreateOptimizedImages: migrated (0.0251s) ===================
== 20130617014127 RenameShaAndExtColumns: migrating ===========================
-- rename_column(:optimized_images, :sha, :sha1)
-> 0.0015s
-- change_column(:optimized_images, :sha1, :string, {:limit=>40})
-> 0.0124s
-- rename_column(:optimized_images, :ext, :extension)
-> 0.0015s
-- change_column(:optimized_images, :extension, :string, {:limit=>10})
-> 0.0107s
== 20130617014127 RenameShaAndExtColumns: migrated (0.0277s) ==================
== 20130617180009 RenameShaColumn: migrating ==================================
-- remove_index(:uploads, :sha)
-> 0.0011s
-- rename_column(:uploads, :sha, :sha1)
-> 0.0010s
-- change_column(:uploads, :sha1, :string, {:limit=>40})
-> 0.0204s
-- add_index(:uploads, :sha1, {:unique=>true})
-> 0.0039s
== 20130617180009 RenameShaColumn: migrated (0.0278s) =========================
== 20130617181804 AddPostIdToEmailLogs: migrating =============================
-- add_column(:email_logs, :post_id, :integer, {:null=>true})
-> 0.0004s
-- add_column(:email_logs, :topic_id, :integer, {:null=>true})
-> 0.0003s
== 20130617181804 AddPostIdToEmailLogs: migrated (0.0020s) ====================
== 20130619063902 AddDeferToPostActions: migrating ============================
-- add_column(:post_actions, :defer, :boolean)
-> 0.0003s
-- add_column(:post_actions, :defer_by, :int)
-> 0.0002s
== 20130619063902 AddDeferToPostActions: migrated (0.0015s) ===================
== 20130621042855 ChangeSupressToSuppress: migrating ==========================
== 20130621042855 ChangeSupressToSuppress: migrated (0.0109s) =================
== 20130622110348 AddUrlIndexToUploads: migrating =============================
-- add_index(:uploads, :url)
-> 0.0103s
== 20130622110348 AddUrlIndexToUploads: migrated (0.0115s) ====================
== 20130624203206 ChangeIpToInetInTopicLinkClicks: migrating ==================
-- add_column(:topic_link_clicks, :ip_address, :inet)
-> 0.0050s
-- execute("UPDATE topic_link_clicks SET ip_address = inet(\n (ip >> 24 & 255) || '.' ||\n (ip >> 16 & 255) || '.' ||\n (ip >> 8 & 255) || '.' ||\n (ip >> 0 & 255)\n );")
-> 0.0007s
-- change_column(:topic_link_clicks, :ip_address, :inet, {:null=>false})
-> 0.0005s
-- remove_column(:topic_link_clicks, :ip)
-> 0.0002s
== 20130624203206 ChangeIpToInetInTopicLinkClicks: migrated (0.0077s) =========
== 20130625022454 ChangeIpToInetInViews: migrating ============================
-- add_column(:views, :ip_address, :inet)
-> 0.0034s
-- execute("UPDATE views SET ip_address = inet(\n (ip >> 24 & 255) || '.' ||\n (ip >> 16 & 255) || '.' ||\n (ip >> 8 & 255) || '.' ||\n (ip >> 0 & 255)\n );")
-> 0.0004s
-- change_column(:views, :ip_address, :inet, {:null=>false})
-> 0.0003s
-- remove_column(:views, :ip)
-> 0.0002s
== 20130625022454 ChangeIpToInetInViews: migrated (0.0054s) ===================
== 20130625170842 RemoveAccessPassword: migrating =============================
-- execute("SELECT count(*) FROM site_settings where name='access_password' and char_length(value) > 0")
-> 0.0003s
== 20130625170842 RemoveAccessPassword: migrated (0.0013s) ====================
== 20130625201113 AddTitleToUsers: migrating ==================================
-- add_column(:users, :title, :string)
-> 0.0005s
== 20130625201113 AddTitleToUsers: migrated (0.0015s) =========================
== 20130709184941 AddDeletedByIdToPosts: migrating ============================
-- add_column(:posts, :deleted_by_id, :integer, {:null=>true})
-> 0.0004s
-- add_column(:topics, :deleted_by_id, :integer, {:null=>true})
-> 0.0003s
-- add_column(:invites, :deleted_by_id, :integer, {:null=>true})
-> 0.0003s
-- rename_column(:post_actions, :deleted_by, :deleted_by_id)
-> 0.0014s
== 20130709184941 AddDeletedByIdToPosts: migrated (0.0036s) ===================
== 20130710201248 AddNukedUserToPosts: migrating ==============================
-- add_column(:posts, :nuked_user, :boolean, {:default=>false})
-> 0.0312s
== 20130710201248 AddNukedUserToPosts: migrated (0.0325s) =====================
== 20130712041133 AddPermissionTypeToCategoryGroups: migrating ================
-- add_column(:category_groups, :permission_type, :integer, {:default=>1})
-> 0.0060s
-- rename_column(:categories, :secure, :read_restricted)
-> 0.0015s
== 20130712041133 AddPermissionTypeToCategoryGroups: migrated (0.0088s) =======
== 20130712163509 AddMissingIdColumns: migrating ==============================
-- add_column(:category_featured_topics, :id, :primary_key)
-> 0.0115s
-- add_column(:topic_users, :id, :primary_key)
-> 0.0187s
== 20130712163509 AddMissingIdColumns: migrated (0.0317s) =====================
== 20130723212758 RenameAdminLog: migrating ===================================
-- rename_table(:admin_logs, :staff_action_logs)
-> 0.0025s
-- rename_column(:staff_action_logs, :admin_id, :staff_user_id)
-> 0.0007s
== 20130723212758 RenameAdminLog: migrated (0.0044s) ==========================
== 20130724201552 CreateBlockedEmails: migrating ==============================
-- create_table(:blocked_emails)
-> 0.0082s
-- add_index(:blocked_emails, :email, {:unique=>true})
-> 0.0044s
== 20130724201552 CreateBlockedEmails: migrated (0.0140s) =====================
== 20130725213613 AddMoreToStaffActionLog: migrating ==========================
-- add_column(:staff_action_logs, :context, :string)
-> 0.0004s
-- add_column(:staff_action_logs, :ip_address, :string)
-> 0.0002s
-- add_column(:staff_action_logs, :email, :string)
-> 0.0002s
== 20130725213613 AddMoreToStaffActionLog: migrated (0.0019s) =================
== 20130728172550 AddUrlToOptimizedImages: migrating ==========================
-- add_column(:optimized_images, :url, :string)
-> 0.0032s
-- execute("UPDATE optimized_images\n SET url = substring(u.url from '^/uploads/[^/]+/')\n || '_optimized/'\n || substring(oi.sha1 for 3) || '/'\n || substring(oi.sha1 from 4 for 3) || '/'\n || substring(oi.sha1 from 7 for 11) || oi.extension\n FROM optimized_images oi\n JOIN uploads u ON u.id = oi.upload_id\n WHERE optimized_images.id = oi.id;")
-> 0.0009s
-- change_column(:optimized_images, :url, :string, {:null=>false})
-> 0.0004s
== 20130728172550 AddUrlToOptimizedImages: migrated (0.0058s) =================
== 20130731163035 AddReportIndexToIncomingLinks: migrating ====================
-- add_index(:incoming_links, [:created_at, :user_id])
-> 0.0041s
-- add_index(:incoming_links, [:created_at, :domain])
-> 0.0037s
== 20130731163035 AddReportIndexToIncomingLinks: migrated (0.0092s) ===========
== 20130807202516 AddLastMatchIndexToBlockedEmails: migrating =================
-- add_index(:blocked_emails, :last_match_at)
-> 0.0110s
== 20130807202516 AddLastMatchIndexToBlockedEmails: migrated (0.0124s) ========
== 20130809160751 FixSeenNotificationIds: migrating ===========================
-- execute("UPDATE users SET\n seen_notification_id = COALESCE((SELECT MAX(notifications.id)\n FROM notifications\n WHERE user_id = users.id AND created_at <= users.last_seen_at), 0)")
-> 0.0009s
== 20130809160751 FixSeenNotificationIds: migrated (0.0019s) ==================
== 20130809204732 AddFilterIndexesToStaffActionLogs: migrating ================
-- add_index(:staff_action_logs, [:action, :id])
-> 0.0041s
-- add_index(:staff_action_logs, [:staff_user_id, :id])
-> 0.0040s
-- add_index(:staff_action_logs, [:target_user_id, :id])
-> 0.0037s
== 20130809204732 AddFilterIndexesToStaffActionLogs: migrated (0.0130s) =======
== 20130809211409 AddAvatarToUsers: migrating =================================
-- add_column(:users, :use_uploaded_avatar, :boolean, {:default=>false})
-> 0.0322s
-- add_column(:users, :uploaded_avatar_template, :string)
-> 0.0004s
-- add_column(:users, :uploaded_avatar_id, :integer)
-> 0.0003s
== 20130809211409 AddAvatarToUsers: migrated (0.0343s) ========================
== 20130813204212 CreateScreenedUrls: migrating ===============================
-- create_table(:screened_urls)
-> 0.0073s
-- add_index(:screened_urls, :url, {:unique=>true})
-> 0.0037s
-- add_index(:screened_urls, :last_match_at)
-> 0.0038s
== 20130813204212 CreateScreenedUrls: migrated (0.0163s) ======================
== 20130813224817 RenameBlockedEmailsToScreenedEmails: migrating ==============
-- rename_table(:blocked_emails, :screened_emails)
-> 0.0033s
== 20130813224817 RenameBlockedEmailsToScreenedEmails: migrated (0.0045s) =====
== 20130816024250 CreateOauth2UserInfos: migrating ============================
-- create_table(:oauth2_user_infos)
-> 0.0067s
-- add_index(:oauth2_user_infos, [:uid, :provider], {:unique=>true})
-> 0.0140s
== 20130816024250 CreateOauth2UserInfos: migrated (0.0220s) ===================
== 20130819192358 AddValueColumnsToStaffActionLogs: migrating =================
-- add_column(:staff_action_logs, :subject, :text)
-> 0.0004s
-- add_column(:staff_action_logs, :previous_value, :text)
-> 0.0002s
-- add_column(:staff_action_logs, :new_value, :text)
-> 0.0002s
== 20130819192358 AddValueColumnsToStaffActionLogs: migrated (0.0019s) ========
== 20130820174431 AddSubjectIndexToStaffActionLogs: migrating =================
-- add_index(:staff_action_logs, [:subject, :id])
-> 0.0041s
== 20130820174431 AddSubjectIndexToStaffActionLogs: migrated (0.0052s) ========
== 20130822213513 AddIpAddressToScreeningTables: migrating ====================
-- add_column(:screened_emails, :ip_address, :inet)
-> 0.0004s
-- add_column(:screened_urls, :ip_address, :inet)
-> 0.0002s
== 20130822213513 AddIpAddressToScreeningTables: migrated (0.0016s) ===========
== 20130823201420 DropDefaultsOnEmailDigestColumnsOfUsers: migrating ==========
-- change_column_default(:users, :email_digests, nil)
-> 0.0019s
-- change_column(:users, :digest_after_days, :integer, {:default=>nil, :null=>true})
-> 0.0022s
== 20130823201420 DropDefaultsOnEmailDigestColumnsOfUsers: migrated (0.0052s) =
== 20130826011521 CreatePluginStoreRows: migrating ============================
-- create_table(:plugin_store_rows)
-> 0.0065s
-- add_index(:plugin_store_rows, [:plugin_name, :key], {:unique=>true})
-> 0.0037s
== 20130826011521 CreatePluginStoreRows: migrated (0.0113s) ===================
== 20130828192526 FixOptimizedImagesUrls: migrating ===========================
-- execute("UPDATE optimized_images\n SET url = substring(oi.url from '^\\/uploads\\/[^/]+\\/_optimized\\/[0-9a-f]{3}\\/[0-9a-f]{3}\\/[0-9a-f]{11}')\n || '_'\n || oi.width\n || 'x'\n || oi.height\n || substring(oi.url from '\\.\\w{3,4}$')\n FROM optimized_images oi\n WHERE optimized_images.id = oi.id\n AND oi.url ~ '^\\/uploads\\/[^/]+\\/_optimized\\/[0-9a-f]{3}\\/[0-9a-f]{3}\\/[0-9a-f]{11}\\.';")
-> 0.0007s
== 20130828192526 FixOptimizedImagesUrls: migrated (0.0017s) ==================
== 20130903154323 AllowNullUserIdOnPosts: migrating ===========================
-- change_column(:posts, :user_id, :integer, {:null=>true})
-> 0.0072s
-- execute("UPDATE posts SET user_id = NULL WHERE nuked_user = true")
-> 0.0004s
-- remove_column(:posts, :nuked_user)
-> 0.0003s
== 20130903154323 AllowNullUserIdOnPosts: migrated (0.0092s) ==================
== 20130904181208 AllowNullUserIdOnTopics: migrating ==========================
-- change_column(:topics, :user_id, :integer, {:null=>true})
-> 0.0036s
== 20130904181208 AllowNullUserIdOnTopics: migrated (0.0049s) =================
== 20130906081326 RenameSystemUsername: migrating =============================
-- execute("update site_settings set name = 'site_contact_username' where name = 'system_username'")
-> 0.0002s
== 20130906081326 RenameSystemUsername: migrated (0.0014s) ====================
== 20130906171631 AddIndexToUploads: migrating ================================
-- add_index(:uploads, [:id, :url])
-> 0.0042s
== 20130906171631 AddIndexToUploads: migrated (0.0055s) =======================
== 20130910040235 IndexTopicsForFrontPage: migrating ==========================
-- add_index(:topics, [:deleted_at, :visible, :archetype, :id])
-> 0.0042s
-- add_index(:topics, [:id, :deleted_at])
-> 0.0036s
== 20130910040235 IndexTopicsForFrontPage: migrated (0.0091s) =================
== 20130910220317 RenameStaffActionLogsToUserHistory: migrating ===============
-- remove_index(:staff_action_logs, [:staff_user_id, :id])
-> 0.0009s
-- rename_table(:staff_action_logs, :user_histories)
-> 0.0036s
-- rename_column(:user_histories, :staff_user_id, :acting_user_id)
-> 0.0015s
-- add_index(:user_histories, [:acting_user_id, :action, :id])
-> 0.0038s
== 20130910220317 RenameStaffActionLogsToUserHistory: migrated (0.0113s) ======
== 20130911182437 CreateUserStats: migrating ==================================
-- create_table(:user_stats, {:id=>false})
-> 0.0009s
-- execute("ALTER TABLE user_stats ADD PRIMARY KEY (user_id)")
-> 0.0132s
-- execute("INSERT INTO user_stats (user_id) SELECT id FROM users")
-> 0.0006s
== 20130911182437 CreateUserStats: migrated (0.0160s) =========================
== 20130912185218 ActingUserNull: migrating ===================================
-- change_column(:user_histories, :acting_user_id, :integer, {:null=>true})
-> 0.0009s
== 20130912185218 ActingUserNull: migrated (0.0019s) ==========================
== 20130913210454 AddMobileToSiteCustomizations: migrating ====================
-- add_column(:site_customizations, :mobile_stylesheet, :text)
-> 0.0003s
-- add_column(:site_customizations, :mobile_header, :text)
-> 0.0002s
-- add_column(:site_customizations, :mobile_stylesheet_baked, :text)
-> 0.0002s
== 20130913210454 AddMobileToSiteCustomizations: migrated (0.0018s) ===========
== 20130917174738 AddTopicIdToUserHistories: migrating ========================
-- add_column(:user_histories, :topic_id, :integer)
-> 0.0003s
== 20130917174738 AddTopicIdToUserHistories: migrated (0.0012s) ===============
== 20131001060630 AddEmailAlwaysToUsers: migrating ============================
-- add_column(:users, :email_always, :bool, {:default=>false, :null=>false})
-> 0.0364s
== 20131001060630 AddEmailAlwaysToUsers: migrated (0.0376s) ===================
== 20131002070347 AddUserIdParentTypeIndexOnViews: migrating ==================
-- add_index(:views, [:user_id, :parent_type, :parent_id])
-> 0.0041s
== 20131002070347 AddUserIdParentTypeIndexOnViews: migrated (0.0054s) =========
== 20131003061137 MoveColumnsToUserStats: migrating ===========================
-- add_column(:user_stats, :topics_entered, :integer, {:default=>0, :null=>false})
-> 0.0063s
-- add_column(:user_stats, :time_read, :integer, {:default=>0, :null=>false})
-> 0.0054s
-- add_column(:user_stats, :days_visited, :integer, {:default=>0, :null=>false})
-> 0.0056s
-- add_column(:user_stats, :posts_read_count, :integer, {:default=>0, :null=>false})
-> 0.0060s
-- add_column(:user_stats, :likes_given, :integer, {:default=>0, :null=>false})
-> 0.0055s
-- add_column(:user_stats, :likes_received, :integer, {:default=>0, :null=>false})
-> 0.0173s
-- add_column(:user_stats, :topic_reply_count, :integer, {:default=>0, :null=>false})
-> 0.0061s
-- execute("UPDATE user_stats s\n SET topics_entered = u.topics_entered,\n time_read = u.time_read,\n days_visited = u.days_visited,\n posts_read_count = u.posts_read_count,\n likes_given = u.likes_given,\n likes_received = u.likes_received,\n topic_reply_count = u.topic_reply_count\n FROM users u WHERE u.id = s.user_id\n ")
-> 0.0007s
-- remove_column(:users, :topics_entered)
-> 0.0004s
-- remove_column(:users, :time_read)
-> 0.0003s
-- remove_column(:users, :days_visited)
-> 0.0003s
-- remove_column(:users, :posts_read_count)
-> 0.0003s
-- remove_column(:users, :likes_given)
-> 0.0003s
-- remove_column(:users, :likes_received)
-> 0.0003s
-- remove_column(:users, :topic_reply_count)
-> 0.0003s
== 20131003061137 MoveColumnsToUserStats: migrated (0.0570s) ==================
== 20131014203951 BackfillPostUploadReverseIndex: migrating ===================
-- execute("TRUNCATE TABLE post_uploads")
-> 0.0051s
== 20131014203951 BackfillPostUploadReverseIndex: migrated (0.0108s) ==========
== 20131015131652 CreatePostDetails: migrating ================================
-- create_table(:post_details)
-> 0.0163s
-- add_index(:post_details, [:post_id, :key], {:unique=>true})
-> 0.0040s
== 20131015131652 CreatePostDetails: migrated (0.0217s) =======================
== 20131017014509 AddPostCountToCategories: migrating =========================
-- add_column(:categories, :post_count, :integer, {:null=>false, :default=>0})
-> 0.0128s
-- execute(" UPDATE categories\n SET post_count = (SELECT COALESCE(SUM(posts_count),0) FROM topics\n WHERE category_id = categories.id AND deleted_at IS NULL)\n")
-> 0.0007s
== 20131017014509 AddPostCountToCategories: migrated (0.0149s) ================
== 20131017030605 AddLatestToCategories: migrating ============================
-- add_column(:categories, :latest_post_id, :integer)
-> 0.0005s
-- add_column(:categories, :latest_topic_id, :integer)
-> 0.0003s
-- execute(" UPDATE categories c\n SET latest_post_id = x.post_id\n FROM (select category_id, max(p.id) post_id FROM posts p\n JOIN topics t on t.id = p.topic_id\n WHERE p.deleted_at IS NULL AND NOT p.hidden AND t.visible\n GROUP BY category_id\n ) x\n WHERE x.category_id = c.id\n")
-> 0.0009s
-- execute(" UPDATE categories c\n SET latest_topic_id = x.topic_id\n FROM (select category_id, max(t.id) topic_id\n FROM topics t\n WHERE t.deleted_at IS NULL AND t.visible\n GROUP BY category_id\n ) x\n WHERE x.category_id = c.id\n")
-> 0.0003s
== 20131017030605 AddLatestToCategories: migrated (0.0034s) ===================
== 20131017205954 CreateScreenedIpAddresses: migrating ========================
-- create_table(:screened_ip_addresses)
-> 0.0068s
-- add_index(:screened_ip_addresses, :ip_address, {:unique=>true})
-> 0.0036s
-- add_index(:screened_ip_addresses, :last_match_at)
-> 0.0034s
== 20131017205954 CreateScreenedIpAddresses: migrated (0.0151s) ===============
== 20131018050738 AddPositionToCategories: migrating ==========================
-- add_column(:categories, :position, :integer)
-> 0.0004s
-- execute("UPDATE categories SET position = id")
-> 0.0002s
-- change_column(:categories, :position, :integer, {:null=>false})
-> 0.0004s
== 20131018050738 AddPositionToCategories: migrated (0.0021s) =================
== 20131022045114 AddUncategorizedCategory: migrating =========================
-- execute("SELECT 1 FROM categories WHERE lower(name) = 'uncategorized'")
-> 0.0003s
-- execute("INSERT INTO categories\n (name,color,slug,description,text_color, user_id, created_at, updated_at, position)\n VALUES ('Uncategorized', 'AB9364', 'uncategorized', '', 'FFFFFF', -1, now(), now(), 0 )\n RETURNING id\n ")
-> 0.0004s
-- execute("INSERT INTO site_settings(name, data_type, value, created_at, updated_at)\n VALUES ('uncategorized_category_id', 3, 1, now(), now())")
-> 0.0003s
-- execute("DELETE from site_settings where name in ('uncategorized_name', 'uncategorized_text_color', 'uncategorized_color')")
-> 0.0002s
-- execute("UPDATE topics SET category_id = 1 WHERE archetype = 'regular' AND category_id IS NULL")
-> 0.0003s
-- execute("ALTER table topics ADD CONSTRAINT has_category_id CHECK (category_id IS NOT NULL OR archetype <> 'regular')")
-> 0.0005s
== 20131022045114 AddUncategorizedCategory: migrated (0.0033s) ================
== 20131022151218 CreateApiKeys: migrating ====================================
-- create_table(:api_keys)
-> 0.0047s
-- add_index(:api_keys, :key)
-> 0.0036s
-- add_index(:api_keys, :user_id, {:unique=>true})
-> 0.0043s
-- execute("INSERT INTO api_keys (key, created_at, updated_at) SELECT value, CURRENT_TIMESTAMP, CURRENT_TIMESTAMP FROM site_settings WHERE name = 'api_key'")
-> 0.0002s
-- execute("DELETE FROM site_settings WHERE name = 'api_key'")
-> 0.0002s
== 20131022151218 CreateApiKeys: migrated (0.0143s) ===========================
== 20131023163509 AddParentCategoryIdToCategories: migrating ==================
-- add_column(:categories, :parent_category_id, :integer)
-> 0.0004s
== 20131023163509 AddParentCategoryIdToCategories: migrated (0.0015s) =========
== 20131105101051 AddOriginToUploads: migrating ===============================
-- add_column(:uploads, :origin, :string, {:limit=>1000})
-> 0.0003s
== 20131105101051 AddOriginToUploads: migrated (0.0013s) ======================
== 20131107154900 RenameBannedToSuspended: migrating ==========================
-- rename_column(:users, :banned_at, :suspended_at)
-> 0.0023s
-- rename_column(:users, :banned_till, :suspended_till)
-> 0.0019s
== 20131107154900 RenameBannedToSuspended: migrated (0.0053s) =================
== 20131114185225 AddParticipantCountToTopics: migrating ======================
-- add_column(:topics, :participant_count, :integer, {:default=>1})
-> 0.0275s
-- execute("UPDATE topics SET participant_count =\n (SELECT COUNT(DISTINCT p.user_id) FROM posts AS p WHERE p.topic_id = topics.id)")
-> 0.0005s
== 20131114185225 AddParticipantCountToTopics: migrated (0.0294s) =============
== 20131115165105 AddEditReasonToPosts: migrating =============================
-- add_column(:posts, :edit_reason, :string)
-> 0.0004s
== 20131115165105 AddEditReasonToPosts: migrated (0.0015s) ====================
== 20131118173159 RenameBestOfToSummary: migrating ============================
-- rename_column(:topics, :has_best_of, :has_summary)
-> 0.0021s
== 20131118173159 RenameBestOfToSummary: migrated (0.0031s) ===================
== 20131120055018 MoveEmojiToNewLocation: migrating ===========================
-- execute("update posts set cooked = regexp_replace(cooked, '(<img[^>]*)assets/emoji/', '\\1plugins/emoji/images/' , 'g') where cooked like '%emoji%'")
-> 0.0004s
== 20131120055018 MoveEmojiToNewLocation: migrated (0.0014s) ==================
== 20131122064921 IncreaseTwitterUserIdLength: migrating ======================
-- change_column(:twitter_user_infos, :twitter_user_id, :bigint)
-> 0.0117s
== 20131122064921 IncreaseTwitterUserIdLength: migrated (0.0130s) =============
== 20131206200009 RenameAutoCloseDaysToHours: migrating =======================
-- rename_column(:categories, :auto_close_days, :auto_close_hours)
-> 0.0013s
-- execute("update categories set auto_close_hours = auto_close_hours * 24")
-> 0.0002s
== 20131206200009 RenameAutoCloseDaysToHours: migrated (0.0027s) ==============
== 20131209091702 CreatePostRevisions: migrating ==============================
-- create_table(:post_revisions)
-> 0.0166s
-- execute("INSERT INTO post_revisions (user_id, post_id, modifications, number, created_at, updated_at)\n SELECT user_id, versioned_id, modifications, number, created_at, updated_at\n FROM versions\n WHERE versioned_type = 'Post'")
-> 0.0004s
-- change_table(:post_revisions)
-> 0.0073s
== 20131209091702 CreatePostRevisions: migrated (0.0257s) =====================
== 20131209091742 CreateTopicRevisions: migrating =============================
-- create_table(:topic_revisions)
-> 0.0073s
-- execute("INSERT INTO topic_revisions (user_id, topic_id, modifications, number, created_at, updated_at)\n SELECT user_id, versioned_id, modifications, number, created_at, updated_at\n FROM versions\n WHERE versioned_type = 'Topic'")
-> 0.0004s
-- change_table(:topic_revisions)
-> 0.0068s
== 20131209091742 CreateTopicRevisions: migrated (0.0158s) ====================
== 20131210163702 AddWordCountToPosts: migrating ==============================
-- add_column(:posts, :word_count, :integer)
-> 0.0004s
-- add_column(:topics, :word_count, :integer)
-> 0.0004s
== 20131210163702 AddWordCountToPosts: migrated (0.0020s) =====================
== 20131210181901 MigrateWordCounts: migrating ================================
-- execute("SELECT id FROM posts WHERE word_count IS NULL LIMIT 500")
-> 0.0004s
-- execute("SELECT id FROM topics WHERE word_count IS NULL LIMIT 500")
-> 0.0004s
== 20131210181901 MigrateWordCounts: migrated (0.0019s) =======================
== 20131210234530 RenameVersionColumn: migrating ==============================
-- add_column(:posts, :version, :integer, {:default=>1, :null=>false})
-> 0.0152s
-- execute("UPDATE posts SET version = cached_version")
-> 0.0004s
-- remove_column(:posts, :cached_version)
-> 0.0003s
== 20131210234530 RenameVersionColumn: migrated (0.0173s) =====================
== 20131212225511 AddPostCountStatsColumnsToCategories: migrating =============
-- change_table(:categories)
-> 0.0010s
== 20131212225511 AddPostCountStatsColumnsToCategories: migrated (0.0023s) ====
== 20131216164557 MakePositionNullableInCategories: migrating =================
-- change_column(:categories, :position, :integer, {:null=>true})
-> 0.0004s
== 20131216164557 MakePositionNullableInCategories: migrated (0.0015s) ========
== 20131217174004 CreateTopicEmbeds: migrating ================================
-- create_table(:topic_embeds, {:force=>true})
-> 0.0071s
-- add_index(:topic_embeds, :embed_url, {:unique=>true})
-> 0.0037s
== 20131217174004 CreateTopicEmbeds: migrated (0.0122s) =======================
== 20131219203905 AddCookMethodToPosts: migrating =============================
-- add_column(:posts, :cook_method, :integer, {:default=>1, :null=>false})
-> 0.0269s
== 20131219203905 AddCookMethodToPosts: migrated (0.0283s) ====================
== 20131223171005 CreateTopTopics: migrating ==================================
-- create_table(:top_topics, {:force=>true})
-> 0.0072s
-- add_index(:top_topics, :topic_id, {:unique=>true})
-> 0.0037s
-- add_index(:top_topics, :yearly_posts_count, {:order=>"desc"})
-> 0.0035s
-- add_index(:top_topics, :yearly_views_count, {:order=>"desc"})
-> 0.0035s
-- add_index(:top_topics, :yearly_likes_count, {:order=>"desc"})
-> 0.0128s
-- add_index(:top_topics, :monthly_posts_count, {:order=>"desc"})
-> 0.0045s
-- add_index(:top_topics, :monthly_views_count, {:order=>"desc"})
-> 0.0036s
-- add_index(:top_topics, :monthly_likes_count, {:order=>"desc"})
-> 0.0039s
-- add_index(:top_topics, :weekly_posts_count, {:order=>"desc"})
-> 0.0035s
-- add_index(:top_topics, :weekly_views_count, {:order=>"desc"})
-> 0.0034s
-- add_index(:top_topics, :weekly_likes_count, {:order=>"desc"})
-> 0.0032s
-- add_index(:top_topics, :daily_posts_count, {:order=>"desc"})
-> 0.0037s
-- add_index(:top_topics, :daily_views_count, {:order=>"desc"})
-> 0.0036s
-- add_index(:top_topics, :daily_likes_count, {:order=>"desc"})
-> 0.0034s
== 20131223171005 CreateTopTopics: migrated (0.0653s) =========================
== 20131227164338 AddScoresToTopTopics: migrating =============================
-- add_column(:top_topics, :daily_score, :float)
-> 0.0004s
-- add_column(:top_topics, :weekly_score, :float)
-> 0.0002s
-- add_column(:top_topics, :monthly_score, :float)
-> 0.0003s
-- add_column(:top_topics, :yearly_score, :float)
-> 0.0003s
== 20131227164338 AddScoresToTopTopics: migrated (0.0023s) ====================
== 20131229221725 AddWatchNewTopicsToUsers: migrating =========================
-- add_column(:users, :watch_new_topics, :boolean, {:default=>false, :null=>false})
-> 0.0316s
== 20131229221725 AddWatchNewTopicsToUsers: migrated (0.0330s) ================
== 20131230010239 AddLastEmailedPostNumberToTopicUser: migrating ==============
-- add_column(:topic_users, :last_emailed_post_number, :integer)
-> 0.0005s
== 20131230010239 AddLastEmailedPostNumberToTopicUser: migrated (0.0017s) =====
== 20140101235747 AddCategoryUsers: migrating =================================
-- create_table(:category_users)
-> 0.0037s
== 20140101235747 AddCategoryUsers: migrated (0.0048s) ========================
== 20140102104229 AddAliasLevelToGroups: migrating ============================
-- add_column(:groups, :alias_level, :integer, {:default=>0})
-> 0.0098s
== 20140102104229 AddAliasLevelToGroups: migrated (0.0112s) ===================
== 20140102194802 RemoveDefaultFromExternalLinksInNewTab: migrating ===========
-- change_column_default(:users, :external_links_in_new_tab, nil)
-> 0.0019s
== 20140102194802 RemoveDefaultFromExternalLinksInNewTab: migrated (0.0031s) ==
== 20140107220141 RemoveEnableWideCategoryList: migrating =====================
-- execute("DELETE FROM site_settings WHERE name = 'enable_wide_category_list'")
-> 0.0002s
== 20140107220141 RemoveEnableWideCategoryList: migrated (0.0012s) ============
== 20140109205940 RenameFavoritesToStarred: migrating =========================
-- execute("UPDATE site_settings SET name = 'max_stars_per_day' where name = 'max_favorites_per_day'")
-> 0.0002s
-- execute("UPDATE site_settings SET value = REPLACE(value, '|favorited', '|starred') where name = 'top_menu'")
-> 0.0002s
== 20140109205940 RenameFavoritesToStarred: migrated (0.0012s) ================
== 20140116170655 DropHotTopics: migrating ====================================
-- drop_table(:hot_topics)
-> 0.0007s
== 20140116170655 DropHotTopics: migrated (0.0017s) ===========================
== 20140120155706 AddLoungeCategory: migrating ================================
-- execute("INSERT INTO site_settings(name, data_type, value, created_at, updated_at)\n VALUES ('lounge_category_id', 3, 2, now(), now())")
-> 0.0002s
== 20140120155706 AddLoungeCategory: migrated (0.0835s) =======================
== 20140121204628 AddInvalidatedAtToInvites: migrating ========================
-- add_column(:invites, :invalidated_at, :datetime)
-> 0.0004s
== 20140121204628 AddInvalidatedAtToInvites: migrated (0.0014s) ===============
== 20140122043508 AddMetaCategory: migrating ==================================
-- execute("INSERT INTO site_settings(name, data_type, value, created_at, updated_at)\n VALUES ('meta_category_id', 3, 3, now(), now())")
-> 0.0002s
== 20140122043508 AddMetaCategory: migrated (0.0022s) =========================
== 20140124202427 AddPostsReadToUserVisits: migrating =========================
-- add_column(:user_visits, :posts_read, :integer, {:default=>0})
-> 0.0088s
-- execute("UPDATE user_visits SET posts_read = 1")
-> 0.0002s
== 20140124202427 AddPostsReadToUserVisits: migrated (0.0103s) ================
== 20140129164541 RemoveCategoryHotness: migrating ============================
-- remove_column(:categories, :hotness)
-> 0.0004s
== 20140129164541 RemoveCategoryHotness: migrated (0.0014s) ===================
== 20140206044818 AddLocaleToUser: migrating ==================================
-- add_column(:users, :locale, :string, {:limit=>10})
-> 0.0004s
== 20140206044818 AddLocaleToUser: migrated (0.0014s) =========================
== 20140206195001 AddDefaultsToCategoryPostsAndTopicsFields: migrating ========
-- change_column_default(:categories, :posts_week, 0)
-> 0.0012s
-- change_column_default(:categories, :posts_month, 0)
-> 0.0011s
-- change_column_default(:categories, :posts_year, 0)
-> 0.0011s
-- change_column_default(:categories, :topics_week, 0)
-> 0.0011s
-- change_column_default(:categories, :topics_month, 0)
-> 0.0010s
-- change_column_default(:categories, :topics_year, 0)
-> 0.0011s
== 20140206195001 AddDefaultsToCategoryPostsAndTopicsFields: migrated (0.0079s)
== 20140206215029 AddMailingListModeToUsers: migrating ========================
-- rename_column(:users, :watch_new_topics, :mailing_list_mode)
-> 0.0022s
== 20140206215029 AddMailingListModeToUsers: migrated (0.0032s) ===============
== 20140210194146 AddPrimaryGroupIdToUsers: migrating =========================
-- add_column(:users, :primary_group_id, :integer, {:null=>true})
-> 0.0004s
== 20140210194146 AddPrimaryGroupIdToUsers: migrated (0.0013s) ================
== 20140211230222 MoveCasSettings: migrating ==================================
-- drop_table(:cas_user_infos)
-> 0.0009s
== 20140211230222 MoveCasSettings: migrated (0.0062s) =========================
== 20140211234523 AddTargetsTopicToPostActions: migrating =====================
-- add_column(:post_actions, :targets_topic, :boolean, {:default=>false})
-> 0.0222s
== 20140211234523 AddTargetsTopicToPostActions: migrated (0.0236s) ============
== 20140214151255 AddSkippedToEmailLogs: migrating ============================
-- add_column(:email_logs, :skipped, :boolean, {:default=>:false})
-> 0.0140s
-- add_column(:email_logs, :skipped_reason, :string)
-> 0.0003s
-- add_index(:email_logs, [:skipped, :created_at])
-> 0.0042s
== 20140214151255 AddSkippedToEmailLogs: migrated (0.0199s) ===================
== 20140220160510 RenameSiteSettings: migrating ===============================
-- execute("UPDATE site_settings SET name = 'allow_restore' WHERE name = 'allow_import'")
-> 0.0002s
-- execute("UPDATE site_settings SET name = 'topics_per_period_in_top_summary' WHERE name = 'topics_per_period_in_summary'")
-> 0.0001s
== 20140220160510 RenameSiteSettings: migrated (0.0015s) ======================
== 20140220163213 RenameDeleteUserMaxAge: migrating ===========================
-- execute("UPDATE site_settings SET name = 'delete_user_max_post_age' WHERE name = 'delete_user_max_age'")
-> 0.0002s
== 20140220163213 RenameDeleteUserMaxAge: migrated (0.0012s) ==================
== 20140224232712 AddProfileBackgroundToUser: migrating =======================
-- add_column(:users, :profile_background, :string, {:limit=>255})
-> 0.0005s
== 20140224232712 AddProfileBackgroundToUser: migrated (0.0015s) ==============
== 20140224232913 AddSingleSignOnRecords: migrating ===========================
-- create_table(:single_sign_on_records)
-> 0.0076s
-- add_index(:single_sign_on_records, :external_id, {:unique=>true})
-> 0.0035s
== 20140224232913 AddSingleSignOnRecords: migrated (0.0123s) ==================
== 20140227104930 AddCustomEmailInToCategories: migrating =====================
-- add_column(:categories, :email_in, :string, {:null=>true})
-> 0.0004s
-- add_column(:categories, :email_in_allow_strangers, :boolean, {:default=>false})
-> 0.0141s
-- add_index(:categories, :email_in, {:unique=>true})
-> 0.0040s
== 20140227104930 AddCustomEmailInToCategories: migrated (0.0199s) ============
== 20140227201005 AddStaffCategory: migrating =================================
-- execute("INSERT INTO site_settings(name, data_type, value, created_at, updated_at)\n VALUES ('staff_category_id', 3, 4, now(), now())")
-> 0.0002s
== 20140227201005 AddStaffCategory: migrated (0.0026s) ========================
== 20140228005443 AddExternalUsernameToSingleSignOnRecord: migrating ==========
-- add_column(:single_sign_on_records, :external_username, :string)
-> 0.0003s
== 20140228005443 AddExternalUsernameToSingleSignOnRecord: migrated (0.0014s) =
== 20140228173431 AddExternalEmailAndExternalNameToSingleSignOnRecord: migrating
-- add_column(:single_sign_on_records, :external_email, :string)
-> 0.0003s
-- add_column(:single_sign_on_records, :external_name, :string)
-> 0.0003s
== 20140228173431 AddExternalEmailAndExternalNameToSingleSignOnRecord: migrated (0.0016s)
== 20140228205743 AddAdminOnlyToUserHistories: migrating ======================
-- add_column(:user_histories, :admin_only, :boolean, {:default=>false})
-> 0.0276s
-- execute("UPDATE user_histories SET admin_only = true WHERE action = 3")
-> 0.0005s
== 20140228205743 AddAdminOnlyToUserHistories: migrated (0.0328s) =============
== 20140303185354 AddNewSinceToUserStats: migrating ===========================
-- add_column(:user_stats, :new_since, :datetime)
-> 0.0004s
-- execute("UPDATE user_stats AS us\n SET new_since = u.created_at\n FROM users AS u\n WHERE u.id = us.user_id")
-> 0.0006s
-- change_column(:user_stats, :new_since, :datetime, {:null=>false})
-> 0.0004s
== 20140303185354 AddNewSinceToUserStats: migrated (0.0026s) ==================
== 20140304200606 CreateBadgeTypes: migrating =================================
-- create_table(:badge_types)
-> 0.0065s
-- add_index(:badge_types, [:name], {:unique=>true})
-> 0.0129s
== 20140304200606 CreateBadgeTypes: migrated (0.0208s) ========================
== 20140304201403 CreateBadges: migrating =====================================
-- create_table(:badges)
-> 0.0099s
-- add_index(:badges, [:name], {:unique=>true})
-> 0.0033s
== 20140304201403 CreateBadges: migrated (0.0145s) ============================
== 20140305100909 CreateUserBadges: migrating =================================
-- create_table(:user_badges)
-> 0.0069s
-- add_index(:user_badges, [:badge_id, :user_id], {:unique=>true})
-> 0.0036s
== 20140305100909 CreateUserBadges: migrated (0.0119s) ========================
== 20140306223522 MoveTopicRevisionsToPostRevisions: migrating ================
-- execute("\n INSERT INTO post_revisions(user_id, post_id, modifications, number, created_at, updated_at)\n SELECT tr.user_id, p.id, tr.modifications, tr.number, tr.created_at, tr.updated_at\n FROM topic_revisions tr\n JOIN topics t ON t.id = tr.topic_id\n JOIN posts p ON p.topic_id = t.id AND p.post_number = 1\n\n")
-> 0.0011s
-- execute("\n UPDATE post_revisions r SET number = 2 + (\n SELECT COUNT(*) FROM post_revisions r2\n WHERE r2.post_id = r.post_id AND r2.created_at < r.created_at\n )\n\n")
-> 0.0004s
-- execute("\n UPDATE posts p SET version = 1 + (\n SELECT COUNT(*) FROM post_revisions r\n WHERE r.post_id = p.id\n )\n\n")
-> 0.0003s
-- execute("\n DROP TABLE topic_revisions\n\n")
-> 0.0007s
== 20140306223522 MoveTopicRevisionsToPostRevisions: migrated (0.0036s) =======
== 20140318150412 AddExcerptToTopics: migrating ===============================
-- add_column(:topics, :excerpt, :string, {:limit=>1000})
-> 0.0004s
-- execute("SELECT id FROM topics WHERE pinned_at IS NOT NULL")
-> 0.0002s
== 20140318150412 AddExcerptToTopics: migrated (0.0018s) ======================
== 20140318203559 AddCreatedAtIndexToPosts: migrating =========================
-- execute("CREATE INDEX idx_posts_created_at_topic_id ON posts(created_at, topic_id) WHERE deleted_at IS NULL")
-> 0.0026s
-- add_column(:categories, :topics_day, :integer, {:default=>0})
-> 0.0270s
-- add_column(:categories, :posts_day, :integer, {:default=>0})
-> 0.0172s
-- execute("DROP INDEX index_topics_on_deleted_at_and_visible_and_archetype_and_id")
-> 0.0003s
-- add_index(:topics, [:deleted_at, :visible, :archetype, :category_id, :id], {:name=>"idx_topics_front_page"})
-> 0.0040s
== 20140318203559 AddCreatedAtIndexToPosts: migrated (0.0525s) ================
== 20140320042653 FacebookUserInfosUsernameCanBeNil: migrating ================
-- change_column("facebook_user_infos", :username, :string, {:null=>true})
-> 0.0006s
== 20140320042653 FacebookUserInfosUsernameCanBeNil: migrated (0.0018s) =======
== 20140402201432 MakeContentSha1Nullable: migrating ==========================
-- change_column(:topic_embeds, :content_sha1, :string, {:limit=>40, :null=>true})
-> 0.0004s
== 20140402201432 MakeContentSha1Nullable: migrated (0.0015s) =================
== 20140404143501 AddTitleToTopicLinks: migrating =============================
-- add_column(:topic_links, :title, :string)
-> 0.0003s
-- add_column(:topic_links, :crawled_at, :datetime)
-> 0.0003s
== 20140404143501 AddTitleToTopicLinks: migrated (0.0016s) ====================
== 20140407055830 AddPinnedGloballyToTopics: migrating ========================
-- add_column(:topics, :pinned_globally, :boolean, {:null=>false, :default=>false})
-> 0.0178s
-- execute("UPDATE topics set pinned_globally = 't' where category_id = (\n SELECT value::int FROM site_settings WHERE name = 'uncategorized_category_id') AND pinned_at IS NOT NULL\n ")
-> 0.0005s
== 20140407055830 AddPinnedGloballyToTopics: migrated (0.0196s) ===============
== 20140407202158 SiteSettingCommaToPipe: migrating ===========================
-- execute(" UPDATE site_settings\n SET value = replace(value, ',', '|')\n WHERE name = 'white_listed_spam_host_domains'\n ;\n")
-> 0.0002s
-- execute(" UPDATE site_settings\n SET value = replace(value, ',', '|')\n WHERE name = 'exclude_rel_nofollow_domains'\n ;\n")
-> 0.0002s
== 20140407202158 SiteSettingCommaToPipe: migrated (0.0016s) ==================
== 20140408061512 AddWikiToPosts: migrating ===================================
-- add_column(:posts, :wiki, :boolean, {:default=>false, :null=>false})
-> 0.0281s
== 20140408061512 AddWikiToPosts: migrated (0.0295s) ==========================
== 20140408152401 AddDefaultValueToTopTopicScores: migrating ==================
-- change_column_default(:top_topics, :daily_score, 0)
-> 0.0012s
-- change_column_default(:top_topics, :weekly_score, 0)
-> 0.0010s
-- change_column_default(:top_topics, :monthly_score, 0)
-> 0.0011s
-- change_column_default(:top_topics, :yearly_score, 0)
-> 0.0011s
== 20140408152401 AddDefaultValueToTopTopicScores: migrated (0.0056s) =========
== 20140415054717 AllowLongerUsernames: migrating =============================
-- change_column(:users, :username, :string, {:limit=>60})
-> 0.0007s
-- change_column(:users, :username_lower, :string, {:limit=>60})
-> 0.0006s
== 20140415054717 AllowLongerUsernames: migrated (0.0023s) ====================
== 20140416202746 CreateColorSchemes: migrating ===============================
-- create_table(:color_schemes)
-> 0.0071s
== 20140416202746 CreateColorSchemes: migrated (0.0082s) ======================
== 20140416202801 CreateColorSchemeColors: migrating ==========================
-- create_table(:color_scheme_colors)
-> 0.0142s
-- add_index(:color_scheme_colors, [:color_scheme_id])
-> 0.0037s
== 20140416202801 CreateColorSchemeColors: migrated (0.0193s) =================
== 20140416235757 RemoveColorHexcodeFromBadgeTypes: migrating =================
-- remove_column(:badge_types, :color_hexcode, :string)
-> 0.0003s
== 20140416235757 RemoveColorHexcodeFromBadgeTypes: migrated (0.0015s) ========
== 20140421235646 AddUserCustomFields: migrating ==============================
-- create_table(:user_custom_fields)
-> 0.0075s
-- add_index(:user_custom_fields, [:user_id, :name])
-> 0.0044s
== 20140421235646 AddUserCustomFields: migrated (0.0133s) =====================
== 20140422195623 AddVisibileToGroups: migrating ==============================
-- add_column(:groups, :visible, :boolean, {:default=>true, :null=>false})
-> 0.0094s
== 20140422195623 AddVisibileToGroups: migrated (0.0107s) =====================
== 20140425125742 AddCustomFields: migrating ==================================
-- create_table(:category_custom_fields)
-> 0.0074s
-- create_table(:group_custom_fields)
-> 0.0164s
-- create_table(:post_custom_fields)
-> 0.0064s
-- add_index(:category_custom_fields, [:category_id, :name])
-> 0.0037s
-- add_index(:group_custom_fields, [:group_id, :name])
-> 0.0035s
-- add_index(:post_custom_fields, [:post_id, :name])
-> 0.0035s
== 20140425125742 AddCustomFields: migrated (0.0424s) =========================
== 20140425135354 AddTopicCustomFields: migrating =============================
-- create_table(:topic_custom_fields)
-> 0.0067s
-- add_index(:topic_custom_fields, [:topic_id, :name])
-> 0.0131s
-- execute(" INSERT INTO topic_custom_fields(topic_id, name, value)\n SELECT id, (each(meta_data)).key, (each(meta_data)).value\n FROM topics WHERE meta_data <> ''\n")
-> 0.0010s
-- remove_column(:topics, :meta_data)
-> 0.0004s
== 20140425135354 AddTopicCustomFields: migrated (0.0226s) ====================
== 20140425172618 AddTitleableToBadges: migrating =============================
-- add_column(:badges, :allow_title, :boolean, {:null=>false, :default=>false})
-> 0.0129s
== 20140425172618 AddTitleableToBadges: migrated (0.0143s) ====================
== 20140429175951 AddRegistrationIpAddressToUsers: migrating ==================
-- add_column(:users, :registration_ip_address, :inet)
-> 0.0005s
== 20140429175951 AddRegistrationIpAddressToUsers: migrated (0.0016s) =========
== 20140504174212 IncrementReservedTrustLevelBadgeIds: migrating ==============
-- execute("ALTER SEQUENCE badges_id_seq START WITH 100")
-> 0.0002s
== 20140504174212 IncrementReservedTrustLevelBadgeIds: migrated (0.0086s) =====
== 20140505145918 AddLastRedirectedToTopAtToUsers: migrating ==================
-- add_column(:users, :last_redirected_to_top_at, :datetime)
-> 0.0005s
== 20140505145918 AddLastRedirectedToTopAtToUsers: migrated (0.0015s) =========
== 20140506200235 RemoveSeedColorScheme: migrating ============================
-- execute("DELETE FROM color_schemes WHERE id = 1")
-> 0.0003s
-- execute("DELETE FROM color_scheme_colors WHERE color_scheme_id = 1")
-> 0.0003s
== 20140506200235 RemoveSeedColorScheme: migrated (0.0015s) ===================
== 20140507173327 RemoveOpacityFromColorSchemeColors: migrating ===============
-- remove_column(:color_scheme_colors, :opacity)
-> 0.0004s
== 20140507173327 RemoveOpacityFromColorSchemeColors: migrated (0.0014s) ======
== 20140508053815 AddInvitedGroups: migrating =================================
-- create_table(:invited_groups)
-> 0.0041s
== 20140508053815 AddInvitedGroups: migrated (0.0052s) ========================
== 20140515220111 InitFixedCategoryPositionsValue: migrating ==================
== 20140515220111 InitFixedCategoryPositionsValue: migrated (0.0014s) =========
== 20140520062826 AddMultipleAwardToBadges: migrating =========================
-- add_column(:badges, :multiple_grant, :boolean, {:default=>false, :null=>false})
-> 0.0225s
-- remove_index(:user_badges, {:column=>[:badge_id, :user_id]})
-> 0.0012s
-- add_index(:user_badges, [:badge_id, :user_id])
-> 0.0046s
== 20140520062826 AddMultipleAwardToBadges: migrated (0.0297s) ================
== 20140520063859 RemoveHasCustomAvatarFromUserStats: migrating ===============
-- remove_column(:user_stats, :has_custom_avatar)
-> 0.0004s
== 20140520063859 RemoveHasCustomAvatarFromUserStats: migrated (0.0016s) ======
== 20140521192142 CreateGoogleUserInfos: migrating ============================
-- create_table(:google_user_infos)
-> 0.0165s
-- add_index(:google_user_infos, :user_id, {:unique=>true})
-> 0.0040s
-- add_index(:google_user_infos, :google_user_id, {:unique=>true})
-> 0.0036s
== 20140521192142 CreateGoogleUserInfos: migrated (0.0253s) ===================
== 20140521220115 GoogleOpenidDefaultHasChanged: migrating ====================
== 20140521220115 GoogleOpenidDefaultHasChanged: migrated (0.0014s) ===========
== 20140522003151 AddUserAvatars: migrating ===================================
-- create_table(:user_avatars)
-> 0.0043s
-- add_index(:user_avatars, [:user_id])
-> 0.0041s
-- execute(" INSERT INTO user_avatars(user_id, custom_upload_id)\n SELECT id, uploaded_avatar_id\n FROM users\n")
-> 0.0002s
-- execute(" UPDATE users SET uploaded_avatar_id = NULL\n WHERE NOT use_uploaded_avatar\n")
-> 0.0002s
== 20140522003151 AddUserAvatars: migrated (0.0100s) ==========================
== 20140525233953 RemoveUploadedAvatarTemplateFromUsers: migrating ============
-- remove_column(:users, :uploaded_avatar_template)
-> 0.0003s
== 20140525233953 RemoveUploadedAvatarTemplateFromUsers: migrated (0.0013s) ===
== 20140526185749 ChangeCategoryUniqunessContstraint: migrating ===============
-- remove_index(:categories, {:name=>"index_categories_on_name"})
-> 0.0009s
-- add_index(:categories, [:parent_category_id, :name], {:unique=>true})
-> 0.0036s
== 20140526185749 ChangeCategoryUniqunessContstraint: migrated (0.0056s) ======
== 20140526201939 AddDisableJumpReplyToUsers: migrating =======================
-- add_column(:users, :disable_jump_reply, :boolean, {:default=>false, :null=>false})
-> 0.0313s
== 20140526201939 AddDisableJumpReplyToUsers: migrated (0.0327s) ==============
== 20140527163207 CreateUserProfiles: migrating ===============================
-- create_table(:user_profiles, {:id=>false})
-> 0.0037s
-- execute("ALTER TABLE user_profiles ADD PRIMARY KEY (user_id)")
-> 0.0025s
-- execute("INSERT INTO user_profiles (user_id) SELECT id FROM users")
-> 0.0005s
== 20140527163207 CreateUserProfiles: migrated (0.0080s) ======================
== 20140527233225 AddSystemSavatarVersionToUserAvatars: migrating =============
-- add_column(:user_avatars, :system_avatar_version, :integer, {:default=>0})
-> 0.0086s
== 20140527233225 AddSystemSavatarVersionToUserAvatars: migrated (0.0098s) ====
== 20140528015354 AddBakedAtToPosts: migrating ================================
-- add_column(:posts, :baked_at, :datetime)
-> 0.0004s
== 20140528015354 AddBakedAtToPosts: migrated (0.0016s) =======================
== 20140529045508 RemoveUseUploadedAvatarFromUser: migrating ==================
-- remove_column(:users, :use_uploaded_avatar)
-> 0.0004s
== 20140529045508 RemoveUseUploadedAvatarFromUser: migrated (0.0014s) =========
== 20140530002535 RemoveSystemAvatarsFromUserAvatars: migrating ===============
-- execute("UPDATE users SET uploaded_avatar_id = NULL WHERE uploaded_avatar_id IN (\n SELECT system_upload_id FROM user_avatars\n )")
-> 0.0006s
-- remove_column(:user_avatars, :system_upload_id)
-> 0.0003s
-- remove_column(:user_avatars, :system_avatar_version)
-> 0.0003s
== 20140530002535 RemoveSystemAvatarsFromUserAvatars: migrated (0.0160s) ======
== 20140530043913 AddBakedVersionToPost: migrating ============================
-- add_column(:posts, :baked_version, :integer)
-> 0.0004s
== 20140530043913 AddBakedVersionToPost: migrated (0.0016s) ===================
== 20140604145431 DisableExternalAuthsByDefault: migrating ====================
== 20140604145431 DisableExternalAuthsByDefault: migrated (0.0011s) ===========
== 20140607035234 AddWebsiteToUserProfiles: migrating =========================
-- add_column(:user_profiles, :website, :string)
-> 0.0003s
-- execute("UPDATE user_profiles SET website = (SELECT website FROM users where user_profiles.user_id = users.id)")
-> 0.0003s
-- remove_column(:users, :website)
-> 0.0003s
== 20140607035234 AddWebsiteToUserProfiles: migrated (0.0019s) ================
== 20140610012414 AddPostIdToUserBadges: migrating ============================
-- add_column(:user_badges, :post_id, :integer)
-> 0.0003s
== 20140610012414 AddPostIdToUserBadges: migrated (0.0012s) ===================
== 20140610012833 AddIconToBadges: migrating ==================================
-- add_column(:badges, :icon, :string, {:default=>"fa-certificate"})
-> 0.0135s
== 20140610012833 AddIconToBadges: migrated (0.0149s) =========================
== 20140610034314 MoveBioToUserProfiles: migrating ============================
-- add_column(:user_profiles, :bio_raw, :text)
-> 0.0004s
-- add_column(:user_profiles, :bio_cooked, :text)
-> 0.0003s
-- execute("UPDATE user_profiles SET bio_raw = subquery.bio_raw, bio_cooked = subquery.bio_cooked FROM (\n SELECT bio_raw, bio_cooked, id FROM users\n ) as subquery WHERE user_profiles.user_id = subquery.id")
-> 0.0005s
-- remove_column(:users, :bio_raw)
-> 0.0002s
-- remove_column(:users, :bio_cooked)
-> 0.0002s
== 20140610034314 MoveBioToUserProfiles: migrated (0.0028s) ===================
== 20140612010718 MoveProfileBackgroundToUserProfiles: migrating ==============
-- add_column(:user_profiles, :profile_background, :string, {:limit=>255})
-> 0.0003s
-- execute("UPDATE user_profiles SET profile_background = (SELECT profile_background FROM users WHERE user_profiles.user_id = users.id)")
-> 0.0003s
-- remove_column(:users, :profile_background)
-> 0.0002s
== 20140612010718 MoveProfileBackgroundToUserProfiles: migrated (0.0019s) =====
== 20140617053829 AddNotificationIdToUserBadge: migrating =====================
-- add_column(:user_badges, :notification_id, :integer)
-> 0.0003s
== 20140617053829 AddNotificationIdToUserBadge: migrated (0.0013s) ============
== 20140617080955 RenameRegisteredUsers: migrating ============================
-- execute("update groups set name = 'trust_level_0' where name = 'registered_users' and id = 10")
-> 0.0004s
== 20140617080955 RenameRegisteredUsers: migrated (0.0014s) ===================
== 20140617193351 AddPostIdIndexOnTopicLinks: migrating =======================
-- add_index(:topic_links, :post_id)
-> 0.0113s
== 20140617193351 AddPostIdIndexOnTopicLinks: migrated (0.0126s) ==============
== 20140618001820 DontAutoMutoTopics: migrating ===============================
-- execute("DELETE FROM topic_users WHERE notification_level = 0 and notifications_reason_id =7 AND first_visited_at IS NULL")
-> 0.0004s
-- execute("UPDATE topic_users SET notification_level = 1,\n notifications_reason_id = NULL\n WHERE notification_level = 0 AND notifications_reason_id =7")
-> 0.0002s
== 20140618001820 DontAutoMutoTopics: migrated (0.0016s) ======================
== 20140618163511 AddDismissedBannerKeyToUserProfile: migrating ===============
-- add_column(:user_profiles, :dismissed_banner_key, :integer, {:nullable=>true})
-> 0.0003s
== 20140618163511 AddDismissedBannerKeyToUserProfile: migrated (0.0013s) ======
== 20140620184031 AddHiddenAtToPosts: migrating ===============================
-- add_column(:posts, :hidden_at, :timestamp)
-> 0.0004s
== 20140620184031 AddHiddenAtToPosts: migrated (0.0015s) ======================
== 20140623195618 FixCategoriesConstraint: migrating ==========================
-- remove_index(:categories, {:name=>"index_categories_on_parent_category_id_and_name"})
-> 0.0012s
-- execute("DELETE FROM categories WHERE id IN (SELECT id FROM (SELECT id, row_number() over (partition BY parent_category_id, name ORDER BY id) AS rnum FROM categories) t WHERE t.rnum > 1)")
-> 0.0005s
-- execute("CREATE UNIQUE INDEX unique_index_categories_on_name ON categories (COALESCE(parent_category_id, -1), name)")
-> 0.0032s
== 20140623195618 FixCategoriesConstraint: migrated (0.0060s) =================
== 20140624044600 AddRawDataToSearch: migrating ===============================
-- add_column(:post_search_data, :raw_data, :text)
-> 0.0003s
-- add_column(:user_search_data, :raw_data, :text)
-> 0.0002s
-- add_column(:category_search_data, :raw_data, :text)
-> 0.0002s
-- add_column(:post_search_data, :locale, :string)
-> 0.0003s
-- add_column(:user_search_data, :locale, :text)
-> 0.0002s
-- add_column(:category_search_data, :locale, :text)
-> 0.0002s
== 20140624044600 AddRawDataToSearch: migrated (0.0028s) ======================
== 20140627193814 AddImagesToCategories: migrating ============================
-- add_column(:categories, :logo_url, :string)
-> 0.0003s
-- add_column(:categories, :background_url, :string)
-> 0.0003s
== 20140627193814 AddImagesToCategories: migrated (0.0017s) ===================
== 20140703022838 AddFieldsToBadges: migrating ================================
-- add_column(:badges, :listable, :boolean, {:default=>true})
-> 0.0178s
-- add_column(:badges, :target_posts, :boolean, {:default=>false})
-> 0.0138s
-- add_column(:badges, :query, :text)
-> 0.0004s
== 20140703022838 AddFieldsToBadges: migrated (0.0334s) =======================
== 20140705081453 IndexUserBadges: migrating ==================================
-- execute("DELETE FROM user_badges USING user_badges ub2\n WHERE user_badges.badge_id = ub2.badge_id AND\n user_badges.user_id = ub2.user_id AND\n user_badges.post_id IS NOT NULL AND\n user_badges.id < ub2.id\n ")
-> 0.0006s
-- add_index(:user_badges, [:badge_id, :user_id, :post_id], {:unique=>true, :where=>"post_id IS NOT NULL"})
-> 0.0057s
== 20140705081453 IndexUserBadges: migrated (0.0075s) =========================
== 20140707071913 AddSelfEditsToPosts: migrating ==============================
-- add_column(:posts, :self_edits, :integer, {:null=>false, :default=>0})
-> 0.0188s
-- execute("\n UPDATE posts p SET self_edits = (SELECT COUNT(*) FROM post_revisions pr WHERE pr.post_id = p.id AND pr.user_id=p.user_id)\n ")
-> 0.0006s
== 20140707071913 AddSelfEditsToPosts: migrated (0.0207s) =====================
== 20140710005023 AddBadgePostsAndTopicsView: migrating =======================
-- add_column(:categories, :allow_badges, :boolean, {:default=>true, :null=>false})
-> 0.0221s
-- execute("CREATE VIEW badge_posts AS\n SELECT p.*\n FROM posts p\n JOIN topics t ON t.id = p.topic_id\n JOIN categories c ON c.id = t.category_id\n WHERE c.allow_badges AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n t.visible")
-> 0.0033s
== 20140710005023 AddBadgePostsAndTopicsView: migrated (0.0268s) ==============
== 20140710224658 AddIsQuoteToTopicLinks: migrating ===========================
-- add_column(:topic_links, :quote, :boolean, {:default=>false, :null=>false})
-> 0.0150s
-- execute("\n UPDATE topic_links\n SET quote = true\n WHERE id IN (\n SELECT l.id\n FROM topic_links l\n JOIN posts p ON p.id = l.post_id\n JOIN posts lp ON l.link_post_id = lp.id\n WHERE p.raw LIKE '%[quote=%post:' ||\n lp.post_number::varchar || ',%topic:' ||\n lp.topic_id::varchar || '%]%[/quote]%'\n )")
-> 0.0011s
== 20140710224658 AddIsQuoteToTopicLinks: migrated (0.0175s) ==================
== 20140711063215 AddReadFaqToUserStats: migrating ============================
-- add_column(:user_stats, :read_faq, :datetime)
-> 0.0004s
== 20140711063215 AddReadFaqToUserStats: migrated (0.0015s) ===================
== 20140711143146 RemoveNotNullFromEmail: migrating ===========================
-- execute("ALTER TABLE invites ALTER COLUMN email DROP NOT NULL")
-> 0.0002s
== 20140711143146 RemoveNotNullFromEmail: migrated (0.0012s) ==================
== 20140711193923 RemoveEmailInAddressSetting: migrating ======================
== 20140711193923 RemoveEmailInAddressSetting: migrated (0.0014s) =============
== 20140711233329 BadgesOnlyOnPublicCategories: migrating =====================
-- execute("DROP VIEW badge_posts")
-> 0.0008s
-- execute("CREATE VIEW badge_posts AS\n SELECT p.*\n FROM posts p\n JOIN topics t ON t.id = p.topic_id\n JOIN categories c ON c.id = t.category_id\n WHERE c.allow_badges AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n NOT c.read_restricted AND\n t.visible")
-> 0.0031s
== 20140711233329 BadgesOnlyOnPublicCategories: migrated (0.0050s) ============
== 20140714060646 AddEnabledToBadges: migrating ===============================
-- add_column(:badges, :enabled, :boolean, {:default=>true, :null=>false})
-> 0.0124s
== 20140714060646 AddEnabledToBadges: migrated (0.0138s) ======================
== 20140715013018 CorrectPostNumberIndex: migrating ===========================
-- execute(" UPDATE posts SET post_number = post_number + 1\n WHERE id IN (\n SELECT p1.id\n FROM posts p1\n JOIN\n (\n SELECT post_number, topic_id, min(id) min_id\n FROM posts\n GROUP BY post_number, topic_id\n HAVING COUNT(*) > 1\n ) pp ON p1.topic_id = pp.topic_id AND\n p1.post_number >= pp.post_number AND\n p1.id <> pp.min_id\n )\n")
-> 0.0007s
-- remove_index(:posts, [:topic_id, :post_number])
-> 0.0010s
-- add_index(:posts, [:topic_id, :post_number], {:unique=>true})
-> 0.0126s
== 20140715013018 CorrectPostNumberIndex: migrated (0.0158s) ==================
== 20140715051412 AddAutoRevokeToBadges: migrating ============================
-- add_column(:badges, :auto_revoke, :boolean, {:default=>true, :null=>false})
-> 0.0116s
== 20140715051412 AddAutoRevokeToBadges: migrated (0.0130s) ===================
== 20140715055242 AddQuotedPosts: migrating ===================================
-- create_table(:quoted_posts)
-> 0.0128s
-- add_index(:quoted_posts, [:post_id, :quoted_post_id], {:unique=>true})
-> 0.0039s
-- add_index(:quoted_posts, [:quoted_post_id, :post_id], {:unique=>true})
-> 0.0034s
-- execute(" SELECT id, cooked\n FROM posts\n WHERE raw like '%quote=%' AND id > 0\n ORDER BY id\n LIMIT 1000\n")
-> 0.0004s
== 20140715055242 AddQuotedPosts: migrated (0.0219s) ==========================
== 20140715160720 UpdateUsersCaseInsensitiveEmails: migrating =================
-- execute("DROP INDEX index_users_on_email")
-> 0.0003s
-- execute(" SELECT id, email, count\n FROM (SELECT id, email,\n row_number() OVER(PARTITION BY lower(email) ORDER BY id asc) AS count\n FROM users) dups\n WHERE dups.count > 1\n")
-> 0.0004s
-- execute("UPDATE users SET email = lower(email)")
-> 0.0002s
-- execute("CREATE UNIQUE INDEX index_users_on_email ON users ((lower(email)));")
-> 0.0028s
== 20140715160720 UpdateUsersCaseInsensitiveEmails: migrated (0.0048s) ========
== 20140715190552 RemoveUncategorizedParents: migrating =======================
-- execute("SELECT value FROM site_settings WHERE name = 'uncategorized_category_id'")
-> 0.0002s
-- execute("UPDATE categories SET parent_category_id = NULL where id = 1")
-> 0.0004s
== 20140715190552 RemoveUncategorizedParents: migrated (0.0016s) ==============
== 20140716063802 AddBadgeGroupings: migrating ================================
-- create_table(:badge_groupings)
-> 0.0067s
-- add_column(:badges, :badge_grouping_id, :integer)
-> 0.0004s
== 20140716063802 AddBadgeGroupings: migrated (0.0084s) =======================
== 20140717024528 DescriptionOptionalInBadgeGrouping: migrating ===============
-- change_column(:badge_groupings, :description, :text, {:null=>true})
-> 0.0005s
== 20140717024528 DescriptionOptionalInBadgeGrouping: migrated (0.0015s) ======
== 20140718041445 SetDefaultBadgeGrouping: migrating ==========================
-- execute("UPDATE badges SET badge_grouping_id = 5 WHERE badge_grouping_id IS NULL")
-> 0.0003s
-- change_column(:badges, :badge_grouping_id, :integer, {:null=>false, :default=>5})
-> 0.0022s
== 20140718041445 SetDefaultBadgeGrouping: migrated (0.0035s) =================
== 20140721063820 AddTriggerToBadges: migrating ===============================
-- add_column(:badges, :trigger, :integer)
-> 0.0003s
== 20140721063820 AddTriggerToBadges: migrated (0.0012s) ======================
== 20140721161249 AddAgreedAtAndAgreedByIdToPostAction: migrating =============
-- add_column(:post_actions, :agreed_at, :datetime)
-> 0.0004s
-- add_column(:post_actions, :agreed_by_id, :integer)
-> 0.0002s
== 20140721161249 AddAgreedAtAndAgreedByIdToPostAction: migrated (0.0021s) ====
== 20140721162307 RenameDeferColumnsOnPostAction: migrating ===================
-- rename_column(:post_actions, :defer_by, :defered_by_id)
-> 0.0016s
-- add_column(:post_actions, :defered_at, :datetime)
-> 0.0003s
-- execute("UPDATE post_actions SET defered_at = updated_at WHERE defer = 't'")
-> 0.0003s
-- remove_column(:post_actions, :defer)
-> 0.0003s
== 20140721162307 RenameDeferColumnsOnPostAction: migrated (0.0037s) ==========
== 20140723011456 AddShowPostsToBadges: migrating =============================
-- add_column(:badges, :show_posts, :boolean, {:null=>false, :default=>false})
-> 0.0205s
== 20140723011456 AddShowPostsToBadges: migrated (0.0220s) ====================
== 20140725050636 RemoveInvalidIncomingLinks: migrating =======================
-- execute("DELETE FROM incoming_links WHERE url ILIKE '%avatar%.png'")
-> 0.0005s
== 20140725050636 RemoveInvalidIncomingLinks: migrated (0.0017s) ==============
== 20140725172830 RemoveMessageFromPostAction: migrating ======================
-- remove_column(:post_actions, :message)
-> 0.0003s
== 20140725172830 RemoveMessageFromPostAction: migrated (0.0013s) =============
== 20140727030954 AddEditHistoryPublicToUsers: migrating ======================
-- add_column(:users, :edit_history_public, :boolean, {:default=>false, :null=>false})
-> 0.0307s
== 20140727030954 AddEditHistoryPublicToUsers: migrated (0.0320s) =============
== 20140728120708 FixIndexOnPostAction: migrating =============================
-- remove_index("post_actions", {:name=>"idx_unique_actions"})
-> 0.0010s
-- add_index("post_actions", ["user_id", "post_action_type_id", "post_id", "deleted_at", "targets_topic"], {:name=>"idx_unique_actions", :unique=>true})
-> 0.0038s
== 20140728120708 FixIndexOnPostAction: migrated (0.0060s) ====================
== 20140728144308 AddFirstPostCreatedAtToUserStat: migrating ==================
-- add_column(:user_stats, :first_post_created_at, :datetime)
-> 0.0004s
-- execute(" WITH first_posts AS (\n SELECT p.id,\n p.user_id,\n p.created_at,\n ROW_NUMBER() OVER (PARTITION BY p.user_id ORDER BY p.created_at ASC) AS row\n FROM posts p\n )\n UPDATE user_stats us\n SET first_post_created_at = fp.created_at\n FROM first_posts fp\n WHERE fp.row = 1\n AND fp.user_id = us.user_id\n")
-> 0.0006s
== 20140728144308 AddFirstPostCreatedAtToUserStat: migrated (0.0021s) =========
== 20140728152804 AddPostAndTopicCountsToUserStat: migrating ==================
-- add_column(:user_stats, :post_count, :integer, {:default=>0, :null=>false})
-> 0.0065s
-- add_column(:user_stats, :topic_count, :integer, {:default=>0, :null=>false})
-> 0.0054s
-- execute(" UPDATE user_stats\n SET post_count = pc.count\n FROM (SELECT user_id, COUNT(*) AS count FROM posts GROUP BY user_id) AS pc\n WHERE pc.user_id = user_stats.user_id\n")
-> 0.0005s
-- execute(" UPDATE user_stats\n SET topic_count = tc.count\n FROM (SELECT user_id, COUNT(*) AS count FROM topics GROUP BY user_id) AS tc\n WHERE tc.user_id = user_stats.user_id\n")
-> 0.0004s
== 20140728152804 AddPostAndTopicCountsToUserStat: migrated (0.0141s) =========
== 20140729092525 RemoveUniqueConstraintFromInvitesIndex: migrating ===========
-- remove_index(:invites, [:email, :invited_by_id])
-> 0.0012s
-- add_index(:invites, [:email, :invited_by_id], {:unique=>false})
-> 0.0036s
== 20140729092525 RemoveUniqueConstraintFromInvitesIndex: migrated (0.0061s) ==
== 20140730203029 AddDisagreedAtAndDisagreedByIdToPostAction: migrating =======
-- add_column(:post_actions, :disagreed_at, :datetime)
-> 0.0004s
-- add_column(:post_actions, :disagreed_by_id, :integer)
-> 0.0002s
-- execute(" UPDATE post_actions\n SET disagreed_at = deleted_at,\n disagreed_by_id = deleted_by_id,\n deleted_at = NULL,\n deleted_by_id = NULL\n WHERE deleted_by_id != user_id\n")
-> 0.0003s
== 20140730203029 AddDisagreedAtAndDisagreedByIdToPostAction: migrated (0.0023s)
== 20140731011328 AddReplyQuotedToPosts: migrating ============================
-- add_column(:posts, :reply_quoted, :boolean, {:null=>false, :default=>false})
-> 0.0172s
-- execute("UPDATE posts p\n SET reply_quoted = true\n WHERE EXISTS(\n SELECT 1 FROM quoted_posts q\n JOIN posts p1 ON p1.post_number = p.reply_to_post_number AND p1.topic_id = p.topic_id\n WHERE q.post_id = p.id AND q.quoted_post_id = p1.id\n ) AND p.reply_to_post_number IS NOT NULL")
-> 0.0008s
== 20140731011328 AddReplyQuotedToPosts: migrated (0.0193s) ===================
== 20140801052028 FixIncomingLinks: migrating =================================
-- execute("DROP INDEX incoming_index")
-> 0.0002s
-- add_column(:incoming_links, :post_id, :integer)
-> 0.0003s
-- remove_column(:incoming_links, :updated_at)
-> 0.0002s
-- remove_column(:incoming_links, :url)
-> 0.0002s
-- execute("UPDATE incoming_links l SET post_id = (\n SELECT p.id FROM posts p WHERE p.topic_id = l.topic_id AND p.post_number = l.post_number\n )")
-> 0.0005s
-- execute("DELETE FROM incoming_links WHERE post_id IS NULL")
-> 0.0001s
-- change_column(:incoming_links, :post_id, :integer, {:null=>false})
-> 0.0003s
-- add_index(:incoming_links, :post_id)
-> 0.0068s
== 20140801052028 FixIncomingLinks: migrated (0.0100s) ========================
== 20140801170444 CreatePostTimingsUserIndex: migrating =======================
-- add_index(:post_timings, :user_id)
-> 0.0044s
== 20140801170444 CreatePostTimingsUserIndex: migrated (0.0056s) ==============
== 20140804010803 IncomingLinkNormalization: migrating ========================
-- remove_column(:incoming_links, :post_number)
-> 0.0003s
-- remove_column(:incoming_links, :domain)
-> 0.0003s
-- add_column(:incoming_links, :incoming_referer_id, :integer)
-> 0.0003s
-- create_table(:incoming_referers)
-> 0.0061s
-- execute("INSERT INTO incoming_referers(url, https, domain, port, path)\n SELECT referer,\n CASE WHEN a[1] = 's' THEN true ELSE false END,\n a[2] as domain,\n CASE WHEN a[1] = 's' THEN\n COALESCE(a[4]::integer, 443)::integer\n ELSE\n COALESCE(a[4]::integer, 80)::integer\n END,\n COALESCE(a[5], '') path\n FROM\n (\n SELECT referer, regexp_matches(referer, 'http(s)?://([^/:]+)(:(d+))?(.*)') a\n FROM\n (\n SELECT DISTINCT referer\n FROM incoming_links WHERE referer ~ '^https?://.+'\n ) Z\n ) X\n WHERE a[2] IS NOT NULL")
-> 0.0006s
-- execute("UPDATE incoming_links l\n SET incoming_referer_id = r.id\n FROM incoming_referers r\n WHERE r.url = l.referer")
-> 0.0003s
-- create_table(:incoming_domains)
-> 0.0036s
-- execute("INSERT INTO incoming_domains(name, port, https)\n SELECT DISTINCT domain, port, https\n FROM incoming_referers")
-> 0.0002s
-- execute("UPDATE incoming_referers l\n SET incoming_domain_id = d.id\n FROM incoming_domains d\n WHERE d.name = l.domain AND d.https = l.https AND d.port = l.port")
-> 0.0003s
-- remove_column(:incoming_referers, :domain)
-> 0.0003s
-- remove_column(:incoming_referers, :port)
-> 0.0002s
-- remove_column(:incoming_referers, :https)
-> 0.0002s
-- change_column(:incoming_referers, :incoming_domain_id, :integer, {:null=>false})
-> 0.0004s
-- add_index(:incoming_referers, [:path, :incoming_domain_id], {:unique=>true})
-> 0.0037s
-- add_index(:incoming_domains, [:name, :https, :port], {:unique=>true})
-> 0.0035s
-- remove_column(:incoming_links, :referer)
-> 0.0003s
== 20140804010803 IncomingLinkNormalization: migrated (0.0222s) ===============
== 20140804030041 RemoveUrlFromIncomingReferer: migrating =====================
-- remove_column(:incoming_referers, :url)
-> 0.0003s
== 20140804030041 RemoveUrlFromIncomingReferer: migrated (0.0016s) ============
== 20140804060439 DropTopicIdFromIncomingLinks: migrating =====================
-- remove_column(:incoming_links, :topic_id)
-> 0.0003s
== 20140804060439 DropTopicIdFromIncomingLinks: migrated (0.0013s) ============
== 20140804072504 ViewsToTopicViews: migrating ================================
-- remove_column(:views, :parent_type)
-> 0.0005s
-- rename_column(:views, :parent_id, :topic_id)
-> 0.0008s
-- rename_table(:views, :topic_views)
-> 0.0028s
-- add_index(:topic_views, [:topic_id])
-> 0.0036s
-- add_index(:topic_views, [:user_id, :topic_id])
-> 0.0034s
== 20140804072504 ViewsToTopicViews: migrated (0.0124s) =======================
== 20140804075613 NormalizeTopicViewDataAndIndex: migrating ===================
-- remove_index(:topic_views, [:topic_id])
-> 0.0010s
-- remove_index(:topic_views, [:user_id, :topic_id])
-> 0.0008s
-- execute("CREATE TEMPORARY TABLE tmp_views_user(user_id int, topic_id int, viewed_at date, ip_address inet)")
-> 0.0010s
-- execute("INSERT INTO tmp_views_user(user_id, topic_id, ip_address, viewed_at)\n SELECT user_id, topic_id, min(ip_address::varchar)::inet, min(viewed_at)\n FROM topic_views\n WHERE user_id IS NOT NULL\n GROUP BY user_id, topic_id\n ")
-> 0.0004s
-- execute("CREATE TEMPORARY TABLE tmp_views_ip(topic_id int, viewed_at date, ip_address inet)")
-> 0.0008s
-- execute("INSERT INTO tmp_views_ip(topic_id, ip_address, viewed_at)\n SELECT topic_id, ip_address, min(viewed_at)\n FROM topic_views\n WHERE user_id IS NULL\n GROUP BY user_id, topic_id, ip_address\n ")
-> 0.0003s
-- execute("truncate table topic_views")
-> 0.0062s
-- execute("INSERT INTO topic_views(user_id, topic_id, ip_address, viewed_at)\n SELECT user_id, topic_id, ip_address, viewed_at FROM tmp_views_user\n UNION ALL\n SELECT NULL, topic_id, ip_address, viewed_at FROM tmp_views_ip\n ")
-> 0.0003s
-- execute("CREATE UNIQUE INDEX user_id_topic_id_topic_views ON topic_views(user_id, topic_id) WHERE user_id IS NOT NULL")
-> 0.0023s
-- execute("CREATE UNIQUE INDEX ip_address_topic_id_topic_views ON topic_views(ip_address, topic_id) WHERE user_id IS NULL")
-> 0.0024s
-- add_index(:topic_views, [:topic_id, :viewed_at])
-> 0.0037s
-- add_index(:topic_views, [:viewed_at, :topic_id])
-> 0.0033s
== 20140804075613 NormalizeTopicViewDataAndIndex: migrated (0.0241s) ==========
== 20140805061612 AddBioCookedVersionToUserProfile: migrating =================
-- add_column(:user_profiles, :bio_cooked_version, :integer)
-> 0.0004s
-- add_index(:user_profiles, [:bio_cooked_version])
-> 0.0041s
== 20140805061612 AddBioCookedVersionToUserProfile: migrated (0.0059s) ========
== 20140806003116 FixupBadgeIds: migrating ====================================
-- add_column(:badges, :system, :boolean, {:default=>false, :null=>false})
-> 0.0186s
== 20140806003116 FixupBadgeIds: migrated (0.0200s) ===========================
== 20140807033123 AddIndexOnLastSeenToUsers: migrating ========================
-- add_index(:users, [:last_seen_at])
-> 0.0045s
== 20140807033123 AddIndexOnLastSeenToUsers: migrated (0.0058s) ===============
== 20140808051823 CreateTopicSearchIndex: migrating ===========================
-- create_table(:topic_search_data, {:id=>false})
-> 0.0053s
-- execute("CREATE INDEX idx_search_topic ON topic_search_data USING gin (search_data)")
-> 0.0004s
== 20140808051823 CreateTopicSearchIndex: migrated (0.0071s) ==================
== 20140809224243 AddUserBadgeUniqueIndex: migrating ==========================
-- add_column(:user_badges, :seq, :integer, {:default=>0, :null=>false})
-> 0.0150s
-- execute("\n UPDATE user_badges ub1 SET seq = X.seq\n FROM (\n SELECT ub.id, rank() OVER (PARTITION BY user_id ORDER BY granted_at) seq\n FROM user_badges ub\n JOIN badges b ON b.id = ub.badge_id\n WHERE b.multiple_grant\n ) X\n WHERE ub1.id = X.id\n ")
-> 0.0009s
-- execute("\n DELETE FROM user_badges ub1\n WHERE ub1.id NOT IN (\n SELECT MIN(ub.id)\n FROM user_badges ub\n GROUP BY ub.user_id, ub.badge_id, ub.seq\n )\n ")
-> 0.0002s
-- add_index(:user_badges, [:badge_id, :user_id, :seq], {:unique=>true, :where=>"post_id IS NULL"})
-> 0.0037s
== 20140809224243 AddUserBadgeUniqueIndex: migrated (0.0212s) =================
== 20140811094300 RenameDeferedColumnsOnPostAction: migrating =================
-- rename_column(:post_actions, :defered_by_id, :deferred_by_id)
-> 0.0016s
-- rename_column(:post_actions, :defered_at, :deferred_at)
-> 0.0015s
== 20140811094300 RenameDeferedColumnsOnPostAction: migrated (0.0043s) ========
== 20140813175357 AddDefaultToActive: migrating ===============================
-- change_column(:users, :active, :boolean, {:default=>false, :null=>false})
-> 0.0044s
== 20140813175357 AddDefaultToActive: migrated (0.0056s) ======================
== 20140815183851 FixIndexOnPostActions: migrating ============================
-- execute("UPDATE post_actions SET targets_topic = false WHERE targets_topic IS NULL")
-> 0.0002s
-- change_column(:post_actions, :targets_topic, :boolean, {:default=>false, :null=>false})
-> 0.0032s
-- execute("\n DELETE FROM post_actions pa\n USING post_actions x\n WHERE pa.user_id = x.user_id AND\n pa.post_action_type_id = x.post_action_type_id AND\n pa.post_id = x.post_id AND\n pa.targets_topic = x.targets_topic AND\n pa.id < x.id AND\n pa.deleted_at IS NULL AND\n x.deleted_at IS NULL\n ")
-> 0.0004s
-- remove_index("post_actions", {:name=>"idx_unique_actions"})
-> 0.0009s
-- add_index("post_actions", ["user_id", "post_action_type_id", "post_id", "targets_topic"], {:name=>"idx_unique_actions", :unique=>true, :where=>"deleted_at IS NULL"})
-> 0.0040s
== 20140815183851 FixIndexOnPostActions: migrated (0.0100s) ===================
== 20140815191556 FixPostActionsIndexAgain: migrating =========================
-- remove_index("post_actions", {:name=>"idx_unique_actions"})
-> 0.0010s
-- add_index("post_actions", ["user_id", "post_action_type_id", "post_id", "targets_topic"], {:name=>"idx_unique_actions", :unique=>true, :where=>"deleted_at IS NULL AND disagreed_at IS NULL AND deferred_at IS NULL"})
-> 0.0038s
== 20140815191556 FixPostActionsIndexAgain: migrated (0.0060s) ================
== 20140815215618 AddNameLowerToCategories: migrating =========================
-- add_column(:categories, :name_lower, :string, {:limit=>50})
-> 0.0004s
-- execute("update categories set name_lower = lower(name)")
-> 0.0003s
-- change_column(:categories, :name_lower, :string, {:limit=>50, :null=>false})
-> 0.0004s
== 20140815215618 AddNameLowerToCategories: migrated (0.0023s) ================
== 20140817011612 AddExternalAvatarUrlToSingleSignOnRecord: migrating =========
-- add_column(:single_sign_on_records, :external_avatar_url, :string)
-> 0.0003s
== 20140817011612 AddExternalAvatarUrlToSingleSignOnRecord: migrated (0.0013s)
== 20140818023700 IndexEmailTokens: migrating =================================
-- add_index(:email_tokens, [:user_id])
-> 0.0105s
== 20140818023700 IndexEmailTokens: migrated (0.0118s) ========================
== 20140826234625 RenameSettingsPop3sToPop3: migrating ========================
-- execute("UPDATE site_settings SET name = replace(name, 'pop3s', 'pop3') WHERE name ILIKE 'pop3%'")
-> 0.0002s
== 20140826234625 RenameSettingsPop3sToPop3: migrated (0.0012s) ===============
== 20140827044811 RemoveNullableDates: migrating ==============================
-- execute("DROP VIEW badge_posts")
-> 0.0007s
-- execute("select table_name, column_name from information_schema.columns\n WHERE column_name IN ('created_at','updated_at') AND\n table_schema = 'public' AND\n is_nullable = 'YES' AND\n is_updatable = 'YES' AND\n data_type = 'timestamp without time zone'")
-> 0.0055s
-- execute("UPDATE \"users\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0004s
-- change_column(:users, :created_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"users\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0003s
-- change_column(:users, :updated_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"versions\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:versions, :created_at, :datetime, {:null=>false})
-> 0.0007s
-- execute("UPDATE \"versions\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:versions, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"uploads\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:uploads, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"uploads\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:uploads, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"message_bus\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:message_bus, :created_at, :datetime, {:null=>false})
-> 0.0006s
-- execute("UPDATE \"topic_links\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topic_links, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"topic_links\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_links, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"notifications\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:notifications, :created_at, :datetime, {:null=>false})
-> 0.0008s
-- execute("UPDATE \"notifications\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:notifications, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"posts\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:posts, :created_at, :datetime, {:null=>false})
-> 0.0033s
-- execute("UPDATE \"posts\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0003s
-- change_column(:posts, :updated_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"post_replies\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:post_replies, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_replies\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_replies, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"incoming_links\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:incoming_links, :created_at, :datetime, {:null=>false})
-> 0.0008s
-- execute("UPDATE \"site_settings\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:site_settings, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"site_settings\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:site_settings, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_open_ids\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:user_open_ids, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"user_open_ids\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:user_open_ids, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"topics\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topics, :created_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"topics\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topics, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_featured_topics\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:category_featured_topics, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_featured_topics\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:category_featured_topics, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"categories\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:categories, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"categories\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:categories, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_actions\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:user_actions, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_actions\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:user_actions, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"topic_link_clicks\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:topic_link_clicks, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_link_clicks\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_link_clicks, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"post_action_types\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:post_action_types, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_action_types\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_action_types, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_actions\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:post_actions, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_actions\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_actions, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"category_featured_users\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:category_featured_users, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_featured_users\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:category_featured_users, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"twitter_user_infos\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:twitter_user_infos, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"twitter_user_infos\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:twitter_user_infos, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_allowed_users\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topic_allowed_users, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_allowed_users\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_allowed_users, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"facebook_user_infos\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0004s
-- change_column(:facebook_user_infos, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"facebook_user_infos\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:facebook_user_infos, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"email_logs\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0004s
-- change_column(:email_logs, :created_at, :datetime, {:null=>false})
-> 0.0014s
-- execute("UPDATE \"email_logs\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:email_logs, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"email_tokens\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:email_tokens, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"email_tokens\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:email_tokens, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"topic_invites\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topic_invites, :created_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"topic_invites\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_invites, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"drafts\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:drafts, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"drafts\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:drafts, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"invites\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:invites, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"invites\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:invites, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"site_customizations\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:site_customizations, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"site_customizations\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:site_customizations, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"github_user_infos\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:github_user_infos, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"github_user_infos\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:github_user_infos, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"site_contents\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:site_contents, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"site_contents\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:site_contents, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"group_users\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:group_users, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"group_users\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:group_users, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_groups\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:category_groups, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_groups\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:category_groups, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"user_histories\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:user_histories, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_histories\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:user_histories, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"groups\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:groups, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"groups\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:groups, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"screened_emails\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0004s
-- change_column(:screened_emails, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"screened_emails\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:screened_emails, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"oauth2_user_infos\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:oauth2_user_infos, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"oauth2_user_infos\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:oauth2_user_infos, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"screened_urls\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:screened_urls, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"screened_urls\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:screened_urls, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"api_keys\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:api_keys, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"api_keys\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:api_keys, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"post_details\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:post_details, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_details\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_details, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"screened_ip_addresses\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:screened_ip_addresses, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"screened_ip_addresses\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:screened_ip_addresses, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_revisions\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:post_revisions, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_revisions\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_revisions, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_embeds\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topic_embeds, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_embeds\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_embeds, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"single_sign_on_records\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:single_sign_on_records, :created_at, :datetime, {:null=>false})
-> 0.0005s
-- execute("UPDATE \"single_sign_on_records\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:single_sign_on_records, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"badge_types\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:badge_types, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"badge_types\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:badge_types, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"color_schemes\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:color_schemes, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"color_schemes\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:color_schemes, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"color_scheme_colors\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:color_scheme_colors, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"color_scheme_colors\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:color_scheme_colors, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_custom_fields\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:user_custom_fields, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"user_custom_fields\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:user_custom_fields, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"category_custom_fields\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:category_custom_fields, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"category_custom_fields\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:category_custom_fields, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"group_custom_fields\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:group_custom_fields, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"group_custom_fields\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:group_custom_fields, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"post_custom_fields\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:post_custom_fields, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"post_custom_fields\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:post_custom_fields, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"topic_custom_fields\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:topic_custom_fields, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"topic_custom_fields\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:topic_custom_fields, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"invited_groups\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:invited_groups, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"invited_groups\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:invited_groups, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"badges\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:badges, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"badges\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:badges, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"google_user_infos\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0003s
-- change_column(:google_user_infos, :created_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"google_user_infos\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:google_user_infos, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"user_avatars\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:user_avatars, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"user_avatars\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:user_avatars, :updated_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"quoted_posts\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:quoted_posts, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"quoted_posts\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0001s
-- change_column(:quoted_posts, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("UPDATE \"badge_groupings\" SET created_at = CURRENT_TIMESTAMP WHERE created_at IS NULL")
-> 0.0002s
-- change_column(:badge_groupings, :created_at, :datetime, {:null=>false})
-> 0.0003s
-- execute("UPDATE \"badge_groupings\" SET updated_at = CURRENT_TIMESTAMP WHERE updated_at IS NULL")
-> 0.0002s
-- change_column(:badge_groupings, :updated_at, :datetime, {:null=>false})
-> 0.0004s
-- execute("CREATE VIEW badge_posts AS\n SELECT p.*\n FROM posts p\n JOIN topics t ON t.id = p.topic_id\n JOIN categories c ON c.id = t.category_id\n WHERE c.allow_badges AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n NOT c.read_restricted AND\n t.visible")
-> 0.0032s
== 20140827044811 RemoveNullableDates: migrated (0.0901s) =====================
== 20140828172407 CreatePermalinks: migrating =================================
-- create_table(:permalinks)
-> 0.0076s
-- add_index(:permalinks, :url)
-> 0.0039s
== 20140828172407 CreatePermalinks: migrated (0.0128s) ========================
== 20140828200231 MakeUrlColBiggerInPermalinks: migrating =====================
-- remove_index(:permalinks, :url)
-> 0.0010s
-- change_column(:permalinks, :url, :string, {:limit=>1000, :null=>false})
-> 0.0075s
-- add_index(:permalinks, :url, {:unique=>true})
-> 0.0038s
== 20140828200231 MakeUrlColBiggerInPermalinks: migrated (0.0137s) ============
== 20140831191346 RemoveCategoryGroupsOrphanedByRemovingCategoryOrGroup: migrating
-- execute("DELETE FROM category_groups\n WHERE group_id NOT IN (\n SELECT groups.id FROM groups)\n OR category_id NOT IN (\n SELECT categories.id FROM categories)")
-> 0.0005s
== 20140831191346 RemoveCategoryGroupsOrphanedByRemovingCategoryOrGroup: migrated (0.0016s)
== 20140904055702 CorrectPostActionIndex: migrating ===========================
-- execute("DELETE FROM post_actions pa\n USING post_actions pa2\n WHERE pa.post_action_type_id IN (3,4,7,8) AND\n pa2.post_action_type_id IN (3,4,7,8) AND\n pa.deleted_at IS NULL AND\n pa2.deleted_at IS NULL AND\n pa.disagreed_at IS NULL AND\n pa2.disagreed_at IS NULL AND\n pa.deferred_at IS NULL AND\n pa2.deferred_at IS NULL AND\n pa.id < pa2.id AND\n pa.user_id = pa2.user_id AND\n pa.post_id = pa2.post_id AND\n pa.targets_topic = pa2.targets_topic")
-> 0.0005s
>> DELETED 0 invalid rows from post_actions
-- add_index(:post_actions, ["user_id", "post_id", "targets_topic"], {:name=>"idx_unique_flags", :unique=>true, :where=>"deleted_at IS NULL AND\n disagreed_at IS NULL AND\n deferred_at IS NULL AND\n post_action_type_id IN (3,4,7,8)"})
-> 0.0040s
== 20140904055702 CorrectPostActionIndex: migrated (0.0056s) ==================
== 20140904160015 AddViaEmailToPosts: migrating ===============================
-- add_column(:posts, :via_email, :boolean, {:default=>false, :null=>false})
-> 0.0279s
== 20140904160015 AddViaEmailToPosts: migrated (0.0293s) ======================
== 20140904215629 RenameTrustLevelSettings: migrating =========================
-- execute("UPDATE site_settings\n SET name = regexp_replace(name, '^basic_', 'tl1_')")
-> 0.0003s
-- execute("UPDATE site_settings\n SET name = regexp_replace(name, '^regular_', 'tl2_')")
-> 0.0002s
-- execute("UPDATE site_settings\n SET name = regexp_replace(name, '^leader_', 'tl3_')")
-> 0.0002s
== 20140904215629 RenameTrustLevelSettings: migrated (0.0019s) ================
== 20140905055251 RenameTrustLevelBadges: migrating ===========================
-- execute("UPDATE badges SET name = 'Member' WHERE name = 'Regular User' AND id = 2")
-> 0.0003s
-- execute("UPDATE badges SET name = 'Regular' WHERE name = 'Leader' AND id = 3")
-> 0.0002s
-- execute("UPDATE badges SET name = 'Leader' WHERE name = 'Elder' AND id = 4")
-> 0.0002s
== 20140905055251 RenameTrustLevelBadges: migrated (0.0020s) ==================
== 20140905171733 CreateWarnings: migrating ===================================
-- create_table(:warnings)
-> 0.0047s
-- add_index(:warnings, :user_id)
-> 0.0035s
-- add_index(:warnings, :topic_id, {:unique=>true})
-> 0.0126s
== 20140905171733 CreateWarnings: migrated (0.0223s) ==========================
== 20140908165716 MigrateWarningTopicSubtypes: migrating ======================
-- execute("UPDATE topics AS t\n SET subtype = 'moderator_warning'\n FROM warnings AS w\n WHERE w.topic_id = t.id")
-> 0.0007s
== 20140908165716 MigrateWarningTopicSubtypes: migrated (0.0017s) =============
== 20140908191429 TrimProfileLength: migrating ================================
-- execute("UPDATE user_profiles SET bio_raw=LEFT(bio_raw, 3000)")
-> 0.0003s
== 20140908191429 TrimProfileLength: migrated (0.0013s) =======================
== 20140910130155 CreateTopicUserIndex: migrating =============================
-- add_index(:topic_users, [:user_id, :topic_id], {:unique=>true})
-> 0.0043s
== 20140910130155 CreateTopicUserIndex: migrated (0.0057s) ====================
== 20140911065449 PrivateMessagesHaveNoCategoryId: migrating ==================
-- execute("UPDATE topics SET category_id = NULL WHERE category_id IS NOT NULL AND archetype = 'private_message'")
-> 0.0003s
-- execute("ALTER TABLE topics ADD CONSTRAINT pm_has_no_category CHECK (category_id IS NULL OR archetype <> 'private_message')")
-> 0.0005s
== 20140911065449 PrivateMessagesHaveNoCategoryId: migrated (0.0018s) =========
== 20140913192733 AddTrustLevelLockedColumn: migrating ========================
-- add_column(:users, :trust_level_locked, :boolean, {:default=>false, :null=>false})
-> 0.0229s
-- execute(" UPDATE users\n SET trust_level_locked = 't'\n WHERE trust_level = 4\n")
-> 0.0005s
== 20140913192733 AddTrustLevelLockedColumn: migrated (0.0248s) ===============
== 20140923042349 AddRetainHoursToUploads: migrating ==========================
-- add_column(:uploads, :retain_hours, :integer)
-> 0.0004s
== 20140923042349 AddRetainHoursToUploads: migrated (0.0015s) =================
== 20140924192418 RenameContentType: migrating ================================
-- rename_column(:site_contents, :content_type, :text_type)
-> 0.0014s
-- rename_column(:site_contents, :content, :value)
-> 0.0010s
-- rename_table(:site_contents, :site_texts)
-> 0.0032s
== 20140924192418 RenameContentType: migrated (0.0067s) =======================
== 20140925173220 CreateUserFields: migrating =================================
-- create_table(:user_fields)
-> 0.0174s
== 20140925173220 CreateUserFields: migrated (0.0187s) ========================
== 20140929181930 AddEditableToUserFields: migrating ==========================
-- add_column(:user_fields, :editable, :boolean, {:default=>false, :null=>false})
-> 0.0077s
== 20140929181930 AddEditableToUserFields: migrated (0.0090s) =================
== 20140929204155 MigrateTosSetting: migrating ================================
-- execute("SELECT * FROM site_settings WHERE name = 'tos_accept_required' AND value = 't'")
-> 0.0002s
== 20140929204155 MigrateTosSetting: migrated (0.0014s) =======================
== 20141001101041 AddPostIdToUserHistories: migrating =========================
-- add_column(:user_histories, :post_id, :integer)
-> 0.0008s
== 20141001101041 AddPostIdToUserHistories: migrated (0.0019s) ================
== 20141002181613 AddDescriptionToUserFields: migrating =======================
-- add_column(:user_fields, :description, :string, {:null=>true})
-> 0.0004s
-- execute("UPDATE user_fields SET description=name")
-> 0.0002s
-- change_column(:user_fields, :description, :string, {:null=>false})
-> 0.0009s
== 20141002181613 AddDescriptionToUserFields: migrated (0.0025s) ==============
== 20141007224814 AddBadgeGrantedTitleToUserProfile: migrating ================
-- add_column(:user_profiles, :badge_granted_title, :boolean, {:default=>false})
-> 0.0102s
-- execute("UPDATE user_profiles SET badge_granted_title = true\n WHERE EXISTS (\n SELECT 1 FROM users WHERE users.id = user_id AND title IN ('Leader', 'Regular')\n )")
-> 0.0008s
-- execute("UPDATE user_profiles SET badge_granted_title = true\n WHERE EXISTS (\n SELECT 1 FROM users WHERE users.id = user_id AND title IN (SELECT name FROM badges WHERE allow_title)\n )")
-> 0.0004s
== 20141007224814 AddBadgeGrantedTitleToUserProfile: migrated (0.0134s) =======
== 20141008152953 AddExernalUrlToPermalinks: migrating ========================
-- add_column(:permalinks, :external_url, :string, {:limit=>1000})
-> 0.0004s
== 20141008152953 AddExernalUrlToPermalinks: migrated (0.0016s) ===============
== 20141008181228 AddRequiredSignupToUserFields: migrating ====================
-- add_column(:user_fields, :required, :boolean, {:default=>true, :null=>false})
-> 0.0076s
== 20141008181228 AddRequiredSignupToUserFields: migrated (0.0088s) ===========
== 20141008192525 AddAutoCloseBasedOnLastPostAndAutoCloseHoursToTopics: migrating
-- add_column(:topics, :auto_close_based_on_last_post, :boolean, {:default=>false})
-> 0.0184s
-- add_column(:topics, :auto_close_hours, :float)
-> 0.0004s
== 20141008192525 AddAutoCloseBasedOnLastPostAndAutoCloseHoursToTopics: migrated (0.0201s)
== 20141008192526 AddAutoCloseBasedOnLastPostToCategories: migrating ==========
-- add_column(:categories, :auto_close_based_on_last_post, :boolean, {:default=>false})
-> 0.0286s
== 20141008192526 AddAutoCloseBasedOnLastPostToCategories: migrated (0.0300s) =
== 20141014032859 AddHiddenToPostRevision: migrating ==========================
-- add_column(:post_revisions, :hidden, :boolean, {:null=>false, :default=>false})
-> 0.0206s
== 20141014032859 AddHiddenToPostRevision: migrated (0.0225s) =================
== 20141014191645 FixTosName: migrating =======================================
-- execute("UPDATE user_fields SET name = 'Terms of Service' WHERE name = 'I have read and accept the <a href=\"/tos\" target=\"_blank\">Terms of Service</a>.'")
-> 0.0004s
== 20141014191645 FixTosName: migrated (0.0018s) ==============================
== 20141015060145 AddRawEmailToPosts: migrating ===============================
-- add_column(:posts, :raw_email, :text)
-> 0.0004s
== 20141015060145 AddRawEmailToPosts: migrated (0.0018s) ======================
== 20141016183307 AddExpansionBackgroundToUserProfiles: migrating =============
-- add_column(:user_profiles, :expansion_background, :string, {:limit=>255})
-> 0.0003s
== 20141016183307 AddExpansionBackgroundToUserProfiles: migrated (0.0013s) ====
== 20141020153415 AddPublicVersionToPosts: migrating ==========================
-- add_column(:posts, :public_version, :integer, {:null=>false, :default=>1})
-> 0.0178s
-- execute(" UPDATE posts\n SET public_version = 1 + (SELECT COUNT(*) FROM post_revisions pr WHERE post_id = posts.id AND pr.hidden = 'f')\n WHERE public_version <> 1 + (SELECT COUNT(*) FROM post_revisions pr WHERE post_id = posts.id AND pr.hidden = 'f')\n")
-> 0.0007s
== 20141020153415 AddPublicVersionToPosts: migrated (0.0199s) =================
== 20141020154935 RenameExpansionToCard: migrating ============================
-- rename_column(:user_profiles, :expansion_background, :card_background)
-> 0.0016s
== 20141020154935 RenameExpansionToCard: migrated (0.0027s) ===================
== 20141020164816 AddImageToBadges: migrating =================================
-- add_column(:badges, :image, :string, {:limit=>255})
-> 0.0003s
== 20141020164816 AddImageToBadges: migrated (0.0015s) ========================
== 20141020174120 AddCardImageToUserProfiles: migrating =======================
-- add_column(:user_profiles, :card_image_badge_id, :integer)
-> 0.0003s
== 20141020174120 AddCardImageToUserProfiles: migrated (0.0013s) ==============
== 20141030222425 RenameSeenPostCount: migrating ==============================
-- rename_column(:topic_users, :seen_post_count, :highest_seen_post_number)
-> 0.0014s
== 20141030222425 RenameSeenPostCount: migrated (0.0024s) =====================
== 20141110150304 AddFooterToSiteCustomization: migrating =====================
-- add_column(:site_customizations, :footer, :text)
-> 0.0007s
-- add_column(:site_customizations, :mobile_footer, :text)
-> 0.0002s
== 20141110150304 AddFooterToSiteCustomization: migrated (0.0020s) ============
== 20141118011735 CorrectUsernameSearch: migrating ============================
-- execute("update user_search_data\n set search_data = TO_TSVECTOR('simple', username_lower || ' ' || lower(name))\n from users\n where users.id = user_search_data.user_id")
-> 0.0005s
== 20141118011735 CorrectUsernameSearch: migrated (0.0017s) ===================
== 20141120035016 AddAllowedIpsToApiKeys: migrating ===========================
-- change_table(:api_keys)
-> 0.0035s
== 20141120035016 AddAllowedIpsToApiKeys: migrated (0.0045s) ==================
== 20141120043401 AddHiddenToApiKeys: migrating ===============================
-- change_table(:api_keys)
-> 0.0117s
== 20141120043401 AddHiddenToApiKeys: migrated (0.0130s) ======================
== 20141211114517 FixEmojiPath: migrating =====================================
-- execute(" UPDATE posts\n SET cooked = REPLACE(cooked, '/plugins/emoji/images/', '/plugins/emoji/images/emoji_one/')\n WHERE cooked LIKE '%/plugins/emoji/images/%'\n")
-> 0.0006s
== 20141211114517 FixEmojiPath: migrated (0.0025s) ============================
== 20141216112341 ResolveDuplicateGroupNames: migrating =======================
== 20141216112341 ResolveDuplicateGroupNames: migrated (0.0273s) ==============
== 20141222051622 RemoveOverrideDefaultStylesFromSiteCustomizations: migrating
-- remove_column(:site_customizations, :override_default_style)
-> 0.0004s
== 20141222051622 RemoveOverrideDefaultStylesFromSiteCustomizations: migrated (0.0017s)
== 20141222224220 FixEmojiPathTake2: migrating ================================
-- execute(" UPDATE posts\n SET cooked = REPLACE(cooked, '/plugins/emoji/images/', '/images/emoji/')\n WHERE cooked LIKE '%/plugins/emoji/images/%'\n")
-> 0.0003s
== 20141222224220 FixEmojiPathTake2: migrated (0.0017s) =======================
== 20141222230707 AmendSiteCustomization: migrating ===========================
-- remove_column(:site_customizations, :position)
-> 0.0003s
== 20141222230707 AmendSiteCustomization: migrated (0.0013s) ==================
== 20141223145058 CreateCsvExportLogs: migrating ==============================
-- create_table(:csv_export_logs)
-> 0.0073s
== 20141223145058 CreateCsvExportLogs: migrated (0.0086s) =====================
== 20141228151019 RenameCsvExportLogsToUserExports: migrating =================
-- rename_table(:csv_export_logs, :user_exports)
-> 0.0029s
== 20141228151019 RenameCsvExportLogsToUserExports: migrated (0.0042s) ========
== 20150102113309 CleanUpUserHistory: migrating ===============================
== 20150102113309 CleanUpUserHistory: migrated (0.0038s) ======================
== 20150106215342 RemoveStars: migrating ======================================
-- execute(" INSERT INTO post_actions(user_id, post_id, post_action_type_id, created_at, updated_at)\n SELECT tu.user_id, p.id, 1, coalesce(tu.starred_at, now()), coalesce(tu.starred_at, now())\n FROM topic_users tu\n JOIN posts p ON p.topic_id = tu.topic_id AND p.post_number = 1\n LEFT JOIN post_actions pa ON\n pa.post_id = p.id AND\n pa.user_id = tu.user_id AND\n pa.post_action_type_id = 1\n WHERE pa.post_id IS NULL AND tu.starred\n")
-> 0.0009s
0 stars were converted to bookmarks!
-- execute(" DELETE FROM user_actions WHERE action_type = 10\n")
-> 0.0002s
-- remove_column(:topic_users, :starred)
-> 0.0004s
-- remove_column(:topic_users, :starred_at)
-> 0.0002s
-- remove_column(:topic_users, :unstarred_at)
-> 0.0002s
-- remove_column(:topics, :star_count)
-> 0.0004s
== 20150106215342 RemoveStars: migrated (0.0043s) =============================
== 20150108002354 AddLikedAndBookmarkedToTopicUser: migrating =================
-- add_column(:topic_users, :liked, :boolean, {:default=>false})
-> 0.0158s
-- add_column(:topic_users, :bookmarked, :boolean, {:default=>false})
-> 0.0106s
-- execute("UPDATE topic_users\n SET liked = true\n WHERE EXISTS (SELECT 1 FROM post_actions pa\n JOIN posts p ON p.id = pa.post_id\n JOIN topics t ON t.id = p.topic_id\n WHERE pa.deleted_at IS NULL AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n pa.user_id = topic_users.user_id AND\n p.topic_id = topic_users.topic_id AND\n post_action_type_id = 2)\n ")
-> 0.0014s
-- execute("UPDATE topic_users\n SET bookmarked = true\n WHERE EXISTS (SELECT 1 FROM post_actions pa\n JOIN posts p ON p.id = pa.post_id\n JOIN topics t ON t.id = p.topic_id\n WHERE pa.deleted_at IS NULL AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n pa.user_id = topic_users.user_id AND\n p.topic_id = topic_users.topic_id AND\n post_action_type_id = 1)\n ")
-> 0.0008s
== 20150108002354 AddLikedAndBookmarkedToTopicUser: migrated (0.0300s) ========
== 20150108202057 CreateBookmarkActions: migrating ============================
-- execute("INSERT INTO user_actions (action_type,\n user_id,\n target_topic_id,\n target_post_id,\n acting_user_id,\n created_at,\n updated_at)\n SELECT DISTINCT 3,\n pa.user_id,\n p.topic_id,\n pa.post_id,\n pa.user_id,\n pa.created_at,\n pa.updated_at\n FROM post_actions AS pa\n INNER JOIN posts AS p ON p.id = pa.post_id AND p.post_number = 1\n WHERE NOT EXISTS (SELECT 1 FROM user_actions AS ua WHERE ua.target_post_id = pa.post_id AND ua.action_type = 3 AND ua.user_id = pa.user_id)\n AND pa.post_action_type_id = 1\n AND pa.deleted_at IS NULL")
-> 0.0013s
== 20150108202057 CreateBookmarkActions: migrated (0.0026s) ===================
== 20150108211557 IndexTopicCustomFieldValues: migrating ======================
-- add_index(:topic_custom_fields, :value)
-> 0.0040s
== 20150108211557 IndexTopicCustomFieldValues: migrated (0.0053s) =============
== 20150108221703 GroupManagers: migrating ====================================
-- create_table(:group_managers)
-> 0.0044s
-- add_index(:group_managers, [:group_id, :user_id], {:unique=>true})
-> 0.0036s
== 20150108221703 GroupManagers: migrated (0.0093s) ===========================
== 20150112172258 AddNewSiteCustomizationTypes: migrating =====================
-- add_column(:site_customizations, :head_tag, :text)
-> 0.0009s
-- add_column(:site_customizations, :body_tag, :text)
-> 0.0002s
== 20150112172258 AddNewSiteCustomizationTypes: migrated (0.0021s) ============
== 20150112172259 MigrateSiteTextToSiteCustomization: migrating ===============
-- execute(" DO\n $do$\n BEGIN\n IF EXISTS(SELECT 1 FROM site_texts WHERE (text_type = 'head' OR text_type = 'bottom')) THEN\n INSERT INTO site_customizations (name, user_id, enabled, key, created_at, updated_at, head_tag, body_tag)\n VALUES\n (\n 'Migrated from Site Text',\n -1,\n 't',\n '472c9852-ed84-4d56-8340-c43439411546',\n now(),\n now(),\n (SELECT value FROM site_texts WHERE text_type = 'head' LIMIT 1),\n (SELECT value FROM site_texts WHERE text_type = 'bottom' LIMIT 1)\n );\n END IF;\n END\n $do$\n")
-> 0.0010s
== 20150112172259 MigrateSiteTextToSiteCustomization: migrated (0.0027s) ======
== 20150114093325 AddTopToSiteCustomization: migrating ========================
-- add_column(:site_customizations, :top, :text)
-> 0.0003s
-- add_column(:site_customizations, :mobile_top, :text)
-> 0.0002s
-- execute(" UPDATE site_customizations\n SET top = (SELECT value FROM site_texts WHERE text_type = 'top' LIMIT 1),\n mobile_top = (SELECT value FROM site_texts WHERE text_type = 'top' LIMIT 1),\n head_tag = (SELECT value FROM site_texts WHERE text_type = 'head' LIMIT 1),\n body_tag = (SELECT value FROM site_texts WHERE text_type = 'bottom' LIMIT 1)\n WHERE name = 'Migrated from Site Text'\n")
-> 0.0005s
== 20150114093325 AddTopToSiteCustomization: migrated (0.0026s) ===============
== 20150115172310 RenameUserExportColumn: migrating ===========================
-- rename_column(:user_exports, :export_type, :file_name)
-> 0.0013s
== 20150115172310 RenameUserExportColumn: migrated (0.0023s) ==================
== 20150119192813 AddPostsIndexIncludingDeleted: migrating ====================
-- add_index(:posts, [:user_id, :created_at])
-> 0.0041s
== 20150119192813 AddPostsIndexIncludingDeleted: migrated (0.0052s) ===========
== 20150123145128 AddAutomaticMembershipToGroup: migrating ====================
-- add_column(:groups, :automatic_membership_email_domains, :text)
-> 0.0003s
-- add_column(:groups, :automatic_membership_retroactive, :boolean, {:default=>false})
-> 0.0101s
== 20150123145128 AddAutomaticMembershipToGroup: migrated (0.0118s) ===========
== 20150129204520 AddShowOnProfileToUserFields: migrating =====================
-- add_column(:user_fields, :show_on_profile, :boolean, {:default=>false, :null=>false})
-> 0.0146s
== 20150129204520 AddShowOnProfileToUserFields: migrated (0.0160s) ============
== 20150203041207 AddApplicationRequests: migrating ===========================
-- create_table(:application_requests)
-> 0.0047s
-- add_index(:application_requests, [:date, :req_type], {:unique=>true})
-> 0.0037s
== 20150203041207 AddApplicationRequests: migrated (0.0097s) ==================
== 20150205032808 ResetApplicationRequests: migrating =========================
-- execute("TRUNCATE TABLE application_requests")
-> 0.0124s
== 20150205032808 ResetApplicationRequests: migrated (0.0137s) ================
== 20150205172051 AddCustomTypeToUserHistories: migrating =====================
-- add_column(:user_histories, :custom_type, :string)
-> 0.0009s
== 20150205172051 AddCustomTypeToUserHistories: migrated (0.0020s) ============
== 20150206004143 FlushApplicationRequests: migrating =========================
-- execute("TRUNCATE TABLE application_requests")
-> 0.0049s
== 20150206004143 FlushApplicationRequests: migrated (0.0060s) ================
== 20150213174159 CreateDigestUnsubscribeKeys: migrating ======================
-- create_table(:digest_unsubscribe_keys, {:id=>false})
-> 0.0012s
-- execute("ALTER TABLE digest_unsubscribe_keys ADD PRIMARY KEY (key)")
-> 0.0033s
-- add_index(:digest_unsubscribe_keys, :created_at)
-> 0.0043s
== 20150213174159 CreateDigestUnsubscribeKeys: migrated (0.0108s) =============
== 20150224004420 AddPinnedIndexes: migrating =================================
-- add_index(:topics, :pinned_globally, {:where=>"pinned_globally"})
-> 0.0045s
-- add_index(:topics, :pinned_at, {:where=>"pinned_at IS NOT NULL"})
-> 0.0035s
== 20150224004420 AddPinnedIndexes: migrated (0.0093s) ========================
== 20150227043622 AddLongDescriptionToBadges: migrating =======================
-- add_column(:badges, :long_description, :text)
-> 0.0004s
== 20150227043622 AddLongDescriptionToBadges: migrated (0.0015s) ==============
== 20150301224250 CreateSuggestedForIndex: migrating ==========================
-- add_index(:topics, [:created_at, :visible], {:where=>"deleted_at IS NULL AND archetype <> 'private_message'"})
-> 0.0041s
== 20150301224250 CreateSuggestedForIndex: migrated (0.0057s) =================
== 20150306050437 AddAllTimeAndOpLikesToTopTopics: migrating ==================
-- add_column(:top_topics, :all_score, :float, {:default=>0})
-> 0.0895s
-- add_column(:top_topics, "daily_op_likes_count", :integer, {:default=>0, :null=>false})
-> 0.0458s
-- add_index(:top_topics, ["daily_op_likes_count"])
-> 0.0044s
-- add_column(:top_topics, "weekly_op_likes_count", :integer, {:default=>0, :null=>false})
-> 0.0488s
-- add_index(:top_topics, ["weekly_op_likes_count"])
-> 0.0039s
-- add_column(:top_topics, "monthly_op_likes_count", :integer, {:default=>0, :null=>false})
-> 0.0494s
-- add_index(:top_topics, ["monthly_op_likes_count"])
-> 0.0035s
-- add_column(:top_topics, "yearly_op_likes_count", :integer, {:default=>0, :null=>false})
-> 0.0512s
-- add_index(:top_topics, ["yearly_op_likes_count"])
-> 0.0036s
== 20150306050437 AddAllTimeAndOpLikesToTopTopics: migrated (0.3018s) =========
== 20150318143915 CreateDirectoryItems: migrating =============================
-- create_table(:directory_items, {:force=>true})
-> 0.0054s
-- add_index(:directory_items, :period_type)
-> 0.0037s
== 20150318143915 CreateDirectoryItems: migrated (0.0104s) ====================
== 20150323034933 AddAllowPrivateMessagesToUserProfile: migrating =============
-- add_column(:user_profiles, :allow_private_messages, :boolean, {:default=>true, :null=>false})
-> 0.0096s
== 20150323034933 AddAllowPrivateMessagesToUserProfile: migrated (0.0115s) ====
== 20150323062322 RemoveAllowPrivateMessagesFromUserProfile: migrating ========
-- remove_column(:user_profiles, :allow_private_messages)
-> 0.0004s
== 20150323062322 RemoveAllowPrivateMessagesFromUserProfile: migrated (0.0017s)
== 20150323234856 AddMutedUsers: migrating ====================================
-- create_table(:muted_users, {:force=>true})
-> 0.0049s
-- add_index(:muted_users, [:user_id, :muted_user_id], {:unique=>true})
-> 0.0034s
-- add_index(:muted_users, [:muted_user_id, :user_id], {:unique=>true})
-> 0.0035s
== 20150323234856 AddMutedUsers: migrated (0.0132s) ===========================
== 20150324184222 AddMoreToDirectoryItems: migrating ==========================
-- add_column(:directory_items, :days_visited, :integer, {:null=>false, :default=>0})
-> 0.0162s
-- add_column(:directory_items, :posts_read, :integer, {:null=>false, :default=>0})
-> 0.0098s
== 20150324184222 AddMoreToDirectoryItems: migrated (0.0274s) =================
== 20150325183400 FixGroupUserCount: migrating ================================
-- execute("UPDATE groups g SET user_count = (SELECT COUNT(user_id) FROM group_users gu WHERE gu.group_id = g.id)")
-> 0.0006s
== 20150325183400 FixGroupUserCount: migrated (0.0019s) =======================
== 20150325190959 CreateQueuedPosts: migrating ================================
-- create_table(:queued_posts, {:force=>true})
-> 0.0102s
-- add_index(:queued_posts, [:queue, :state, :created_at], {:name=>"by_queue_status"})
-> 0.0036s
-- add_index(:queued_posts, [:topic_id, :queue, :state, :created_at], {:name=>"by_queue_status_topic"})
-> 0.0037s
== 20150325190959 CreateQueuedPosts: migrated (0.0189s) =======================
== 20150410002033 AddPrimaryGroupToGroups: migrating ==========================
-- add_column(:groups, :primary_group, :boolean, {:default=>false, :null=>false})
-> 0.0097s
== 20150410002033 AddPrimaryGroupToGroups: migrated (0.0111s) =================
== 20150410002551 AddTitleToGroups: migrating =================================
-- add_column(:groups, :title, :string)
-> 0.0004s
== 20150410002551 AddTitleToGroups: migrated (0.0016s) ========================
== 20150421085850 IncreaseUrlLengthOnTopicEmbed: migrating ====================
-- remove_index(:topic_embeds, :embed_url)
-> 0.0010s
-- change_column(:topic_embeds, :embed_url, :string, {:limit=>1000, :null=>false})
-> 0.0072s
-- add_index(:topic_embeds, :embed_url, {:unique=>true})
-> 0.0036s
== 20150421085850 IncreaseUrlLengthOnTopicEmbed: migrated (0.0131s) ===========
== 20150421190714 AddQueuedPostIdToUserActions: migrating =====================
-- add_column(:user_actions, :queued_post_id, :integer, {:null=>true})
-> 0.0004s
== 20150421190714 AddQueuedPostIdToUserActions: migrated (0.0016s) ============
== 20150422160235 AddLinkPostIdIndexOnTopicLinks: migrating ===================
-- add_index(:topic_links, [:link_post_id, :reflection])
-> 0.0040s
== 20150422160235 AddLinkPostIdIndexOnTopicLinks: migrated (0.0052s) ==========
== 20150501152228 RenameTotalVotesToVoters: migrating =========================
== 20150501152228 RenameTotalVotesToVoters: migrated (0.0056s) ================
== 20150505044154 AddStylesheetCache: migrating ===============================
-- create_table(:stylesheet_cache)
-> 0.0070s
-- add_index(:stylesheet_cache, [:target, :digest], {:unique=>true})
-> 0.0041s
== 20150505044154 AddStylesheetCache: migrated (0.0123s) ======================
== 20150513094042 AddIndexOnPostActions: migrating ============================
-- add_index(:post_actions, [:user_id, :post_action_type_id], {:where=>"deleted_at IS NULL"})
-> 0.0038s
== 20150513094042 AddIndexOnPostActions: migrated (0.0049s) ===================
== 20150514023016 AddUnreadNotificationsIndex: migrating ======================
-- add_index(:notifications, [:user_id, :notification_type], {:where=>"not read", :name=>"idx_notifications_speedup_unread_count"})
-> 0.0037s
== 20150514023016 AddUnreadNotificationsIndex: migrated (0.0050s) =============
== 20150514043155 AddUserActionsAllIndex: migrating ===========================
-- add_index(:user_actions, [:user_id, :created_at, :action_type], {:name=>"idx_user_actions_speed_up_user_all"})
-> 0.0040s
== 20150514043155 AddUserActionsAllIndex: migrated (0.0052s) ==================
== 20150525151759 SetDefaultS3Region: migrating ===============================
-- execute(" UPDATE site_settings\n SET value = 'us-east-1'\n WHERE name = 's3_region'\n AND LENGTH(COALESCE(value, '')) = 0\n")
-> 0.0002s
== 20150525151759 SetDefaultS3Region: migrated (0.0013s) ======================
== 20150609163211 MigrateEmbeddableHost: migrating ============================
-- execute("UPDATE site_settings SET name = 'embeddable_hosts', data_type = 9 WHERE name = 'embeddable_host'")
-> 0.0002s
== 20150609163211 MigrateEmbeddableHost: migrated (0.0011s) ===================
== 20150617080349 AddIndexOnPostNotifications: migrating ======================
-- add_index(:notifications, [:user_id, :topic_id, :post_number])
-> 0.0071s
== 20150617080349 AddIndexOnPostNotifications: migrated (0.0083s) =============
== 20150617233018 AddIndexTargetPostIdOnUserActions: migrating ================
-- add_index(:user_actions, [:target_post_id])
-> 0.0035s
== 20150617233018 AddIndexTargetPostIdOnUserActions: migrated (0.0047s) =======
== 20150617234511 AddStaffIndexToUsers: migrating =============================
-- add_index(:users, [:id], {:name=>"idx_users_admin", :where=>"admin"})
-> 0.0038s
-- add_index(:users, [:id], {:name=>"idx_users_moderator", :where=>"moderator"})
-> 0.0035s
== 20150617234511 AddStaffIndexToUsers: migrated (0.0087s) ====================
== 20150702201926 AddTopicTemplateToCategories: migrating =====================
-- add_column(:categories, :topic_template, :text, {:null=>true})
-> 0.0004s
== 20150702201926 AddTopicTemplateToCategories: migrated (0.0014s) ============
== 20150706215111 AddMobileToUserVisits: migrating ============================
-- add_column(:user_visits, :mobile, :boolean, {:default=>false})
-> 0.0126s
== 20150706215111 AddMobileToUserVisits: migrated (0.0140s) ===================
== 20150707163251 AddReportsIndexToUserVisits: migrating ======================
-- add_index(:user_visits, [:visited_at, :mobile])
-> 0.0040s
== 20150707163251 AddReportsIndexToUserVisits: migrated (0.0053s) =============
== 20150709021818 AddLikeCountToPostMenu: migrating ===========================
-- execute("UPDATE site_settings\nSET value = replace(value, 'like', 'like-count|like')\nWHERE name = 'post_menu'\nAND value NOT LIKE '%like-count%'\n")
-> 0.0003s
== 20150709021818 AddLikeCountToPostMenu: migrated (0.0014s) ==================
== 20150713203955 EnlargeUsersEmailField: migrating ===========================
-- change_column(:users, :email, :string, {:limit=>513})
-> 0.0031s
== 20150713203955 EnlargeUsersEmailField: migrated (0.0042s) ==================
== 20150724165259 AddIndexToPostCustomFields: migrating =======================
-- execute(" CREATE INDEX index_post_custom_fields_on_name_and_value ON post_custom_fields USING btree (name, left(value, 200))\n")
-> 0.0028s
== 20150724165259 AddIndexToPostCustomFields: migrated (0.0040s) ==============
== 20150724182342 AddActionCodeToPost: migrating ==============================
-- add_column(:posts, :action_code, :string, {:null=>true})
-> 0.0004s
== 20150724182342 AddActionCodeToPost: migrated (0.0015s) =====================
== 20150727193414 CreateUserFieldOptions: migrating ===========================
-- create_table(:user_field_options, {:force=>true})
-> 0.0100s
== 20150727193414 CreateUserFieldOptions: migrated (0.0114s) ==================
== 20150727210019 AddPinnedUntilToTopics: migrating ===========================
-- add_column(:topics, :pinned_until, :datetime, {:null=>true})
-> 0.0005s
== 20150727210019 AddPinnedUntilToTopics: migrated (0.0017s) ==================
== 20150727210748 AddQuarterlyToTopTopics: migrating ==========================
-- add_column(:top_topics, :quarterly_posts_count, :integer, {:default=>0, :null=>false})
-> 0.0637s
-- add_column(:top_topics, :quarterly_views_count, :integer, {:default=>0, :null=>false})
-> 0.0437s
-- add_column(:top_topics, :quarterly_likes_count, :integer, {:default=>0, :null=>false})
-> 0.0658s
-- add_column(:top_topics, :quarterly_score, :float, {:default=>0.0})
-> 0.0439s
-- add_column(:top_topics, :quarterly_op_likes_count, :integer, {:default=>0, :null=>false})
-> 0.0644s
-- add_index(:top_topics, [:quarterly_posts_count])
-> 0.0038s
-- add_index(:top_topics, [:quarterly_views_count])
-> 0.0034s
-- add_index(:top_topics, [:quarterly_likes_count])
-> 0.0036s
-- add_index(:top_topics, [:quarterly_op_likes_count])
-> 0.0034s
== 20150727210748 AddQuarterlyToTopTopics: migrated (0.2976s) =================
== 20150727230537 AddExampleColumnComments: migrating =========================
COMMENT ON TABLE posts
COMMENT ON COLUMN posts.post_number
COMMENT ON COLUMN posts.raw
COMMENT ON COLUMN posts.cooked
COMMENT ON COLUMN posts.reply_to_post_number
COMMENT ON COLUMN posts.reply_quoted
COMMENT ON TABLE topics
== 20150727230537 AddExampleColumnComments: migrated (0.0023s) ================
== 20150728004647 CorrectCustomFieldsMigration: migrating =====================
-- execute(" DROP INDEX index_post_custom_fields_on_name_and_value\n")
-> 0.0003s
-- execute(" CREATE INDEX index_post_custom_fields_on_name_and_value ON post_custom_fields USING btree (name, left(value, 200))\n")
-> 0.0030s
== 20150728004647 CorrectCustomFieldsMigration: migrated (0.0046s) ============
== 20150728210202 MigrateOldModeratorPosts: migrating =========================
-- execute("UPDATE posts SET action_code = 'closed.enabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now closed. New replies are no longer allowed.'")
-> 0.0004s
-- execute("UPDATE posts SET action_code = 'closed.disabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now opened. New replies are allowed.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'archived.enabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now archived. It is frozen and cannot be changed in any way.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'archived.disabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now unarchived. It is no longer frozen, and can be changed.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'pinned.enabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now pinned. It will appear at the top of its category until it is unpinned by staff for everyone, or by individual users for themselves.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'pinned.disabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now unpinned. It will no longer appear at the top of its category.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'pinned_globally.enabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now pinned globally. It will appear at the top of its category and all topic lists until it is unpinned by staff for everyone, or by individual users for themselves.'")
-> 0.0002s
-- execute("UPDATE posts SET action_code = 'pinned_globally.disabled', raw = '', cooked = '', post_type = 3 where post_type = 2 AND raw = 'This topic is now unpinned. It will no longer appear at the top of its category.'")
-> 0.0002s
== 20150728210202 MigrateOldModeratorPosts: migrated (0.0088s) ================
== 20150729150523 MigrateAutoClosePosts: migrating ============================
-- execute("UPDATE posts SET action_code = 'autoclosed.enabled', post_type = 3 WHERE post_type = 2 AND (raw ~* 'This topic was automatically closed after 1 day. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed after \\d+ days. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed after 1 hour. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed after \\d+ hours. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed 1 day after the last reply. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed \\d+ days after the last reply. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed 1 hour after the last reply. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed \\d+ hours after the last reply. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed 1 minute after the last reply. New replies are no longer allowed.' OR raw ~* 'This topic was automatically closed \\d+ minutes after the last reply. New replies are no longer allowed.')")
-> 0.0018s
== 20150729150523 MigrateAutoClosePosts: migrated (0.0036s) ===================
== 20150730154830 AddPositionToUserFields: migrating ==========================
-- add_column(:user_fields, :position, :integer, {:default=>0})
-> 0.0197s
-- execute("UPDATE user_fields SET position = (SELECT COUNT(*) from user_fields as uf2 where uf2.id < user_fields.id)")
-> 0.0004s
== 20150730154830 AddPositionToUserFields: migrated (0.0214s) =================
== 20150731225331 MigrateOldMovedPosts: migrating =============================
-- execute("UPDATE posts SET post_type = 3, action_code = 'split_topic' WHERE post_type = 2 AND raw ~* '^I moved [a\\d]+ posts? to a new topic:'")
-> 0.0004s
-- execute("UPDATE posts SET post_type = 3, action_code = 'split_topic' WHERE post_type = 2 AND raw ~* '^I moved [a\\d]+ posts? to an existing topic:'")
-> 0.0003s
== 20150731225331 MigrateOldMovedPosts: migrated (0.0019s) ====================
== 20150802233112 AddPostStats: migrating =====================================
-- add_column(:drafts, :revisions, :int, {:null=>false, :default=>1})
-> 0.0199s
-- create_table(:post_stats)
-> 0.0041s
-- add_index(:post_stats, [:post_id])
-> 0.0038s
== 20150802233112 AddPostStats: migrated (0.0292s) ============================
== 20150806210727 AddEmbeddedCssToSiteCustomizations: migrating ===============
-- add_column(:site_customizations, :embedded_css, :text)
-> 0.0003s
-- add_column(:site_customizations, :embedded_css_baked, :text)
-> 0.0002s
== 20150806210727 AddEmbeddedCssToSiteCustomizations: migrated (0.0026s) ======
== 20150818190757 CreateEmbeddableHosts: migrating ============================
-- create_table(:embeddable_hosts, {:force=>true})
-> 0.0070s
-- execute("SELECT c.id FROM categories AS c\n INNER JOIN site_settings AS s ON s.value = c.name\n WHERE s.name = 'embed_category'")
-> 0.0006s
-- execute("SELECT value FROM site_settings WHERE name = 'uncategorized_category_id'")
-> 0.0002s
-- execute("SELECT value FROM site_settings WHERE name = 'embeddable_hosts'")
-> 0.0001s
-- execute("DELETE FROM site_settings WHERE name IN ('embeddable_hosts', 'embed_category')")
-> 0.0002s
== 20150818190757 CreateEmbeddableHosts: migrated (0.0094s) ===================
== 20150822141540 FixMigratedHosts: migrating =================================
-- execute("UPDATE embeddable_hosts SET host = regexp_replace(host, '^https?://', '', 'i')")
-> 0.0003s
== 20150822141540 FixMigratedHosts: migrated (0.0013s) ========================
== 20150828155137 AddSuppressFromHomepageToCategory: migrating ================
-- add_column(:categories, :suppress_from_homepage, :boolean, {:default=>false})
-> 0.0185s
== 20150828155137 AddSuppressFromHomepageToCategory: migrated (0.0198s) =======
== 20150901192313 AddGrantTrustLevelToGroups: migrating =======================
-- add_column(:groups, :grant_trust_level, :integer)
-> 0.0004s
== 20150901192313 AddGrantTrustLevelToGroups: migrated (0.0017s) ==============
== 20150914021445 CreateUserProfileViews: migrating ===========================
-- create_table(:user_profile_views)
-> 0.0178s
-- add_index(:user_profile_views, :user_profile_id)
-> 0.0045s
-- add_index(:user_profile_views, :user_id)
-> 0.0124s
-- add_index(:user_profile_views, [:viewed_at, :ip_address, :user_profile_id], {:where=>"user_id IS NULL", :unique=>true, :name=>"unique_profile_view_ip"})
-> 0.0098s
-- add_index(:user_profile_views, [:viewed_at, :user_id, :user_profile_id], {:where=>"user_id IS NOT NULL", :unique=>true, :name=>"unique_profile_view_user"})
-> 0.0038s
== 20150914021445 CreateUserProfileViews: migrated (0.0498s) ==================
== 20150914034541 AddViewsToUserProfile: migrating ============================
-- add_column(:user_profiles, :views, :integer, {:default=>0, :null=>false})
-> 0.0096s
== 20150914034541 AddViewsToUserProfile: migrated (0.0109s) ===================
== 20150917071017 AddCategoryIdToUserHistories: migrating =====================
-- add_column(:user_histories, :category_id, :integer)
-> 0.0004s
-- add_index(:user_histories, :category_id)
-> 0.0036s
== 20150917071017 AddCategoryIdToUserHistories: migrated (0.0052s) ============
== 20150918004206 AddUserIdGroupIdIndexToGroupUsers: migrating ================
-- add_index(:group_users, [:user_id, :group_id], {:unique=>true})
-> 0.0035s
== 20150918004206 AddUserIdGroupIdIndexToGroupUsers: migrated (0.0047s) =======
== 20150924022040 AddFancyTitleToTopic: migrating =============================
-- add_column(:topics, :fancy_title, :string, {:limit=>400, :null=>true})
-> 0.0004s
== 20150924022040 AddFancyTitleToTopic: migrated (0.0016s) ====================
== 20150925000915 ExcludeWhispersFromBadges: migrating ========================
-- execute("DROP VIEW badge_posts")
-> 0.0008s
-- execute("CREATE VIEW badge_posts AS\n SELECT p.*\n FROM posts p\n JOIN topics t ON t.id = p.topic_id\n JOIN categories c ON c.id = t.category_id\n WHERE c.allow_badges AND\n p.deleted_at IS NULL AND\n t.deleted_at IS NULL AND\n NOT c.read_restricted AND\n t.visible AND\n p.post_type IN (1,2,3)\n ")
-> 0.0034s
== 20150925000915 ExcludeWhispersFromBadges: migrated (0.0053s) ===============
== 20151016163051 MergePollsVotes: migrating ==================================
== 20151016163051 MergePollsVotes: migrated (0.0222s) =========================
== 20151103233815 AddLowerTitleIndexOnTopics: migrating =======================
-- execute("CREATE INDEX index_topics_on_lower_title ON topics (LOWER(title))")
-> 0.0150s
== 20151103233815 AddLowerTitleIndexOnTopics: migrated (0.0165s) ==============
== 20151105181635 AddStagedToUser: migrating ==================================
-- add_column(:users, :staged, :boolean, {:null=>false, :default=>false})
-> 0.0383s
== 20151105181635 AddStagedToUser: migrated (0.0397s) =========================
== 20151107041044 FixIncorrectTopicCreatorAfterMove: migrating ================
-- execute("UPDATE topics SET user_id = p.user_id\n FROM posts p\n WHERE p.topic_id = topics.id AND\n p.post_number = 1 AND\n p.user_id <> topics.user_id")
-> 0.0009s
== 20151107041044 FixIncorrectTopicCreatorAfterMove: migrated (0.0020s) =======
== 20151107042241 AddOwnerToGroupUsers: migrating =============================
-- add_column(:group_users, :owner, :boolean, {:null=>false, :default=>false})
-> 0.0126s
== 20151107042241 AddOwnerToGroupUsers: migrated (0.0140s) ====================
== 20151109124147 DropGroupManagers: migrating ================================
-- execute("UPDATE group_users SET owner = true\n WHERE exists (SELECT 1 FROM group_managers m\n WHERE m.group_id = group_users.group_id AND\n m.user_id = group_users.user_id)")
-> 0.0006s
-- drop_table("group_managers")
-> 0.0006s
== 20151109124147 DropGroupManagers: migrated (0.0025s) =======================
== 20151113205046 CreateTranslationOverrides: migrating =======================
-- create_table(:translation_overrides, {:force=>true})
-> 0.0071s
-- add_index(:translation_overrides, [:locale, :translation_key], {:unique=>true})
-> 0.0038s
== 20151113205046 CreateTranslationOverrides: migrated (0.0122s) ==============
== 20151117165756 AddAutomaticallyUnpinTopicsToUsers: migrating ===============
-- add_column(:users, :automatically_unpin_topics, :boolean, {:nullabe=>false, :default=>true})
-> 0.0463s
== 20151117165756 AddAutomaticallyUnpinTopicsToUsers: migrated (0.0477s) ======
== 20151124172631 AddIsSupportToCategories: migrating =========================
-- add_column(:categories, :is_support, :boolean, {:default=>false, :null=>false})
-> 0.0173s
== 20151124172631 AddIsSupportToCategories: migrated (0.0187s) ================
== 20151124192339 RenameNinjaEdit: migrating ==================================
-- execute("UPDATE site_settings SET name = 'editing_grace_period' WHERE name = 'ninja_edit_window'")
-> 0.0002s
== 20151124192339 RenameNinjaEdit: migrated (0.0015s) =========================
== 20151125194322 RemoveSiteText: migrating ===================================
-- execute("INSERT INTO translation_overrides (locale, translation_key, value, created_at, updated_at)\n SELECT 'en',\n CASE\n WHEN text_type = 'usage_tips' THEN 'system_messages.usage_tips.text_body_template'\n WHEN text_type = 'education_new_topic' THEN 'education.new-topic'\n WHEN text_type = 'education_new_reply' THEN 'education.new-reply'\n WHEN text_type = 'login_required_welcome_message' THEN 'login_required.welcome_message'\n END,\n value,\n created_at,\n updated_at\n FROM site_texts\n WHERE text_type in ('usage_tips',\n 'education_new_topic',\n 'education_new_reply',\n 'login_required_welcome_message')")
-> 0.0004s
-- drop_table(:site_texts)
-> 0.0005s
== 20151125194322 RemoveSiteText: migrated (0.0022s) ==========================
== 20151126173356 RenameIsSupportToContainsMessages: migrating ================
-- rename_column(:categories, :is_support, :contains_messages)
-> 0.0018s
== 20151126173356 RenameIsSupportToContainsMessages: migrated (0.0031s) =======
== 20151126233623 AddBakedHeadAndBodyToSiteCustomizations: migrating ==========
-- add_column(:site_customizations, :head_tag_baked, :text)
-> 0.0004s
-- add_column(:site_customizations, :body_tag_baked, :text)
-> 0.0003s
== 20151126233623 AddBakedHeadAndBodyToSiteCustomizations: migrated (0.0018s) =
== 20151127011837 AddHeaderAndFooterBakedToSiteCustomizations: migrating ======
-- add_column(:site_customizations, :header_baked, :text)
-> 0.0003s
-- add_column(:site_customizations, :mobile_header_baked, :text)
-> 0.0002s
-- add_column(:site_customizations, :footer_baked, :text)
-> 0.0002s
-- add_column(:site_customizations, :mobile_footer_baked, :text)
-> 0.0002s
== 20151127011837 AddHeaderAndFooterBakedToSiteCustomizations: migrated (0.0021s)
== 20151201035631 AddGroupMentions: migrating =================================
-- create_table(:group_mentions)
-> 0.0040s
-- add_index(:group_mentions, [:post_id, :group_id], {:unique=>true})
-> 0.0056s
-- add_index(:group_mentions, [:group_id, :post_id], {:unique=>true})
-> 0.0036s
== 20151201035631 AddGroupMentions: migrated (0.0146s) ========================
== 20151201161726 AddIncomingEmailToGroups: migrating =========================
-- add_column(:groups, :incoming_email, :string, {:null=>true})
-> 0.0004s
-- add_index(:groups, :incoming_email, {:unique=>true})
-> 0.0118s
== 20151201161726 AddIncomingEmailToGroups: migrated (0.0136s) ================
== 20151214165852 AddNotificationLevelToGroupUsers: migrating =================
-- add_column(:group_users, :notification_level, :integer, {:default=>3, :null=>false})
-> 0.0209s
== 20151214165852 AddNotificationLevelToGroupUsers: migrated (0.0222s) ========
== 20151218232200 AddUniqueIndexToCategoryUsers: migrating ====================
-- execute("DELETE FROM category_users cu USING category_users cu1\n WHERE cu.user_id = cu1.user_id AND\n cu.category_id = cu1.category_id AND\n cu.notification_level = cu1.notification_level AND\n cu.id < cu1.id\n")
-> 0.0005s
-- add_index(:category_users, [:user_id, :category_id, :notification_level], {:name=>"idx_category_users_u1", :unique=>true})
-> 0.0040s
-- add_index(:category_users, [:category_id, :user_id, :notification_level], {:name=>"idx_category_users_u2", :unique=>true})
-> 0.0035s
== 20151218232200 AddUniqueIndexToCategoryUsers: migrated (0.0094s) ===========
== 20151219045559 AddHasMessagesToGroups: migrating ===========================
-- add_column(:groups, :has_messages, :boolean, {:default=>false, :null=>false})
-> 0.0125s
-- execute(" UPDATE groups g SET has_messages = true\n WHERE exists(SELECT group_id FROM topic_allowed_groups WHERE group_id = g.id)\n")
-> 0.0006s
== 20151219045559 AddHasMessagesToGroups: migrated (0.0145s) ==================
== 20151220232725 AddUserArchivedMessagesGroupArchivedMessages: migrating =====
-- create_table(:user_archived_messages)
-> 0.0041s
-- add_index(:user_archived_messages, [:user_id, :topic_id], {:unique=>true})
-> 0.0039s
-- create_table(:group_archived_messages)
-> 0.0038s
-- add_index(:group_archived_messages, [:group_id, :topic_id], {:unique=>true})
-> 0.0044s
== 20151220232725 AddUserArchivedMessagesGroupArchivedMessages: migrated (0.0177s)
== 20160108051129 FixIncorrectUserHistory: migrating ==========================
-- execute("SELECT min(id) FROM user_histories WHERE (action = 16 AND previous_value in ('0','1','2','3','4')) OR\n(action = 19 AND target_user_id IS NULL AND details IS NOT NULL)\n")
-> 0.0006s
-- execute("SELECT max(id) FROM user_histories WHERE (action = 16 AND previous_value in ('0','1','2','3','4')) OR\n(action = 19 AND target_user_id IS NULL AND details IS NOT NULL)\n")
-> 0.0003s
== 20160108051129 FixIncorrectUserHistory: migrated (0.0021s) =================
== 20160110053003 ArchiveSystemMessagesWithNoReplies: migrating ===============
-- execute("\n INSERT INTO user_archived_messages (user_id, topic_id, created_at, updated_at)\n SELECT p.user_id, p.topic_id, p.created_at, p.updated_at\n FROM posts p\n JOIN topics t ON t.id = p.topic_id\n LEFT JOIN user_archived_messages um ON um.user_id = p.user_id AND um.topic_id = p.topic_id\n WHERE t.subtype = 'system_message' AND\n t.posts_count = 1 AND\n t.archetype = 'private_message' AND\n um.id IS NULL AND\n p.user_id IS NOT NULL AND\n p.topic_id IS NOT NULL AND\n p.post_number = 1\n")
-> 0.0009s
== 20160110053003 ArchiveSystemMessagesWithNoReplies: migrated (0.0021s) ======
== 20160112025852 RemoveUsersFromTopicAllowedUsers: migrating =================
-- execute(" DELETE FROM topic_allowed_users tu\n USING topic_allowed_groups tg\n JOIN group_users gu ON gu.group_id = tg.group_id\n WHERE tu.user_id = gu.user_id AND tg.topic_id = tu.topic_id\n")
-> 0.0007s
== 20160112025852 RemoveUsersFromTopicAllowedUsers: migrated (0.0017s) ========
== 20160112101818 RemoveContainsMessageOnCategory: migrating ==================
-- remove_column(:categories, :contains_messages)
-> 0.0004s
== 20160112101818 RemoveContainsMessageOnCategory: migrated (0.0014s) =========
== 20160112104733 AddContainsMessagesBackToCategories: migrating ==============
-- add_column(:categories, :contains_messages, :boolean)
-> 0.0004s
== 20160112104733 AddContainsMessagesBackToCategories: migrated (0.0013s) =====
== 20160113160742 CreateIncomingEmails: migrating =============================
-- create_table(:incoming_emails)
-> 0.0171s
-- add_index(:incoming_emails, :created_at)
-> 0.0036s
-- add_index(:incoming_emails, :message_id)
-> 0.0036s
-- add_index(:incoming_emails, :error)
-> 0.0115s
== 20160113160742 CreateIncomingEmails: migrated (0.0374s) ====================
== 20160118174335 RebakeHtmlCustomizations: migrating =========================
-- execute("UPDATE site_customizations SET body_tag_baked = NULL,\n head_tag_baked = NULL,\n header_baked = NULL,\n mobile_header_baked = NULL,\n footer_baked = NULL,\n mobile_footer_baked = NULL")
-> 0.0003s
== 20160118174335 RebakeHtmlCustomizations: migrated (0.0016s) ================
== 20160118233631 BackfillIncomingEmails: migrating ===========================
-- execute(" INSERT INTO incoming_emails (post_id, created_at, updated_at, user_id, topic_id, message_id, from_address, to_addresses, subject)\n SELECT posts.id\n , posts.created_at\n , posts.created_at\n , posts.user_id\n , posts.topic_id\n , array_to_string(regexp_matches(posts.raw_email, '^ *Message-Id: .*<([^>]+)>', 'im'), '')\n , users.email\n , array_to_string(regexp_matches(array_to_string(regexp_matches(posts.raw_email, '^to:.+$', 'im'), ''), '[^< \"''(]+@[^> \"'')]+'), '')\n , topics.title\n FROM posts\n JOIN topics ON posts.topic_id = topics.id\n JOIN users ON posts.user_id = users.id\n WHERE posts.user_id IS NOT NULL\n AND posts.topic_id IS NOT NULL\n AND posts.via_email = 't'\n AND posts.raw_email ~* 'Message-Id'\n ORDER BY posts.id;\n")
-> 0.0014s
== 20160118233631 BackfillIncomingEmails: migrated (0.0025s) ==================
== 20160127105314 ChangeDefaultNotificationLevelOnGroups: migrating ===========
-- execute("UPDATE group_users SET notification_level = 2")
-> 0.0001s
-- change_column(:group_users, :notification_level, :integer, {:null=>false, :default=>2})
-> 0.0024s
== 20160127105314 ChangeDefaultNotificationLevelOnGroups: migrated (0.0036s) ==
== 20160127222802 MigrateUncategorizedDescriptionSetting: migrating ===========
-- execute("INSERT INTO translation_overrides (locale, translation_key, value, created_at, updated_at)\n SELECT 'en', 'category.uncategorized_description', value, created_at, updated_at\n FROM site_settings\n WHERE name = 'uncategorized_description'\n AND value <> 'Topics that don''t need a category, or don''t fit into any other existing category.'")
-> 0.0003s
-- execute("DELETE FROM site_settings WHERE name = 'uncategorized_description'")
-> 0.0001s
== 20160127222802 MigrateUncategorizedDescriptionSetting: migrated (0.0015s) ==
== 20160201181320 FixEmailLogs: migrating =====================================
-- execute(" UPDATE email_logs\n SET user_id = u.id\n FROM email_logs el\n LEFT JOIN users u ON u.email = el.to_address\n WHERE email_logs.id = el.id\n AND email_logs.user_id IS NULL\n AND NOT email_logs.skipped\n")
-> 0.0006s
== 20160201181320 FixEmailLogs: migrated (0.0016s) ============================
== 20160206210202 RemoveInvalidWebsites: migrating ============================
-- execute("UPDATE user_profiles SET website = NULL WHERE website = 'http://'")
-> 0.0003s
== 20160206210202 RemoveInvalidWebsites: migrated (0.0014s) ===================
== 20160215075528 AddUnreadPmIndexToNotifications: migrating ==================
-- add_index(:notifications, [:user_id, :id], {:unique=>true, :where=>"notification_type = 6 AND NOT read"})
-> 0.0042s
== 20160215075528 AddUnreadPmIndexToNotifications: migrated (0.0054s) =========
== 20160224033122 CreateInstagramUserInfos: migrating =========================
-- create_table(:instagram_user_infos)
-> 0.0069s
== 20160224033122 CreateInstagramUserInfos: migrated (0.0084s) ================
== 20160225050317 AddUserOptions: migrating ===================================
-- create_table(:user_options, {:id=>false})
-> 0.0029s
-- add_index(:user_options, [:user_id], {:unique=>true})
-> 0.0039s
-- execute(" INSERT INTO user_options (\n user_id,\n email_always,\n mailing_list_mode,\n email_digests,\n email_direct,\n email_private_messages,\n external_links_in_new_tab,\n enable_quoting,\n dynamic_favicon,\n disable_jump_reply,\n edit_history_public,\n automatically_unpin_topics,\n digest_after_days\n )\n SELECT id,\n email_always,\n mailing_list_mode,\n email_digests,\n email_direct,\n COALESCE(email_private_messages,true),\n external_links_in_new_tab,\n enable_quoting,\n dynamic_favicon,\n disable_jump_reply,\n edit_history_public,\n automatically_unpin_topics,\n digest_after_days\n FROM users\n")
-> 0.0004s
== 20160225050317 AddUserOptions: migrated (0.0085s) ==========================
== 20160225050318 AllowDefaultsOnUsersTable: migrating ========================
-- change_column(:users, :email_digests, :boolean, {:null=>false, :default=>true})
-> 0.0042s
-- change_column(:users, :external_links_in_new_tab, :boolean, {:null=>false, :default=>false})
-> 0.0038s
== 20160225050318 AllowDefaultsOnUsersTable: migrated (0.0092s) ===============
== 20160225050319 MoveTrackingOptionsToUserOptions: migrating =================
-- add_column(:user_options, :auto_track_topics_after_msecs, :integer)
-> 0.0003s
-- add_column(:user_options, :new_topic_duration_minutes, :integer)
-> 0.0003s
-- add_column(:user_options, :last_redirected_to_top_at, :datetime)
-> 0.0003s
-- execute(" UPDATE user_options\n SET auto_track_topics_after_msecs = users.auto_track_topics_after_msecs,\n new_topic_duration_minutes = users.new_topic_duration_minutes,\n last_redirected_to_top_at = users.last_redirected_to_top_at\n FROM users\n WHERE users.id = user_options.user_id\n")
-> 0.0005s
== 20160225050319 MoveTrackingOptionsToUserOptions: migrated (0.0025s) ========
== 20160225050320 AddEmailPreviousRepliesToUserOptions: migrating =============
-- add_column(:user_options, :email_previous_replies, :integer, {:null=>false, :default=>1})
-> 0.0165s
== 20160225050320 AddEmailPreviousRepliesToUserOptions: migrated (0.0179s) ====
== 20160225095306 AddEmailInReplyToToUserOptions: migrating ===================
-- add_column(:user_options, :email_in_reply_to, :boolean, {:null=>false, :default=>true})
-> 0.0061s
-- change_column(:user_options, :email_previous_replies, :integer, {:default=>2, :null=>false})
-> 0.0027s
-- execute("UPDATE user_options SET email_previous_replies = 2")
-> 0.0002s
== 20160225095306 AddEmailInReplyToToUserOptions: migrated (0.0103s) ==========
== 20160302063432 RebuildDirectoryItemWithIndex: migrating ====================
-- remove_index(:directory_items, [:period_type])
-> 0.0012s
-- execute("TRUNCATE TABLE directory_items RESTART IDENTITY")
-> 0.0031s
-- add_index(:directory_items, [:period_type, :user_id], {:unique=>true})
-> 0.0040s
== 20160302063432 RebuildDirectoryItemWithIndex: migrated (0.0095s) ===========
== 20160302104253 AddLikeNotificationFrequencyToUserOptions: migrating ========
-- add_column(:user_options, :like_notification_frequency, :integer, {:null=>false, :default=>1})
-> 0.0058s
== 20160302104253 AddLikeNotificationFrequencyToUserOptions: migrated (0.0071s)
== 20160302170230 RenameDigestAfterDaysToDigestAfterMinutes: migrating ========
-- rename_column(:user_options, :digest_after_days, :digest_after_minutes)
-> 0.0014s
-- execute("UPDATE user_options SET digest_after_minutes = digest_after_minutes * 1440 WHERE digest_after_minutes IS NOT NULL")
-> 0.0002s
-- execute("UPDATE site_settings SET value = value::integer * 1440 WHERE name = 'default_email_digest_frequency' AND value IS NOT NULL")
-> 0.0002s
== 20160302170230 RenameDigestAfterDaysToDigestAfterMinutes: migrated (0.0032s)
== 20160303183607 ClearCommonPasswordsCache: migrating ========================
== 20160303183607 ClearCommonPasswordsCache: migrated (0.0011s) ===============
== 20160303234317 AddRejectionMessageToIncomingEmail: migrating ===============
-- add_column(:incoming_emails, :rejection_message, :text)
-> 0.0003s
== 20160303234317 AddRejectionMessageToIncomingEmail: migrated (0.0015s) ======
== 20160307190919 CreateEmailChangeRequests: migrating ========================
-- create_table(:email_change_requests)
-> 0.0064s
-- add_index(:email_change_requests, :user_id)
-> 0.0037s
== 20160307190919 CreateEmailChangeRequests: migrated (0.0114s) ===============
== 20160308193142 RenameConfirmTranslationKey: migrating ======================
-- execute("UPDATE translation_overrides SET translation_key = 'user_notifications.confirm_new_email.subject_template'\n WHERE translation_key = 'user_notifications.authorize_email.subject_template'")
-> 0.0003s
-- execute("UPDATE translation_overrides SET translation_key = 'user_notifications.confirm_new_email.text_body_template'\n WHERE translation_key = 'user_notifications.authorize_email.text_body_template'")
-> 0.0002s
== 20160308193142 RenameConfirmTranslationKey: migrated (0.0015s) =============
== 20160309073132 AddMailingListModeFrequency: migrating ======================
-- add_column(:user_options, :mailing_list_mode_frequency, :integer, {:default=>0, :null=>false})
-> 0.0058s
== 20160309073132 AddMailingListModeFrequency: migrated (0.0070s) =============
== 20160317174357 CreateGivenDailyLikes: migrating ============================
-- create_table(:given_daily_likes, {:id=>false, :force=>true})
-> 0.0014s
-- add_index(:given_daily_likes, [:user_id, :given_date], {:unique=>true})
-> 0.0041s
-- add_index(:given_daily_likes, [:limit_reached, :user_id])
-> 0.0036s
-- execute("SELECT value FROM site_settings WHERE name = 'max_likes_per_day'")
-> 0.0002s
-- execute("INSERT INTO given_daily_likes (user_id, likes_given, limit_reached, given_date)\n SELECT pa.user_id,\n COUNT(*),\n CASE WHEN COUNT(*) >= 50 THEN true\n ELSE false\n END,\n pa.created_at::date\n FROM post_actions AS pa\n WHERE pa.post_action_type_id = 2\n AND pa.deleted_at IS NULL\n GROUP BY pa.user_id, pa.created_at::date")
-> 0.0006s
== 20160317174357 CreateGivenDailyLikes: migrated (0.0113s) ===================
== 20160317201955 AddIncludeTl0InDigestsToUserOptions: migrating ==============
-- add_column(:user_options, :include_tl0_in_digests, :boolean, {:default=>false})
-> 0.0130s
== 20160317201955 AddIncludeTl0InDigestsToUserOptions: migrated (0.0144s) =====
== 20160321164925 ClosePollsInClosedTopics: migrating =========================
== 20160321164925 ClosePollsInClosedTopics: migrated (0.0183s) ================
== 20160326001747 AddUserFirstVisit: migrating ================================
-- add_column(:users, :first_seen_at, :datetime)
-> 0.0004s
== 20160326001747 AddUserFirstVisit: migrated (0.0015s) =======================
== 20160329101122 RemoveWikiColor: migrating ==================================
-- execute("DELETE FROM color_scheme_colors WHERE name = 'wiki'")
-> 0.0002s
== 20160329101122 RemoveWikiColor: migrated (0.0013s) =========================
== 20160405172827 CreateUserFirsts: migrating =================================
-- create_table(:user_firsts, {:force=>true})
-> 0.0047s
-- add_index(:user_firsts, [:user_id, :first_type], {:unique=>true})
-> 0.0060s
== 20160405172827 CreateUserFirsts: migrated (0.0122s) ========================
== 20160407160756 RemoveUserFirsts: migrating =================================
-- table_exists?(:user_firsts)
-> 0.0005s
-- drop_table(:user_firsts)
-> 0.0006s
== 20160407160756 RemoveUserFirsts: migrated (0.0022s) ========================
== 20160407180149 CreateOnceoffLogs: migrating ================================
-- create_table(:onceoff_logs)
-> 0.0066s
-- add_index(:onceoff_logs, :job_name)
-> 0.0037s
== 20160407180149 CreateOnceoffLogs: migrated (0.0115s) =======================
== 20160408131959 AddShowOnUserCardToUserFields: migrating ====================
-- add_column(:user_fields, :show_on_user_card, :boolean, {:default=>false, :null=>false})
-> 0.0074s
== 20160408131959 AddShowOnUserCardToUserFields: migrated (0.0087s) ===========
== 20160408175727 AddCompiledJsToTranslationOverrides: migrating ==============
-- add_column(:translation_overrides, :compiled_js, :text, {:null=>true})
-> 0.0003s
== 20160408175727 AddCompiledJsToTranslationOverrides: migrated (0.0015s) =====
== 20160418065403 AddBounceKeyToEmailLog: migrating ===========================
-- add_column(:email_logs, :bounce_key, :string)
-> 0.0003s
== 20160418065403 AddBounceKeyToEmailLog: migrated (0.0013s) ==================
== 20160420172330 AddIsAutoGeneratedToIncomingEmails: migrating ===============
-- add_column(:incoming_emails, :is_auto_generated, :boolean, {:default=>false})
-> 0.0262s
== 20160420172330 AddIsAutoGeneratedToIncomingEmails: migrated (0.0276s) ======
== 20160425141954 FixIncomingEmailsIndices: migrating =========================
-- add_index(:incoming_emails, :post_id)
-> 0.0108s
== 20160425141954 FixIncomingEmailsIndices: migrated (0.0122s) ================
== 20160427202222 AddSupportForBouncedEmails: migrating =======================
-- add_column(:email_logs, :bounced, :boolean, {:null=>false, :default=>false})
-> 0.0165s
-- add_column(:incoming_emails, :is_bounce, :boolean, {:null=>false, :default=>false})
-> 0.0168s
-- add_column(:user_stats, :bounce_score, :integer, {:null=>false, :default=>0})
-> 0.0057s
-- add_column(:user_stats, :reset_bounce_score_after, :datetime)
-> 0.0003s
== 20160427202222 AddSupportForBouncedEmails: migrated (0.0408s) ==============
== 20160503205953 CreateTags: migrating =======================================
-- create_table(:tags)
-> 0.0074s
-- create_table(:topic_tags)
-> 0.0037s
-- create_table(:tag_users)
-> 0.0120s
-- add_index(:tags, :name, {:unique=>true})
-> 0.0140s
-- add_index(:topic_tags, [:topic_id, :tag_id], {:unique=>true})
-> 0.0042s
-- add_index(:tag_users, [:user_id, :tag_id, :notification_level], {:name=>"idx_tag_users_ix1", :unique=>true})
-> 0.0036s
-- add_index(:tag_users, [:tag_id, :user_id, :notification_level], {:name=>"idx_tag_users_ix2", :unique=>true})
-> 0.0118s
== 20160503205953 CreateTags: migrated (0.0584s) ==============================
== 20160514100852 RemoveInvalidTopicUser: migrating ===========================
-- execute(" DELETE FROM topic_users\n USING topic_users tu\n LEFT JOIN users u ON u.id = tu.user_id\n WHERE u.id IS NULL\n AND topic_users.id = tu.id\n")
-> 0.0008s
== 20160514100852 RemoveInvalidTopicUser: migrated (0.0020s) ==================
== 20160520022627 ShortenTopicCustomFieldsIndex: migrating ====================
-- remove_index(:topic_custom_fields, :value)
-> 0.0010s
-- add_index(:topic_custom_fields, [:value, :name], {:name=>"topic_custom_fields_value_key_idx", :where=>"value IS NOT NULL AND char_length(value) < 400"})
-> 0.0040s
== 20160520022627 ShortenTopicCustomFieldsIndex: migrated (0.0063s) ===========
== 20160527015355 CorrectMailingListModeFrequency: migrating ==================
-- execute("UPDATE user_options SET mailing_list_mode_frequency = 1 where mailing_list_mode")
-> 0.0004s
== 20160527015355 CorrectMailingListModeFrequency: migrated (0.0016s) =========
== 20160527191614 CreateCategoryTags: migrating ===============================
-- create_table(:category_tags)
-> 0.0052s
-- add_index(:category_tags, [:category_id, :tag_id], {:name=>"idx_category_tags_ix1", :unique=>true})
-> 0.0036s
-- add_index(:category_tags, [:tag_id, :category_id], {:name=>"idx_category_tags_ix2", :unique=>true})
-> 0.0033s
== 20160527191614 CreateCategoryTags: migrated (0.0135s) ======================
== 20160530003739 CreateSchedulerStats: migrating =============================
-- create_table(:scheduler_stats)
-> 0.0065s
== 20160530003739 CreateSchedulerStats: migrated (0.0076s) ====================
== 20160530203810 AddMessageIdToEmailLogs: migrating ==========================
-- add_column(:email_logs, :message_id, :string)
-> 0.0004s
-- add_index(:email_logs, :message_id)
-> 0.0036s
== 20160530203810 AddMessageIdToEmailLogs: migrated (0.0050s) =================
== 20160602164008 CreateTagGroups: migrating ==================================
-- create_table(:tag_groups)
-> 0.0065s
-- create_table(:tag_group_memberships)
-> 0.0037s
-- add_index(:tag_group_memberships, [:tag_group_id, :tag_id], {:unique=>true})
-> 0.0036s
== 20160602164008 CreateTagGroups: migrated (0.0150s) =========================
== 20160606204319 CreateCategoryTagGroups: migrating ==========================
-- create_table(:category_tag_groups)
-> 0.0038s
-- add_index(:category_tag_groups, [:category_id, :tag_group_id], {:name=>"idx_category_tag_groups_ix1", :unique=>true})
-> 0.0037s
== 20160606204319 CreateCategoryTagGroups: migrated (0.0088s) =================
== 20160607213656 AddTagGroupOptions: migrating ===============================
-- add_column(:tag_groups, :parent_tag_id, :integer)
-> 0.0003s
-- add_column(:tag_groups, :one_per_topic, :boolean, {:default=>false})
-> 0.0149s
== 20160607213656 AddTagGroupOptions: migrated (0.0167s) ======================
== 20160609203508 RemoveTagCountFromTagGroups: migrating ======================
-- remove_column(:tag_groups, :tag_count)
-> 0.0005s
== 20160609203508 RemoveTagCountFromTagGroups: migrated (0.0018s) =============
== 20160615024524 RenameDigestUnsbscribeKeys: migrating =======================
-- rename_table(:digest_unsubscribe_keys, :unsubscribe_keys)
-> 0.0034s
-- add_column(:unsubscribe_keys, :unsubscribe_key_type, :string)
-> 0.0029s
-- add_column(:unsubscribe_keys, :topic_id, :int)
-> 0.0002s
-- add_column(:unsubscribe_keys, :post_id, :int)
-> 0.0002s
-- execute("UPDATE unsubscribe_keys SET unsubscribe_key_type = 'digest' WHERE unsubscribe_key_type IS NULL")
-> 0.0002s
== 20160615024524 RenameDigestUnsbscribeKeys: migrated (0.0082s) ==============
== 20160615165447 RenameNumFlagsToBlockNewUser: migrating =====================
-- execute("update site_settings set name = 'num_spam_flags_to_block_new_user' where name = 'num_flags_to_block_new_user'")
-> 0.0002s
== 20160615165447 RenameNumFlagsToBlockNewUser: migrated (0.0012s) ============
== 20160627104436 UseHttpsNameChangeInSiteSettings: migrating =================
-- execute("UPDATE site_settings SET name = 'force_https' WHERE name = 'use_https'")
-> 0.0002s
== 20160627104436 UseHttpsNameChangeInSiteSettings: migrated (0.0011s) ========
== 20160707195549 AddCompilerVersionToSiteCustomizations: migrating ===========
-- add_column(:site_customizations, :compiler_version, :integer, {:default=>0, :null=>false})
-> 0.0096s
== 20160707195549 AddCompilerVersionToSiteCustomizations: migrated (0.0108s) ==
== 20160716112354 RemoveEditHistoryPublic: migrating ==========================
-- remove_column(:user_options, :edit_history_public)
-> 0.0003s
== 20160716112354 RemoveEditHistoryPublic: migrated (0.0014s) =================
== 20160719002225 AddDeletedPostIndexToPosts: migrating =======================
-- add_index(:posts, [:topic_id, :post_number], {:where=>"deleted_at IS NOT NULL", :name=>"idx_posts_deleted_posts"})
-> 0.0039s
== 20160719002225 AddDeletedPostIndexToPosts: migrated (0.0050s) ==============
== 20160722071221 AddAuthTokenCreatedAtToUsers: migrating =====================
-- add_column(:users, :auth_token_created_at, :datetime, {:null=>true})
-> 0.0004s
== 20160722071221 AddAuthTokenCreatedAtToUsers: migrated (0.0014s) ============
== 20160725015749 RenameAuthTokenCreatedAt: migrating =========================
-- rename_column(:users, :auth_token_created_at, :auth_token_updated_at)
-> 0.0027s
== 20160725015749 RenameAuthTokenCreatedAt: migrated (0.0036s) ================
== 20160727233044 CreateDevelopersTable: migrating ============================
-- create_table(:developers)
-> 0.0037s
== 20160727233044 CreateDevelopersTable: migrated (0.0047s) ===================
== 20160815002002 AddUserApiKeys: migrating ===================================
-- create_table(:user_api_keys)
-> 0.0064s
-- add_index(:user_api_keys, [:key], {:unique=>true})
-> 0.0037s
-- add_index(:user_api_keys, [:user_id])
-> 0.0036s
-- add_index(:user_api_keys, [:client_id])
-> 0.0039s
== 20160815002002 AddUserApiKeys: migrated (0.0190s) ==========================
== 20160815210156 AddFlairUrlToGroups: migrating ==============================
-- add_column(:groups, :flair_url, :string)
-> 0.0004s
-- add_column(:groups, :flair_bg_color, :string)
-> 0.0002s
== 20160815210156 AddFlairUrlToGroups: migrated (0.0018s) =====================
== 20160816052836 UserApiClientIdIsUnique: migrating ==========================
-- remove_index(:user_api_keys, [:client_id])
-> 0.0010s
-- add_index(:user_api_keys, [:client_id], {:unique=>true})
-> 0.0089s
== 20160816052836 UserApiClientIdIsUnique: migrated (0.0112s) =================
== 20160816063534 AddRevokedAtToUserApiKeys: migrating ========================
-- add_column(:user_api_keys, :revoked_at, :datetime)
-> 0.0004s
== 20160816063534 AddRevokedAtToUserApiKeys: migrated (0.0016s) ===============
== 20160823171911 AddPathWhitelistToEmbeddableHosts: migrating ================
-- add_column(:embeddable_hosts, :path_whitelist, :string)
-> 0.0004s
== 20160823171911 AddPathWhitelistToEmbeddableHosts: migrated (0.0014s) =======
== 20160826195018 AddFlairColorToGroups: migrating ============================
-- add_column(:groups, :flair_color, :string)
-> 0.0003s
== 20160826195018 AddFlairColorToGroups: migrated (0.0013s) ===================
== 20160905082217 CreateWebHookEventTypes: migrating ==========================
-- create_table(:web_hook_event_types)
-> 0.0068s
== 20160905082217 CreateWebHookEventTypes: migrated (0.0081s) =================
== 20160905082248 CreateWebHooks: migrating ===================================
-- create_table(:web_hooks)
-> 0.0079s
== 20160905082248 CreateWebHooks: migrated (0.0091s) ==========================
== 20160905084502 CreateWebHookEvents: migrating ==============================
-- create_table(:web_hook_events)
-> 0.0099s
== 20160905084502 CreateWebHookEvents: migrated (0.0112s) =====================
== 20160905085445 CreateJoinTableWebHooksWebHookEventTypes: migrating =========
-- create_join_table(:web_hooks, :web_hook_event_types)
-> 0.0008s
-- add_index(:web_hook_event_types_hooks, [:web_hook_event_type_id, :web_hook_id], {:name=>"idx_web_hook_event_types_hooks_on_ids", :unique=>true})
-> 0.0037s
== 20160905085445 CreateJoinTableWebHooksWebHookEventTypes: migrated (0.0058s)
== 20160905091958 CreateJoinTableWebHooksGroups: migrating ====================
-- create_join_table(:web_hooks, :groups)
-> 0.0007s
-- add_index(:groups_web_hooks, [:web_hook_id, :group_id], {:unique=>true})
-> 0.0037s
== 20160905091958 CreateJoinTableWebHooksGroups: migrated (0.0054s) ===========
== 20160905092148 CreateJoinTableWebHooksCategories: migrating ================
-- create_join_table(:web_hooks, :categories)
-> 0.0006s
-- add_index(:categories_web_hooks, [:web_hook_id, :category_id], {:unique=>true})
-> 0.0036s
== 20160905092148 CreateJoinTableWebHooksCategories: migrated (0.0053s) =======
== 20160906200439 AddViaWizardToColorSchemes: migrating =======================
-- add_column(:color_schemes, :via_wizard, :boolean, {:default=>false, :null=>false})
-> 0.0073s
-- add_column(:color_schemes, :theme_id, :string, {:null=>true})
-> 0.0003s
== 20160906200439 AddViaWizardToColorSchemes: migrated (0.0089s) ==============
== 20160919003141 AddAvatarUrlToFacebookInfo: migrating =======================
-- add_column(:facebook_user_infos, :avatar_url, :string)
-> 0.0003s
== 20160919003141 AddAvatarUrlToFacebookInfo: migrated (0.0015s) ==============
== 20160919054014 AddFieldsToFacebookUserInfo: migrating ======================
-- add_column(:facebook_user_infos, :about_me, :text)
-> 0.0003s
-- add_column(:facebook_user_infos, :location, :string)
-> 0.0002s
-- add_column(:facebook_user_infos, :website, :text)
-> 0.0002s
== 20160919054014 AddFieldsToFacebookUserInfo: migrated (0.0019s) =============
== 20160920165833 AddModeratorToInvites: migrating ============================
-- add_column(:invites, :moderator, :boolean, {:default=>false, :null=>false})
-> 0.0317s
== 20160920165833 AddModeratorToInvites: migrated (0.0332s) ===================
== 20160930123330 AddNotificationLevelWhenReplying: migrating =================
-- add_column(:user_options, :notification_level_when_replying, :integer)
-> 0.0004s
== 20160930123330 AddNotificationLevelWhenReplying: migrated (0.0015s) ========
== 20161010230853 SingleSignOnIncreaseExternalAvatarUrl: migrating ============
-- change_column(:single_sign_on_records, :external_avatar_url, :string, {:limit=>1000})
-> 0.0094s
== 20161010230853 SingleSignOnIncreaseExternalAvatarUrl: migrated (0.0107s) ===
== 20161013012136 AddScopesToUserApiKeys: migrating ===========================
-- add_column(:user_api_keys, :scopes, :text, {:array=>true, :null=>false, :default=>[]})
-> 0.0162s
-- execute("UPDATE user_api_keys SET scopes = scopes || ARRAY['write'] WHERE write")
-> 0.0004s
-- execute("UPDATE user_api_keys SET scopes = scopes || ARRAY['read'] WHERE read")
-> 0.0002s
-- execute("UPDATE user_api_keys SET scopes = scopes || ARRAY['push'] WHERE push")
-> 0.0002s
-- remove_column(:user_api_keys, :read)
-> 0.0003s
-- remove_column(:user_api_keys, :write)
-> 0.0002s
-- remove_column(:user_api_keys, :push)
-> 0.0002s
== 20161013012136 AddScopesToUserApiKeys: migrated (0.0192s) ==================
== 20161014171034 AddDirectoryItemsIndexes: migrating =========================
-- add_index(:directory_items, :likes_received, {:algorithm=>:concurrently})
-> 0.0042s
-- add_index(:directory_items, :likes_given, {:algorithm=>:concurrently})
-> 0.0035s
-- add_index(:directory_items, :topics_entered, {:algorithm=>:concurrently})
-> 0.0033s
-- add_index(:directory_items, :topic_count, {:algorithm=>:concurrently})
-> 0.0035s
-- add_index(:directory_items, :post_count, {:algorithm=>:concurrently})
-> 0.0035s
-- add_index(:directory_items, :posts_read, {:algorithm=>:concurrently})
-> 0.0037s
-- add_index(:directory_items, :days_visited, {:algorithm=>:concurrently})
-> 0.0036s
== 20161014171034 AddDirectoryItemsIndexes: migrated (0.0268s) ================
== 20161025083648 FixCategoryLogoAndBackgroundUrls: migrating =================
== 20161025083648 FixCategoryLogoAndBackgroundUrls: migrated (0.0009s) ========
== 20161029181306 AddImageUrlToPosts: migrating ===============================
-- add_column(:posts, :image_url, :string)
-> 0.0005s
== 20161029181306 AddImageUrlToPosts: migrated (0.0014s) ======================
== 20161031183811 AddSortFieldsToCategories: migrating ========================
-- add_column(:categories, :sort_order, :string)
-> 0.0004s
-- add_column(:categories, :sort_ascending, :boolean)
-> 0.0002s
== 20161031183811 AddSortFieldsToCategories: migrated (0.0016s) ===============
== 20161102024700 AddPostUploadsIndexes: migrating ============================
-- add_index(:post_uploads, :post_id)
-> 0.0089s
-- add_index(:post_uploads, :upload_id)
-> 0.0036s
== 20161102024700 AddPostUploadsIndexes: migrated (0.0138s) ===================
== 20161102024818 AddUploadedAvatarIdIndexToUsers: migrating ==================
-- add_index(:users, :uploaded_avatar_id)
-> 0.0102s
== 20161102024818 AddUploadedAvatarIdIndexToUsers: migrated (0.0112s) =========
== 20161102024838 AddUserAvatarsIndexes: migrating ============================
-- add_index(:user_avatars, :custom_upload_id)
-> 0.0036s
-- add_index(:user_avatars, :gravatar_upload_id)
-> 0.0038s
== 20161102024838 AddUserAvatarsIndexes: migrated (0.0086s) ===================
== 20161102024900 AddUserProfilesIndexes: migrating ===========================
-- add_index(:user_profiles, :profile_background)
-> 0.0039s
-- add_index(:user_profiles, :card_background)
-> 0.0036s
== 20161102024900 AddUserProfilesIndexes: migrated (0.0085s) ==================
== 20161102024920 AddCategoriesIndexes: migrating =============================
-- add_index(:categories, :logo_url)
-> 0.0039s
-- add_index(:categories, :background_url)
-> 0.0034s
== 20161102024920 AddCategoriesIndexes: migrated (0.0085s) ====================
== Seed from /var/www/discourse/db/fixtures/001_categories.rb
== Seed from /var/www/discourse/db/fixtures/002_groups.rb
== Seed from /var/www/discourse/db/fixtures/003_post_action_types.rb
- PostActionType {:id=>1, :name_key=>"bookmark", :is_flag=>false, :position=>1}
- PostActionType {:id=>2, :name_key=>"like", :is_flag=>false, :icon=>"heart", :position=>2}
- PostActionType {:id=>3, :name_key=>"off_topic", :is_flag=>true, :position=>3}
- PostActionType {:id=>4, :name_key=>"inappropriate", :is_flag=>true, :position=>4}
- PostActionType {:id=>5, :name_key=>"vote", :is_flag=>false, :position=>5}
- PostActionType {:id=>8, :name_key=>"spam", :is_flag=>true, :position=>6}
- PostActionType {:id=>6, :name_key=>"notify_user", :is_flag=>true, :position=>7}
- PostActionType {:id=>7, :name_key=>"notify_moderators", :is_flag=>true, :position=>8}
== Seed from /var/www/discourse/db/fixtures/004_screened_ip_addresses.rb
- ScreenedIpAddress {:id=>1, :ip_address=>"10.0.0.0/8", :action_type=>2}
- ScreenedIpAddress {:id=>2, :ip_address=>"192.168.0.0/16", :action_type=>2}
- ScreenedIpAddress {:id=>3, :ip_address=>"127.0.0.0/8", :action_type=>2}
- ScreenedIpAddress {:id=>4, :ip_address=>"172.16.0.0/12", :action_type=>2}
- ScreenedIpAddress {:id=>5, :ip_address=>"fc00::/7", :action_type=>2}
== Seed from /var/www/discourse/db/fixtures/005_badge_types.rb
- BadgeType {:id=>1, :name=>"Gold"}
- BadgeType {:id=>2, :name=>"Silver"}
- BadgeType {:id=>3, :name=>"Bronze"}
== Seed from /var/www/discourse/db/fixtures/006_badges.rb
- BadgeGrouping {:id=>1, :name=>"Getting Started", :default_position=>10}
- BadgeGrouping {:id=>2, :name=>"Community", :default_position=>11}
- BadgeGrouping {:id=>3, :name=>"Posting", :default_position=>12}
- BadgeGrouping {:id=>4, :name=>"Trust Level", :default_position=>13}
- BadgeGrouping {:id=>5, :name=>"Other", :default_position=>14}
- Badge {:id=>1, :default_name=>"Basic User", :badge_type_id=>3, :query=>"\n SELECT u.id user_id, current_timestamp granted_at FROM users u\n WHERE trust_level >= 1 AND (\n :backfill OR u.id IN (:user_ids)\n )\n", :default_badge_grouping_id=>4, :trigger=>4, :default_allow_title=>false, :default_icon=>"fa-user", :system=>true}
- Badge {:id=>2, :default_name=>"Member", :badge_type_id=>3, :query=>"\n SELECT u.id user_id, current_timestamp granted_at FROM users u\n WHERE trust_level >= 2 AND (\n :backfill OR u.id IN (:user_ids)\n )\n", :default_badge_grouping_id=>4, :trigger=>4, :default_allow_title=>false, :default_icon=>"fa-user", :system=>true}
- Badge {:id=>3, :default_name=>"Regular", :badge_type_id=>2, :query=>"\n SELECT u.id user_id, current_timestamp granted_at FROM users u\n WHERE trust_level >= 3 AND (\n :backfill OR u.id IN (:user_ids)\n )\n", :default_badge_grouping_id=>4, :trigger=>4, :default_allow_title=>true, :default_icon=>"fa-user", :system=>true}
- Badge {:id=>4, :default_name=>"Leader", :badge_type_id=>1, :query=>"\n SELECT u.id user_id, current_timestamp granted_at FROM users u\n WHERE trust_level >= 4 AND (\n :backfill OR u.id IN (:user_ids)\n )\n", :default_badge_grouping_id=>4, :trigger=>4, :default_allow_title=>true, :default_icon=>"fa-user", :system=>true}
- Badge {:id=>17, :default_name=>"Reader", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>false, :show_posts=>false, :query=>" SELECT id user_id, current_timestamp granted_at\n FROM users\n WHERE id IN\n (\n SELECT pt.user_id\n FROM post_timings pt\n JOIN badge_posts b ON b.post_number = pt.post_number AND\n b.topic_id = pt.topic_id\n JOIN topics t ON t.id = pt.topic_id\n LEFT JOIN user_badges ub ON ub.badge_id = 17 AND ub.user_id = pt.user_id\n WHERE ub.id IS NULL AND t.posts_count > 100\n GROUP BY pt.user_id, pt.topic_id, t.posts_count\n HAVING count(*) >= t.posts_count\n )\n", :default_badge_grouping_id=>1, :auto_revoke=>false, :system=>true}
- Badge {:id=>16, :default_name=>"Read Guidelines", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>false, :show_posts=>false, :query=>" SELECT user_id, read_faq granted_at\n FROM user_stats\n WHERE read_faq IS NOT NULL AND (user_id IN (:user_ids) OR :backfill)\n", :default_badge_grouping_id=>1, :trigger=>8, :system=>true}
- Badge {:id=>14, :default_name=>"First Link", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT l.user_id, l.post_id, l.created_at granted_at\n FROM\n (\n SELECT MIN(l1.id) id\n FROM topic_links l1\n JOIN badge_posts p1 ON p1.id = l1.post_id\n JOIN badge_posts p2 ON p2.id = l1.link_post_id\n WHERE NOT reflection AND p1.topic_id <> p2.topic_id AND not quote AND\n (:backfill OR ( p1.id in (:post_ids) ))\n GROUP BY l1.user_id\n ) ids\n JOIN topic_links l ON l.id = ids.id\n", :default_badge_grouping_id=>1, :trigger=>2, :system=>true}
- Badge {:id=>15, :default_name=>"First Quote", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT ids.user_id, q.post_id, q.created_at granted_at\n FROM\n (\n SELECT p1.user_id, MIN(q1.id) id\n FROM quoted_posts q1\n JOIN badge_posts p1 ON p1.id = q1.post_id\n JOIN badge_posts p2 ON p2.id = q1.quoted_post_id\n WHERE (:backfill OR ( p1.id IN (:post_ids) ))\n GROUP BY p1.user_id\n ) ids\n JOIN quoted_posts q ON q.id = ids.id\n", :default_badge_grouping_id=>1, :trigger=>2, :system=>true}
- Badge {:id=>11, :default_name=>"First Like", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT pa1.user_id, pa1.created_at granted_at, pa1.post_id\n FROM (\n SELECT pa.user_id, min(pa.id) id\n FROM post_actions pa\n JOIN badge_posts p on p.id = pa.post_id\n WHERE post_action_type_id = 2 AND\n (:backfill OR pa.post_id IN (:post_ids) )\n GROUP BY pa.user_id\n ) x\n JOIN post_actions pa1 on pa1.id = x.id\n", :default_badge_grouping_id=>1, :trigger=>1, :system=>true}
- Badge {:id=>13, :default_name=>"First Flag", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>false, :query=>" SELECT pa1.user_id, pa1.created_at granted_at, pa1.post_id\n FROM (\n SELECT pa.user_id, min(pa.id) id\n FROM post_actions pa\n JOIN badge_posts p on p.id = pa.post_id\n WHERE post_action_type_id IN (3,4,7,8) AND\n (:backfill OR pa.post_id IN (:post_ids) )\n GROUP BY pa.user_id\n ) x\n JOIN post_actions pa1 on pa1.id = x.id\n", :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>1, :auto_revoke=>false, :system=>true}
- Badge {:id=>25, :default_name=>"Promoter", :default_icon=>"fa-user-plus", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>false, :show_posts=>false, :query=>"\n SELECT u.id user_id, current_timestamp granted_at\n FROM users u\n WHERE u.id IN (\n SELECT invited_by_id\n FROM invites i\n JOIN users u2 ON u2.id = i.user_id\n WHERE i.deleted_at IS NULL AND u2.active AND u2.trust_level >= 0 AND not u2.blocked\n GROUP BY invited_by_id\n HAVING COUNT(*) >= 1\n ) AND u.active AND NOT u.blocked AND u.id > 0 AND\n (:backfill OR u.id IN (:user_ids) )\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>true, :system=>true}
- Badge {:id=>26, :default_name=>"Campaigner", :default_icon=>"fa-user-plus", :badge_type_id=>2, :multiple_grant=>false, :target_posts=>false, :show_posts=>false, :query=>"\n SELECT u.id user_id, current_timestamp granted_at\n FROM users u\n WHERE u.id IN (\n SELECT invited_by_id\n FROM invites i\n JOIN users u2 ON u2.id = i.user_id\n WHERE i.deleted_at IS NULL AND u2.active AND u2.trust_level >= 1 AND not u2.blocked\n GROUP BY invited_by_id\n HAVING COUNT(*) >= 3\n ) AND u.active AND NOT u.blocked AND u.id > 0 AND\n (:backfill OR u.id IN (:user_ids) )\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>true, :system=>true}
- Badge {:id=>27, :default_name=>"Champion", :default_icon=>"fa-user-plus", :badge_type_id=>1, :multiple_grant=>false, :target_posts=>false, :show_posts=>false, :query=>"\n SELECT u.id user_id, current_timestamp granted_at\n FROM users u\n WHERE u.id IN (\n SELECT invited_by_id\n FROM invites i\n JOIN users u2 ON u2.id = i.user_id\n WHERE i.deleted_at IS NULL AND u2.active AND u2.trust_level >= 2 AND not u2.blocked\n GROUP BY invited_by_id\n HAVING COUNT(*) >= 5\n ) AND u.active AND NOT u.blocked AND u.id > 0 AND\n (:backfill OR u.id IN (:user_ids) )\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>true, :system=>true}
- Badge {:id=>12, :default_name=>"First Share", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT views.user_id, i2.post_id, i2.created_at granted_at\n FROM\n (\n SELECT i.user_id, MIN(i.id) i_id\n FROM incoming_links i\n JOIN badge_posts p on p.id = i.post_id\n WHERE i.user_id IS NOT NULL\n GROUP BY i.user_id\n ) as views\n JOIN incoming_links i2 ON i2.id = views.i_id\n", :default_badge_grouping_id=>1, :trigger=>0, :system=>true}
- Badge {:id=>21, :default_name=>"Nice Share", :badge_type_id=>3, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT views.user_id, i2.post_id, current_timestamp granted_at\n FROM\n (\n SELECT i.user_id, MIN(i.id) i_id\n FROM incoming_links i\n JOIN badge_posts p on p.id = i.post_id\n WHERE i.user_id IS NOT NULL\n GROUP BY i.user_id,i.post_id\n HAVING COUNT(*) > 25\n ) as views\n JOIN incoming_links i2 ON i2.id = views.i_id\n", :default_badge_grouping_id=>2, :trigger=>0, :system=>true}
- Badge {:id=>22, :default_name=>"Good Share", :badge_type_id=>2, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT views.user_id, i2.post_id, current_timestamp granted_at\n FROM\n (\n SELECT i.user_id, MIN(i.id) i_id\n FROM incoming_links i\n JOIN badge_posts p on p.id = i.post_id\n WHERE i.user_id IS NOT NULL\n GROUP BY i.user_id,i.post_id\n HAVING COUNT(*) > 300\n ) as views\n JOIN incoming_links i2 ON i2.id = views.i_id\n", :default_badge_grouping_id=>2, :trigger=>0, :system=>true}
- Badge {:id=>23, :default_name=>"Great Share", :badge_type_id=>1, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT views.user_id, i2.post_id, current_timestamp granted_at\n FROM\n (\n SELECT i.user_id, MIN(i.id) i_id\n FROM incoming_links i\n JOIN badge_posts p on p.id = i.post_id\n WHERE i.user_id IS NOT NULL\n GROUP BY i.user_id,i.post_id\n HAVING COUNT(*) > 1000\n ) as views\n JOIN incoming_links i2 ON i2.id = views.i_id\n", :default_badge_grouping_id=>2, :trigger=>0, :system=>true}
- Badge {:id=>5, :default_name=>"Welcome", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT p.user_id, min(post_id) post_id, min(pa.created_at) granted_at\n FROM post_actions pa\n JOIN badge_posts p on p.id = pa.post_id\n WHERE post_action_type_id = 2 AND\n (:backfill OR pa.post_id IN (:post_ids) )\n GROUP BY p.user_id\n", :default_badge_grouping_id=>2, :trigger=>1, :system=>true}
- Badge {:id=>9, :default_name=>"Autobiographer", :badge_type_id=>3, :multiple_grant=>false, :query=>" SELECT u.id user_id, current_timestamp granted_at\n FROM users u\n JOIN user_profiles up on u.id = up.user_id\n WHERE bio_raw IS NOT NULL AND LENGTH(TRIM(bio_raw)) > 10 AND\n uploaded_avatar_id IS NOT NULL AND\n (:backfill OR u.id IN (:user_ids) )\n", :default_badge_grouping_id=>1, :trigger=>8, :system=>true}
- Badge {:id=>10, :default_name=>"Editor", :badge_type_id=>3, :multiple_grant=>false, :query=>" SELECT p.user_id, min(p.id) post_id, min(p.created_at) granted_at\n FROM badge_posts p\n WHERE p.self_edits > 0 AND\n (:backfill OR p.id IN (:post_ids) )\n GROUP BY p.user_id\n", :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>2, :system=>true}
- Badge {:id=>6, :default_name=>"Nice Post", :badge_type_id=>3, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number > 1 AND p.like_count >= 10 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>7, :default_name=>"Good Post", :badge_type_id=>2, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number > 1 AND p.like_count >= 25 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>8, :default_name=>"Great Post", :badge_type_id=>1, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number > 1 AND p.like_count >= 50 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>18, :default_name=>"Nice Topic", :badge_type_id=>3, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number = 1 AND p.like_count >= 10 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>19, :default_name=>"Good Topic", :badge_type_id=>2, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number = 1 AND p.like_count >= 25 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>20, :default_name=>"Great Topic", :badge_type_id=>1, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>"\n SELECT p.user_id, p.id post_id, p.updated_at granted_at\n FROM badge_posts p\n WHERE p.post_number = 1 AND p.like_count >= 50 AND\n (:backfill OR p.id IN (:post_ids) )\n", :default_badge_grouping_id=>3, :trigger=>1, :system=>true}
- Badge {:id=>24, :default_name=>"Anniversary", :default_icon=>"fa-clock-o", :badge_type_id=>2, :query=>" SELECT u.id AS user_id, MIN(u.created_at + interval '1 year') AS granted_at\n FROM users u\n JOIN posts p ON p.user_id = u.id\n WHERE u.id > 0\n AND u.active\n AND NOT u.blocked\n AND u.created_at + interval '1 year' < now()\n AND p.deleted_at IS NULL\n AND NOT p.hidden\n AND p.created_at + interval '1 year' > now()\n AND (:backfill OR u.id IN (:user_ids))\n GROUP BY u.id\n HAVING COUNT(p.id) > 0\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>28, :default_name=>"Popular Link", :badge_type_id=>3, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT tl.user_id, post_id, current_timestamp granted_at\n FROM topic_links tl\n JOIN posts p ON p.id = post_id AND p.deleted_at IS NULL\n JOIN topics t ON t.id = p.topic_id AND t.deleted_at IS NULL AND t.archetype <> 'private_message'\n WHERE NOT tl.internal\n AND tl.clicks >= 50\n GROUP BY tl.user_id, tl.post_id\n", :badge_grouping_id=>3, :default_badge_grouping_id=>3, :trigger=>0, :system=>true}
- Badge {:id=>29, :default_name=>"Hot Link", :badge_type_id=>2, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT tl.user_id, post_id, current_timestamp granted_at\n FROM topic_links tl\n JOIN posts p ON p.id = post_id AND p.deleted_at IS NULL\n JOIN topics t ON t.id = p.topic_id AND t.deleted_at IS NULL AND t.archetype <> 'private_message'\n WHERE NOT tl.internal\n AND tl.clicks >= 300\n GROUP BY tl.user_id, tl.post_id\n", :badge_grouping_id=>3, :default_badge_grouping_id=>3, :trigger=>0, :system=>true}
- Badge {:id=>30, :default_name=>"Famous Link", :badge_type_id=>1, :multiple_grant=>true, :target_posts=>true, :show_posts=>true, :query=>" SELECT tl.user_id, post_id, current_timestamp granted_at\n FROM topic_links tl\n JOIN posts p ON p.id = post_id AND p.deleted_at IS NULL\n JOIN topics t ON t.id = p.topic_id AND t.deleted_at IS NULL AND t.archetype <> 'private_message'\n WHERE NOT tl.internal\n AND tl.clicks >= 1000\n GROUP BY tl.user_id, tl.post_id\n", :badge_grouping_id=>3, :default_badge_grouping_id=>3, :trigger=>0, :system=>true}
- Badge {:id=>36, :name=>"Appreciated", :default_name=>"Appreciated", :default_icon=>"fa-heart", :badge_type_id=>3, :query=>" SELECT p.user_id, current_timestamp AS granted_at\n FROM posts AS p\n WHERE p.like_count >= 1\n AND (:backfill OR p.user_id IN (:user_ids))\n GROUP BY p.user_id\n HAVING count(*) > 20\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>37, :name=>"Respected", :default_name=>"Respected", :default_icon=>"fa-heart", :badge_type_id=>2, :query=>" SELECT p.user_id, current_timestamp AS granted_at\n FROM posts AS p\n WHERE p.like_count >= 2\n AND (:backfill OR p.user_id IN (:user_ids))\n GROUP BY p.user_id\n HAVING count(*) > 100\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>31, :name=>"Admired", :default_name=>"Admired", :default_icon=>"fa-heart", :badge_type_id=>1, :query=>" SELECT p.user_id, current_timestamp AS granted_at\n FROM posts AS p\n WHERE p.like_count >= 5\n AND (:backfill OR p.user_id IN (:user_ids))\n GROUP BY p.user_id\n HAVING count(*) > 300\n", :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>38, :default_name=>"Thank You", :default_icon=>"fa-heart", :badge_type_id=>3, :query=>" SELECT us.user_id, current_timestamp AS granted_at\n FROM user_stats AS us\n INNER JOIN posts AS p ON p.user_id = us.user_id\n WHERE p.like_count > 0\n AND us.likes_given >= 10\n AND (:backfill OR us.user_id IN (:user_ids))\n GROUP BY us.user_id, us.likes_given\n HAVING COUNT(*) > 20\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>32, :default_name=>"Gives Back", :default_icon=>"fa-heart", :badge_type_id=>2, :query=>" SELECT us.user_id, current_timestamp AS granted_at\n FROM user_stats AS us\n INNER JOIN posts AS p ON p.user_id = us.user_id\n WHERE p.like_count > 0\n AND us.likes_given >= 100\n AND (:backfill OR us.user_id IN (:user_ids))\n GROUP BY us.user_id, us.likes_given\n HAVING COUNT(*) > 100\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>39, :default_name=>"Empathetic", :default_icon=>"fa-heart", :badge_type_id=>1, :query=>" SELECT us.user_id, current_timestamp AS granted_at\n FROM user_stats AS us\n INNER JOIN posts AS p ON p.user_id = us.user_id\n WHERE p.like_count > 0\n AND us.likes_given >= 1000\n AND (:backfill OR us.user_id IN (:user_ids))\n GROUP BY us.user_id, us.likes_given\n HAVING COUNT(*) > 500\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>33, :name=>"Out of Love", :default_name=>"Out of Love", :default_icon=>"fa-heart", :badge_type_id=>3, :query=>" SELECT gdl.user_id, current_timestamp AS granted_at\n FROM given_daily_likes AS gdl\n WHERE gdl.limit_reached\n AND (:backfill OR gdl.user_id IN (:user_ids))\n GROUP BY gdl.user_id\n HAVING COUNT(*) >= 1\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>34, :name=>"Higher Love", :default_name=>"Higher Love", :default_icon=>"fa-heart", :badge_type_id=>2, :query=>" SELECT gdl.user_id, current_timestamp AS granted_at\n FROM given_daily_likes AS gdl\n WHERE gdl.limit_reached\n AND (:backfill OR gdl.user_id IN (:user_ids))\n GROUP BY gdl.user_id\n HAVING COUNT(*) >= 5\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>35, :name=>"Crazy in Love", :default_name=>"Crazy in Love", :default_icon=>"fa-heart", :badge_type_id=>1, :query=>" SELECT gdl.user_id, current_timestamp AS granted_at\n FROM given_daily_likes AS gdl\n WHERE gdl.limit_reached\n AND (:backfill OR gdl.user_id IN (:user_ids))\n GROUP BY gdl.user_id\n HAVING COUNT(*) >= 20\n", :badge_grouping_id=>2, :default_badge_grouping_id=>2, :trigger=>0, :auto_revoke=>false, :system=>true}
- Badge {:id=>40, :default_name=>"First Mention", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>" SELECT acting_user_id AS user_id, min(target_post_id) AS post_id, min(p.created_at) AS granted_at\n FROM user_actions\n JOIN posts p ON p.id = target_post_id\n JOIN topics t ON t.id = topic_id\n JOIN categories c on c.id = category_id\n WHERE action_type = 7\n AND NOT read_restricted\n AND p.deleted_at IS NULL\n AND t.deleted_at IS NULL\n AND t.visible\n AND t.archetype <> 'private_message'\n AND (:backfill OR p.id IN (:post_ids))\n GROUP BY acting_user_id\n", :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>2, :system=>true}
- Badge {:id=>41, :default_name=>"First Emoji", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>nil, :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>0, :system=>true}
- Badge {:id=>42, :default_name=>"First Onebox", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>nil, :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>0, :system=>true}
- Badge {:id=>43, :default_name=>"First Reply By Email", :badge_type_id=>3, :multiple_grant=>false, :target_posts=>true, :show_posts=>true, :query=>nil, :badge_grouping_id=>1, :default_badge_grouping_id=>1, :trigger=>0, :system=>true}
== Seed from /var/www/discourse/db/fixtures/007_web_hook_event_types.rb
- WebHookEventType {:id=>1, :name=>"topic"}
- WebHookEventType {:id=>2, :name=>"post"}
- WebHookEventType {:id=>3, :name=>"user"}
== Seed from /var/www/discourse/db/fixtures/009_users.rb
- User {:id=>-1, :name=>"system", :username=>"system", :username_lower=>"system", :email=>"no_email", :password=>"315980dc7acc49e5609a554ff4b45f00", :active=>true, :admin=>true, :moderator=>true, :approved=>true, :trust_level=>4}
== Seed from /var/www/discourse/db/fixtures/500_lounge_category.rb
== Seed from /var/www/discourse/db/fixtures/501_meta_category.rb
== Seed from /var/www/discourse/db/fixtures/502_staff_category.rb
== Seed from /var/www/discourse/db/fixtures/999_settings.rb
== Seed from /var/www/discourse/db/fixtures/999_topics.rb
Seeding welcome topics
I, [2016-11-06T20:01:37.147081 #13] INFO -- : > cd /var/www/discourse && su discourse -c 'bundle exec rake assets:precompile'
I, [2016-11-06T20:01:43.691283 #2048] INFO -- : Writing /var/www/discourse/public/assets/vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js
I, [2016-11-06T20:01:52.992943 #2048] INFO -- : Writing /var/www/discourse/public/assets/common-9a5018c2bb0083a35824d4ac7359ec7cd01df4bb26fbf91e5b7ab449180f55cd.css
I, [2016-11-06T20:01:52.993666 #2048] INFO -- : Writing /var/www/discourse/public/assets/select2-d6b5d8d83dbc18fb8d77c8761d331cd9e5123c9684950bab0406e98a24ac5ae8.png
I, [2016-11-06T20:01:52.994267 #2048] INFO -- : Writing /var/www/discourse/public/assets/select2-spinner-f6ecff617ec2ba7f559e6f535cad9b70a3f91120737535dab4d4548a6c83576c.gif
I, [2016-11-06T20:01:52.995142 #2048] INFO -- : Writing /var/www/discourse/public/assets/select2x2-6fe28d687dc0ed4d96016238c608ba1e7198c9c9accfa0b360b78018b9fb9bc2.png
I, [2016-11-06T20:01:52.995672 #2048] INFO -- : Writing /var/www/discourse/public/assets/chosen-sprite-4467005376a6b7f2eda6e24d07e382e829045c6c582b8764ff78077484b35350.png
I, [2016-11-06T20:01:52.996500 #2048] INFO -- : Writing /var/www/discourse/public/assets/spinner_96-2aa4bebb9cae6fdb5cd0f962da0d86f9370606fbcb52156b1416fe194c110f8f.gif
I, [2016-11-06T20:01:52.997175 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/stackexchange-9e9f17242c6d44137d40a3e55c71129060b103bfa31b7fead4ca3f18358da29f.png
I, [2016-11-06T20:01:52.998489 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/twitter-4ff0f6e16c5f53ddd3b51eeeff8610ea0432d8ebafce89785d75c231386f80d7.png
I, [2016-11-06T20:01:52.998886 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/wikipedia-8feddaf7544a35c824f2e4274227fe8e7e7af71ddfe26523fe5fe20497cf5799.png
I, [2016-11-06T20:01:52.999632 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/github-399dde69546053c9b4b248be54bf45f0a16bbc690b05380fb0973c0208a9dbdb.png
I, [2016-11-06T20:01:53.000624 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/amazon-882adb9da23d489f1d53ba95c6ea4052536732d9caa57ec82a8f8d0f508e48ea.png
I, [2016-11-06T20:01:53.000958 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_drive_48px-d4aa36b0667a280410a0eb0c8ea02717c72ba76c581a6d68945cb6bf4fbd1b29.png
I, [2016-11-06T20:01:53.001285 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_docs_48px-fb0c868b2a2e570a37726dfa8e91eda673bf34c4bdb4c867e4e4607ce4bfb04b.png
I, [2016-11-06T20:01:53.001958 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_forms_48px-a89b95f68150f83307fd3b31173bdacbdb492320d0a05a99b6ebcf985bdc6a56.png
I, [2016-11-06T20:01:53.002278 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_sheets_48px-052ea7c8810fa9962ca4f9f43cf9d6ddfedbd95e808a7d10a5dc1bcd603db7c1.png
I, [2016-11-06T20:01:53.002597 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_slides_48px-0c1b96992b26f2bf03b3da2a9575936c05e9df3bcbee4971e93fd6a6aa7a61ba.png
I, [2016-11-06T20:01:53.003245 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_branding/logo_calendar_128px-3dee7e14b248a4f6faa2258d01908ee3a0311c24054cb2d4b9666b8e991622cf.png
I, [2016-11-06T20:02:07.414533 #2048] INFO -- : Writing /var/www/discourse/public/assets/desktop-8372497b07dda982e84c7cdbebdd3b79c562b3c3a2cf46cee33fcfbec8dc3dd7.css
I, [2016-11-06T20:02:18.734259 #2048] INFO -- : Writing /var/www/discourse/public/assets/mobile-df0fbe7b97f435d236f4ee650fc448e2b680395e0a475237a367b2ba25e80851.css
I, [2016-11-06T20:02:23.992778 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js
I, [2016-11-06T20:02:24.909308 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin-70237cca0e6b5712f11f8962d654b1470ff3fdbf6a30e18e15a8537991ff2c55.css
I, [2016-11-06T20:02:24.924038 #2048] INFO -- : Writing /var/www/discourse/public/assets/preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js
I, [2016-11-06T20:02:24.944256 #2048] INFO -- : Writing /var/www/discourse/public/assets/browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js
I, [2016-11-06T20:02:25.213433 #2048] INFO -- : Writing /var/www/discourse/public/assets/embed-e1e0e6a3430b6ebd34a6fa687e069c3001f52453ab9a72e7a40ed824f369dc5b.css
I, [2016-11-06T20:02:25.216761 #2048] INFO -- : Writing /var/www/discourse/public/assets/break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js
I, [2016-11-06T20:02:25.707866 #2048] INFO -- : Writing /var/www/discourse/public/assets/ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js
I, [2016-11-06T20:02:26.542093 #2048] INFO -- : Writing /var/www/discourse/public/assets/pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js
I, [2016-11-06T20:02:27.528070 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard-1a1f027c81d5f23dc95bfdf6fdcda4dccf6ec8009503a64b1820c8c7d978c080.css
I, [2016-11-06T20:02:28.556409 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js
I, [2016-11-06T20:02:28.606023 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js
I, [2016-11-06T20:02:28.840562 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js
I, [2016-11-06T20:02:29.105200 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js
I, [2016-11-06T20:02:29.219740 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js
I, [2016-11-06T20:02:29.341492 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js
I, [2016-11-06T20:02:29.463185 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js
I, [2016-11-06T20:02:29.637258 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js
I, [2016-11-06T20:02:29.771524 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js
I, [2016-11-06T20:02:29.928613 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js
I, [2016-11-06T20:02:30.047346 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js
I, [2016-11-06T20:02:30.171583 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js
I, [2016-11-06T20:02:30.313522 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js
I, [2016-11-06T20:02:30.442101 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js
I, [2016-11-06T20:02:30.565335 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js
I, [2016-11-06T20:02:30.712314 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js
I, [2016-11-06T20:02:30.854363 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js
I, [2016-11-06T20:02:30.977494 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js
I, [2016-11-06T20:02:31.118732 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js
I, [2016-11-06T20:02:31.246724 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js
I, [2016-11-06T20:02:31.373986 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js
I, [2016-11-06T20:02:31.499777 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js
I, [2016-11-06T20:02:31.622618 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js
I, [2016-11-06T20:02:31.745095 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js
I, [2016-11-06T20:02:31.887196 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js
I, [2016-11-06T20:02:32.015493 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js
I, [2016-11-06T20:02:32.152737 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js
I, [2016-11-06T20:02:32.273187 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js
I, [2016-11-06T20:02:32.391792 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js
I, [2016-11-06T20:02:32.538721 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js
I, [2016-11-06T20:02:32.671398 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js
I, [2016-11-06T20:02:32.823059 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js
I, [2016-11-06T20:02:32.982068 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js
I, [2016-11-06T20:02:33.158439 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js
I, [2016-11-06T20:02:33.315454 #2048] INFO -- : Writing /var/www/discourse/public/assets/locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js
I, [2016-11-06T20:02:33.326072 #2048] INFO -- : Writing /var/www/discourse/public/assets/docker-manager-app-d73193fccf5ecd9a028a2b452ca1bd2d0dd53a3969b7cbcf1c2db145aeffacdf.js
I, [2016-11-06T20:02:34.136884 #2048] INFO -- : Writing /var/www/discourse/public/assets/docker-manager-app-3222545eb5e1e367a75e7c4f22425ae49781c8f40f99332c7e8e59e10d335347.css
I, [2016-11-06T20:02:34.236709 #2048] INFO -- : Writing /var/www/discourse/public/assets/docker-manager-vendor-5ae6424eab01916a4efff0d807662635eb6e705497ff0a27699552e0ab3a1716.js
I, [2016-11-06T20:02:34.336284 #2048] INFO -- : Writing /var/www/discourse/public/assets/docker-manager-vendor-bd31ba5c62bfa9dd69271dcaa7fdd6bcf52c7aaca661274675163f28eb2b8aa7.css
I, [2016-11-06T20:02:34.340435 #2048] INFO -- : Writing /var/www/discourse/public/assets/images/docker-manager-aff8eaea0445c0488c19f8cfd14faa8c2b278924438f19048eacc175d7d134e4.png
I, [2016-11-06T20:02:34.344554 #2048] INFO -- : Writing /var/www/discourse/public/assets/FontAwesome-7ed24c05432403117372891543f0cb6a7922100919e7ae077c1f3faf67658dc2.otf
I, [2016-11-06T20:02:34.348084 #2048] INFO -- : Writing /var/www/discourse/public/assets/fontawesome-webfont-e219ece8f4d3e4ac455ef31cd3a7c7b5057ea68a109937fc26b03c6e99ee9322.eot
I, [2016-11-06T20:02:34.354215 #2048] INFO -- : Writing /var/www/discourse/public/assets/fontawesome-webfont-d67041fe5d50eef9ef671643968f7ce6b130eaaaaa2ce4d496b18d0a33aeb87b.svg
I, [2016-11-06T20:02:34.358097 #2048] INFO -- : Writing /var/www/discourse/public/assets/fontawesome-webfont-7b5a4320fba0d4c8f79327645b4b9cc875a2ec617a557e849b813918eb733499.ttf
I, [2016-11-06T20:02:34.361999 #2048] INFO -- : Writing /var/www/discourse/public/assets/fontawesome-webfont-c812ddc9e475d3e65d68a6b3b589ce598a2a5babb7afc55477d59215c4a38a40.woff
I, [2016-11-06T20:02:34.365500 #2048] INFO -- : Writing /var/www/discourse/public/assets/fontawesome-webfont-ff82aeed6b9bb6701696c84d1b223d2e682eb78c89117a438ce6cfea8c498995.woff2
I, [2016-11-06T20:02:34.367942 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicon-24b22a63aae0cf353d72b6b728504377bfc42edc6563f202e3a1401763497249.ico
I, [2016-11-06T20:02:34.370263 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/apple-a712ad4bb88fe52b860cd93ffd1bd83576cf7a2184f47774d9b36c5cc0720e5f.png
I, [2016-11-06T20:02:34.372493 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/discourse-45592da881634fc2b96be5457707abb4aa1e2af507ead2ca7431bc3aa7af72b3.png
I, [2016-11-06T20:02:34.382304 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/google_play-006dba29fd6c3a555a8ebef0ad37b3f46c22f33c29c8cd08ef302fa9b1da8735.png
I, [2016-11-06T20:02:34.384615 #2048] INFO -- : Writing /var/www/discourse/public/assets/favicons/rottentomatoes-c3e340d0a6c5dcb0959b4f27fd07b8c44d86d8d442af01e3a7c87c5f3510ae15.png
I, [2016-11-06T20:02:34.387307 #2048] INFO -- : Writing /var/www/discourse/public/assets/logo-dev-c01cbcbdf2b52c6c22d3acfd47b0b5e5e7c363fe4ef53623d49772f2cb835f8f.png
I, [2016-11-06T20:02:34.389440 #2048] INFO -- : Writing /var/www/discourse/public/assets/logo-single-dev-2a362bd89a2a1fd3c291f96795b58f98fd1dce87ae90a9950bed74c1389a06a8.png
I, [2016-11-06T20:02:34.391735 #2048] INFO -- : Writing /var/www/discourse/public/assets/logo-single-d7a0dacc998273856c42737dba8693fbdb9e5fd929d36afeb3f13844f147e865.png
I, [2016-11-06T20:02:34.393865 #2048] INFO -- : Writing /var/www/discourse/public/assets/logo-ba2f2da6eac779d8b34d4aa977be739e4de07f7d34e970f4b8ac32682706c122.png
I, [2016-11-06T20:02:34.401175 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/admin-5dba790a345e4d4c386c661f37844821e7732c438e8e5fbbb5751252ab58933e.hbs
I, [2016-11-06T20:02:34.402984 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/api-keys-050ad66b4c78da23194ebb093d8249f35ba5781e35102ea6e6f669c98e907b61.hbs
I, [2016-11-06T20:02:34.404631 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/api-390a6ca91326056731e7761a9edeb9608dd4ad28927fc6443274120aa4296999.hbs
I, [2016-11-06T20:02:34.406255 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/backups-logs-ff0667efc6b3c5c640f0d555e2afac5089229ffbd18e3c066ee9358db856ccfa.hbs
I, [2016-11-06T20:02:34.407951 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/backups-d2754551d18b1e68eee8924b8384fc8febf15575ae441f0bf591ab7e736f928c.hbs
I, [2016-11-06T20:02:34.409652 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/backups_index-7e410fa4ccef739d88dbdc66397705377cbf9fa6f7eda44dad8a3d5b9df3583e.hbs
I, [2016-11-06T20:02:34.411395 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/badges-index-38e66e4262231ddf48207cea25e755046e135a856f8b1a6faaa04fb4268779d4.hbs
I, [2016-11-06T20:02:34.413311 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/badges-show-7268ab6704dec403d1dcfac6dd503ace0699f45e674bed812b392b494e7b29d3.hbs
I, [2016-11-06T20:02:34.415043 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/badges-acd4c30b4adf0a36bdbe5d514490eb880c643ef4a6608ca98740198d603f7ed0.hbs
I, [2016-11-06T20:02:34.416709 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-form-row-0aa859b347bffd13cff8f184e2e7977445949d403d1f76effadee1ef7169815b.hbs
I, [2016-11-06T20:02:34.418389 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-nav-ae3b76d8368b554d7929ee55642bcbcb84f62d0d46b67d6b30af72185d5b2412.hbs
I, [2016-11-06T20:02:34.420070 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-report-counts-3ec75bc60393df86a59358e34bbb85f6a320428f555ca4725ed097a73be8c4c4.hbs
I, [2016-11-06T20:02:34.421726 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-report-per-day-counts-0696eadd309580e5f0a2a7b88dde7050da3d43533c60b9e371b9028fa82d4436.hbs
I, [2016-11-06T20:02:34.423385 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-report-trust-level-counts-cc469469ad9d47f5cb97c13cbf8f88faeaff1745dd15d86df137e625a803aafc.hbs
I, [2016-11-06T20:02:34.425079 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-user-field-item-e263ea01836537644074b0662ff1eb101a3d5d2df6bdcf5add850f0aa937765c.hbs
I, [2016-11-06T20:02:34.426981 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-web-hook-event-chooser-ff3e131e1f96c9069f1fbb5169ad9b2c0c79ad628827c970a85431e5d472fc6f.hbs
I, [2016-11-06T20:02:34.428448 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/admin-web-hook-event-a9ec3015f33c204acebdcb9df68c537eb3b273a2cf27fb0585b11f604dc8b476.hbs
I, [2016-11-06T20:02:34.430388 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/customize-link-b2faa79503d09bc9e18bc4e1553ddd880189d6d933095679a1b666436b72f484.hbs
I, [2016-11-06T20:02:34.432284 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/embeddable-host-bd77bfe8f621e9942341aba6bab070aa28c9391d1734de484f1d46d88882cee0.hbs
I, [2016-11-06T20:02:34.434129 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/embedding-setting-f8dadbd1b396722c935aec001082f58868a0e70900ddb5b462bd624f0e05c13f.hbs
I, [2016-11-06T20:02:34.435999 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/group-member-8fc85a3430dd54fb0f73ff4a7a774d95fbe0a05ce26756b7ced6211a157549f8.hbs
I, [2016-11-06T20:02:34.437792 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/highlighted-code-4e50944d8d9cf38b0fca7b1be610ca0e288ea80290e0ab8725624d1c74e01e94.hbs
I, [2016-11-06T20:02:34.439686 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/permalink-form-28b724658a105a04a5be1abaf22c47c2bd37a4a32c7d96f227564f7e497c5f9a.hbs
I, [2016-11-06T20:02:34.441445 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/save-controls-68c78292b70fdda13100b18383a7494e74f74d1cb77dac30a756751e705609fa.hbs
I, [2016-11-06T20:02:34.443179 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/screened-ip-address-form-d1ceeabd1957aecf2b38c1bc8d37e05de28a4b0721ac87b5729d4729f92335e8.hbs
I, [2016-11-06T20:02:34.445107 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/setting-validation-message-14ad51ba99e814950468c224a4fa637d09e8a4612f4da182fc2646ffc8ddbd23.hbs
I, [2016-11-06T20:02:34.446989 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-setting-6abd7e8ccf7317431ad51409d29153edf7474972c512a86d790051520fabb270.hbs
I, [2016-11-06T20:02:34.448750 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/bool-abeb562ee766f65ba615996202f7ffe1ce88ac1c1a75d28c2c2605ab4066c55d.hbs
I, [2016-11-06T20:02:34.450622 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/category-list-37f369b782f3e773c7e3b04bd8518ec417318ab74fe66214f355564ed46f1896.hbs
I, [2016-11-06T20:02:34.452461 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/enum-cc71eeb610ed4c33ff190acbe3b4bfbdbb13caa23810f0e69c63e5121d551731.hbs
I, [2016-11-06T20:02:34.454267 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/host-list-d2c0a017879d2336b627b902f516d5f426b60afe22bcd99dc9b4c943478ca28a.hbs
I, [2016-11-06T20:02:34.456137 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/list-5ee18ec03619927c44a094ee39de5c1717cef1f9c078c743327a95815b89acb1.hbs
I, [2016-11-06T20:02:34.458008 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/string-06481daae868d94f6408da77a8abbc47154ad0efda1fb72cd85cea7a0c7133f6.hbs
I, [2016-11-06T20:02:34.460022 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/url-list-f1310d191a75006ead6c5fe0b196b1461a9ba85e6d7f7537543bc750f3acf495.hbs
I, [2016-11-06T20:02:34.479736 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-settings/value-list-25fc2f2ba6830bd549767826487499c3d3120610df610a8090824a834f4a84ed.hbs
I, [2016-11-06T20:02:34.481611 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/site-text-summary-093f43735083c5e282be1ef63ecccf898d534c085c4c35754b5525c4d93e9622.hbs
I, [2016-11-06T20:02:34.483613 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/components/value-list-18851e71a3d6a5454a4a3c656e3cffa445bcbc0b5f0bc0bf4a811fd7abd456c1.hbs
I, [2016-11-06T20:02:34.485333 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-css-html-index-9359b2da639e49da5777dc1b5429746d77d13cadd6118425434ce8da57151355.hbs
I, [2016-11-06T20:02:34.487434 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-css-html-show-2dc64ca266a44effe7e8f9b8ba24f11e50f529588b9f0d56247757c2f6753385.hbs
I, [2016-11-06T20:02:34.489094 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-css-html-ce873824390ebc616093ca962a17e9366219303ad3e602f547769eb7a36118e2.hbs
I, [2016-11-06T20:02:34.490777 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-email-templates-edit-f10414a2db7c7a016ed1e0ace59ccdf228708b1c36de77664a034bd87ad915ac.hbs
I, [2016-11-06T20:02:34.492634 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-email-templates-index-ad2896e7ecd7c72f78553f9ea0fa527ba4e2664e944ed3c05e50476e825b9a27.hbs
I, [2016-11-06T20:02:34.494314 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-email-templates-ad2298386e163c1e07ca910433ba0522730e927bff4734a07a954aec7b8e81fc.hbs
I, [2016-11-06T20:02:34.496123 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize-012cdda28d08141a4264cab84ef391962e541df89c2821af65c25c39f09cf81b.hbs
I, [2016-11-06T20:02:34.498201 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/customize_colors-a7c3d03e7c71215df5feab4d0849938c97ac8c1e3e69cbe6a3ea4fefaee1560e.hbs
I, [2016-11-06T20:02:34.500541 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/dashboard-92398a060e93188e9d2d4f99d69e366e294b885718ccca5e98e63208395efc4e.hbs
I, [2016-11-06T20:02:34.502273 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-bounced-aaca2fdc3324d8a57883dc2867268bfcd01b95ef9f2f8edaabe4403d67d33a6e.hbs
I, [2016-11-06T20:02:34.504175 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-received-d6f62cae94148dc74f4b39c59a318713b240ed4917c80348ecc9d38174fc0209.hbs
I, [2016-11-06T20:02:34.506055 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-rejected-20f54d38ab87b653aa6f549e0b80e6c4754cc0d7e571b72e3013d9fb38bd97c8.hbs
I, [2016-11-06T20:02:34.507894 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-sent-2e9b5b8e0ce12f1d68b328f5afdfb75e832dc8b3acfbd6378512da803cb76c7d.hbs
I, [2016-11-06T20:02:34.509886 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-skipped-caad1800350ad98da9b0d725078947834b4aa5d7bca6b641c5dfe4063f2320cb.hbs
I, [2016-11-06T20:02:34.511720 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email-0e31766328ec8ea3320bfad7b521bf7067dbdc2ebfd3facbfd39ea8d76a9a81f.hbs
I, [2016-11-06T20:02:34.513540 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email_index-11171c764b088d1af93736ec64a06da6183f222b334147b89468c0cdcde7d2e2.hbs
I, [2016-11-06T20:02:34.515417 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/email_preview_digest-f18350ed29d9bd2a1552f87bf85fab427f57349c4af8126771920557386c648f.hbs
I, [2016-11-06T20:02:34.517278 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/embedding-648de4df2a918c81d11815ef8917305f5b1e9e0aa28c96d6640b68d4432567bb.hbs
I, [2016-11-06T20:02:34.519151 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/emojis-313bc14f1a6d5d33fabfe36d83b40463d6e5dadb115bb637fd437d8bd769c71b.hbs
I, [2016-11-06T20:02:34.521543 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/flags-list-01101a530d1e6797b45c85eaac273b7b2bb1930d12afb215ed98b16ef088edff.hbs
I, [2016-11-06T20:02:34.523406 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/flags-caac0ca7e37481bc124b34f27818c66a28263a44d80ba8269199bfe491552016.hbs
I, [2016-11-06T20:02:34.525500 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/group-6ff222c0ce6c4f6bf1ff7f07a8533c0a4dbdd71265fb695a569917a97fd3f94e.hbs
I, [2016-11-06T20:02:34.527402 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/groups-bulk-complete-d755e439607e0f45b50b3530e536ae03110d22ecfec9d310f0d2c007b5daa6a0.hbs
I, [2016-11-06T20:02:34.529228 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/groups-bulk-9925696f7db936418b92f68143157651ef957df8394f646237b6e5a14f5d8581.hbs
I, [2016-11-06T20:02:34.530988 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/groups-9df1bbc031e9d009abc042c9c1e8f7754217e279ff30dece8736ef4063b22265.hbs
I, [2016-11-06T20:02:34.532831 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/groups_type-6837e43b56a27f111bc7d5035b98fa625b89b76ff76470d4dcb5c618c21cf015.hbs
I, [2016-11-06T20:02:34.534629 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/_site_customization_change_details-aadfa0a8bacdbeade9c939c418083dffd020140568d3959afa0c44764c2850aa.hbs
I, [2016-11-06T20:02:34.536408 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/details_modal-8442596bcab3ca5d400a6c64e87bb47279134deb60953e58843cea6fea280386.hbs
I, [2016-11-06T20:02:34.538186 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_emails-299921222aa45c89c8533cb950ff15b1d8fa7581b6c61e40c9baf90660d6e531.hbs
I, [2016-11-06T20:02:34.540132 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_emails_list_item-3f80b4ba816de26d6ced3c036de43eda05fbf3ab2d205363285ab64403ddcafe.hbs
I, [2016-11-06T20:02:34.541952 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_ip_addresses-ad125ba9f7ca7f2bda7af25bec6b9062f33795f2d1e55793b4a8488b6af48343.hbs
I, [2016-11-06T20:02:34.543886 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_ip_addresses_list_item-023aa96d738ec8e3221078c3d75d08972ae6fe2ddf54e5562b9bb934504b8ef8.hbs
I, [2016-11-06T20:02:34.545669 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_urls-8af18790bbcc286d4e557791777c7ca57f88721340b05bd804d66c672d8482cb.hbs
I, [2016-11-06T20:02:34.547431 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/screened_urls_list_item-de6800cf807b9703f99757eb3df4a3547175252b88d0c3ff85eb13ddfcb0f10d.hbs
I, [2016-11-06T20:02:34.549235 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/site_customization_change_modal-99f973bb27c265e8485fb6344eb3b1836f22eba67256d11f12858696eb69bfe1.hbs
I, [2016-11-06T20:02:34.551107 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/staff_action_logs-3fb303423546a43b9b5ce27385a22aeed441760159bc383991331059c1701fe0.hbs
I, [2016-11-06T20:02:34.552888 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs/staff_action_logs_list_item-b2ba8c7ea91f08ce73c929a67d02276dded7243d09323fc9197f5982a69e02fc.hbs
I, [2016-11-06T20:02:34.554812 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/logs-0220ea2bee74f2107d9c9e160253c0b1124ebac7c90077ad8a6aa836beff0e06.hbs
I, [2016-11-06T20:02:34.556502 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_agree_flag-a538e592de7e40a98572718fff85ccf1ccf0a3b207e60ac018d68f99e18eba0b.hbs
I, [2016-11-06T20:02:34.558210 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_badge_preview-ac5f1e1aa59596623cbc96626c629cbd6eb4ea5adea825805dc749c9ee9f5125.hbs
I, [2016-11-06T20:02:34.559960 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_delete_flag-e43c64f869429f00abfc58fe3f015cc91dd4ec5936302d527037ca29ece9486c.hbs
I, [2016-11-06T20:02:34.561631 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_edit_badge_groupings-afa5d6eef443398e3edece702a297897d234507473f7cd26bcb07646235fd70e.hbs
I, [2016-11-06T20:02:34.563322 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_incoming_email-c5ee364650a6b0654121e1d29c9be9b764944673b61a8f10513a3d102a566dde.hbs
I, [2016-11-06T20:02:34.564879 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_start_backup-cc337bbb6d89495aa76fc2f797e652ba420d957e17ce7f2a6af3cd6506d4fe75.hbs
I, [2016-11-06T20:02:34.566507 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/modal/admin_suspend_user-42e31709a68cc9bb49f5b7a4a5d13f4ef7a648f46b9375b8a8b591ffb8ac609a.hbs
I, [2016-11-06T20:02:34.568166 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/permalinks-a19bb74c0ad4ba1fd51aebbf6f72c6b20b1db2f56f6141510531792cd20386eb.hbs
I, [2016-11-06T20:02:34.569743 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/permalinks_list_item-f80977245bb4e8c22ab1ed2ee0e2daf926756eeb69469bbe75208376e5c45ca2.hbs
I, [2016-11-06T20:02:34.571374 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/plugins-index-355ba5678f7aac99b4e7c484d2ddf1774f5b1fa39e3b794dd733c6b730ff659e.hbs
I, [2016-11-06T20:02:34.572932 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/plugins-a01c9b3fa3dba99d3ded216dd50a3f7bf3efca569037ffa10f60153a7add53c0.hbs
I, [2016-11-06T20:02:34.574497 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/reports-6f1ce943f1e8dbd92cfd2a1a355c3fd670a7c5fc192e4956374abf49f03c4c5d.hbs
I, [2016-11-06T20:02:34.576078 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/site-settings-category-9d11656caeb4361606618bd5f0884fb68b7ff8cfbb7d4f4298459f0d06ad6251.hbs
I, [2016-11-06T20:02:34.577707 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/site-settings-623fc1482f74c19ebe5a215da42771a45d824e67db7cfbf0ca5908bc28fcfaad.hbs
I, [2016-11-06T20:02:34.579393 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/site-text-edit-7bbefee562fc44ab2da7b213d2be8653b8a3b1ed95d069d9f325378eb8b11fb2.hbs
I, [2016-11-06T20:02:34.580984 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/site-text-index-c141a5a0ac497b9d971d159b2d97d2b6976eb3afd79cfb9d08eb6652182cb1e3.hbs
I, [2016-11-06T20:02:34.582543 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/site-text-cc2e2295f9d52fe602e955c212e77a505db5f93868a1b7f5c7db4a3a71648982.hbs
I, [2016-11-06T20:02:34.584143 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/user-fields-5da73654b366b4fda51ba507c02748d609216156c337f93458ba68a38b8980ce.hbs
I, [2016-11-06T20:02:34.586568 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/user-index-ab6936b98aff4dda35e5a5d2153e360cbd73f47aba7798d36c2f4fc1d4006f8f.hbs
I, [2016-11-06T20:02:34.588350 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/user-tl3-requirements-466172737c8e2b5b06cd52954799f81317d6dc8c26e1d78e4bf9a1384cfdb0db.hbs
I, [2016-11-06T20:02:34.589943 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/user-21c0112ca234c1a611de6217c184b5e877d59fbb2d7f11e4271d4edd9affaf49.hbs
I, [2016-11-06T20:02:34.591622 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/user_badges-8b6954fdd3ab958a3a23a5ef9f8bb65a1de5c65e03e949646d3348efbf9dba45.hbs
I, [2016-11-06T20:02:34.593253 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/users-list-show-9d0084a8ac0d6c0ee159e6c237dcc252f3e44c3624a70cb7f9ff7a59afd4e2be.hbs
I, [2016-11-06T20:02:34.594875 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/users_list-b6fc7b2373d25bff81b824ec00d6fd376576103bf4fe0d3a891dbd231d1f264e.hbs
I, [2016-11-06T20:02:34.596527 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/version-checks-78234ade36fcd4424b37bbb3b6151ec0cd4aadd3489f4a6af2cb07158e1fe701.hbs
I, [2016-11-06T20:02:34.598139 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/web-hooks-show-events-bbcfc85272ecb61d0ae4959b546a75bd7ba91221990b71140fbd3a1766408bcf.hbs
I, [2016-11-06T20:02:34.599964 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/web-hooks-show-1bd823b3ef8652a24c1b756e97b828b0157345333fc8d06c2442253218541a5b.hbs
I, [2016-11-06T20:02:34.601570 #2048] INFO -- : Writing /var/www/discourse/public/assets/admin/templates/web-hooks-8390818ade63d0eecb73db5c9488ac35d053e699d2b9d9c3ce4930314f1e2680.hbs
I, [2016-11-06T20:02:49.548250 #2048] INFO -- : Writing /var/www/discourse/public/assets/application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js
I, [2016-11-06T20:02:49.555363 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js
I, [2016-11-06T20:02:49.559382 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js
I, [2016-11-06T20:02:49.567588 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js
I, [2016-11-06T20:02:49.572668 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/about-e726fb966b1926c24e8c28e61a09653ff16e2df19048278c642082d2a2d67c52.hbs
I, [2016-11-06T20:02:49.574510 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/additional-composer-buttons-8b86a5e079d03c64b04e86d018b522f393cdd509844fcd465ad1d227d3a1c6e7.hbs
I, [2016-11-06T20:02:49.576217 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/application-443ad2e893ac0f8d601d349e6e1771b7b3ba8eecb5bdb44fe375585ebad48474.hbs
I, [2016-11-06T20:02:49.578031 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/badge-selector-autocomplete.raw-e44f2475bc22e99103b9b1c0c63bf88594f646bf6ecfcc9b2b53c87e28a3ae31.hbs
I, [2016-11-06T20:02:49.579835 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/badges/index-45fea7d8e67563b2bc1611cef6ab07fc015f4714a3e0a46f803a9ceaf1bbcb4e.hbs
I, [2016-11-06T20:02:49.581582 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/badges/show-1f7ff9509136349054b7349718401de49d712c3663eb468017b2707fd221e8f0.hbs
I, [2016-11-06T20:02:49.583466 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/bulk-tag-2da1847c1568db8611fc17509666101ed14c37aca35e8ba823a0d70588a48e28.hbs
I, [2016-11-06T20:02:49.585291 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/category-selector-autocomplete.raw-45ffc50a4f4ea78dfa3344b6c5370fe87a1d1e994d9825b053ef9b8ef32b2485.hbs
I, [2016-11-06T20:02:49.587093 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/category-tag-autocomplete.raw-19e522f55d75bc9bedad8c30372427da61989dd5a3811ce6a6d022b366eb30a2.hbs
I, [2016-11-06T20:02:49.588900 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/admin-group-selector-e9d76b908f2e1d1b7bbcbd5f9df64aa6ea8812bdbb3e5a6ff0c11e5a0632276b.hbs
I, [2016-11-06T20:02:49.590644 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/auto-close-form-44a267a05b6fb916726f4d029e653ea854c7c7fedb46ee72cf8a094a0de1379f.hbs
I, [2016-11-06T20:02:49.592340 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/avatar-uploader-60a596858b52c5d3a039606275b3f3e22b1862e98cb3d6815db2cc24f7645f2d.hbs
I, [2016-11-06T20:02:49.594071 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/badge-button-19999b362f0e0653e0d3cdf4f3d26b69f1b0dd93abcf945ae8f211633b00e141.hbs
I, [2016-11-06T20:02:49.595892 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/badge-card-87109206e43b76535852fd6be4324aeef0c3b6c864a21a7c5fddd1908bf00018.hbs
I, [2016-11-06T20:02:49.597741 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/badge-selector-b9c8b1641ff3b5a499e517a296f53dc7fb508850154c2e21fa9f97d61423f134.hbs
I, [2016-11-06T20:02:49.599572 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/basic-topic-list-ddadcddf27e7bc54531ec91414d8917f7425105949ec8342be9e931e2074190c.hbs
I, [2016-11-06T20:02:49.601284 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/bread-crumbs-91eaf26b0609681b9eeeff6eeb93a8c7d3252b4c166ac49f30480c6d75c8b1ea.hbs
I, [2016-11-06T20:02:49.603124 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/bulk-select-button-9f0a56eeaa0488e50264db0e5a7c4bdb40dbbe2af00697b9d6053f4262c5c98a.hbs
I, [2016-11-06T20:02:49.604859 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/categories-and-latest-topics-10ab66b5b251a2682de68db7761a5409cf2cc8b5dc4698065abef04e9ce1d9aa.hbs
I, [2016-11-06T20:02:49.606660 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/categories-only-1a688c5fb76abc50d492b4bdd1611fd1f922a6f84ee969b43253ea7a6c8f901a.hbs
I, [2016-11-06T20:02:49.608449 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/categories-with-featured-topics-dc5348011ec3eaf909f1dcf705be9391372a329f966cf7c81f90dfc4ac4a52ad.hbs
I, [2016-11-06T20:02:49.610274 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/category-drop-e67c0d9f3210efaea2d040a368cc72a9cb35caa05a17d33bf790767e76879b68.hbs
I, [2016-11-06T20:02:49.612025 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/category-selector-eefa65feb95a893cb7885a9c45c33cbfa1530c6becdde4ead88efc86b82dfb1e.hbs
I, [2016-11-06T20:02:49.613755 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/category-title-link-fe4055bdd3231526e971426071a1367b8ff5e078227b3f02b7b68815b4558d92.hbs
I, [2016-11-06T20:02:49.615575 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/category-unread-26ed0ad7150f69fa063a9c0f21c0d9cb2d3098fa80baab6f3bd3366bdda35d70.hbs
I, [2016-11-06T20:02:49.617415 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/check-mark-199d374b333602f00ce432dbad2ca3141e4cc5a487843708e04e5833dbb1d755.hbs
I, [2016-11-06T20:02:49.619096 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/choose-topic-f96ad09d355c21dd30e16799e6ca4e6e259ca1baa0a7cedf0daa2b7800b26557.hbs
I, [2016-11-06T20:02:49.620913 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/color-input-701d0313d383c1f9357b0e1c5e80ca7b0102182527b0e0a8304665ecb0dfba9e.hbs
I, [2016-11-06T20:02:49.622738 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/color-picker-35d58c947d7911543e68d9113d21fd2b96ff02db539b5675cb33e9a13c1cf498.hbs
I, [2016-11-06T20:02:49.624623 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/composer-editor-4c91271089ad21aaf9a3951186e35530a182facf8a5f72790a55700697415224.hbs
I, [2016-11-06T20:02:49.626378 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/composer-messages-2dfe6fcf2f160cfbc97155be58ed6910490950b957bb8cd92197960895ca408b.hbs
I, [2016-11-06T20:02:49.628233 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/composer-title-278ab3c4b67a6186c17df6c0a21731d1e124399ad4eb806734e2cfe97badbb8b.hbs
I, [2016-11-06T20:02:49.629970 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/composer-user-selector-5d1e15828d16b80beff135b502f819d4390bec2bd7837102a63a910092c58657.hbs
I, [2016-11-06T20:02:49.631778 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/conditional-loading-spinner-6186061936396b3dd60db8d64f8d596a159db89bbf914304e3cccc39c461a7c5.hbs
I, [2016-11-06T20:02:49.633562 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/create-topics-notice-b0c647314c90363e1b566e1c9e73fc4ec00921dd3ecf660da16c72132a37355f.hbs
I, [2016-11-06T20:02:49.635286 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/d-button-9443f51dfed6d9c22468a21006bda2bdf50e120e97b9a25167e24e0e4b723704.hbs
I, [2016-11-06T20:02:49.637168 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/d-checkbox-528481fb82a72f106eac7299c75cac5f83065a681a3f01144f6fe8aa26b88670.hbs
I, [2016-11-06T20:02:49.638943 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/d-editor-modal-091d37c40d5cb44f51e2e74be8dcf75dafc4448dbdb78be3e13c12ba29b2a149.hbs
I, [2016-11-06T20:02:49.640731 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/d-editor-23e825c0d6ed8c23e4fc6375ec52de58689b5efe21b4c6e6787b07b938105dec.hbs
I, [2016-11-06T20:02:49.642427 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/date-picker-e5ae884b78dd563ba7d8621f8a7ebfcd03ef5a9cdb0c26912df7e03ed237faad.hbs
I, [2016-11-06T20:02:49.644189 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/desktop-notification-config-8723cf6f3f68f69c835dc2369f37fb1450863e702e78aa7e551ffd8091d93afa.hbs
I, [2016-11-06T20:02:49.645874 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/directory-item-1be82ca1663edb828044967cfd248893eedd76eae808efea2449d521450d1436.hbs
I, [2016-11-06T20:02:49.647623 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/disabled-icon-d8a422f53d7b0e2709cbaa7f7a6db5b5b4ee48bbe8d0bebe33a27111b04044f9.hbs
I, [2016-11-06T20:02:49.649328 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/discourse-banner-9e122ecf880546242feb11209a8d2bfde72f27ce0354a7331492a7dfb01f07fd.hbs
I, [2016-11-06T20:02:49.651061 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/discourse-tag-bound-bd81cdd633736793dfb6460841365b39612297de29c2e69780c9feeaddcd8521.hbs
I, [2016-11-06T20:02:49.652821 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-general-96150aa319b3a5d2872e9a27709c0dccf7ae978bf8311502b2bcc6ade89c1827.hbs
I, [2016-11-06T20:02:49.654633 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-images-597039f43b74cdc67a1094f543af1a565c7b9e17bb21ee16e6f8b78f34994d84.hbs
I, [2016-11-06T20:02:49.656309 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-panel-b230f90b76097b60d690657fb0f353e6507f97ed8b545941890ddf256ab9271b.hbs
I, [2016-11-06T20:02:49.658137 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-security-0534e3700916bca486b4f54f359636721da3b15cb8ed738887e675bf111888ff.hbs
I, [2016-11-06T20:02:49.659922 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-settings-ac4263d1fe08050694665aefecde79445120365b731e735fc1141904714892d2.hbs
I, [2016-11-06T20:02:49.661733 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-tab-0f11eccd9fe59fe2622ec7f4444071dc9e87e64303211eace486d9c3c7c5b280.hbs
I, [2016-11-06T20:02:49.663506 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-tags-b034f00dcc95ab6c1957c6ed4957637d349a94620d6b8ab71f92273076dc85f5.hbs
I, [2016-11-06T20:02:49.665256 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/edit-category-topic-template-5057a47b269da73eee0e7fb161789af5f9992e01f9cc229f6bf65f3c1bcd53d1.hbs
I, [2016-11-06T20:02:49.667053 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/emoji-uploader-c1b3d47a907dfbe7688f2ba31192247ebc21d1548772c057d5f5e3124e1a57ea.hbs
I, [2016-11-06T20:02:49.668932 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/featured-topic-972df25addbc39b880fa1c9eab8cc3bbb9e9aa4853cb228b0adc2b3a1146ee41.hbs
I, [2016-11-06T20:02:49.670652 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/flag-action-type-a1a3e4051a35dcb03f42038ceb8ed2065dcba4ba3e020c97fb3f68055afa3034.hbs
I, [2016-11-06T20:02:49.672503 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/group-post-stream-8dc6df2e59847e7df5845d8acd43ad1d1b1ff98a83dc90188f3946b06d5d95c8.hbs
I, [2016-11-06T20:02:49.674235 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/group-post-7164aa546d5500d556ce3cf27f548217d06542d5a36c9edb108671f78993ce93.hbs
I, [2016-11-06T20:02:49.675967 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/group-selector-7325193a3610134c1964deaa175cfbdc5b178ed929f72dffadebda1352e16350.hbs
I, [2016-11-06T20:02:49.677680 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/image-uploader-0b9e5faf565cd5bdb55d6a1bd5cede6daa235361ce71b2a0409a25c67f38dbc0.hbs
I, [2016-11-06T20:02:49.679577 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/ip-lookup-5fe2669a3e02f59646dc54f377134823e828f17b1538748321ccff84ee33c4fb.hbs
I, [2016-11-06T20:02:49.681343 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/json-file-uploader-fed0b01c3309ea7987af2f661ab0f9a56c3dc8a88b5bccd8c33d7844334f358b.hbs
I, [2016-11-06T20:02:49.683153 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/latest-topic-list-item-648fea89fb4f941d99027dc29acea7d72fbe92320943db14f8b970b47fd0861d.hbs
I, [2016-11-06T20:02:49.684869 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/list-setting-27c75f704bc11a4b0c8fcfe6a71108d6ceed92aa0bb44523804958a8a47fc656.hbs
I, [2016-11-06T20:02:49.686526 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/login-buttons-ba60f5e25fc4bb415c94832efacd76329818230fe9231b12b33f8d511edcbeff.hbs
I, [2016-11-06T20:02:49.688240 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/mobile-category-topic-4fc9b5c038d683fd387ae37b319e75867c3c608f67641714921eadf1d8913faa.hbs
I, [2016-11-06T20:02:49.689920 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/mobile-nav-3890edaed04b9434b28f5c344b1d4f5ff823e3f4ea8b7d7fd94cfe9e7e4ba230.hbs
I, [2016-11-06T20:02:49.691611 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/nav-item-abc8a3224258042ddea4dcc0c687200953f6da20e4321b19502526c491c32ffc.hbs
I, [2016-11-06T20:02:49.693223 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/navigation-bar-b453b351c01e0e02ee85d73afd0bb48e869f95804ee55fd6f3e8c810526e4111.hbs
I, [2016-11-06T20:02:49.694897 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/period-chooser-48490769bc3a31ae9038c6dbe0b233944ab5de9dd2489406783668a369eafda6.hbs
I, [2016-11-06T20:02:49.696535 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/popup-menu-6933ff242e3a69a90687c37c8753906e327362128761282b5b407e88b6b0dc26.hbs
I, [2016-11-06T20:02:49.698266 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/preference-checkbox-81cd8adc06df5c252f9ed20b9b14a8cc144ab07daea48a31980a235ac3bb49c6.hbs
I, [2016-11-06T20:02:49.700014 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/queued-post-fbc4faf9c658a0c7a67c68fe95f4b7c3d65b268efad64f86243d799fd233ada7.hbs
I, [2016-11-06T20:02:49.701946 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/search-advanced-options-0df5dc2a7b5a65c61d823c653e3fb291b0d251e4e7b900050f3d462566098256.hbs
I, [2016-11-06T20:02:49.703704 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/share-source-47b8f376525a73c1d9545f3e5f9cd83ae49511a2b5c56b38a1a906c8d05d3074.hbs
I, [2016-11-06T20:02:49.705433 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/signup-cta-afa98ee35c239054794196f75b455c55ec930548c73e9d9bc55c1a50923604ba.hbs
I, [2016-11-06T20:02:49.707106 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/small-action-861a9b6273225920d93741d4cc4fdcd920799b9260a8445dd31929586693e739.hbs
I, [2016-11-06T20:02:49.708716 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/stream-item-32fde16036b388c9c273597b47321a6cacecf549214d42ff82ffed5f3c2c7e0e.hbs
I, [2016-11-06T20:02:49.710248 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/tag-drop-link-465b254d57d4d2997cd44779449423f9f2bd2380c5f27044cfbaac3fe3ca6712.hbs
I, [2016-11-06T20:02:49.711910 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/tag-drop-bede65efb05cbbb64e1cc4375209fc18dfa554e03524e5023ab6ab4d2e622f41.hbs
I, [2016-11-06T20:02:49.713549 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/tag-list-f942fc10e1d1c5a67aa6cba35c8121870a88c424b96b9d73efb0b71eb4ad8af0.hbs
I, [2016-11-06T20:02:49.715223 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/text-overflow-ccb04ad5e80b5ae1042ae36ee95096bfaa5862665785c41f8ebcd72111322351.hbs
I, [2016-11-06T20:02:49.716857 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/top-period-buttons-73877e9ec3c668fedc133fc62484d0734e9b46476c3c4279dd25afb3d1018db6.hbs
I, [2016-11-06T20:02:49.718517 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/topic-category-91ca1adf2b3ca81bb7312af8033074d1360d52a859645b97c2ae4d0e2e27c1cc.hbs
I, [2016-11-06T20:02:49.720257 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/topic-footer-buttons-cac713f5380dacc2bf568567c95f3d3911192fcf82d0fbb9247d272e9c3c5983.hbs
I, [2016-11-06T20:02:49.721940 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/topic-list-4eef511815460c361abb1de4ce3b68493401f3acb95aeaaa0b3d9d1d8f934f52.hbs
I, [2016-11-06T20:02:49.723502 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/topic-navigation-c46d53057d04034e83fa45544a6f72e88f02336b27ceb97a5878aca086e7f261.hbs
I, [2016-11-06T20:02:49.725103 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/topic-progress-f68f44488ebae1d7448c2d68354d94471751778727eadff8acf7c4aac2c1c851.hbs
I, [2016-11-06T20:02:49.726684 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/track-selected-37a212bb745f7c3cbaae972e0cb4b810068f6ad246345653aabd00694f2d0fed.hbs
I, [2016-11-06T20:02:49.728277 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-badge-5e4bae96abbe974560ad41b8e112f8e5cd96512c9f7cbd5ed143b2c7fbbf8cf4.hbs
I, [2016-11-06T20:02:49.729845 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-fields/confirm-018c27776aca8d7ac181c39f7f90b1a9c3cd51cce930b51e5b8beebeec725c49.hbs
I, [2016-11-06T20:02:49.731431 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-fields/dropdown-71da3856cc29912c0ae64dc489a8650fed34121075e4b1262f78453a9248aa3f.hbs
I, [2016-11-06T20:02:49.733073 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-fields/text-95c7097f9d85c714d801d0318c0739e05b4f239e66006d0a7db9d9326bf81914.hbs
I, [2016-11-06T20:02:49.734699 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-info-b18d2f898bbcdcbecb9c3b6f6017c6eb585456a82c6c6479b2668b6fc6006b5f.hbs
I, [2016-11-06T20:02:49.736348 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/components/user-stat-e6688dee0a1628b1f0ebe18f63b35ebd9cb18141933737eaa7c157a26b5db0a9.hbs
I, [2016-11-06T20:02:49.738029 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/composer/custom-body-daa041da604db849f86e1bc81ab57d5678a58e5ed0f18ffdf2c23ac39c336218.hbs
I, [2016-11-06T20:02:49.739647 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/composer/education-7eb148de47d58707b5413f450417279521dd184c0e12ac14bb78861b01c4aec4.hbs
I, [2016-11-06T20:02:49.741170 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/composer/group-mentioned-d9c1740c9f0521e1669893254a91abf2bb6cba371fd1b6f1038f16454c8aefb1.hbs
I, [2016-11-06T20:02:49.742735 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/composer/similar-topics-f024b0e0928b76bfdaca080d80d8a7c1e573d9abe5265480efc411185a9f2695.hbs
I, [2016-11-06T20:02:49.744610 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/composer-a57e332eb4d3d49479264ce903421a69d571d42e481e7508bc814185d616412f.hbs
I, [2016-11-06T20:02:49.746258 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/discovery/categories-e5f5a800f319069dbd498ccba0ffd00762e7d361fdefb31718799e16a23d8ee1.hbs
I, [2016-11-06T20:02:49.748026 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/discovery/topics-3f0a898b5fc274b60a4384bec3358422999868c19b674b498ce8011bceda3ffc.hbs
I, [2016-11-06T20:02:49.749640 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/discovery-2c362c01d68f238f799704622c603266d8c3e50599abf66688e66aedae28821b.hbs
I, [2016-11-06T20:02:49.751269 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/emoji-selector-autocomplete.raw-e559ddb976cc6e214ec548ef045bf1b141be64d862981d0bedeb5c23a02c660a.hbs
I, [2016-11-06T20:02:49.752974 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/emoji-toolbar.raw-e203c54ef1e53a53ed27273a6d166ec771fa7f646a8a14fd90951fce1bb9851c.hbs
I, [2016-11-06T20:02:49.754577 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/exception-4596df130ce065a987da9bb5eec33eb69f0d2c431bbb9dbf7cc0f01a18245728.hbs
I, [2016-11-06T20:02:49.756329 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/full-page-search-6934f8ec9838d0956bd70960d045657aeb306ef1c7e3b42b51bc90020dfc816f.hbs
I, [2016-11-06T20:02:49.757874 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/group-index-66824fae1598a729263f0a7190dc32c3dea3a354930e6507cece48bbeb9cee65.hbs
I, [2016-11-06T20:02:49.759454 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/group-posts-8c677513082d3544672be2aa5c79bbe989c04431222579d4b580fe3f56bafccd.hbs
I, [2016-11-06T20:02:49.761096 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/group-selector-autocomplete.raw-e44f2475bc22e99103b9b1c0c63bf88594f646bf6ecfcc9b2b53c87e28a3ae31.hbs
I, [2016-11-06T20:02:49.762644 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/group-a76acf3248b9a95b7c04d24c66fb551ae7acf6756f2b18dc665f26f486baf0b3.hbs
I, [2016-11-06T20:02:49.764254 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/action-list.raw-cfbf4bb5ee43c052f5d3a8a9e36966244614dd93acec16428ccef47c014cfdc7.hbs
I, [2016-11-06T20:02:49.765802 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/activity-column.raw-fab89d8f52df537daef02ab659d7a4fcb2e710d38c0a9764aa75595df10a1234.hbs
I, [2016-11-06T20:02:49.767374 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/category-column.raw-f7d0e17bf1067adb8beb64fe6fa27c37f0978029b358d6577002ce37d31972b8.hbs
I, [2016-11-06T20:02:49.768906 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/post-count-or-badges.raw-f03d8a6e1968633214a235c9e79a141724ce23e17434ed7464274a9d7fb1f4ed.hbs
I, [2016-11-06T20:02:49.770460 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/posters-column.raw-72d1725fd731d4dda6db7ffa0f17c92d2b87d0387956d1b2517c90c484b00ae7.hbs
I, [2016-11-06T20:02:49.772122 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/posts-count-column.raw-14c55aca6822f92daed140e420485b9c4a3ca7c903be83c2e4644071ed8eb093.hbs
I, [2016-11-06T20:02:49.773676 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/topic-excerpt.raw-f088e6a713118285fbb0ceb5d8553884f2591ae445184997a9c255526576bab1.hbs
I, [2016-11-06T20:02:49.775286 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/topic-list-item.raw-bbdf5852780b72f96e214a56e4e143f6d6653b6e049e77df46af00128be10fd6.hbs
I, [2016-11-06T20:02:49.776923 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/list/visited-line.raw-ccb0658188bbb5e67a7af8b554104d6c337004efa400740cdcccf366a3eabc11.hbs
I, [2016-11-06T20:02:49.778521 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/login-preferences-c25369862d6058f979de314e5f5f26a27242941844ae826797574525331de0e2.hbs
I, [2016-11-06T20:02:49.780196 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/components/basic-topic-list-c4fec81cff18278abf224aa3e528378f1481f04049fe501a6c233aca99da6663.hbs
I, [2016-11-06T20:02:49.781965 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/components/directory-item-2a3a4051b646c63a77a3d2daf27e252b046e63f0954c447026e1edb74e673e77.hbs
I, [2016-11-06T20:02:49.783574 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/components/mobile-nav-8e7a2b8afac6ed9e319a1d57b1ce23729cb3753d95e514430a4ef9229bf0bec9.hbs
I, [2016-11-06T20:02:49.785144 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/components/navigation-bar-90865fb61830acf39d4e65e16d4482cacaa542f02fd9b8751d04a58a827ebea9.hbs
I, [2016-11-06T20:02:49.786710 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/discovery/categories-f9c1e36dc73d0951c96a0d0e7b234c561523671cccd45eee07f7d05c63ccec11.hbs
I, [2016-11-06T20:02:49.788434 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/discovery/topics-cdc773ec269b288ed93c26bcb0f59fb397852b8c7bd62e60edc673a5e5bbd995.hbs
I, [2016-11-06T20:02:49.790083 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/list/topic_list_item.raw-368395a8e130d39356020bfbb1e74d9159a40894177ad0f5c1cd112132954f69.hbs
I, [2016-11-06T20:02:49.791719 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/modal/login-4e81c88cb78249faf9022faa849efe4050d64bf1cfa5cb4219557933d12a8329.hbs
I, [2016-11-06T20:02:49.793374 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/mobile/users-a6b961df5d65725d5bfd9d85fc7385732b4dd2765015a38ab1a1c50c1f48e029.hbs
I, [2016-11-06T20:02:49.795094 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/avatar_selector-8a951b535fa0110c0cf11112427630253e8aef64fc99f3b1ae605cbbe482fa80.hbs
I, [2016-11-06T20:02:49.796693 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/bulk_actions_buttons-242a13dea5c15cdb14bfcd40d3c074d64a1e359421713d3bd8b543a6fb458b4d.hbs
I, [2016-11-06T20:02:49.798374 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/bulk_change_category-e06f2327941b793cc6544a06a1b678066d2b227dd0c0f3b6679b017276fcca42.hbs
I, [2016-11-06T20:02:49.800006 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/bulk_notification_level-e9c642b41c685bb83d55d28e815fec42b8812560333eb0ad6ee044d47b7419e8.hbs
I, [2016-11-06T20:02:49.801596 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/change-owner-4148ba0161babc7e6a1dbc75961d969fd1d626aeafd2fcb30ccafcd4449ae570.hbs
I, [2016-11-06T20:02:49.803212 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/change-timestamp-d0fdf0b8c0a65c60296147813f2218dbe8f5de423730c6e142c883fbb5b68422.hbs
I, [2016-11-06T20:02:49.804956 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/create-account-fc819d4e2a742e451598df67605f89e4b2e577b2f0deabd49028fdaf53faba5a.hbs
I, [2016-11-06T20:02:49.806543 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/dismiss-read-401f65c1144643246c241d9d04bb17dca9f9c28e900dcef1f6daa5c87b452e5c.hbs
I, [2016-11-06T20:02:49.808226 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/edit-category-61acaf778d1254578ff1c6dda5deb0fbb46b2aef6fc2a54683bf5d08e9819017.hbs
I, [2016-11-06T20:02:49.809815 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/edit-topic-auto-close-5c693731f02ab2490c1e3209cb9c5fce299bf8218a3c82307d98b724f185c440.hbs
I, [2016-11-06T20:02:49.811724 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/feature-topic-0616805bd255ed10cbdfe1258a9f3426b4424c0bbdf8f0971132773bea57060a.hbs
I, [2016-11-06T20:02:49.813403 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/flag-774abacedebaf341f318c0fdf66dc08eb1a1257828366e02776dcc6e6b84127a.hbs
I, [2016-11-06T20:02:49.815085 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/forgot-password-35041989544e3526eeae11cea153e7dafa7ea27d0e1eda46b4d865c58b1b560b.hbs
I, [2016-11-06T20:02:49.816813 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/history-ce0844d731e3da0e055a1f7b4cac4ff27b87a6c4665a311545c07a64f01361d1.hbs
I, [2016-11-06T20:02:49.818372 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/invite-d99117f1f1c67298bbb474d0eda0f8077eef8749c7e6c385367bb24051ac1315.hbs
I, [2016-11-06T20:02:49.820075 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/keyboard-shortcuts-help-2f3108e4a40980db27ef54fd573df6a0967cc87021f7903b8004a61c96bc92bd.hbs
I, [2016-11-06T20:02:49.821673 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/login-c376de1f7587475271de71156367149b0549fa799cb1621d0a5a738c7c25ce23.hbs
I, [2016-11-06T20:02:49.823311 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/merge-topic-2da1629c5b97165066c3db66b0adf1403956af20ab9279872207a3d24873e1b9.hbs
I, [2016-11-06T20:02:49.824935 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/modal-47b20ee0443d4c16a0da3f2687b0172ba0cf039f0446b047b7acca67ea94b506.hbs
I, [2016-11-06T20:02:49.826499 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/not-activated-e48628189f2daadf0a9e6a6af99d6a5a382ab5011f8d0612b6c24723d1e5cf1f.hbs
I, [2016-11-06T20:02:49.828104 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/option_boolean-34df02d56b8b53fee30be155a1eef480d9cfec9c4a48db64d2a916e45eefb25b.hbs
I, [2016-11-06T20:02:49.829647 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/post-enqueued-6dd5e4b8a142478df0e714458bad286a277bdac10a8a896ed014de1024cdf6b1.hbs
I, [2016-11-06T20:02:49.831214 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/raw_email-c424c679ee784e6814b20cb5f68b8455300a3cf43f68d36d93095807319ad955.hbs
I, [2016-11-06T20:02:49.832763 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/reorder-categories-063dd3831545d932aaf9f4e4f20cda2ff819d21bd84617c7b279e74236615203.hbs
I, [2016-11-06T20:02:49.834279 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/search_help-20e06d6bc36cc6f375387e8fedc7ee474d20b43be432feb42ea027732ee3da37.hbs
I, [2016-11-06T20:02:49.835902 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/split-topic-eb5c63eac19e4c3ddc9a668ead14bd13b9c694d710edcc8a4d7de56fad5d784a.hbs
I, [2016-11-06T20:02:49.837471 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/topic-bulk-actions-16f2e1c1d0ba12ca0d48c69c0503e35cc3460c2ce1bd0746617d636b03deb921.hbs
I, [2016-11-06T20:02:49.839087 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/upload-customization-80528597a5cca912123cdc0bef72d66fee94f32f528463c75ccc5e77bc1af75b.hbs
I, [2016-11-06T20:02:49.840663 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/modal/upload-selector-8f40b1181b01b1ab00b50a3085a032970e43da1b0233f1c7134e721a872aa6c6.hbs
I, [2016-11-06T20:02:49.842259 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/navigation/categories-8cc738d04a374999b9a383d973bcc54b9efd8ae1c341ad6532b9b11965073d2e.hbs
I, [2016-11-06T20:02:49.843875 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/navigation/category-97be39d3e40f9828848b9796edb66e24be2c38eccfa496638f1f5aeee4d875c8.hbs
I, [2016-11-06T20:02:49.845412 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/navigation/default-4a8cc8b300190e51ca8dfd8905b64b432e142f4ff5237a3eb83be80dfaf1b48a.hbs
I, [2016-11-06T20:02:49.847015 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/post/poster-avatar.raw-51555ddef389250ed8cc1c76050139129f1591ad8200130953aacecb03ad757d.hbs
I, [2016-11-06T20:02:49.848583 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/preferences/card-badge-681c2feeb6e6e7e53656f9cb92962eadac5ad439a6c6d413e6a57100ef19bc05.hbs
I, [2016-11-06T20:02:49.850170 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/queued-posts-f2257ae52b6939144382c84b2b19e7e3f25c40dc2586bb28eeffe71020e3df33.hbs
I, [2016-11-06T20:02:49.851768 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/quote-button-d9baa7943085688ae9d9acdbce3188d12ad3d53b091da6bc4c7331ef26e83900.hbs
I, [2016-11-06T20:02:49.853347 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/rename-tag-6e6ef46da0f4fda98cd2bc64273debe6378813ca46cc7fe198183ccfb038e54c.hbs
I, [2016-11-06T20:02:49.854979 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/selected-posts-af61e5cdb1a6268e6d64cb2aaba12c47a6818f5cb9990a7adaa3a34782d683de.hbs
I, [2016-11-06T20:02:49.856535 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/share-dc8c676d2fd3fa4fee642f014499153d397b9d79e2422f7d57e53b44a807ac50.hbs
I, [2016-11-06T20:02:49.858069 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/static-f986f5e761df00a7337ea316653f4d6b55926fb9d0aec8f96b916f1312b3f74b.hbs
I, [2016-11-06T20:02:49.859652 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/tag-groups-index-96740fe3575e952e00397252c997b93a2d56a48aa01ec685a61ec3bf21cd06d5.hbs
I, [2016-11-06T20:02:49.861227 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/tag-groups-show-5ac9c9868bb275383a46b170b500fb994ca368452bd31d28e45658378e5e72d2.hbs
I, [2016-11-06T20:02:49.862768 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/tag-groups-b79a437cdb1543b464e7fb8347657b77490021338ee1e5db4ce86b52552f4849.hbs
I, [2016-11-06T20:02:49.864439 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/tags/index-fca2a8c78644d9cf5c575ef5b1ecea5e859766edef41b17f0df23bccb6ac83ea.hbs
I, [2016-11-06T20:02:49.866088 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/tags/show-11e33ade55aa1b7a0a6aacdc611a85a7fcf428a7dc2eb407f64bbd9f78c72bed.hbs
I, [2016-11-06T20:02:49.867682 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic/unsubscribe-c08a0a500c350793c760bea97df9cbcced5a9fcf19a6ad228b2a315a0e04dbd8.hbs
I, [2016-11-06T20:02:49.869282 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-entrance-e1b2f245cd2952ff0da5c6a8df850e7442c1a8f9eaf578906d5d9d9123cf62eb.hbs
I, [2016-11-06T20:02:49.870848 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-list-header-column.raw-2e044ba5410e330021386c8aed77a9af200dd51a76932dc42dfffa9ae7efb8e4.hbs
I, [2016-11-06T20:02:49.872492 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-list-header.raw-b9eff5b34b71d96fd689eed5549fd89fc42fefccf63ac08aabafc5479f45a74b.hbs
I, [2016-11-06T20:02:49.874050 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-post-badges.raw-c4985a790db7391b577e82d1a36fce35500a0707d9015e55894718634c92b67e.hbs
I, [2016-11-06T20:02:49.875605 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-status.raw-b772fd9909942a81b2a70b7cd2669f0081a6520e0fff8d9b2a36f3f35647073f.hbs
I, [2016-11-06T20:02:49.877636 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/topic-bc4d2676ea0f7c9c7a2aefe966666619db26485abe5f2ec3102a54045211727e.hbs
I, [2016-11-06T20:02:49.879285 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/about-facf22d7a218ee9be6771f041be3bd9a2cc1f86bf42433f038df32d682c33f92.hbs
I, [2016-11-06T20:02:49.880845 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/activity-632ba5f4ee19749b51454002b3b200f3167d0d8df2a8c5b864eaa7c16b358aed.hbs
I, [2016-11-06T20:02:49.882361 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/badge-title-96bc35d502df3683fefa7205269cce31ca64a6bae6c9ec56f6ce052b9c5e33b8.hbs
I, [2016-11-06T20:02:49.883905 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/badges-ca2a3062e06f537415e76e6da55cdc50569045d2d48c6c62c726ce9666a93add.hbs
I, [2016-11-06T20:02:49.885459 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/email-2b1c768447bfd25bc029e0aabe9d28df2152587cd2a6aa61f5436924bf9cae03.hbs
I, [2016-11-06T20:02:49.887067 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/messages-a1cd21ba3987321a7ca7e68e21b5988d8e55b5051ed2b2dea5c822c46db232f5.hbs
I, [2016-11-06T20:02:49.888649 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/notifications-index-5389768a3f0cb7f8369bdd248a0f323f4f6d2125811fce61fc963ca2b1067818.hbs
I, [2016-11-06T20:02:49.890231 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/notifications-50a8a13c4b52ed3ef206425509d01a49d8bd94432d67b3c1da6c22a7c74e2cbb.hbs
I, [2016-11-06T20:02:49.891833 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/posts-7237eaf7b4f228c31daf221215bd2847c14cf321efe56775f2907336ba24a969.hbs
I, [2016-11-06T20:02:49.893391 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/preferences/_save-button-b12aa995fad7277c416518897aa986e2242acc8cd8f82ecea1a822a56ed87d3e.hbs
I, [2016-11-06T20:02:49.895703 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/preferences-d13f1ed396f83b16a003f427ac9cca2a58d33fb728f60272bb989cbd7179690d.hbs
I, [2016-11-06T20:02:49.897247 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/stream-ac97eb1a8523f0494c3b8b4bacedd062587766a37e1330d57026222703de6ade.hbs
I, [2016-11-06T20:02:49.899093 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/summary-fc367430bc733dfa8aa372106d7ceb373f4890103120481e666406566038c3d2.hbs
I, [2016-11-06T20:02:49.900699 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user/username-9c404137a30e53de236532d7bea9d40aef1d8c91edd273c07a4a278e38c4e0e8.hbs
I, [2016-11-06T20:02:49.902485 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user-card-fe029ec5a34f3a4d38863823bab3ddbcf3d4d2b5f71666a6fd44b07d7b6ab035.hbs
I, [2016-11-06T20:02:49.904354 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user-invited-show-4c6a03f239f8d2db18093e41f85cfb295020f38d50b171bd5ffcaa9cb06f4b02.hbs
I, [2016-11-06T20:02:49.905958 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user-selector-autocomplete.raw-82f1bd8f2c75bbcc040a94e6a3f1b3e1f1c630cf77f3e8dc34b9e53f0f4ac291.hbs
I, [2016-11-06T20:02:49.907552 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user-topics-list-d9d2d9e99c52e651e9a7b02659e8d770a75b99ea0b7d67a98451194eca942854.hbs
I, [2016-11-06T20:02:49.909483 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/user-68741c3a64e9c1dae631303b44ebdbe8d1806420ed4e4111a55b911d4e40a284.hbs
I, [2016-11-06T20:02:49.911148 #2048] INFO -- : Writing /var/www/discourse/public/assets/discourse/templates/users-58d3371272fe79f1965ac1d8366418e6e0a94705068ffb76f71e33953b710f3b.hbs
I, [2016-11-06T20:02:49.916055 #2048] INFO -- : Writing /var/www/discourse/public/assets/docs/yuidoc-15ccfbcbae101060b3998aa1cb2a9d148b96f81255484f265a5a883d05002f00.json
I, [2016-11-06T20:02:49.920625 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js
I, [2016-11-06T20:02:49.922770 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js
I, [2016-11-06T20:02:49.924505 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/application-a31c651a57592bbe6dd050b75829e733b30a0b1cf06025ed43eee9e0cab2e865.hbs
I, [2016-11-06T20:02:49.926169 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/invite-list-user-e7f0724d1a57ba8a31625b459bef766a8de85fae4dbb9eec158229afbe4b8ca0.hbs
I, [2016-11-06T20:02:49.927847 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/invite-list-4ae98c2ac84faa9eb710f3a32ca8ad29dd83059923939dd9bc7a487b1804260c.hbs
I, [2016-11-06T20:02:49.929474 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/radio-button-27e9bc8238f243d9cc15becd420a59ccdedb097cb27e9f57c33a74ec16130003.hbs
I, [2016-11-06T20:02:49.931064 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/staff-count-a3448a38465da964ee0a4950a1ebd8b33070830158bba3abd3e9736c061df264.hbs
I, [2016-11-06T20:02:49.932665 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/theme-preview-1615efe1d52313ac0ab75248e97b32c23253696ab81825e04e57abdd3bdf1bfa.hbs
I, [2016-11-06T20:02:49.934217 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-dropdown-147d45bc88e555b715e28cc1eef973128eeb1d7032221bff7f3aca7a4bc0cc8f.hbs
I, [2016-11-06T20:02:49.935882 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-image-5d4b908404de2748dc336556c1968e609422fb1203288c74b2e361b853127cf4.hbs
I, [2016-11-06T20:02:49.937424 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-radio-8b21a7cdfe4cd6bbd3b63e53a0d03be6250d6404b558eae0d0073dbcdf35ac9b.hbs
I, [2016-11-06T20:02:49.939044 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-text-fdabe4df3e2385d0ccd3412392ff7087c4da5f56bbf3e825613933bcade6821e.hbs
I, [2016-11-06T20:02:49.940589 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-textarea-4367fa6c42c3bd5aa8bccf5873210f51e78d5efcddc7dfd00c9386d86b7deb67.hbs
I, [2016-11-06T20:02:49.942132 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-field-45cae6737acf6ce28cf30d645a4e7c33929acf6dbbb10743e3734402209cf03b.hbs
I, [2016-11-06T20:02:49.943708 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-image-preview-59aa6ed85be8ba7792fcf9c0256444dcf746c8b9d5e9949f04eed9a2f16923cc.hbs
I, [2016-11-06T20:02:49.945354 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/components/wizard-step-eb154bcd585b052d4710499ed9ad358dd5e6354c43d8f7f3f162022d21a48e04.hbs
I, [2016-11-06T20:02:49.946969 #2048] INFO -- : Writing /var/www/discourse/public/assets/wizard/templates/step-afb66ca72062340063f603d2091bf1a5171f13167bdd8fcda8b22e69a0e9ceac.hbs
Start compiling CSS: 2016-11-06 20:02:49 UTC
Compiling css for default
target: desktop desktop_fe91330518dcdd5c1f15af4cb136bc60ff7493dd.css
target: mobile mobile_fe91330518dcdd5c1f15af4cb136bc60ff7493dd.css
target: desktop_rtl desktop_rtl_fe91330518dcdd5c1f15af4cb136bc60ff7493dd.css
target: mobile_rtl mobile_rtl_fe91330518dcdd5c1f15af4cb136bc60ff7493dd.css
Done compiling CSS: 2016-11-06 20:03:02 UTC
Compressing: vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js
uglifyjs '/var/www/discourse/public/assets/_vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js' -p relative -c -m -o '/var/www/discourse/public/assets/vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js.map' --source-map-url '/assets/vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js.map'
gzip /var/www/discourse/public/assets/vendor-52ed1f7ea87a692ca7ec8f3b75bb76997f730cae151edfe8f467849ef9ddde78.js
Compressing: admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js
uglifyjs '/var/www/discourse/public/assets/_admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js' -p relative -c -m -o '/var/www/discourse/public/assets/admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js.map' --source-map-url '/assets/admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js.map'
gzip /var/www/discourse/public/assets/admin-7afd26dc1ac22baa2580b2c70e1d5785fa17aba06457e96af080df9fb3926f6e.js
Compressing: preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js
uglifyjs '/var/www/discourse/public/assets/_preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js' -p relative -c -m -o '/var/www/discourse/public/assets/preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js.map' --source-map-url '/assets/preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js.map'
gzip /var/www/discourse/public/assets/preload-store-9a5d6688476c54b0eb6e11cf444ab9dc19602f99f10114228f41fe605c31ac4d.js
Compressing: browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js
uglifyjs '/var/www/discourse/public/assets/_browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js' -p relative -c -m -o '/var/www/discourse/public/assets/browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js.map' --source-map-url '/assets/browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js.map'
gzip /var/www/discourse/public/assets/browser-update-f57286e74ddbc53aa899689b01ef467078911e4138050c561939955849af35dd.js
Compressing: break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js
uglifyjs '/var/www/discourse/public/assets/_break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js' -p relative -c -m -o '/var/www/discourse/public/assets/break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js.map' --source-map-url '/assets/break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js.map'
gzip /var/www/discourse/public/assets/break_string-cc617154cd957804f2f6a1f3bc68258c9cdca3d4b9a322bf777d145fed04790e.js
Compressing: ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js
uglifyjs '/var/www/discourse/public/assets/_ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js' -p relative -c -m -o '/var/www/discourse/public/assets/ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js.map' --source-map-url '/assets/ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js.map'
gzip /var/www/discourse/public/assets/ember_jquery-5bc98ec46a799a78ead48d23df534d67c737906cdc100d826b0a001a8a1c1b8b.js
Compressing: pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js
uglifyjs '/var/www/discourse/public/assets/_pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js' -p relative -c -m -o '/var/www/discourse/public/assets/pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js.map' --source-map-url '/assets/pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js.map'
gzip /var/www/discourse/public/assets/pretty-text-bundle-82f102e81c27277a66fe2360dbd63d6dbb98eb3b0b83116d48b6c6c01dd36eb3.js
Compressing: wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js
uglifyjs '/var/www/discourse/public/assets/_wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js' -p relative -c -m -o '/var/www/discourse/public/assets/wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js.map' --source-map-url '/assets/wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js.map'
gzip /var/www/discourse/public/assets/wizard-application-bc01989b01a00a393c72ffacff9f113faa6371083e1f929184c64f1a6e3dda4a.js
Compressing: wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js
uglifyjs '/var/www/discourse/public/assets/_wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js' -p relative -c -m -o '/var/www/discourse/public/assets/wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js.map' --source-map-url '/assets/wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js.map'
gzip /var/www/discourse/public/assets/wizard-vendor-c7b999087a3c233eb2346562db6ec6a472a50c50cf676a2ea23304c4091d7716.js
Compressing: locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js
uglifyjs '/var/www/discourse/public/assets/locales/_vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js.map' --source-map-url '/assets/locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js.map'
gzip /var/www/discourse/public/assets/locales/vi-7428dd9a279346d08b79f1dcb702a5d230872c3a6f83ae6f1a23ee038450f765.js
Compressing: locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js
uglifyjs '/var/www/discourse/public/assets/locales/_fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js.map' --source-map-url '/assets/locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js.map'
gzip /var/www/discourse/public/assets/locales/fi-a3fc0bdc15bcf2d33fbcd811a1e4ff2527d787d6f84e2b23303a26835650ff4f.js
Compressing: locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js
uglifyjs '/var/www/discourse/public/assets/locales/_id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js.map' --source-map-url '/assets/locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js.map'
gzip /var/www/discourse/public/assets/locales/id-a3e613c8661368a2cd5d2c1ba35a5e43e8edda6a994165f4565b74f605d67581.js
Compressing: locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js
uglifyjs '/var/www/discourse/public/assets/locales/_ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js.map' --source-map-url '/assets/locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js.map'
gzip /var/www/discourse/public/assets/locales/ko-d73f24f1515e887a3427dd2ba5fbbe4c03d952db2e1c3328ddc940e552746fc2.js
Compressing: locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js
uglifyjs '/var/www/discourse/public/assets/locales/_bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js.map' --source-map-url '/assets/locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js.map'
gzip /var/www/discourse/public/assets/locales/bs_BA-ec20e14d2c2afdc8d53f3a79f65b8d891a1f6f0ae696e5e6eac4a6d1b302c77d.js
Compressing: locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js
uglifyjs '/var/www/discourse/public/assets/locales/_ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js.map' --source-map-url '/assets/locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js.map'
gzip /var/www/discourse/public/assets/locales/ru-87bf91aea8b7abf0ecb4c14c78da4c1c803229f5c535580e2e896a11fe8810cc.js
Compressing: locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js
uglifyjs '/var/www/discourse/public/assets/locales/_fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js.map' --source-map-url '/assets/locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js.map'
gzip /var/www/discourse/public/assets/locales/fr-93c98ca0ebee151df3985406f785a76c8eb47e8d3dea87dc152396c0331d7852.js
Compressing: locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js
uglifyjs '/var/www/discourse/public/assets/locales/_ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js.map' --source-map-url '/assets/locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js.map'
gzip /var/www/discourse/public/assets/locales/ar-7752ebab76f943df38c9d81de21702ca8535f47f2260abc49a1e22b27e3f2802.js
Compressing: locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js
uglifyjs '/var/www/discourse/public/assets/locales/_zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js.map' --source-map-url '/assets/locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js.map'
gzip /var/www/discourse/public/assets/locales/zh_TW-8c7e098f653dc4d0511493734d26e770f381568355dad57fcd87c02bc23acf58.js
Compressing: locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js
uglifyjs '/var/www/discourse/public/assets/locales/_zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js.map' --source-map-url '/assets/locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js.map'
gzip /var/www/discourse/public/assets/locales/zh_CN-35b3fc6ce33620a3f480770f2825d026fc408047ee4bfbd8fe349a4a833d3419.js
Compressing: locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js
uglifyjs '/var/www/discourse/public/assets/locales/_te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js.map' --source-map-url '/assets/locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js.map'
gzip /var/www/discourse/public/assets/locales/te-05d2deb7605f046151d6f24013ab8e5def3235db6a1e44bf84a0b4a46e09e0b4.js
Compressing: locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js
uglifyjs '/var/www/discourse/public/assets/locales/_fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js.map' --source-map-url '/assets/locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js.map'
gzip /var/www/discourse/public/assets/locales/fa_IR-40fd1a78ea17bc19b9bcc96d470ab1c610100494ce8586296e4b022fa10eb7a2.js
Compressing: locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js
uglifyjs '/var/www/discourse/public/assets/locales/_pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js.map' --source-map-url '/assets/locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js.map'
gzip /var/www/discourse/public/assets/locales/pt_BR-bace131b9dde2f4b73b69cee6f70c7c725ba20cfb78daa586fa2d4e21fab1bac.js
Compressing: locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js
uglifyjs '/var/www/discourse/public/assets/locales/_pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js.map' --source-map-url '/assets/locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js.map'
gzip /var/www/discourse/public/assets/locales/pt-07ed9c90cafd9a1dd957418eecd6668d2120acc6b03f61deb7f9b7a679bdbe7b.js
Compressing: locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js
uglifyjs '/var/www/discourse/public/assets/locales/_sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js.map' --source-map-url '/assets/locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js.map'
gzip /var/www/discourse/public/assets/locales/sk-ab5408918b49009f1882dc99809c190abaa1964c888e6b555950b25535bde4de.js
Compressing: locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js
uglifyjs '/var/www/discourse/public/assets/locales/_nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js.map' --source-map-url '/assets/locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js.map'
gzip /var/www/discourse/public/assets/locales/nb_NO-aaf57bb5cf3696085a74547c5b5ec9d207f727111d6f1691233d17092c1443bb.js
Compressing: locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js
uglifyjs '/var/www/discourse/public/assets/locales/_es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js.map' --source-map-url '/assets/locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js.map'
gzip /var/www/discourse/public/assets/locales/es-f57a3511c727bd320b80bd9f6d0368d40382326e9acec2d4e841c676f68c43c2.js
Compressing: locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js
uglifyjs '/var/www/discourse/public/assets/locales/_de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js.map' --source-map-url '/assets/locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js.map'
gzip /var/www/discourse/public/assets/locales/de-7d9cac1cc3c9e9605aa2ce47daa9a815ae64c22790c2f2162a5d4cc2cb7c5e1f.js
Compressing: locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js
uglifyjs '/var/www/discourse/public/assets/locales/_it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js.map' --source-map-url '/assets/locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js.map'
gzip /var/www/discourse/public/assets/locales/it-62144b8b97ca704fe796b19f407b362224c91a8c372dfbfbbd9a75ff0cc974f1.js
Compressing: locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js
uglifyjs '/var/www/discourse/public/assets/locales/_da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js.map' --source-map-url '/assets/locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js.map'
gzip /var/www/discourse/public/assets/locales/da-8bc95a3ddca27b7ce24cf5a996f94296457678e4765a38f84e38e12f2632962c.js
Compressing: locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js
uglifyjs '/var/www/discourse/public/assets/locales/_en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js.map' --source-map-url '/assets/locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js.map'
gzip /var/www/discourse/public/assets/locales/en-8dcdc17075d941a4ea0b5ca773ff03c8f55226fba61b350cae5da6cc9a124c28.js
Compressing: locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js
uglifyjs '/var/www/discourse/public/assets/locales/_gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js.map' --source-map-url '/assets/locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js.map'
gzip /var/www/discourse/public/assets/locales/gl-8c34e0cf6f02b98b0932577dacedf634db9166b589b5496d131cea35be1a3aad.js
Compressing: locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js
uglifyjs '/var/www/discourse/public/assets/locales/_tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js.map' --source-map-url '/assets/locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js.map'
gzip /var/www/discourse/public/assets/locales/tr_TR-3e1dd21d2a651884aa505d79f4685ac929f87a65b64fc27a65d38349385edb19.js
Compressing: locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js
uglifyjs '/var/www/discourse/public/assets/locales/_sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js.map' --source-map-url '/assets/locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js.map'
gzip /var/www/discourse/public/assets/locales/sv-fe632ea1c35b8b93b753f74b034f7f01996b39249cc7197616f2eb19da3f7b79.js
Compressing: locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js
uglifyjs '/var/www/discourse/public/assets/locales/_nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js.map' --source-map-url '/assets/locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js.map'
gzip /var/www/discourse/public/assets/locales/nl-246f81f6ecc7490a8f18b8bc278a8fc78a62e5afb8a5d990fefe045c76dfd3ac.js
Compressing: locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js
uglifyjs '/var/www/discourse/public/assets/locales/_pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js.map' --source-map-url '/assets/locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js.map'
gzip /var/www/discourse/public/assets/locales/pl_PL-36f5a3d7cb940038b8d8d2e3ef75187be947b0d66a694056c84e80677f6de96f.js
Compressing: locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js
uglifyjs '/var/www/discourse/public/assets/locales/_ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js.map' --source-map-url '/assets/locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js.map'
gzip /var/www/discourse/public/assets/locales/ja-28a7369a1366ce16536c99042b47292ee258b282094da9dd7fe45851b8d67162.js
Compressing: locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js
uglifyjs '/var/www/discourse/public/assets/locales/_sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js.map' --source-map-url '/assets/locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js.map'
gzip /var/www/discourse/public/assets/locales/sq-e958f2dc7da2347d777b1dddbd94819d64d21e8738399a2b9ad6749f3432deb9.js
Compressing: locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js
uglifyjs '/var/www/discourse/public/assets/locales/_et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js.map' --source-map-url '/assets/locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js.map'
gzip /var/www/discourse/public/assets/locales/et-ed89679e8af706757c260f995270d50b49dfb7577322f352914510fcd8464fea.js
Compressing: locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js
uglifyjs '/var/www/discourse/public/assets/locales/_he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js.map' --source-map-url '/assets/locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js.map'
gzip /var/www/discourse/public/assets/locales/he-e82761719a683b548fff6bc88c281bd432843183b28f29d6a4e6d46ee4ad3163.js
Compressing: locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js
uglifyjs '/var/www/discourse/public/assets/locales/_cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js.map' --source-map-url '/assets/locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js.map'
gzip /var/www/discourse/public/assets/locales/cs-ecdcbb050277e6287c684fafa3c53840cbfb1bfbc52e8ec5f23a967e81210ec7.js
Compressing: locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js
uglifyjs '/var/www/discourse/public/assets/locales/_ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js.map' --source-map-url '/assets/locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js.map'
gzip /var/www/discourse/public/assets/locales/ro-36e0dbd7bdfebf1de969d6be46538c9b402dd072b40ad8d5808702b45a4179da.js
Compressing: locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js
uglifyjs '/var/www/discourse/public/assets/locales/_uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js' -p relative -c -m -o '/var/www/discourse/public/assets/locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js' --source-map-root '/assets/locales' --source-map '/var/www/discourse/public/assets/locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js.map' --source-map-url '/assets/locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js.map'
gzip /var/www/discourse/public/assets/locales/uk-4984b169c5dfd2a67c4dc5f300f5793ccc2ec4d895750ac8fa6fb9fbc5d3ff25.js
Compressing: docker-manager-app-d73193fccf5ecd9a028a2b452ca1bd2d0dd53a3969b7cbcf1c2db145aeffacdf.js
gzip /var/www/discourse/public/assets/docker-manager-app-d73193fccf5ecd9a028a2b452ca1bd2d0dd53a3969b7cbcf1c2db145aeffacdf.js
Compressing: docker-manager-vendor-5ae6424eab01916a4efff0d807662635eb6e705497ff0a27699552e0ab3a1716.js
gzip /var/www/discourse/public/assets/docker-manager-vendor-5ae6424eab01916a4efff0d807662635eb6e705497ff0a27699552e0ab3a1716.js
Compressing: application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js
uglifyjs '/var/www/discourse/public/assets/_application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js' -p relative -c -m -o '/var/www/discourse/public/assets/application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js' --source-map-root '/assets' --source-map '/var/www/discourse/public/assets/application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js.map' --source-map-url '/assets/application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js.map'
gzip /var/www/discourse/public/assets/application-4befa770d3fe27a926ff79faafc9172344c9a952b06b8338586820f8c4247861.js
Compressing: discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js
uglifyjs '/var/www/discourse/public/assets/discourse/controllers/_application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js' -p relative -c -m -o '/var/www/discourse/public/assets/discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js' --source-map-root '/assets/discourse/controllers' --source-map '/var/www/discourse/public/assets/discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js.map' --source-map-url '/assets/discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js.map'
gzip /var/www/discourse/public/assets/discourse/controllers/application-4b46985acabba9d61c087cd357c6d5b00133a6b0619913a576bf458c548bedd8.js
Compressing: discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js
uglifyjs '/var/www/discourse/public/assets/discourse/helpers/_application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js' -p relative -c -m -o '/var/www/discourse/public/assets/discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js' --source-map-root '/assets/discourse/helpers' --source-map '/var/www/discourse/public/assets/discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js.map' --source-map-url '/assets/discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js.map'
gzip /var/www/discourse/public/assets/discourse/helpers/application-96fa9dd14131f46914ea4c7ffc2981a33a069023a64e3a09a377b507553988be.js
Compressing: discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js
uglifyjs '/var/www/discourse/public/assets/discourse/routes/_application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js' -p relative -c -m -o '/var/www/discourse/public/assets/discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js' --source-map-root '/assets/discourse/routes' --source-map '/var/www/discourse/public/assets/discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js.map' --source-map-url '/assets/discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js.map'
gzip /var/www/discourse/public/assets/discourse/routes/application-077c11b10cac0d5785f939fa4b2011452c6bf4da7f78bba0c39b31a0e3b1a356.js
Compressing: wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js
uglifyjs '/var/www/discourse/public/assets/wizard/controllers/_application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js' -p relative -c -m -o '/var/www/discourse/public/assets/wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js' --source-map-root '/assets/wizard/controllers' --source-map '/var/www/discourse/public/assets/wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js.map' --source-map-url '/assets/wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js.map'
gzip /var/www/discourse/public/assets/wizard/controllers/application-ac59b2e04eaed71128e02513d84ad9aa765b451d9c57ba356c8561c927240945.js
Compressing: wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js
uglifyjs '/var/www/discourse/public/assets/wizard/routes/_application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js' -p relative -c -m -o '/var/www/discourse/public/assets/wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js' --source-map-root '/assets/wizard/routes' --source-map '/var/www/discourse/public/assets/wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js.map' --source-map-url '/assets/wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js.map'
gzip /var/www/discourse/public/assets/wizard/routes/application-266349c0539b224b98ba399d99569579c8be902eae03f47cb47317a7399138e0.js
I, [2016-11-06T20:04:26.128923 #13] INFO -- : Purging temp files
Bundling assets
Compressing Javascript and Generating Source Maps
I, [2016-11-06T20:04:26.136750 #13] INFO -- : File > /usr/local/bin/discourse chmod: +x
I, [2016-11-06T20:04:26.139759 #13] INFO -- : File > /usr/local/bin/rails chmod: +x
I, [2016-11-06T20:04:26.142776 #13] INFO -- : File > /usr/local/bin/rake chmod: +x
I, [2016-11-06T20:04:26.145728 #13] INFO -- : File > /etc/update-motd.d/10-web chmod: +x
I, [2016-11-06T20:04:26.147500 #13] INFO -- : File > /etc/logrotate.d/rails chmod:
I, [2016-11-06T20:04:26.149681 #13] INFO -- : File > /etc/logrotate.d/nginx chmod:
I, [2016-11-06T20:04:26.153566 #13] INFO -- : File > /etc/runit/1.d/00-ensure-links chmod: +x
I, [2016-11-06T20:04:26.158316 #13] INFO -- : File > /root/.bash_profile chmod: 644
I, [2016-11-06T20:04:26.159007 #13] INFO -- : Replacing (?-mix:server.+{) with limit_req_zone $binary_remote_addr zone=flood:10m rate=$reqs_per_secondr/s;
limit_req_zone $binary_remote_addr zone=bot:10m rate=$reqs_per_minuter/m;
limit_req_status 429;
server {
in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:04:26.159318 #13] INFO -- : Replacing (?-mix:location @discourse {) with location @discourse {
limit_req zone=flood burst=$burst_per_second nodelay;
limit_req zone=bot burst=$burst_per_minute nodelay; in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:04:26.160040 #13] INFO -- : > mkdir -p /shared/ssl/
I, [2016-11-06T20:04:26.161471 #13] INFO -- :
I, [2016-11-06T20:04:26.161547 #13] INFO -- : > [ -e /shared/ssl/dhparams.pem ] || openssl dhparam -out /shared/ssl/dhparams.pem 2048
Generating DH parameters, 2048 bit long safe prime, generator 2
This is going to take a long time
......................+.......................................................................................................................................................................................+.....................................................................................................................................................................+.............................................................................................................................................................................................................................+..........+....................+.............+.....................................................+.................+.........+........................................................................................................+...................................................................................................................................................+................................+...........................................................+..............................................................+.+...............................................+.........................................................................................................................................+..............................................+...........................+...........................................+.........+.+............................................................................................................................................+...................+........................+..........................................................+....................................................................................................................+..................................................................+....+...............+.......................................................................................................................................................................................................................+................................................................................................................+.........+..............................................................................................................................................................................+............................................+........................................................................................+............................................................................................................+..................................................+..............................................................................................................................+.....................................................................+.............................+...................................+........................................................................................................+..........................................+..+.....................................................................................................................................................................................................+...........................................................................................................................................................................................................+........................+................+..+........................+....................................................................................................................................................+............................................................................................................................................................................................................................................+...................................+..............................+..............................+.........................................................+...................................................................................................................................................................................................................................................................+...............................+..................+..........................................................................................+......................................................................+.............................................................+................................+..................................................+....................................................................................................................+..............................................................................................+..................................+................................................................................................................................................................................+........................................................................................+..............................+.........................................................................................................................................+......................................+.......................................................+...................................................................................................+....................................................196:M 06 Nov 20:05:17.099 * 10 changes in 300 seconds. Saving...
196:M 06 Nov 20:05:17.102 * Background saving started by pid 4477
.4477:C 06 Nov 20:05:17.113 * DB saved on disk
4477:C 06 Nov 20:05:17.113 * RDB: 6 MB of memory used by copy-on-write
.........196:M 06 Nov 20:05:17.202 * Background saving terminated with success
...........................................+........+................................................................+........................................................................................................................................................................................................................................+.............+.......................................................................................................................................................................+..................................................................................................................................................+.........................+......+...........................................+..................................................+..................................+....................................................................................................+..............................................................................................................+...........................+.........................................................+..........................................................................................................................................................................................................................................................................................................................+.............................................+......................................................................................................................................+.....+................................................................................................................+......................................................................................................................................................................................................+........................................................................................................................................................................................+........................................+....................+...............................................................................................................................................+...............................................................+.....................................................................+..............+.............................................+............................................+........................+...............................+..........................................................+....+..+........................+.......................................................................................................................................................+..........................................................................................................+...................................................................................................................................................................................................................................................................................................+...............................................+................+.......................................................................................................................................................................................................................................................................................................................................................................................................................................+...........................+....+...............................................................................................+......................................................................................................................................................................................+......................................................+.........+..............+...................................................+.................................................................................................................................................................................................................................................................................................................................................................+.............................+...................................+.............................................+.........................+...................................................................................................................+...........................................+.........+.....................................................+..................................................................................................+..+...............+.......+.............................+.............................................................................+.................................................................................................................................................+............................................+..............................................................................................+........................................................................+........................................................................................................................................................+................+..+..............+........................................+....................+..........................................................+.....................................+..........................................................................................+......................................................................................................+.......................+.....................+........................................................................................................+...................................................................................................................................................................................................+............................................................................................................+...+............................................................................................................................................+...............................................+...................................................................+.........+...........................................................................................................................................................................+.............................+...............+........+.........+............................................................................................................................................................................................................................................................+..........................................+...........................................................................+..............................+...........................................................................................................+........................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................+..............................+..................................................+......................................+.........+............................................+...........+.....................................................................................................................................................................................................................+...................................................................................................................+.....................................................................................................................................................................................+.............................................................................................................................+.......................................................................................................................................................................................................................................................................+................+...................................................................................+.................................................................................................................................................+.........................................................................+.............................+.............................+.....+.................................................+.......................+.............+..............+....................................................................................................................................+........................................................+......................................+...............+..........................................................................................................................+..............+.+.........................................................................................................................................................................................+.......................................................+............+..............................................................................+...............................................................................................................................................................................................+.......................+..........................................................................+..............................................................+....................+.............................................................................+...........................+........................................................................................................................+.....................................+..............+................................................................................................................................................................................................+.................................................................+.................................................+...............................................................................................................................................................+...........................+...............................................................................................................................................................+............................................................................................................................................................................................................................................................+...............................................................+...............................+...........................................................................................................................................................................................................................+...................................................+..........................................................................................................................................................+.................................+.......................................................................................................+..........................+......................................................................................................................................................................+............................+...........................................................................................................................................+..................................+....................+...........+..................+......+................................+.................................................+...................................................................................+......................+..+..............................................+.....................+..................................................................................................+...................+...............................................................................................................................................................................................................+....................................................................................+.....................+.+....................................................................................................................+..........................................................................................................................................................+.....................................................+.....................................+.....................................................................................+.............................................+.........................................................+...................................+..................................................................................+................+.........................................................+.....................................................................................+....................................................................................................................................................................................................................+..........................................................................................................................................+............................................+...........................................................................+..................+.......................................+...............................................................................................+.........+.............................................................................................................................................................+..................................................................................................................................................................+.+................................................................................................................................................................................................................................................................................................................................................................................................................................+..............................+..............................+...........................................................................................................................................................................................................................................................................................................................................................................................................................+...............................................................................................................................................................................................................................................................................................................................................................+................................................................................................................................................................................................................+........................................................................................................................................+...........................................+.................................................................................................................................+.................+...........................+...........................................................................................+...........................................................................................................+......................................................................................................................................................................................................................................................................................................................................................................................................................................................+........+..................+..........................................................................................................+......................................................................................................................+...........+.....+................+.............+..............+......................................................................+...........................................................................................................................................................................................................................................+........................................+................................................................................................................................+.........................................................................................................+.............................+...........................................................................................................................................+.................................................................+.............+..................................+.............................................................................+..................................................+...............................................................................................................+...................................................................................+............................................................................................................................................................................................................................................................................................................................................................................................................+..............................................................................................................................................................................................................................+.................+................................................................+..........................................................................................................................................+....................................................................................................................................................................................................+........................+..............................................................+........................................+.......+...................................................................................................................................................................+...............................................................................................................++*++*
I, [2016-11-06T20:08:25.570649 #13] INFO -- :
I, [2016-11-06T20:08:25.570881 #13] INFO -- : Replacing (?-mix:server.+{) with server {
listen 80;
rewrite ^ https://$$ENV_DISCOURSE_HOSTNAME$request_uri? permanent;
}
server {
in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:08:25.571216 #13] INFO -- : Replacing (?m-ix:listen 80;\s+gzip on;) with listen 443 ssl http2;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
# courtesy of https://wiki.mozilla.org/Security/Server_Side_TLS#Recommended_configurations
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA;
ssl_prefer_server_ciphers on;
ssl_certificate /shared/ssl/ssl.crt;
ssl_certificate_key /shared/ssl/ssl.key;
ssl_dhparam /shared/ssl/dhparams.pem;
ssl_session_tickets off;
ssl_session_timeout 1d;
ssl_session_cache shared:SSL:1m;
add_header Strict-Transport-Security 'max-age=31536000'; # remember the certificate for a year and automatically connect to HTTPS for this domain
gzip on;
if ($http_host != $$ENV_DISCOURSE_HOSTNAME) {
rewrite (.*) https://$$ENV_DISCOURSE_HOSTNAME$1 permanent;
} in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:08:25.571993 #13] INFO -- : > if [ -z "$LETSENCRYPT_ACCOUNT_EMAIL" ]; then echo "LETSENCRYPT_ACCOUNT_EMAIL ENV variable is required and has not been set."; exit 1; fi
I, [2016-11-06T20:08:25.573646 #13] INFO -- :
I, [2016-11-06T20:08:25.573724 #13] INFO -- : > /bin/bash -c "if [[ ! \"$LETSENCRYPT_ACCOUNT_EMAIL\" =~ ([^@]+)@([^\.]+) ]]; then echo \"LETSENCRYPT_ACCOUNT_EMAIL is not a valid email address\"; exit 1; fi"
I, [2016-11-06T20:08:25.581843 #13] INFO -- :
I, [2016-11-06T20:08:25.582074 #13] INFO -- : > cd /root && git clone https://github.com/Neilpang/acme.sh.git && cd /root/acme.sh && git reset --hard 267f283a31c7df68ae5852d0b04d8ef6bb36a1b3
Cloning into 'acme.sh'...
I, [2016-11-06T20:08:25.913048 #13] INFO -- : HEAD is now at 267f283 fix bug, upgrade in current dir without installation.
I, [2016-11-06T20:08:25.913155 #13] INFO -- : > touch /var/spool/cron/crontabs/root
I, [2016-11-06T20:08:25.916064 #13] INFO -- :
I, [2016-11-06T20:08:25.916155 #13] INFO -- : > install -d -m 0755 -g root -o root $LETSENCRYPT_DIR
I, [2016-11-06T20:08:25.920609 #13] INFO -- :
I, [2016-11-06T20:08:25.920691 #13] INFO -- : > cd /root/acme.sh && LE_WORKING_DIR="${LETSENCRYPT_DIR}" ./acme.sh --install
[Sun Nov 6 20:08:25 UTC 2016] It is recommended to install nc first, try to install 'nc' or 'netcat'.
[Sun Nov 6 20:08:25 UTC 2016] We use nc for standalone server if you use standalone mode.
[Sun Nov 6 20:08:25 UTC 2016] If you don't use standalone mode, just ignore this warning.
I, [2016-11-06T20:08:25.988797 #13] INFO -- : [Sun Nov 6 20:08:25 UTC 2016] Installing to /shared/letsencrypt
[Sun Nov 6 20:08:25 UTC 2016] Installed to /shared/letsencrypt/acme.sh
[Sun Nov 6 20:08:25 UTC 2016] OK, Close and reopen your terminal to start using acme.sh
[Sun Nov 6 20:08:25 UTC 2016] Installing cron job
[Sun Nov 6 20:08:25 UTC 2016] Good, bash is installed, change the shebang to use bash as prefered.
[Sun Nov 6 20:08:25 UTC 2016] OK
I, [2016-11-06T20:08:25.990921 #13] INFO -- : File > /etc/nginx/letsencrypt.conf chmod:
I, [2016-11-06T20:08:25.994021 #13] INFO -- : File > /etc/runit/1.d/letsencrypt chmod: +x
I, [2016-11-06T20:08:25.994202 #13] INFO -- : Replacing (?-mix:ssl_certificate.+) with ssl_certificate /shared/ssl/$$ENV_DISCOURSE_HOSTNAME.cer;
in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:08:25.994498 #13] INFO -- : Replacing (?-mix:#ACCOUNT_EMAIL=.+) with ACCOUNT_EMAIL=$$ENV_LETSENCRYPT_ACCOUNT_EMAIL
in /shared/letsencrypt/account.conf
I, [2016-11-06T20:08:25.994727 #13] INFO -- : Replacing (?-mix:ssl_certificate_key.+) with ssl_certificate_key /shared/ssl/$$ENV_DISCOURSE_HOSTNAME.key;
in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:08:25.995228 #13] INFO -- : Replacing (?-mix:add_header.+) with # remember the certificate for 80 days and automatically connect to HTTPS for this domain
add_header Strict-Transport-Security 'max-age=6912000'; in /etc/nginx/conf.d/discourse.conf
I, [2016-11-06T20:08:25.995867 #13] INFO -- : > echo "Beginning of custom commands"
I, [2016-11-06T20:08:25.997209 #13] INFO -- : Beginning of custom commands
I, [2016-11-06T20:08:25.997349 #13] INFO -- : > echo "End of custom commands"
I, [2016-11-06T20:08:25.998616 #13] INFO -- : End of custom commands
I, [2016-11-06T20:08:25.998691 #13] INFO -- : Terminating async processes
I, [2016-11-06T20:08:25.998775 #13] INFO -- : Sending INT to HOME=/var/lib/postgresql USER=postgres exec chpst -u postgres:postgres:ssl-cert -U postgres:postgres:ssl-cert /usr/lib/postgresql/9.5/bin/postmaster -D /etc/postgresql/9.5/main pid: 83
2016-11-06 20:08:25 UTC [83-2] LOG: received fast shutdown request
2016-11-06 20:08:25 UTC [83-3] LOG: aborting any active transactions
2016-11-06 20:08:25 UTC [90-2] LOG: autovacuum launcher shutting down
I, [2016-11-06T20:08:26.002143 #13] INFO -- : Sending TERM to exec chpst -u redis -U redis /usr/bin/redis-server /etc/redis/redis.conf pid: 196
196:signal-handler (1478462905) Received SIGTERM scheduling shutdown...
2016-11-06 20:08:25 UTC [87-1] LOG: shutting down
2016-11-06 20:08:26 UTC [87-2] LOG: database system is shut down
196:M 06 Nov 20:08:26.027 # User requested shutdown...
196:M 06 Nov 20:08:26.027 * Saving the final RDB snapshot before exiting.
196:M 06 Nov 20:08:26.041 * DB saved on disk
196:M 06 Nov 20:08:26.041 # Redis is now ready to exit, bye bye...
sha256:7e643a51405169bd9fbd087f6fd5149fef73d6956ebdc882ce9db55bbdb6712a
7a036b44ccabf3484ff98e99aff6de0d43775cf18c998b3741742e6856855e72
Successfully bootstrapped, to startup use ./launcher start app
+ /usr/bin/docker run -d --restart=always -e LANG=en_US.UTF-8 -e RAILS_ENV=production -e UNICORN_WORKERS=4 -e UNICORN_SIDEKIQS=1 -e RUBY_GLOB
AL_METHOD_CACHE_SIZE=131072 -e RUBY_GC_HEAP_GROWTH_MAX_SLOTS=40000 -e RUBY_GC_HEAP_INIT_SLOTS=400000 -e RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR=1.5 -e DISCOURSE_DB_SOCKET=/var/run/postgresql -e DISCOURSE_DB_HOST= -e DISCOURSE_DB_PORT= -e LETSENCRYPT_DIR=/shared/letsencrypt -e DISCOURSE_HOSTNAME=edgewoodcoop.com -e DISCOURSE_DEVELOPER_EMAILS=admin@edgewoodcoop.com -e DISCOURSE_SMTP_ADDRESS=smtp.sparkpostmail.com -e DISCOURSE_SMTP_PORT=587 -e DISCOURSE_SMTP_USER_NAME=SMTP_Injection -e DISCOURSE_SMTP_PASSWORD=623be434ffe94ae86da55b47d9838ee4869d67ee -e LETSENCRYPT_ACCOUNT_EMAIL=admin@edgewoodcoop.com -h ip-172-31-56-171-app -e DOCKER_HOST_IP=172.17.0.1 --name app -t -p 80:80 -p 443:443 -v /var/discourse/shared/standalone:/shared -v /var/discourse/shared/standalone/log/var-log:/var/log --mac-address 02:15:ed:1c:ce:6f local_discourse/app /sbin/boot
422bd4d26df98f1e1a4a926c22e0fca2e86b950e367971fa73b16520a79a75b4
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment