🚲 Tanguy Ortolo a écrit 12285 commentaires

  • # En Python

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 5. Évalué à 3. Dernière modification le 05 décembre 2022 à 11:37.

    Ce qui est assez casse-pied dans ce problème, c'est que les données d'entrées sont dans un ordre qui est optimisé pour la lecture par un lutin grutier ou en l'occurrence une lutine grutière.

    Bref, voici le code :

    import re
    
    from collections import deque
    from io import StringIO
    from typing import Dict, List, Iterable, Iterator, MutableSequence, Sequence
    from typing_extensions import Protocol
    
    
    class Crane(Protocol):
        def load(self, stacks: Sequence[MutableSequence[str]],
                 labels: Iterable[str]) -> None:
            ...
    
        def move(self, orig: str, dest: str, n: int) -> None:
            ...
    
        def top(self) -> str:
            ...
    
    
    class CrateMover:
        def __init__(self) -> None:
            self.stacks = {}  # type: Dict[str, MutableSequence[str]]
            self.labels = []  # type: List[str]
    
        def load(self, stacks: Sequence[MutableSequence[str]],
                 labels: Iterable[str]) -> None:
            for stack, label in zip(stacks, labels):
                self.stacks[label] = stack
            for label in labels:
                self.labels.append(label)
    
        def top(self) -> str:
            result = StringIO()
            for label in self.labels:
                result.write(self.stacks[label][-1])
            return result.getvalue()
    
    
    class CrateMover9000(CrateMover):
        def __init__(self, *args, **kwargs) -> None:
            super().__init__()
    
        def move(self, orig: str, dest: str, n: int) -> None:
            orig_stack = self.stacks[orig]
            dest_stack = self.stacks[dest]
            for _ in range(n):
                dest_stack.append(orig_stack.pop())
    
    
    class CrateMover9001(CrateMover):
        def __init__(self, *args, **kwargs) -> None:
            super().__init__()
    
        def move(self, orig: str, dest: str, n: int) -> None:
            orig_stack = self.stacks[orig]
            dest_stack = self.stacks[dest]
            temp_stack = deque()  # type: deque[str]
            for _ in range(n):
                temp_stack.appendleft(orig_stack.pop())
            dest_stack.extend(temp_stack)
    
    
    def solve(lines: Iterator[str], crane: Crane) -> str:
        re_crates = re.compile(r'^\s*\[')
        stacks = []   # type: List[deque[str]]
        # First lines are crate stack descriptions
        for line in lines:
            if re_crates.match(line):
                # This line describes stacked crates
                for i, label in enumerate(line[1:len(line):4]):
                    if i >= len(stacks):
                        stacks.append(deque())
                    stack = stacks[i]
                    if label != ' ':
                        stack.appendleft(label)
            else:
                # This line provides the labels of crate stacks
                break
        # Current line provides the labels of crate stacks
        labels = line[1:len(line):4]
        # We have enough data to load the crane with crate stacks
        crane.load(stacks, labels)
        # Next line is a blank one
        s = next(lines)
        # Next lines are crate moving instructions
        re_instruction = re.compile(r'^move (\d+) from (.) to (.)$')
        for line in lines:
            m = re_instruction.match(line)
            if m is None:
                raise ValueError("unrecognized input line")
            n = int(m.group(1))
            orig = m.group(2)
            dest = m.group(3)
            crane.move(orig, dest, n)
        return crane.top()
    
    
    def part1(data: Iterable[str]) -> str:
        crane = CrateMover9000()
        return solve(iter(data), crane)
    
    
    def part2(data: Iterable[str]) -> str:
        crane = CrateMover9001()
        return solve(iter(data), crane)
  • # En Python

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 4. Évalué à 4.

    En Python, en utilisant une classe dédiée (je trouve que ça se lit mieux ainsi) :

    from typing import Iterable, Tuple
    
    import aoc
    
    
    class Interval:
        """An interval of integers"""
        def __init__(self, start: int, end: int):
            """Create a new interval of integers, from start to end included"""
            self.start = start
            self.end = end
    
        def includes(self, other):
            """Does this interval include the other one?"""
            return self.start <= other.start and self.end >= other.end
    
        def overlaps(self, other):
            """Does this interval overlap the other one?"""
            return self.end >= other.start and self.start <= other.end
    
    
    def import_interval(s: str) -> Interval:
        """Import an interval from a string such as "2-4" """
        part1, part2 = s.split('-')
        return Interval(int(part1), int(part2))
    
    
    def import_pairs(lines: Iterable[str]) -> Iterable[Tuple[Interval, Interval]]:
        """Import a pair of intervals from a line such as "2-4,5-8\\n" """
        for line in lines:
            part1, part2 = line.rstrip().split(',')
            yield import_interval(part1), import_interval(part2)
    
    
    def solve_both(lines: Iterable[str]) -> Tuple[int, int]:
        """Solve both parts of today's puzzle"""
        inclusions = 0
        overlaps = 0
        for a1, a2 in import_pairs(lines):
            if a1.includes(a2) or a2.includes(a1):
                inclusions += 1
            if a1.overlaps(a2):
                overlaps += 1
        return inclusions, overlaps
  • [^] # Re: un bout de AWK

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 4. Évalué à 5.

    C'était en effet parfaitement taillé pour Awk !

  • # En Python, classieux

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 3. Évalué à 3.

    #! /usr/bin/python3
    
    # Advent of Code 2022, day 2
    
    from typing import Iterable, Optional, TypeVar
    
    # '@' is not a valid item type, but it does no harm, and having it makes the
    # value of each item type equal to its index in this string. :-)
    letters = "@abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
    priorities = {letter: value for (value, letter) in enumerate(letters)}
    
    
    class Rucksack:
        def __init__(self, left: str, right: str):
            self.left = left
            self.right = right
    
        def anomaly(self) -> str:
            for letter in self.left:
                if letter in self.right:
                    return letter
            raise ValueError("no anomaly in this rucksack")
    
        def __contains__(self, letter: str) -> bool:
            return letter in self.left or letter in self.right
    
    
    def import_sack(line):
        n = len(line) - 1  # do not count final '\n'
        left = line[0:n//2]
        right = line[n//2:n]
        return Rucksack(left, right)
    
    
    T = TypeVar('T')
    
    
    def group(iterable: Iterable[T], n: int) -> Iterable[list[T]]:
        result = []  # type: list[T]
        for item in iterable:
            result.append(item)
            if len(result) >= n:
                yield result
                result = []
        yield result
    
    
    def part1(lines: Iterable[str]) -> int:
        total = 0
        for line in lines:
            sack = import_sack(line)
            total += priorities[sack.anomaly()]
        return total
    
    
    def part2(lines: Iterable[str]) -> int:
        total = 0
        for line_group in group(lines, 3):
            sacks = [import_sack(line) for line in line_group]
            for letter in letters:
                if all(letter in sack for sack in sacks):
                    total += priorities[letter]
                    break
        return total
  • [^] # Re: DĂ©jĂ  dans la rubrique liens

    Posté par  (site web personnel) . En réponse au journal Office 365 et Google Workspace en difficulté chez l'école républicaine. Évalué à 10. Dernière modification le 02 décembre 2022 à 15:33.

    Le ministère demande des choses mais que propose-t-il ? Existe-t-il des solutions alternatives qui seraient fournies par l'éducation nationale ?

    Oui : étudier sans informatique, sauf lorsqu'il s'agit d'apprendre la bureautique et l'informatique.

    Sérieusement, les connaissances de compétences de base que l'école est censée transmettre n'ont pas changé depuis cinquante ans, c'est toujours lire, compter, calculer, réfléchir, puis pour aller plus loin, étudier des textes littéraires, résumer, raisonner, avec des bases en diverses sciences. Que des trucs qui se faisaient très bien sans informatique, et qui peuvent toujours très bien se faire sans informatique.

    Je soupçonne même que ces trucs se feraient sans doute mieux sans informatique.

    L'informatique est indispensable lorsqu'il s'agit d'apprendre la bureautique. Ça se fait sans problème sous Google ni Microsoft. L'informatique est, en revanche, secondaire lorsqu'il s'agit d'apprendre la programmation, c'est important à rappeler. L'algorithmique et toute ça théorique, ça se fait sans ordinateur, en tout cas sans coder, donc sans problème avec un tableau noir et du papier.

  • # En Python bref

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 2. Évalué à 4.

    Toujours en Python, mais aujourd'hui, point de modélisation objet, c'est du concis, plus en mode calcul :

    from typing import Iterable, Tuple
    
    def solve_both(lines: Iterable[str]) -> Tuple[int, int]:
        # Symbol -> value for part 1
        values1 = {'A': 1, 'B': 2, 'C': 3, 'X': 1, 'Y': 2, 'Z': 3}
        # Symbol -> value for part 2
        values2 = {'A': 1, 'B': 2, 'C': 3, 'X': -1, 'Y': 0, 'Z': 1}
        score1 = 0  # for part 1
        score2 = 0  # for part 2
        for line in lines:
            char1, char2 = line.split()
            # Values for part 1
            value1_1, value1_2 = values1[char1], values1[char2]
            outcome1 = ((value1_2 - value1_1 + 1) % 3) * 3
            # Values for part 2
            value2_1, result2 = values2[char1], values2[char2]
            value2_2 = (value2_1 + result2 - 1) % 3 + 1
            outcome2 = ((result2 + 1) % 3) * 3
            # We are player 2!
            score1 += value1_2 + outcome1
            score2 += value2_2 + outcome2
        return score1, score2
  • [^] # Re: En Python classieux

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 1. Évalué à 4.

    (Oui, j'aime bien modéliser avec des classes, même quand ça n'a aucun intérêt pratique.)

  • # En Python classieux

    Posté par  (site web personnel) . En réponse au message Avent du Code, jour 1. Évalué à 4. Dernière modification le 01 décembre 2022 à 14:10.

    Du code commun aux deux parties, essentiellement pour modéliser et importer les données :

    import collections
    import itertools
    
    from collections.abc import Iterable, Sequence
    
    import aoc
    
    
    class Pack:
        """An elf backpack, containing a list of food items"""
        def __init__(self, items: Sequence[int]) -> None:
            """Create an elf backpack containing the providing items (an item is
            actually an amount of energy, in calories)"""
            self.items = items
    
        def total(self) -> int:
            """Return the total energy corresponding to the items in a
            backpack"""
            return sum(self.items)
    
    
    def import_packs(lines: Iterable[str]) -> Iterable[Pack]:
        """Read input lines and return an iterator, yielding one elf backpack at a
        time"""
        items = [] # type: list[int]
        for line in lines:
            if line == '\n':
                # A newline separates the description of one backpack from the next
                # one. Therefore, a pack has been entirely listed and can be
                # yielded.
                yield Pack(items)
                items = []
                continue
            items.append(int(line))
        # The last pack has been entirely listed and we have to yield it too.
        yield Pack(items)

    Première partie, on veut le total de l'énergie du sac qui en contient le plus :

    def part1(lines: Iterable[str]) -> int:
        """Solve puzzle part 1: determine the backpack containing most energy, and
        return the amount of energy it contains"""
        packs = import_packs(lines)
        return max(pack.total() for pack in packs)

    Deuxième partie, on veut le total de l'énergie des trois sacs qui en contiennent le plus :

    def part2(lines: Iterable[str]) -> int:
        """Solve puzzle part 2: determine the three backpacks containing most
        energy, and return the amount of energy they contain"""
        packs = import_packs(lines)
        totals = (pack.total() for pack in packs)
        # Sort the energy totals so the greatest are at the end, and sum the three
        # last ones
        return sum(sorted(totals)[-3:])

    Je ne suis pas très satisfait par le fait de trier les totaux, j'aurais bien aimé faire ça en parcourant simplement les sacs, mais je n'ai pas trouvé de façon élégante de le faire.

  • # C'est parti !

    Posté par  (site web personnel) . En réponse au journal Calendrier de l'Avent du code. Évalué à 5.

    Et voilà, cette année, le Père Noël a été invité par ses lutins à participer à leur récolte annuel de fruits étoilés destinés à nourrir les rennes et leur apporter l'énergie magique nécessaire à la tournée de Noël.

    We wish you a merry Christmas and a happy hacking!

  • # Flash

    Posté par  (site web personnel) . En réponse au sondage La pire tentative de web dynamique fut.... Évalué à 10.

    Flash, mais après avoir hésité. Mon avis :

    • Flash a le tort de s'ĂŞtre vraiment imposĂ©, devenant incontournable et donc une plaie dont on pouvait difficilement se passer.
    • Silverlight a au contraire l'avantage de n'avoir jamais vraiment percĂ©, et la difficultĂ© ou la rĂ©ticence Ă  l'installer n'a jamais eu un coĂ»t Ă©levé ;
    • Shockwave : c'Ă©tait un avatar de Flash non ?
    • Pour les applets on parle de Java, j'imagine. L'avantage, c'est que c'Ă©tait plus ou moins libre. Pourri Ă  mes yeux, mais sans trop de rĂ©ticence ou de difficultĂ©s Ă  installer.
    • Java Web Start : si je me souviens bien, ce n'est pas vraiment du web dynamique, ça, juste un mode de distribution de logiciels jetables. MĂŞme impression qu'avec Java.
    • VBScript : ça a existĂ© ce truc ?
    • HTML5 et compagnie : c'est ouvert, implĂ©mentations libres disponibles, bref un vrai progrès Ă  mes yeux.
  • [^] # Re: le futur nous rĂ©serve bien des surprises !

    Posté par  (site web personnel) . En réponse au journal Quelques joyeusetés que nous réserve le futur…. Évalué à 6.

    Même constat pour le côté vidéo et audio. Personnellement, je déteste ça, quand on me passe un enregistrement d'une conférence, je cherche tout de suite à savoir s'il n'y en a pas une transcription.

    Mais en revanche, je maintiens que j'ai toujours l'impression de subvocaliser quand je lis. Comme quand je pense d'ailleurs.

  • [^] # Re: le futur nous rĂ©serve bien des surprises !

    Posté par  (site web personnel) . En réponse au journal Quelques joyeusetés que nous réserve le futur…. Évalué à 4.

    Malheureusement, beaucoup de personnes ont tendance Ă  "subvocaliser" et donc Ă  lire Ă  haute voix dans leur tĂŞte.

    C’est une perte de temps terrible qui rend la lecture fastidieuse et ne permet pas d’utiliser la mémoire court-terme pleinement et qui rend quasi-impossible la lecture de textes longs et complexes avec une compréhension profonde.

    C'est très curieux, personnellement j'ai bien l'impression de prononcer dans ma tête, mais beaucoup plus vite que si je lisais à voix haute. D'ailleurs, j'ai une vitesse de lecture plutôt rapide, comparée à celle des gens avec qui j'ai pu comparer. Et ça me permet de lire des textes longs et complexes en les comprenant bien.

    Mais à côté de ça, j'ai entendu parler de lecture rapide, une technique de lecture sans prononcer dans sa tête, qui serait bien plus rapide. J'ai essayé un peu, mais je n'ai pas accroché, sans doute pas assez pour bien me rendre compte. Pour le peu que j'ai fait, ça m'a justement donné l'impression de survoler un texte sans bien rentrer dedans, c'est très curieux.

  • [^] # Re: Ardoise magique

    Posté par  (site web personnel) . En réponse au journal J'ai testé: une ardoise à cristaux liquides. Évalué à 3. Dernière modification le 29 novembre 2022 à 17:54.

    Non rien.

  • # Ardoise magique

    Posté par  (site web personnel) . En réponse au journal J'ai testé: une ardoise à cristaux liquides. Évalué à 8.

    Je me demande s'il n'existe pas un truc plus low-tech qui répondrait au même besoin: l'ardoise magique. C'est un jouet pour enfants, mais la fonctionnalité a l'air d'être la même, non ?

  • [^] # Re: le futur nous rĂ©serve bien des surprises !

    Posté par  (site web personnel) . En réponse au journal Quelques joyeusetés que nous réserve le futur…. Évalué à 7.

    Pour ma part je cherche au maximum à reformuler pour essayer d'éviter la situation. C'est également considéré comme de l'écriture inclusive me semble-t-il.

    Ça l'est certainement, et c'est une bonne idée, c'est encore plus lisible sans souffrir d'une impression de redondance. Et c'est tout à ton honneur, parce que ça demande encore plus de temps pour écrire ainsi. Ça ne doit pas être évident pour que les phrases n'aient pas l'air trop impersonnelles ou mécaniques je pense.

  • [^] # Re: le futur nous rĂ©serve bien des surprises !

    Posté par  (site web personnel) . En réponse au journal Quelques joyeusetés que nous réserve le futur…. Évalué à 10.

    J'ai fait l'effort d'aller au bout de cette nouvelle, mais si le reste est aussi en écriture inclusive, je n'irais pas plus loin …

    Il y a plusieurs formes d'écriture inclusive, tout de même. Notamment :

    • la forme factorisĂ©e, qui optimise du nombre de caractères Ă  saisir, donc le temps de l'autâ‹…riceâ‹…eur, au dĂ©triment de la lisibilitĂ©, et demande auâ‹…Ă  leâ‹…la lectâ‹…eurâ‹…rice dĂ©velopper luiâ‹…elle-mĂŞme pour pouvoir prononcer la phrase ;
    • la forme dĂ©veloppĂ©e ou naturelle, qui cherche Ă  optimiser la lisibilitĂ©, au prix d'un plus grand nombre de caractères Ă  saisir, et qui consiste simplement pour l'auteur ou l'autrice Ă  Ă©crire la phrase dĂ©veloppĂ©e, grammaticalement correcte et directement prononçable par la lectrice ou le lecteur ;
    • l'invention de mots neutres, comme « iel », « auteurice » et « lectriceur », qui ne peut que complĂ©ter l'un des deux approches prĂ©cĂ©dentes puisque tous les mots ne se prĂŞtent pas Ă  ce genre d'adaptation.

    La première consiste, pour l'auteur ou l'autrice, à économiser du temps – et encore, il n'est même pas certain que cela en fasse gagner – en le faisant payer aux lectrices et lecteurs. Parce que, pour la plupart des gens, lire, c'est prononcer dans sa tête, tout de même, et un truc comme « heureu⋅x⋅ses », eh bien ce n'est pas prononçable, il faut d'abord faire une étape de développement ou d'élimination d'une des deux alternatives dans sa tête.

    La seconde consiste à prendre le temps d'écrire quelque chose de lisible. Je trouve ça bien plus respectueux. Et tout aussi inclusif, pour ceux qui se poseraient la question : « heureuses et heureux », ça veut dire la même chose que, sauf que c'est grammaticalement et orthographiquement correct et que ça se lit directement sans aucune difficulté.

    Je n'ai pas lu cette nouvelle, mais on parle de quelle forme d'écriture inclusive au juste ? La version optimisée pour l'auteur ou l'autrice ou celle optimisée pour la lecture ? Avec un soupçon de mots inventés peut-être ?

    C'est un peu comme lorsqu'on appelle quelqu'un et qu'on tombe sur son répondeur, deux options possibles :

    • laisser un message vocal, qui prend peu de temps Ă  faire mais demandera du temps au destinataire pour l'Ă©couter ;
    • rĂ©diger un SMS, qui prend plus de temps Ă  Ă©crire mais demandera beaucoup moins de temps au destinataire pour le lire.
  • [^] # Re: Ada corse le tout

    Posté par  (site web personnel) . En réponse au journal Calendrier de l'Avent du code. Évalué à 5.

    Je croyais qu'il fallait juste donner une réponse aux énigmes du jour et non montrer son code, du coup comment ça marche le défi avec AdaCore ?

    C'est expliqué dans leur annonce, évidemment il faut montrer le code pour chaque casse-tête.

  • [^] # Re: Ada corse le tout

    Posté par  (site web personnel) . En réponse au journal Calendrier de l'Avent du code. Évalué à 4.

    Ça, c'est typique des problèmes avec une résolution intuitive pas optimale, et qui devient intenable pour la seconde partie.

    PlutĂ´t que de stocker une liste de tous les poissons avec leur compteur interne, l'astuce est de plutĂ´t stocker, pour chaque valeur possible de compteur interne (de 0 Ă  8), le nombre de poissons qui ont cette valeur-lĂ .

    #! /usr/bin/python3
    
    fishes = [0] * 9 # for each value of their internal timer, the number of fishes with that value
    with open("6.in") as f:
        for word in f.read().rstrip().split(','):
            fishes[int(word)] += 1
    
    for day in range(256):
        new_fishes = [0] * 9
        for i, n in enumerate(fishes):
            if i == 0:
                new_fishes[6] += n
                new_fishes[8] += n
            else:
                new_fishes[i - 1] += n
        fishes = new_fishes
    
    print(sum(fishes))
  • # Seulement un dĂ©calage ?

    Posté par  (site web personnel) . En réponse à la dépêche Nouveaux préfixes SI et avenir de la seconde intercalaire. Évalué à 6.

    Le temps universel coordonné, appelé UTC, est établi par le BIPM en considérant qu'une seconde correspond à la durée de 9 192 631 770 oscillations de la fréquence de transition hyperfine de l'atome de césium. De son côté, le service international de la rotation terrestre et des systèmes de référence établit le temps astronomique, appelé UT1, avec une seconde définie comme 1/86400ème d'une rotation complète (jour). Le temps UT1 est physiquement instable, la rotation de la planète ayant tendance à accélérer depuis la mise en place du temps universel.

    Si je comprends bien, la valeur d'une seconde UT1 est variable. Parfois plus courte que celle de la seconde UTC, parfois plus longue.

    Avec une définition commune du jour (24 heures de 60 minutes de 60 secondes), ces deux temps se retrouvent normalement en décalage. Pour le moment, on a toujours géré des cas où UTC était en avance sur UT1, et on l'a recalé en lui ajoutant une seconde de temps en temps.

    La décision a donc été prise de compter sur une prévision des variations astronomiques des 100 prochaines années pour définir les décalages à venir entre UTC et UT1, puis on fixera alors une heure UTC stable qui minimisera le décalage de celui-ci pendant ce siècle.

    On parle donc d'une simple translation d'UTC. C'est bien si la durée de la seconde UT1 reste en moyenne assez proche d'une seconde UTC. Mais si, disons, la rotation de la Terre diminue pendant un moment, c'est plus qu'un simple décalage, qu'il faudrait, c'est une modification de la définition de la seconde.

    Cette modification devra être réalisée d'ici 2035.

    En somme, au lieu d'ajouter ou de retirer une seconde de temps en temps, on parle d'ajouter ou de retirer un paquet de secondes à un moment donné, c'est ça ?

  • [^] # Re: l'Avent, qui commence au 1er dĂ©cembre ?

    Posté par  (site web personnel) . En réponse au journal Calendrier de l'Avent du code. Évalué à 4.

    C'est vrai, ça commence ce dimanche. Seulement, comme la quasi-totalité des calendriers de l'Avent, celui-ci commence le 1er décembre, c'est dans doute plus facile ainsi pour son auteur.

    Avec ou sans la virgule, la phrase reste ambiguë, elle peut se comprendre comme signifient que ce calendrier commence le 1er décembre, ce que j'ai bien sûr voulu dire. Et elle peut se lire comme vient dire que l'Avent commence le 1er, ce qui est faux.

  • [^] # Re: Masquer le root ?

    Posté par  (site web personnel) . En réponse au journal FranceConnect+ et vous?. Évalué à 6. Dernière modification le 18 novembre 2022 à 17:18.

    Sauf que les applis en question ont des fonctionnalités qui sont généralement un sous-ensemble de celles disponibles sur leur site Web, accessible sans restriction depuis n'importe quel navigateur.

    Donc, pourquoi, pour fournir un service qu'ils fournissent très bien avec un simple site Web, mettent-ils des contrôles de sécurité supérieur lorsqu'ils s'agit d'un logiciel pour téléphone ?

  • [^] # Re: Masquer le root ?

    Posté par  (site web personnel) . En réponse au journal FranceConnect+ et vous?. Évalué à 4. Dernière modification le 18 novembre 2022 à 16:49.

    Ou l'utilisation d'un site web avec navigateur sous debogueur, disons ? Je mentionne un débogueur, parce que c'est justement un logiciel différent, qui a sans accès à la mémoire du navigateur justement.

  • [^] # Re: Masquer le root ?

    Posté par  (site web personnel) . En réponse au journal FranceConnect+ et vous?. Évalué à 3.

    Quelle différence par rapport à l'utilisation de deux sites Web sur un navigateur sur PC ?

  • [^] # Re: Masquer le root ?

    Posté par  (site web personnel) . En réponse au journal FranceConnect+ et vous?. Évalué à 8.

    C'est justement les données auxquelles l'utilisateur a accès qu'on veut protéger ici (données bancaires). Si ton terminal est troué et que tu as installé une application malveillante / qu'une merde s'introduit dessus, il y a un risque qu'elle accède à tes données en utilisant le trou. (c-à-d en gagnant les droits root).

    Quelle différence par rapport à l'utilisation du site Web de ma banque depuis mon PC ?

    En tout cas c'est le point de vue, j'imagine. Et les banques doivent certainement suivre des règlementations pour s'assurer de la sécurité (au moins apparente / avec déni plausible) de leurs solutions informatiques.

    Quelle différence par rapport à l'utilisation du site Web de ma banque depuis mon PC ?

  • [^] # Re: Masquer le root ?

    Posté par  (site web personnel) . En réponse au journal FranceConnect+ et vous?. Évalué à 10.

    Ce n'est pas ce logiciel qui est troué (ou en tout cas ce n'est pas pour éviter des failles au niveau de ce logiciel au particulier).

    Dans ce cas ça ne sert à rien. Un logiciel bien conçu ne devrait pas laisser sortir quoi que ce soit de compromettant, auquel l'utilisateur n'est pas déjà censé avoir accès, même en accédant à sa mémoire.

    Ou, pour le dire autrement, un logiciel dont la sécurité dépend de la sécurité du terminal, c'est de la merde.

    C'est juste qu'on considère un OS rooté moins sûr. Ce n'est pas le fait que tu sois administrateur qui rends l'OS moins sûr

    Sauf que téléphone rooté et téléphone dont je suis admin, c'est synonyme. Considérer un système rooté comme moins sûr, c'est considérer que le fait que j'en sois administrateur le rend moins sûr.

    c'est le fait qu'en le rootant il y a des fonctionnalités de sécurité qui sont contournées.

    La seule chose qui est contournée en rootant, c'est le fait de ne pas être admin.