Commit 7b6c4df18558d321cb8bf75ff3754adef0c6784b
Exists in
master
and in
54 other branches
Merge branch 'colab-master'
Showing
4 changed files
with
184 additions
and
103 deletions
Show diff stats
colab-deps/colab-deps.spec
1 | %define name colab-deps | 1 | %define name colab-deps |
2 | -%define version 1.10 | 2 | +%define version 1.11 |
3 | %define release 1 | 3 | %define release 1 |
4 | 4 | ||
5 | -Summary: Collaboration platform for communities (Pyton dependencies) | 5 | +Summary: Collaboration platform for communities (Python dependencies) |
6 | Name: %{name} | 6 | Name: %{name} |
7 | Version: %{version} | 7 | Version: %{version} |
8 | Release: %{release} | 8 | Release: %{release} |
@@ -19,12 +19,14 @@ BuildRequires: gettext, libxml2-devel, libxslt-devel, openssl-devel, libffi-deve | @@ -19,12 +19,14 @@ BuildRequires: gettext, libxml2-devel, libxslt-devel, openssl-devel, libffi-deve | ||
19 | Integrated software development platform (Python dependencies). | 19 | Integrated software development platform (Python dependencies). |
20 | 20 | ||
21 | %prep | 21 | %prep |
22 | -%setup -n %{name}-%{version} -n %{name}-%{version} | 22 | +%setup -q |
23 | 23 | ||
24 | %build | 24 | %build |
25 | +cd %{_builddir} | ||
25 | make | 26 | make |
26 | 27 | ||
27 | %install | 28 | %install |
29 | +cd %{_builddir} | ||
28 | %make_install | 30 | %make_install |
29 | 31 | ||
30 | %clean | 32 | %clean |
@@ -0,0 +1,37 @@ | @@ -0,0 +1,37 @@ | ||
1 | +Name: colab-spb-theme | ||
2 | +Version: 0.2.0 | ||
3 | +Release: 1 | ||
4 | +Summary: SPB-specific Colab theme | ||
5 | +Group: Applications/Publishing | ||
6 | +License: GPLv3 | ||
7 | +URL: https://portal.softwarepublico.gov.br/gitlab/softwarepublico/colab-spb-theme-plugin | ||
8 | +Source0: %{name}-%{version}.tar.gz | ||
9 | +BuildArch: noarch | ||
10 | +BuildRequires: colab >= 1.11 | ||
11 | +Requires: colab >= 1.11 | ||
12 | +%description | ||
13 | +This package contains Colab theme for Software Público Brasileiro platform. | ||
14 | + | ||
15 | +%prep | ||
16 | +%setup -q | ||
17 | + | ||
18 | +%build | ||
19 | +make | ||
20 | + | ||
21 | +%install | ||
22 | + | ||
23 | +install -d %{buildroot}/etc/colab/settings.d/ | ||
24 | + | ||
25 | +cat > %{buildroot}/etc/colab/settings.d/spb_theme.py << EOF | ||
26 | +COLAB_STATICS=['/usr/lib/colab/colab-spb-theme/colab_spb_theme/static'] | ||
27 | +COLAB_TEMPLATES=('/usr/lib/colab/colab-spb-theme/colab_spb_theme/templates',) | ||
28 | +EOF | ||
29 | + | ||
30 | +make install DESTDIR=%{buildroot} | ||
31 | + | ||
32 | +%post | ||
33 | +yes yes | colab-admin collectstatic | ||
34 | + | ||
35 | +%files | ||
36 | +/usr/lib/colab | ||
37 | +/etc/colab |
colab/colab.spec
1 | %define name colab | 1 | %define name colab |
2 | -%define version 1.10.3 | ||
3 | -%define default_release 4 | 2 | +%define version 1.11.0 |
3 | +%define default_release 1 | ||
4 | %{!?release: %define release %{default_release}} | 4 | %{!?release: %define release %{default_release}} |
5 | %define buildvenv /var/tmp/%{name}-%{version} | 5 | %define buildvenv /var/tmp/%{name}-%{version} |
6 | 6 | ||
@@ -14,10 +14,11 @@ Group: Development/Tools | @@ -14,10 +14,11 @@ Group: Development/Tools | ||
14 | BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-buildroot | 14 | BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-buildroot |
15 | Prefix: %{_prefix} | 15 | Prefix: %{_prefix} |
16 | Vendor: Sergio Oliveira <sergio@tracy.com.br> | 16 | Vendor: Sergio Oliveira <sergio@tracy.com.br> |
17 | -Url: https://github.com/colab-community/colab | 17 | +Url: https://github.com/colab/colab |
18 | BuildArch: noarch | 18 | BuildArch: noarch |
19 | -BuildRequires: colab-deps >= 1.10, python-virtualenv | ||
20 | -Requires: colab-deps >= 1.10, solr, mailman-api | 19 | +BuildRequires: colab-deps >= 1.11, python-virtualenv |
20 | +# TODO: Set mailman-api version (0.3c1) | ||
21 | +Requires: colab-deps >= 1.11, solr, mailman-api | ||
21 | 22 | ||
22 | %description | 23 | %description |
23 | Integrated software development platform. | 24 | Integrated software development platform. |
@@ -29,7 +30,7 @@ Integrated software development platform. | @@ -29,7 +30,7 @@ Integrated software development platform. | ||
29 | # install colab into virtualenv to make sure dependencies are OK | 30 | # install colab into virtualenv to make sure dependencies are OK |
30 | rm -rf %{buildvenv} | 31 | rm -rf %{buildvenv} |
31 | cp -r /usr/lib/colab %{buildvenv} | 32 | cp -r /usr/lib/colab %{buildvenv} |
32 | -PATH=%{buildvenv}/bin:$PATH pip install --no-index . | 33 | +PATH=%{buildvenv}/bin:$PATH pip install --use-wheel --no-index . |
33 | virtualenv --relocatable %{buildvenv} | 34 | virtualenv --relocatable %{buildvenv} |
34 | 35 | ||
35 | # cleanup virtualenv | 36 | # cleanup virtualenv |
@@ -43,13 +44,30 @@ rm -f cleanup.list | @@ -43,13 +44,30 @@ rm -f cleanup.list | ||
43 | find %{buildvenv} -type d -empty -delete | 44 | find %{buildvenv} -type d -empty -delete |
44 | 45 | ||
45 | %install | 46 | %install |
46 | -mkdir -p %{buildroot}/etc/colab | ||
47 | -mkdir -p %{buildroot}/usr/lib | 47 | + |
48 | +# install config file | ||
49 | +install -d -m 0755 %{buildroot}/etc/colab | ||
50 | +install -m 0644 misc/etc/colab/gunicorn.py %{buildroot}/etc/colab/gunicorn.py.example | ||
51 | + | ||
52 | +# Create settings dirs | ||
53 | +install -d -m 0755 %{buildroot}/etc/colab/settings.d | ||
54 | +install -d -m 0755 %{buildroot}/etc/colab/plugins.d | ||
55 | + | ||
56 | +# create log dir | ||
57 | +install -d -m 0755 %{buildroot}/var/log/colab | ||
58 | + | ||
59 | +# create celery dir | ||
60 | +install -d -m 0755 %{buildroot}/var/lib/colab/celery | ||
61 | + | ||
62 | +# Create assets dir (stores static files) | ||
63 | +install -d -m 0755 %{buildroot}/var/lib/colab/assets | ||
48 | 64 | ||
49 | # install virtualenv | 65 | # install virtualenv |
66 | +install -d -m 0755 %{buildroot}/usr/lib | ||
50 | rm -rf %{buildroot}/usr/lib/colab | 67 | rm -rf %{buildroot}/usr/lib/colab |
51 | cp -r %{buildvenv} %{buildroot}/usr/lib/colab | 68 | cp -r %{buildvenv} %{buildroot}/usr/lib/colab |
52 | mkdir -p %{buildroot}/%{_bindir} | 69 | mkdir -p %{buildroot}/%{_bindir} |
70 | + | ||
53 | cat > %{buildroot}/%{_bindir}/colab-admin <<EOF | 71 | cat > %{buildroot}/%{_bindir}/colab-admin <<EOF |
54 | #!/bin/sh | 72 | #!/bin/sh |
55 | set -e | 73 | set -e |
@@ -65,6 +83,8 @@ chmod +x %{buildroot}/%{_bindir}/colab-admin | @@ -65,6 +83,8 @@ chmod +x %{buildroot}/%{_bindir}/colab-admin | ||
65 | # install initscript | 83 | # install initscript |
66 | install -d -m 0755 %{buildroot}/lib/systemd/system | 84 | install -d -m 0755 %{buildroot}/lib/systemd/system |
67 | install -m 0644 misc/lib/systemd/system/colab.service %{buildroot}/lib/systemd/system | 85 | install -m 0644 misc/lib/systemd/system/colab.service %{buildroot}/lib/systemd/system |
86 | +install -m 0644 misc/lib/systemd/system/celeryd.service %{buildroot}/lib/systemd/system | ||
87 | +install -m 0644 misc/lib/systemd/system/celerybeat.service %{buildroot}/lib/systemd/system | ||
68 | # install crontab | 88 | # install crontab |
69 | install -d -m 0755 %{buildroot}/etc/cron.d | 89 | install -d -m 0755 %{buildroot}/etc/cron.d |
70 | install -m 0644 misc/etc/cron.d/colab %{buildroot}/etc/cron.d | 90 | install -m 0644 misc/etc/cron.d/colab %{buildroot}/etc/cron.d |
@@ -74,10 +94,22 @@ rm -rf $RPM_BUILD_ROOT | @@ -74,10 +94,22 @@ rm -rf $RPM_BUILD_ROOT | ||
74 | rm -rf %{buildvenv} | 94 | rm -rf %{buildvenv} |
75 | 95 | ||
76 | %files | 96 | %files |
97 | +%defattr(-, root, root) | ||
98 | + | ||
77 | /usr/lib/colab | 99 | /usr/lib/colab |
100 | +#/var/lib/colab # XXX: remove if doesnt break | ||
101 | +/var/lib/colab/assets | ||
102 | +%attr(-, colab, colab) /var/lib/colab/celery | ||
103 | +%attr(-, colab, colab) /var/log/colab | ||
78 | %{_bindir}/* | 104 | %{_bindir}/* |
79 | /etc/cron.d/colab | 105 | /etc/cron.d/colab |
106 | +#/etc/colab # XXX: remove if doesnt break | ||
107 | +/etc/colab/settings.d | ||
108 | +/etc/colab/plugins.d | ||
109 | +/etc/colab/gunicorn.py.example | ||
80 | /lib/systemd/system/colab.service | 110 | /lib/systemd/system/colab.service |
111 | +/lib/systemd/system/celeryd.service | ||
112 | +/lib/systemd/system/celerybeat.service | ||
81 | 113 | ||
82 | %post | 114 | %post |
83 | groupadd colab || true | 115 | groupadd colab || true |
@@ -85,112 +117,122 @@ if ! id colab; then | @@ -85,112 +117,122 @@ if ! id colab; then | ||
85 | useradd --system --gid colab --home-dir /usr/lib/colab --no-create-home colab | 117 | useradd --system --gid colab --home-dir /usr/lib/colab --no-create-home colab |
86 | fi | 118 | fi |
87 | 119 | ||
88 | -mkdir -p /etc/colab | 120 | +mv /etc/colab/gunicorn.py.example /etc/colab/gunicorn.py |
89 | 121 | ||
90 | -if [ ! -f /etc/colab/settings.yaml ]; then | 122 | +if [ ! -f /etc/colab/settings.py ]; then |
91 | SECRET_KEY=$(openssl rand -hex 32) | 123 | SECRET_KEY=$(openssl rand -hex 32) |
92 | - cat > /etc/colab/settings.yaml <<EOF | ||
93 | -## Set to false in production | ||
94 | -DEBUG: true | ||
95 | -TEMPLATE_DEBUG: true | ||
96 | - | ||
97 | -## System admins | ||
98 | -ADMINS: &admin | ||
99 | - - | ||
100 | - - John Foo | ||
101 | - - john@example.com | ||
102 | - - | ||
103 | - - Mary Bar | ||
104 | - - mary@example.com | ||
105 | - | ||
106 | -MANAGERS: *admin | ||
107 | - | ||
108 | -COLAB_FROM_ADDRESS: '"Colab" <noreply@example.com>' | ||
109 | -SERVER_EMAIL: '"Colab" <noreply@example.com>' | ||
110 | - | ||
111 | -EMAIL_HOST: localhost | ||
112 | -EMAIL_PORT: 25 | ||
113 | -EMAIL_SUBJECT_PREFIX: '[colab]' | ||
114 | - | ||
115 | -SECRET_KEY: '$SECRET_KEY' | ||
116 | - | ||
117 | -SITE_URL: 'http://localhost:8001/' | ||
118 | -BROWSERID_AUDIENCES: | ||
119 | - - http://localhost:8001 | ||
120 | -# - http://example.com | ||
121 | -# - https://example.org | ||
122 | -# - http://example.net | ||
123 | - | ||
124 | -ALLOWED_HOSTS: | ||
125 | - - localhost | ||
126 | -# - example.com | ||
127 | -# - example.org | ||
128 | -# - example.net | ||
129 | - | ||
130 | -## Disable indexing | ||
131 | -ROBOTS_NOINDEX: false | ||
132 | - | ||
133 | -## Disable browser id authentication | ||
134 | -# BROWSERID_ENABLED: true | ||
135 | -EOF | ||
136 | - chown root:colab /etc/colab/settings.yaml | ||
137 | - chmod 0640 /etc/colab/settings.yaml | ||
138 | -fi | 124 | + cat > /etc/colab/settings.py <<EOF |
125 | + | ||
126 | +# Set to false in production | ||
127 | +DEBUG = True | ||
128 | +TEMPLATE_DEBUG = True | ||
129 | + | ||
130 | +# System admins | ||
131 | +ADMINS = [['John Foo', 'john@example.com'], ['Mary Bar', 'mary@example.com']] | ||
132 | + | ||
133 | +MANAGERS = ADMINS | ||
134 | + | ||
135 | +COLAB_FROM_ADDRESS = '"Colab" <noreply@example.com>' | ||
136 | +SERVER_EMAIL = '"Colab" <noreply@example.com>' | ||
137 | + | ||
138 | +EMAIL_HOST = 'localhost' | ||
139 | +EMAIL_PORT = 25 | ||
140 | +EMAIL_SUBJECT_PREFIX = '[colab]' | ||
141 | + | ||
142 | +SECRET_KEY = '$(openssl rand -hex 32)' | ||
143 | + | ||
144 | +ALLOWED_HOSTS = [ | ||
145 | + 'localhost', | ||
146 | +# 'example.com', | ||
147 | +# 'example.org', | ||
148 | +# 'example.net', | ||
149 | +] | ||
150 | + | ||
151 | +# Database settings | ||
152 | +# | ||
153 | +# When DEBUG is True colab will create the DB on | ||
154 | +# the repository root. In case of production settings | ||
155 | +# (DEBUG False) the DB settings must be set. | ||
156 | +# | ||
157 | +# DATABASES = { | ||
158 | +# 'default': { | ||
159 | +# 'ENGINE': 'django.db.backends.sqlite3', | ||
160 | +# 'NAME': '/path/to/colab.sqlite3', | ||
161 | +# } | ||
162 | +# } | ||
163 | + | ||
164 | +# Disable indexing | ||
165 | +ROBOTS_NOINDEX = False | ||
166 | + | ||
167 | +LOGGING = { | ||
168 | + 'version': 1, | ||
169 | + 'disable_existing_loggers': True, | ||
170 | + | ||
171 | + 'formatters': { | ||
172 | + 'colab': { 'format' : '[colab] (%%(name)s) %%(levelname)s: %%(message)s'}, | ||
173 | + 'verbose': { 'format' : '%%(asctime)s (%%(name)s) %%(levelname)s: %%(message)s'}, | ||
174 | + }, | ||
175 | + | ||
176 | + 'handlers': { | ||
177 | + 'null': { | ||
178 | + 'level': 'DEBUG', | ||
179 | + 'class': 'logging.NullHandler', | ||
180 | + }, | ||
181 | + 'syslog': { | ||
182 | + 'level': 'WARNING', | ||
183 | + 'class': 'logging.handlers.SysLogHandler', | ||
184 | + 'formatter': 'colab', | ||
185 | + 'address': '/dev/log', | ||
186 | + }, | ||
187 | + 'file': { | ||
188 | + 'level': 'DEBUG', | ||
189 | + 'class': 'logging.handlers.TimedRotatingFileHandler', | ||
190 | + 'filename': '/var/log/colab/colab.log', | ||
191 | + 'interval': 24, # 24 hours | ||
192 | + 'backupCount': 7, # keep last 7 backups | ||
193 | + 'encoding': 'UTF-8', | ||
194 | + 'formatter': 'verbose', | ||
195 | + }, | ||
196 | + }, | ||
197 | + | ||
198 | + 'loggers': { | ||
199 | + 'django': { | ||
200 | + 'handlers': ['file', 'syslog'], | ||
201 | + 'propagate': False, | ||
202 | + }, | ||
203 | + 'revproxy': { | ||
204 | + 'handlers': ['file', 'syslog'], | ||
205 | + 'propagate': False, | ||
206 | + 'level': 'ERROR', | ||
207 | + }, | ||
208 | + }, | ||
209 | +} | ||
139 | 210 | ||
140 | -mkdir -p /etc/colab/settings.d | ||
141 | - | ||
142 | -if [ ! -f /etc/colab/settings.d/00-database.yaml ]; then | ||
143 | - cat > /etc/colab/settings.d/00-database.yaml <<EOF | ||
144 | -DATABASES: | ||
145 | - default: | ||
146 | - ENGINE: django.db.backends.postgresql_psycopg2 | ||
147 | - NAME: colab | ||
148 | - USER: colab | ||
149 | - HOST: localhost | ||
150 | - PORT: 5432 | ||
151 | EOF | 211 | EOF |
152 | - chown root:colab /etc/colab/settings.d/00-database.yaml | ||
153 | - chmod 0640 /etc/colab/settings.d/00-database.yaml | ||
154 | -fi | ||
155 | 212 | ||
156 | -# only applies if there is a local PostgreSQL server | ||
157 | -if [ -x /usr/bin/postgres ]; then | ||
158 | - | ||
159 | - # start/enable the service | ||
160 | - postgresql-setup initdb || true | ||
161 | - systemctl start postgresql | ||
162 | - systemctl enable postgresql | ||
163 | - | ||
164 | - if [ "$(sudo -u postgres -i psql --quiet --tuples-only -c "select count(*) from pg_user where usename = 'colab';")" -eq 0 ]; then | ||
165 | - # create user | ||
166 | - sudo -u postgres -i createuser colab | ||
167 | - fi | ||
168 | - | ||
169 | - if [ "$(sudo -u postgres -i psql --quiet --tuples-only -c "select count(1) from pg_database where datname = 'colab';")" -eq 0 ]; then | ||
170 | - # create database | ||
171 | - sudo -u postgres -i createdb --owner=colab colab | ||
172 | - fi | ||
173 | - | ||
174 | - colab-admin migrate | 213 | + chown root:colab /etc/colab/settings.py |
214 | + chmod 0640 /etc/colab/settings.py | ||
175 | fi | 215 | fi |
176 | 216 | ||
177 | -mkdir -p /var/lock/colab | ||
178 | -chown colab:colab /var/lock/colab | ||
179 | - | ||
180 | -mkdir -p /var/lib/colab-assets | ||
181 | -chown colab:colab /var/lib/colab-assets | 217 | +install -d -m 0750 -o root -g colab /etc/colab/settings.d |
182 | 218 | ||
183 | -mkdir -p /usr/share/nginx/ | 219 | +install -d -m 0755 -o colab -g colab /var/lib/colab-assets |
184 | 220 | ||
185 | -ln -s /var/lib/colab-assets /usr/share/nginx/colab | 221 | +# If nginx is available serve assets using it |
222 | +if [ -d /usr/share/nginx ]; then | ||
223 | + ln -s /var/lib/colab/assets /usr/share/nginx/colab | ||
224 | +fi | ||
186 | 225 | ||
187 | -yes yes | colab-admin collectstatic | 226 | +chown -R colab:colab /var/lib/colab/assets |
227 | +colab-admin collectstatic --noinput | ||
188 | 228 | ||
189 | if [ $1 -gt 1 ]; then | 229 | if [ $1 -gt 1 ]; then |
190 | # upgrade; restart if running | 230 | # upgrade; restart if running |
191 | systemctl try-restart colab | 231 | systemctl try-restart colab |
192 | fi | 232 | fi |
193 | 233 | ||
234 | +systemctl daemon-reload | ||
235 | + | ||
194 | %preun | 236 | %preun |
195 | if [ $1 -eq 0 ]; then | 237 | if [ $1 -eq 0 ]; then |
196 | # package being removed | 238 | # package being removed |
mailman-api/mailman-api.spec
1 | %define name mailman-api | 1 | %define name mailman-api |
2 | -%define version 0.2.10 | ||
3 | -%define unmangled_version 0.2.10 | 2 | +%define version 0.3c1 |
3 | +%define unmangled_version 0.3c1 | ||
4 | %define release 1 | 4 | %define release 1 |
5 | 5 | ||
6 | Summary: REST API daemon to interact with Mailman 2 | 6 | Summary: REST API daemon to interact with Mailman 2 |