feat: port to rougail secret_manager

This commit is contained in:
egarette@silique.fr 2025-03-19 10:14:39 +01:00
parent 60c0db5d1d
commit 608edbece0
7 changed files with 128 additions and 55 deletions

View 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"

View 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 ""

View file

@ -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()

View file

@ -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

View 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

View file

@ -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',)