mirror of
https://github.com/bringout/oca-server-auth.git
synced 2026-04-19 15:12:02 +02:00
Initial commit: OCA Server Auth packages (29 packages)
This commit is contained in:
commit
3ed80311c4
1325 changed files with 127292 additions and 0 deletions
|
|
@ -0,0 +1,47 @@
|
|||
# © 2021 Florian Kantelberg - initOS GmbH
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
import logging
|
||||
|
||||
from odoo import _, api, fields, models
|
||||
|
||||
_logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class VaultStoreWizard(models.TransientModel):
|
||||
_name = "vault.store.wizard"
|
||||
_description = _("Wizard store a shared secret in a vault")
|
||||
|
||||
vault_id = fields.Many2one("vault", "Vault", required=True)
|
||||
entry_id = fields.Many2one(
|
||||
"vault.entry",
|
||||
"Entry",
|
||||
domain="[('vault_id', '=', vault_id)]",
|
||||
required=True,
|
||||
)
|
||||
model = fields.Char(required=True)
|
||||
master_key = fields.Char(compute="_compute_master_key", store=False)
|
||||
name = fields.Char(required=True)
|
||||
iv = fields.Char(required=True)
|
||||
key = fields.Char(required=True)
|
||||
secret = fields.Char(required=True)
|
||||
secret_temporary = fields.Char(required=True)
|
||||
|
||||
@api.depends("entry_id", "vault_id")
|
||||
def _compute_master_key(self):
|
||||
for rec in self:
|
||||
rec.master_key = rec.vault_id.master_key
|
||||
|
||||
def action_store(self):
|
||||
self.ensure_one()
|
||||
try:
|
||||
self.env[self.model].create(
|
||||
{
|
||||
"entry_id": self.entry_id.id,
|
||||
"name": self.name,
|
||||
"iv": self.iv,
|
||||
"value": self.secret,
|
||||
}
|
||||
)
|
||||
except Exception as e:
|
||||
_logger.exception(e)
|
||||
Loading…
Add table
Add a link
Reference in a new issue