отсутствует 1 обязательный позиционный аргумент: 'self' в odoo? - PullRequest
0 голосов
/ 10 февраля 2019

Я пытаюсь создать функцию для отправки сообщения определенному пользователю для этого в моей модели. Я написал этот код

class SkypeBot(models.Model):
    _name = 'my.skype'
    _inherit = ['mail.thread', 'mail.activity', 'res.users']
    _description = 'My Skype'


    skype_login = fields.Char('Your skype Login')
    skype_password = fields.Char('Your skype password')
    skype_message = fields.Char(store=True)

    @api.multi
    def msg(self, message):

        partner_id = self.env['res.users'].search([('id', '=', 2)]).partner_id.id

        _logger.info('^^^^^' * 5)
        _logger.warning(partner_id)
        _logger.info('^^^^^' * 5)

        self.env['mail.message'].create({'message_type': 'notification',
                                         'subtype': self.env.ref('mail.mt_comment').id,  # subject type
                                         'body': message,
                                         'subject': 'Message subject',
                                         'partner_ids': [(4, partner_id), ],
                                         # partner to whom you send notification
                                         })

Я хочу вызвать этот метод (msg) из другого класса MySkype.:

class MySkype(skpy.SkypeEventLoop):
    def onEvent(self, event):
        if isinstance(event, skpy.SkypeNewMessageEvent):  

            message = ('New message from user {} at {}: \'{} \''.format(event.msg.userId,
                                                                   event.msg.time.strftime('%H:%M dd. %d.%m.%Y'),
                                                                   event.msg.content))


            _logger.info('--------'*5)
            _logger.warning(event)
            _logger.info('--------' * 5)
            _logger.warning(message)
            _logger.info('--------' * 5)

            skype_model.SkypeBot.msg(message=message)

from skpy import Skype

sk = MySkype('+375', '1239qW', autoAck=True)
thread = threading.Thread(target=sk.loop)
thread.start()

, но когда вызывается этот метод, я получаю сообщение об ошибке

лют 10 10:42:00 PK odoo12[8534]: 2019-02-10 07:42:00,618 8534 INFO ? odoo.addons.bus.models.bus: Bus.loop listen imbus on db postgres
лют 10 10:42:50 PK odoo12[8534]: 2019-02-10 07:42:50,620 8534 INFO odoo12 werkzeug: 127.0.0.1 - - [10/Feb/2019 07:42:50] "POST /longpolling/poll HTTP/1.1" 200 - 35 0.030 53.925
лют 10 10:42:55 PK odoo12[8534]: 2019-02-10 07:42:55,056 8534 INFO ? odoo.addons.skype_bot.skype_send_message: —--------------------------------------
лют 10 10:42:55 PK odoo12[8534]: 2019-02-10 07:42:55,056 8534 WARNING ? odoo.addons.skype_bot.skype_send_message: [SkypeNewMessageEvent]
лют 10 10:42:55 PK odoo12[8534]: Id: 1014
лют 10 10:42:55 PK odoo12[8534]: Type: NewMessage
лют 10 10:42:55 PK odoo12[8534]: Time: 2019-02-10 07:42:54
лют 10 10:42:55 PK odoo12[8534]: MsgId: 1549784574906
лют 10 10:42:55 PK odoo12[8534]: 2019-02-10 07:42:55,057 8534 INFO ? odoo.addons.skype_bot.skype_send_message: —--------------------------------------
лют 10 10:42:55 PK odoo12[8534]: 2019-02-10 07:42:55,057 8534 WARNING ? odoo.addons.skype_bot.skype_send_message: Test!Test!Test!Test!Test!
лют 10 10:42:55 PK odoo12[8534]: 2019-02-10 07:42:55,057 8534 INFO ? odoo.addons.skype_bot.skype_send_message: —--------------------------------------
лют 10 10:43:40 PK odoo12[8534]: Exception in thread Thread-2:
лют 10 10:43:40 PK odoo12[8534]: Traceback (most recent call last):
лют 10 10:43:40 PK odoo12[8534]: File "/usr/lib/python3.6/threading.py", line 916, in _bootstrap_inner
лют 10 10:43:40 PK odoo12[8534]: self.run()
лют 10 10:43:40 PK odoo12[8534]: File "/usr/lib/python3.6/threading.py", line 864, in run
лют 10 10:43:40 PK odoo12[8534]: self._target(*self._args, **self._kwargs)
лют 10 10:43:40 PK odoo12[8534]: File "/opt/odoo12/odoo-venv/lib/python3.6/site-packages/skpy/main.py", line 207, in loop
лют 10 10:43:40 PK odoo12[8534]: self.cycle()
лют 10 10:43:40 PK odoo12[8534]: File "/opt/odoo12/odoo-venv/lib/python3.6/site-packages/skpy/main.py", line 196, in cycle
лют 10 10:43:40 PK odoo12[8534]: self.onEvent(event)
лют 10 10:43:40 PK odoo12[8534]: File "/opt/odoo12/odoo-custom-addons/skype_bot/skype_send_message.py", line 33, in onEvent
лют 10 10:43:40 PK odoo12[8534]: skype_model.SkypeBot.msg(message=message)
лют 10 10:43:40 PK odoo12[8534]: TypeError: msg() missing 1 required positional argument: 'self'
лют 10 10:43:40 PK odoo12[8534]: 2019-02-10 07:43:40,702 8534 INFO odoo12 werkzeug: 127.0.0.1 - - [10/Feb/2019 07:43:40] "POST /longpolling/poll HTTP/1.1" 200 - 8 0.003 50.051

что я делаю не так и как мне решить эту проблему

Я пытался использовать@ api.model это не помогло мне.Кажется, у меня проблема с инициализацией среды odoo, но я точно могу понять, где

1 Ответ

0 голосов
/ 10 февраля 2019

Как упоминалось в @ TigerhawkT3, вы вызываете метод, как если бы он был статическим методом, а не методом класса.

В Python первый аргумент каждого метода класса (включая *)1004 *) всегда является ссылкой на текущий экземпляр класса.По соглашению этот аргумент всегда имеет имя self. ¹

. Для правильного вызова этого метода необходимо создать экземпляр класса SkypeBot и * 1012.* then call msg():

sbot = SkypeBot()
sbot.msg(message)

Для получения дополнительной информации о решениях по проектированию языка, которые были включены в явное объявление self в качестве параметра, см. этот пост переполнения стека и эта статья Гвидо ван Россум .

...