Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
slapos-caddy
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Guillaume Hervier
slapos-caddy
Commits
f8a696aa
Commit
f8a696aa
authored
Jun 23, 2014
by
Marco Mariani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
abilian: unoconv drop-in replacement
parent
37d8473c
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
101 additions
and
9 deletions
+101
-9
slapos/recipe/slapconfiguration.py
slapos/recipe/slapconfiguration.py
+6
-3
software/abilian/extranet_spr/cloudoooconv
software/abilian/extranet_spr/cloudoooconv
+60
-0
software/abilian/extranet_spr/instance-environment.cfg.in
software/abilian/extranet_spr/instance-environment.cfg.in
+3
-2
software/abilian/extranet_spr/instance-extranet.cfg.in
software/abilian/extranet_spr/instance-extranet.cfg.in
+1
-0
software/abilian/extranet_spr/instance.cfg.in
software/abilian/extranet_spr/instance.cfg.in
+2
-1
software/abilian/extranet_spr/software.cfg
software/abilian/extranet_spr/software.cfg
+29
-3
No files found.
slapos/recipe/slapconfiguration.py
View file @
f8a696aa
...
@@ -174,6 +174,9 @@ class JsonDump(Recipe):
...
@@ -174,6 +174,9 @@ class JsonDump(Recipe):
with
os
.
fdopen
(
os
.
open
(
self
.
_json_output
,
os
.
O_WRONLY
|
os
.
O_CREAT
|
os
.
O_TRUNC
,
0o600
),
'w'
)
as
fout
:
with
os
.
fdopen
(
os
.
open
(
self
.
_json_output
,
os
.
O_WRONLY
|
os
.
O_CREAT
|
os
.
O_TRUNC
,
0o600
),
'w'
)
as
fout
:
fout
.
write
(
json
.
dumps
(
parameter_dict
,
indent
=
2
,
sort_keys
=
True
))
fout
.
write
(
json
.
dumps
(
parameter_dict
,
indent
=
2
,
sort_keys
=
True
))
# also augment the buildout section
options
.
update
(
parameter_dict
)
def
install
(
self
):
def
install
(
self
):
return
[
self
.
_json_output
]
return
[
self
.
_json_output
]
...
...
software/abilian/extranet_spr/cloudoooconv
0 → 100755
View file @
f8a696aa
#!/usr/bin/env cloudoooconv-python
# -*- coding: utf-8 -*-
import
argparse
import
os
# ./conv.py -f pdf -o hello.pdf hello.odp
__version__
=
'0.1'
import
base64
import
sys
import
xmlrpclib
import
mimetypes
import
magic
extension_remap
=
{
'.xlb'
:
'.xls'
}
def
process_file
(
in_fn
,
out_fn
,
fmt
):
cloudooo_uri
=
os
.
environ
[
'CLOUDOOO_URI'
]
proxy
=
xmlrpclib
.
ServerProxy
(
cloudooo_uri
,
allow_none
=
True
)
with
file
(
in_fn
)
as
fin
:
data
=
fin
.
read
()
input_mimetype
=
magic
.
Magic
(
mime
=
True
).
from_buffer
(
data
)
input_extension
=
os
.
path
.
splitext
(
in_fn
)[
1
]
or
mimetypes
.
guess_extension
(
input_mimetype
)
input_extension
=
extension_remap
.
get
(
input_extension
,
input_extension
)
data
=
proxy
.
convertFile
(
base64
.
encodestring
(
data
),
input_extension
.
lstrip
(
'.'
),
fmt
)
with
file
(
out_fn
,
'wb'
)
as
fout
:
fout
.
write
(
base64
.
decodestring
(
data
))
def
run
(
argv
):
prog
=
argv
[
0
]
parser
=
argparse
.
ArgumentParser
(
prog
=
prog
)
parser
.
add_argument
(
'--version'
,
action
=
'version'
,
version
=
'%(prog)s v'
+
__version__
)
parser
.
add_argument
(
'-f'
,
'--format'
)
parser
.
add_argument
(
'-o'
,
'--output'
)
parser
.
add_argument
(
'input'
,
nargs
=
'?'
,
help
=
'input file'
)
args
=
parser
.
parse_args
(
argv
[
1
:])
if
'input'
in
args
:
process_file
(
args
.
input
,
args
.
output
,
args
.
format
)
else
:
sys
.
stderr
.
write
(
'%s: you have to provide a filename as argument
\
n
'
%
prog
)
sys
.
stderr
.
write
(
"Try `%s -h' for more information."
%
prog
)
if
__name__
==
'__main__'
:
run
(
sys
.
argv
)
software/abilian/extranet_spr/instance-environment.cfg.in
View file @
f8a696aa
...
@@ -13,9 +13,9 @@ ABILIAN_CONFIG=${abilian-config:location}/${abilian-config:filename}
...
@@ -13,9 +13,9 @@ ABILIAN_CONFIG=${abilian-config:location}/${abilian-config:filename}
EXTRANET_INSTANCE_PATH=$${directories:extranet_spr-instance}
EXTRANET_INSTANCE_PATH=$${directories:extranet_spr-instance}
ABILIAN_CONFIG_EXTRA_PYTHON=$${config-production-py:rendered}
ABILIAN_CONFIG_EXTRA_PYTHON=$${config-production-py:rendered}
ABILIAN_CONFIG_EXTRA_JSON=$${json-extra-configuration:json-output}:$${buildout:directory}/partition-parameters.json
ABILIAN_CONFIG_EXTRA_JSON=$${json-extra-configuration:json-output}:$${buildout:directory}/partition-parameters.json
CLOUDOOO_URI=$${json-configuration:CLOUDOOO_URI}
LD_LIBRARY_PATH=${cairo:location}/lib:${glib:location}/lib:${pango:location}/lib:${cups:location}/lib:${dbus:location}/lib:${dbus-glib:location}/lib:${fontconfig:location}/lib
LD_LIBRARY_PATH=${cairo:location}/lib:${glib:location}/lib:${pango:location}/lib:${cups:location}/lib:${dbus:location}/lib:${dbus-glib:location}/lib:${fontconfig:location}/lib
# abilian/services/conversion.py does not like it, if PATH does not exist
PATH=$${directories:bin}:${git:location}/bin:${poppler:location}/bin:${postgresql91:location}/bin:${redis:location}/bin:${unoconv-repository:location}:/usr/sbin:/usr/bin:/sbin:/bin
PATH=/usr/sbin:/usr/bin:/sbin:/bin:${git:location}/bin:${poppler:location}/bin:${postgresql91:location}/bin:${redis:location}/bin:${unoconv-repository:location}
...
@@ -31,6 +31,7 @@ inline =
...
@@ -31,6 +31,7 @@ inline =
export ABILIAN_CONFIG_EXTRA_PYTHON=$${instance-environment:ABILIAN_CONFIG_EXTRA_PYTHON}
export ABILIAN_CONFIG_EXTRA_PYTHON=$${instance-environment:ABILIAN_CONFIG_EXTRA_PYTHON}
export ABILIAN_CONFIG_EXTRA_JSON=$${instance-environment:ABILIAN_CONFIG_EXTRA_JSON}
export ABILIAN_CONFIG_EXTRA_JSON=$${instance-environment:ABILIAN_CONFIG_EXTRA_JSON}
export LD_LIBRARY_PATH=$${instance-environment:LD_LIBRARY_PATH}
export LD_LIBRARY_PATH=$${instance-environment:LD_LIBRARY_PATH}
export CLOUDOOO_URI=$${instance-environment:CLOUDOOO_URI}
export PATH=$${instance-environment:PATH}
export PATH=$${instance-environment:PATH}
output = $${buildout:directory}/environment.sh
output = $${buildout:directory}/environment.sh
...
...
software/abilian/extranet_spr/instance-extranet.cfg.in
View file @
f8a696aa
...
@@ -14,6 +14,7 @@ recipe = slapos.cookbook:symbolic.link
...
@@ -14,6 +14,7 @@ recipe = slapos.cookbook:symbolic.link
target-directory = $${directories:bin}
target-directory = $${directories:bin}
link-binary =
link-binary =
${buildout:directory}/bin/abilian
${buildout:directory}/bin/abilian
${buildout:directory}/bin/cloudoooconv-python
[extranet-service]
[extranet-service]
...
...
software/abilian/extranet_spr/instance.cfg.in
View file @
f8a696aa
...
@@ -44,7 +44,8 @@ cert = $${slap-connection:cert-file}
...
@@ -44,7 +44,8 @@ cert = $${slap-connection:cert-file}
[json-extra-configuration]
[json-extra-configuration]
recipe = slapos.cookbook:jsondump
recipe = slapos.cookbook:jsondump
json-output = $${buildout:directory}/abilian-config-extra.json
json-output = $${buildout:directory}/abilian-config-extra.json
UNOCONV_LOCATION = ${unoconv-repository:location}/unoconv
#UNOCONV_LOCATION = ${unoconv-repository:location}/unoconv
UNOCONV_LOCATION = ${cloudoooconv:location}/${cloudoooconv:filename}
BROKER_URL = redis://:$${redis-requirepass:passwd}@[$${redis:ipv4}]:$${redis:port}/2
BROKER_URL = redis://:$${redis-requirepass:passwd}@[$${redis:ipv4}]:$${redis:port}/2
CELERY_RESULT_BACKEND = redis://:$${redis-requirepass:passwd}@[$${redis:ipv4}]:$${redis:port}/2
CELERY_RESULT_BACKEND = redis://:$${redis-requirepass:passwd}@[$${redis:ipv4}]:$${redis:port}/2
SECRET_KEY = $${csrf-secret-key:passwd}
SECRET_KEY = $${csrf-secret-key:passwd}
...
...
software/abilian/extranet_spr/software.cfg
View file @
f8a696aa
...
@@ -23,6 +23,13 @@ extends =
...
@@ -23,6 +23,13 @@ extends =
parts =
parts =
slapos-cookbook
slapos-cookbook
# for poppler (pdftoppm, etc.)
liberation-fonts
ipaex-fonts
ipa-fonts
ocrb-fonts
android-fonts
weasyprint-repository
weasyprint-repository
flask-alembic-repository
flask-alembic-repository
flask-security-repository
flask-security-repository
...
@@ -46,6 +53,7 @@ parts =
...
@@ -46,6 +53,7 @@ parts =
psycopg2
psycopg2
gmp
gmp
eggs
eggs
imagemagick
imagemagick
poppler
poppler
cups
cups
...
@@ -65,6 +73,8 @@ parts =
...
@@ -65,6 +73,8 @@ parts =
config-staging-py-template
config-staging-py-template
config-production-py-template
config-production-py-template
abilian-config
abilian-config
cloudoooconv-python
cloudoooconv
find-links +=
find-links +=
...
@@ -229,7 +239,7 @@ configure-command =
...
@@ -229,7 +239,7 @@ configure-command =
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/instance.cfg.in
url = ${:_profile_base_location_}/instance.cfg.in
output = ${buildout:directory}/instance.cfg
output = ${buildout:directory}/instance.cfg
md5sum =
a865bcd6f894f28c69edf58d4df143ca
md5sum =
6aaed03a96475027eff404c430d7888f
mode = 0644
mode = 0644
[instance-postgres]
[instance-postgres]
...
@@ -250,14 +260,14 @@ mode = 0644
...
@@ -250,14 +260,14 @@ mode = 0644
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/instance-extranet.cfg.in
url = ${:_profile_base_location_}/instance-extranet.cfg.in
output = ${buildout:directory}/instance-extranet.cfg
output = ${buildout:directory}/instance-extranet.cfg
md5sum =
d39a2a7348866130ef4c63857e0f2945
md5sum =
55c580c54045bf21508088d6548c771a
mode = 0644
mode = 0644
[instance-environment]
[instance-environment]
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/instance-environment.cfg.in
url = ${:_profile_base_location_}/instance-environment.cfg.in
output = ${buildout:directory}/instance-environment.cfg
output = ${buildout:directory}/instance-environment.cfg
md5sum =
747242345673e3b241b50bab5609294b
md5sum =
b67de525594c9b522a99ef1890a98037
mode = 0644
mode = 0644
...
@@ -272,6 +282,22 @@ download-only = true
...
@@ -272,6 +282,22 @@ download-only = true
mode = 0755
mode = 0755
[cloudoooconv-python]
recipe = zc.recipe.egg
eggs = python-magic
interpreter = cloudoooconv-python
[cloudoooconv]
recipe = hexagonit.recipe.download
url = ${:_profile_base_location_}/cloudoooconv
md5sum = 5e6033e0f4d13d52229d952ea0faf0ce
location = ${buildout:parts-directory}/${:_buildout_section_name_}
filename = cloudoooconv
download-only = true
mode = 0755
[config-staging-py-template]
[config-staging-py-template]
recipe = hexagonit.recipe.download
recipe = hexagonit.recipe.download
url = ${:_profile_base_location_}/template/${:filename}
url = ${:_profile_base_location_}/template/${:filename}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment