feat: port to rougail secret_manager
This commit is contained in:
parent
60c0db5d1d
commit
608edbece0
7 changed files with 128 additions and 55 deletions
56
locale/fr/LC_MESSAGES/rougail_structural_bitwarden.po
Normal file
56
locale/fr/LC_MESSAGES/rougail_structural_bitwarden.po
Normal file
|
|
@ -0,0 +1,56 @@
|
|||
# SOME DESCRIPTIVE TITLE.
|
||||
# Copyright (C) YEAR ORGANIZATION
|
||||
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: \n"
|
||||
"POT-Creation-Date: 2025-03-11 12:46+0100\n"
|
||||
"PO-Revision-Date: 2025-03-11 12:52+0100\n"
|
||||
"Last-Translator: \n"
|
||||
"Language-Team: \n"
|
||||
"Language: fr\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Generated-By: pygettext.py 1.5\n"
|
||||
"X-Generator: Poedit 3.5\n"
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:47
|
||||
msgid ""
|
||||
"only \"unix_user\" or \"secret\" variable type can have \"bitwarden\" "
|
||||
"attribute, but \"{0}\" has type \"{1}\""
|
||||
msgstr ""
|
||||
"seulement une variable du type \"unix_user\" ou \"secret\" peut avoir un "
|
||||
"attribut \"bitwarden\", mais \"{0}\" a le type \"{1}\""
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:50
|
||||
msgid ""
|
||||
"the variable \"{0}\" has attribute \"bitwarden\" but is a multi variable"
|
||||
msgstr ""
|
||||
"la variable \"{0}\" a l'attribut \"bitwarden\" mais est une variable "
|
||||
"multiple"
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:59
|
||||
msgid ""
|
||||
"the variable \"{0}\" is a follower and leader variable (\"{1}\") is also in "
|
||||
"Bitwarden so this variable could not have default value"
|
||||
msgstr ""
|
||||
"la variable \"{0}\" est une variable suiveuse et la variable meneuse "
|
||||
"(\"{1}\") est aussi dans Bitwarden donc cette variable ne peut avoir avoir "
|
||||
"de valeur par défaut"
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:63
|
||||
msgid "the variable \"{0}\" is in Bitwarden so should have default value"
|
||||
msgstr ""
|
||||
"la variable \"{0}\" est dans Bitwarden donc cette variable devrait avoir un "
|
||||
"valeur par défaut"
|
||||
|
||||
#: src/rougail/structural_bitwarden/config.py:31
|
||||
msgid "The secret pattern to build item name in Bitwarden"
|
||||
msgstr ""
|
||||
"Le patron du secret pour construire le nom de l'élément dans Bitwarden"
|
||||
|
||||
#: src/rougail/structural_bitwarden/config.py:32
|
||||
msgid "The pattern is in Jinja format"
|
||||
msgstr "Le patron est au format Jinja"
|
||||
41
locale/rougail_structural_bitwarden.pot
Normal file
41
locale/rougail_structural_bitwarden.pot
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
# SOME DESCRIPTIVE TITLE.
|
||||
# Copyright (C) YEAR ORGANIZATION
|
||||
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"POT-Creation-Date: 2025-03-11 12:52+0100\n"
|
||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Generated-By: pygettext.py 1.5\n"
|
||||
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:47
|
||||
msgid "only \"unix_user\" or \"secret\" variable type can have \"bitwarden\" attribute, but \"{0}\" has type \"{1}\""
|
||||
msgstr ""
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:50
|
||||
msgid "the variable \"{0}\" has attribute \"bitwarden\" but is a multi variable"
|
||||
msgstr ""
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:59
|
||||
msgid "the variable \"{0}\" is a follower and leader variable (\"{1}\") is also in Bitwarden so this variable could not have default value"
|
||||
msgstr ""
|
||||
|
||||
#: src/rougail/structural_bitwarden/annotator.py:63
|
||||
msgid "the variable \"{0}\" is in Bitwarden so should have default value"
|
||||
msgstr ""
|
||||
|
||||
#: src/rougail/structural_bitwarden/config.py:31
|
||||
msgid "The secret pattern to build item name in Bitwarden"
|
||||
msgstr ""
|
||||
|
||||
#: src/rougail/structural_bitwarden/config.py:32
|
||||
msgid "The pattern is in Jinja format"
|
||||
msgstr ""
|
||||
|
||||
|
|
@ -15,7 +15,5 @@ details.
|
|||
You should have received a copy of the GNU Lesser General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
"""
|
||||
from .object_model import Variable
|
||||
|
||||
|
||||
__all__ = ("Variable",)
|
||||
__all__ = tuple()
|
||||
|
|
|
|||
|
|
@ -20,13 +20,14 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|||
"""
|
||||
from rougail.error import DictConsistencyError
|
||||
from rougail.annotator.variable import Walk
|
||||
from rougail.object_model import JinjaCalculation
|
||||
from .i18n import _
|
||||
|
||||
|
||||
class Annotator(Walk):
|
||||
"""Annotate for bitwarden"""
|
||||
|
||||
level = 95
|
||||
level = 90
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
|
|
@ -40,30 +41,12 @@ class Annotator(Walk):
|
|||
|
||||
def check_variable(self):
|
||||
for variable in self.get_variables():
|
||||
if not variable.bitwarden:
|
||||
if not variable.secret_manager:
|
||||
continue
|
||||
path = variable.path
|
||||
if variable.type not in ["unix_user", "secret"]:
|
||||
msg = _('only "unix_user" or "secret" variable type can have "bitwarden" attribute, but "{0}" has type "{1}"')
|
||||
raise DictConsistencyError(msg.format(path, variable.type), 301, variable.xmlfiles)
|
||||
if variable.multi and path not in self.objectspace.leaders:
|
||||
msg = _('the variable "{0}" has attribute "bitwarden" but is a multi variable')
|
||||
raise DictConsistencyError(msg.format(path), 302, variable.xmlfiles)
|
||||
check_default_value = True
|
||||
if path in self.objectspace.followers:
|
||||
leadership = path.rsplit('.', 1)[0]
|
||||
leader_path = self.objectspace.parents[leadership][0]
|
||||
leader = self.objectspace.paths[leader_path]
|
||||
if leader.bitwarden:
|
||||
if variable.default:
|
||||
msg = _('the variable "{0}" is a follower and leader variable ("{1}") is also in Bitwarden so this variable could not have default value')
|
||||
raise DictConsistencyError(msg.format(path, leader_path), 303, variable.xmlfiles)
|
||||
check_default_value = False
|
||||
if check_default_value and not variable.default:
|
||||
msg = _('the variable "{0}" is in Bitwarden so should have default value')
|
||||
raise DictConsistencyError(msg.format(path), 304, variable.xmlfiles)
|
||||
self.objectspace.informations.add(path, "bitwarden", True)
|
||||
self.objectspace.informations.add(path, "default_value_makes_sense", False)
|
||||
self.objectspace.properties.add(path, "novalidator", True)
|
||||
if 'force_default_on_freeze' in self.objectspace.properties.get(path):
|
||||
self.objectspace.properties.remove(path, 'force_default_on_freeze')
|
||||
variable.default = variable.secret_manager
|
||||
|
|
|
|||
26
src/rougail/structural_bitwarden/i18n.py
Normal file
26
src/rougail/structural_bitwarden/i18n.py
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
"""
|
||||
Silique (https://www.silique.fr)
|
||||
Copyright (C) 2025
|
||||
|
||||
This program is free software: you can redistribute it and/or modify it
|
||||
under the terms of the GNU Lesser General Public License as published by the
|
||||
Free Software Foundation, either version 3 of the License, or (at your
|
||||
option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||
FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
||||
details.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
"""
|
||||
|
||||
from gettext import translation
|
||||
from pathlib import Path
|
||||
|
||||
t = translation(
|
||||
"rougail_structural_bitwarden", str(Path(__file__).parent / "locale"), fallback=True
|
||||
)
|
||||
|
||||
_ = t.gettext
|
||||
Binary file not shown.
|
|
@ -1,31 +0,0 @@
|
|||
"""
|
||||
Silique (https://www.silique.fr)
|
||||
Copyright (C) 2025
|
||||
|
||||
distribued with GPL-2 or later license
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
"""
|
||||
from typing import Optional
|
||||
from pydantic import BaseModel
|
||||
|
||||
|
||||
class Variable(BaseModel):
|
||||
bitwarden: bool=False
|
||||
|
||||
|
||||
__all__ = ('Variable',)
|
||||
|
||||
|
||||
Loading…
Reference in a new issue