[IMP] Improve ospp_base and ospp_slide modules
							parent
							
								
									3c69065731
								
							
						
					
					
						commit
						3eacffc1f7
					
				|  | @ -43,7 +43,7 @@ class OSPPInstance(models.Model): | |||
|         tracking=True) | ||||
|     management_api = fields.Char('Management Api', required=True, tracking=True) | ||||
|     management_key = fields.Char('Management Key', tracking=True) | ||||
|     management_secret = fields.Char('Management Secret', tracking=True) | ||||
|     management_secret = fields.Char('Management Secret') | ||||
|     service_base_host = fields.Char('Service Base Host', tracking=True) | ||||
|     service_scheme = fields.Selection( | ||||
|         [('http', 'HTTP'), ('https', 'HTTPS'), ('ws', 'WS'), ('wss', 'WSS')], | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ | |||
|               <group> | ||||
|                 <field name="management_api"/> | ||||
|                 <field name="management_key"/> | ||||
|                 <field name="management_secret"/> | ||||
|                 <field name="management_secret" password="True"/> | ||||
|               </group> | ||||
|               <group> | ||||
|                 <field name="service_base_host"/> | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| 
 | ||||
| import random | ||||
| import requests | ||||
| from urllib.parse import urlencode | ||||
| import uuid | ||||
| from odoo import models, fields, api, _ | ||||
| from odoo.exceptions import UserError, ValidationError | ||||
|  | @ -157,6 +159,43 @@ class ChannelInstance(models.Model): | |||
|     demo_data = fields.Boolean('Demo Data', default=True) | ||||
|     is_notified = fields.Boolean('Is Notified', default=False) | ||||
| 
 | ||||
|     def action_generate_instance(self): | ||||
|         for rec in self: | ||||
|             if rec.instance_created: | ||||
|                 return True | ||||
| 
 | ||||
|             url = f"{rec.instance_id.management_api}/web/database/create" | ||||
|             master_pwd = f"{rec.instance_id.management_secret}" | ||||
|             dbname = rec.service_name | ||||
|             login = rec.admin_account | ||||
|             password = rec.admin_password | ||||
|             phone = '' | ||||
|             lang = 'zh_CN' | ||||
|             country_code = 'cn' | ||||
|             demo = 1 if rec.demo_data else 0 | ||||
| 
 | ||||
|             headers = { | ||||
|                 'Content-Type': 'application/x-www-form-urlencoded', | ||||
|                 'Cookie': 'frontend_lang=en_US; session_id=645c41edf8f8c7e1e983ba0f5bd9e94d9a3bd4bc' | ||||
|             } | ||||
| 
 | ||||
|             payload = { | ||||
|                 'master_pwd': master_pwd, | ||||
|                 'name': dbname, | ||||
|                 'login': login, | ||||
|                 'password': password, | ||||
|                 'phone': phone, | ||||
|                 'lang': lang, | ||||
|                 'country_code': country_code, | ||||
|                 'demo': demo | ||||
|             } | ||||
| 
 | ||||
|             response = requests.request("POST", url, headers=headers, data=urlencode(payload)) | ||||
|             rec.message = response.text | ||||
|             if response.status_code == 200 and 'error' not in response.text: | ||||
|                 rec.instance_created = True | ||||
|             return True | ||||
| 
 | ||||
|     def name_get(self): | ||||
|         # Prefetch the fields used by the `name_get`, so `browse` doesn't fetch other fields | ||||
|         self.browse(self.ids).read(['name', 'code']) | ||||
|  |  | |||
|  | @ -34,6 +34,9 @@ | |||
|                             <field name="instance_created" optional="hide"/> | ||||
|                             <field name="is_notified" optional="hide"/> | ||||
|                             <field name="user_scope" widget="many2many_tags" invisible="1"/> | ||||
|                             <button name="action_generate_instance" data-hotkey="v" | ||||
|                                      string="Generate Instance" type="object" | ||||
|                                      attrs="{'invisible': [('instance_created', '=', True)]}"/> | ||||
|                         </tree> | ||||
|                         <form> | ||||
|                             <group> | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Oliver Yuan
						Oliver Yuan