Backport OVH modules from 10.0

This commit is contained in:
jcoux
2018-10-29 13:45:20 +01:00
parent c6a0e7c1f5
commit 7fc296d73e
12 changed files with 116 additions and 21 deletions
@@ -5,7 +5,7 @@
{'name': 'Attachments on Swift storage', {'name': 'Attachments on Swift storage',
'summary': 'Store assets and attachments on a Swift compatible object store', 'summary': 'Store assets and attachments on a Swift compatible object store',
'version': '10.0.1.1.0', 'version': '9.0.1.1.0',
'author': 'Camptocamp,Odoo Community Association (OCA)', 'author': 'Camptocamp,Odoo Community Association (OCA)',
'license': 'AGPL-3', 'license': 'AGPL-3',
'category': 'Knowledge Management', 'category': 'Knowledge Management',
+1 -1
View File
@@ -8,7 +8,7 @@ import logging
import os import os
from ..swift_uri import SwiftUri from ..swift_uri import SwiftUri
from odoo import api, exceptions, models, _ from openerp import api, exceptions, models, _
_logger = logging.getLogger(__name__) _logger = logging.getLogger(__name__)
@@ -5,7 +5,7 @@
import os import os
from mock import patch from mock import patch
from odoo.addons.base.tests.test_ir_attachment import TestIrAttachment from openerp.addons.base.tests.test_ir_attachment import TestIrAttachment
from ..swift_uri import SwiftUri from ..swift_uri import SwiftUri
@@ -2,7 +2,7 @@
# Copyright 2017 Camptocamp SA # Copyright 2017 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html)
from odoo.addons.base.tests.test_ir_attachment import TestIrAttachment from openerp.addons.base.tests.test_ir_attachment import TestIrAttachment
from ..swift_uri import SwiftUri from ..swift_uri import SwiftUri
from swiftclient.exceptions import ClientException from swiftclient.exceptions import ClientException
@@ -5,7 +5,7 @@
{'name': 'Base Attachment Object Store', {'name': 'Base Attachment Object Store',
'summary': 'Base module for the implementation of external object store.', 'summary': 'Base module for the implementation of external object store.',
'version': '10.0.1.2.0', 'version': '9.0.1.2.0',
'author': 'Camptocamp,Odoo Community Association (OCA)', 'author': 'Camptocamp,Odoo Community Association (OCA)',
'license': 'AGPL-3', 'license': 'AGPL-3',
'category': 'Knowledge Management', 'category': 'Knowledge Management',
@@ -9,7 +9,8 @@ import psycopg2
import odoo import odoo
from contextlib import closing, contextmanager from contextlib import closing, contextmanager
from odoo import api, exceptions, models, _ from openerp import api, exceptions, models, _
from openerp import SUPERUSER_ID
_logger = logging.getLogger(__name__) _logger = logging.getLogger(__name__)
@@ -40,10 +41,14 @@ class IrAttachment(models.Model):
_local_fields = ('image_small', 'image_medium', 'web_icon_data') _local_fields = ('image_small', 'image_medium', 'web_icon_data')
@api.cr @api.cr
def _register_hook(self): def _register_hook(self, cr):
super(IrAttachment, self)._register_hook() super(IrAttachment, self)._register_hook(cr)
# ignore if we are not using an object storage # ignore if we are not using an object storage
if self._storage() not in self._get_stores(): # Use directly SUPERUSER_ID
# because the uid parameter is required
# in function _storage and
# the SUPERUSER_ID is used directly instead of use the uid parameter.
if self._storage(cr, SUPERUSER_ID) not in self._get_stores():
return return
curframe = inspect.currentframe() curframe = inspect.currentframe()
calframe = inspect.getouterframes(curframe, 2) calframe = inspect.getouterframes(curframe, 2)
+1 -1
View File
@@ -10,7 +10,7 @@
'license': 'AGPL-3', 'license': 'AGPL-3',
'category': 'Extra Tools', 'category': 'Extra Tools',
'depends': [ 'depends': [
'attachment_s3', 'base_attachment_object_storage',
'session_redis', 'session_redis',
'monitoring_status', 'monitoring_status',
'logging_json', 'logging_json',
+89 -7
View File
@@ -30,6 +30,7 @@ PlatformConfig = namedtuple(
class FilestoreKind(object): class FilestoreKind(object):
db = 'db' db = 'db'
s3 = 's3' # or compatible s3 object storage s3 = 's3' # or compatible s3 object storage
swift = 'swift'
file = 'file' file = 'file'
@@ -37,26 +38,104 @@ class CloudPlatform(models.AbstractModel):
_name = 'cloud.platform' _name = 'cloud.platform'
@api.model @api.model
def _config_by_server_env(self, environment): def _platform_kinds(self):
# XXX for backward compatibility, we need this one here, move
# it in cloud_platform_exoscale in V11
return ['exoscale']
# XXX for backward compatibility, we need this one here, move
# it in cloud_platform_exoscale in V11
@api.model
def _config_by_server_env_for_exoscale(self):
configs = { configs = {
'prod': PlatformConfig(filestore=FilestoreKind.s3), 'prod': PlatformConfig(filestore=FilestoreKind.s3),
'integration': PlatformConfig(filestore=FilestoreKind.s3), 'integration': PlatformConfig(filestore=FilestoreKind.s3),
'test': PlatformConfig(filestore=FilestoreKind.db), 'test': PlatformConfig(filestore=FilestoreKind.db),
'dev': PlatformConfig(filestore=FilestoreKind.db), 'dev': PlatformConfig(filestore=FilestoreKind.db),
} }
return configs.get(environment) or configs['dev'] return configs
@api.model
def _config_by_server_env(self, platform_kind, environment):
configs_getter = getattr(
self,
'_config_by_server_env_for_%s' % platform_kind,
None
)
configs = configs_getter() if configs_getter else {}
return configs.get(environment) or FilestoreKind.db
# Due to the addition of the ovh cloud platform
# This will be moved to cloud_platform_exoscale on v11
@api.model @api.model
def install_exoscale(self): def install_exoscale(self):
self.install('exoscale')
@api.model
def install(self, platform_kind):
assert platform_kind in self._platform_kinds()
params = self.env['ir.config_parameter'].sudo() params = self.env['ir.config_parameter'].sudo()
params.set_param('cloud.platform.kind', 'exoscale') params.set_param('cloud.platform.kind', platform_kind)
environment = config['running_env'] environment = config['running_env']
configs = self._config_by_server_env(environment) configs = self._config_by_server_env(platform_kind, environment)
params.set_param('ir_attachment.location', configs.filestore) params.set_param('ir_attachment.location', configs.filestore)
self.check() self.check()
if configs.filestore == FilestoreKind.s3: if configs.filestore in [FilestoreKind.swift, FilestoreKind.s3]:
self.env['ir.attachment'].sudo().force_storage() self.env['ir.attachment'].sudo().force_storage()
_logger.info('cloud platform configured for exoscale') _logger.info('cloud platform configured for {}'.format(platform_kind))
@api.model
def _check_swift(self, environment_name):
params = self.env['ir.config_parameter'].sudo()
use_swift = (params.get_param('ir_attachment.location') ==
FilestoreKind.swift)
if environment_name in ('prod', 'integration'):
assert use_swift, (
"Swift must be used on production and integration instances. "
"It is activated, setting 'ir_attachment.location.' to 'swift'"
" The 'install_exoscale()' function sets this option "
"automatically."
)
if use_swift:
assert os.environ.get('SWIFT_AUTH_URL'), (
"SWIFT_AUTH_URL environment variable is required when "
"ir_attachment.location is 'swift'."
)
assert os.environ.get('SWIFT_ACCOUNT'), (
"SWIFT_ACCOUNT environment variable is required when "
"ir_attachment.location is 'swift'."
)
assert os.environ.get('SWIFT_PASSWORD'), (
"SWIFT_PASSWORD environment variable is required when "
"ir_attachment.location is 'swift'."
)
container_name = os.environ['SWIFT_WRITE_CONTAINER']
if environment_name in ('integration', 'prod'):
assert container_name, (
"SWIFT_WRITE_CONTAINER must not be empty for prod "
"and integration"
)
prod_container = bool(re.match(r'[a-z]+-odoo-prod',
container_name))
if environment_name == 'prod':
assert prod_container, (
"SWIFT_WRITE_CONTAINER should match '<client>-odoo-prod', "
"we got: '%s'" % (container_name,)
)
else:
# if we are using the prod bucket on another instance
# such as an integration, we must be sure to be in read only!
assert not prod_container, (
"SWIFT_WRITE_CONTAINER should not match "
"'<client>-odoo-prod', we got: '%s'" % (container_name,)
)
elif environment_name == 'test':
# store in DB so we don't have files local to the host
assert params.get_param('ir_attachment.location') == 'db', (
"In test instances, files must be stored in the database with "
"'ir_attachment.location' set to 'db'. This is "
"automatically set by the function 'install_ovh()'."
)
@api.model @api.model
def _check_s3(self, environment_name): def _check_s3(self, environment_name):
@@ -148,7 +227,10 @@ class CloudPlatform(models.AbstractModel):
) )
return return
environment_name = config['running_env'] environment_name = config['running_env']
self._check_s3(environment_name) if kind == 'exoscale':
self._check_s3(environment_name)
elif kind == 'ovh':
self._check_swift(environment_name)
self._check_redis(environment_name) self._check_redis(environment_name)
@api.cr @api.cr
+4
View File
@@ -3,3 +3,7 @@
def install_exoscale(ctx): def install_exoscale(ctx):
ctx.env['cloud.platform'].install_exoscale() ctx.env['cloud.platform'].install_exoscale()
def install_ovh(ctx):
ctx.env['cloud.platform'].install('ovh')
@@ -5,7 +5,7 @@
{'name': 'Cloud Platform OVH', {'name': 'Cloud Platform OVH',
'summary': 'Addons required for the Camptocamp Cloud Platform on OVH', 'summary': 'Addons required for the Camptocamp Cloud Platform on OVH',
'version': '10.0.1.1.0', 'version': '9.0.1.1.0',
'author': 'Camptocamp,Odoo Community Association (OCA)', 'author': 'Camptocamp,Odoo Community Association (OCA)',
'license': 'AGPL-3', 'license': 'AGPL-3',
'category': 'Extra Tools', 'category': 'Extra Tools',
+5 -3
View File
@@ -4,13 +4,15 @@
import logging import logging
from odoo import api, models from openerp import api, models
_logger = logging.getLogger(__name__) _logger = logging.getLogger(__name__)
try: try:
from odoo.addons.cloud_platform.models.cloud_platform import FilestoreKind from openerp.addons.cloud_platform.models.cloud_platform \
from odoo.addons.cloud_platform.models.cloud_platform import PlatformConfig import FilestoreKind
from openerp.addons.cloud_platform.models.cloud_platform \
import PlatformConfig
except ImportError: except ImportError:
FilestoreKind = None FilestoreKind = None
PlatformConfig = None PlatformConfig = None
+2
View File
@@ -2,3 +2,5 @@ boto==2.42.0
redis==2.10.5 redis==2.10.5
python-json-logger==0.1.5 python-json-logger==0.1.5
statsd==3.2.1 statsd==3.2.1
python-swiftclient==3.4.0
python-keystoneclient==3.13.0