"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Créer un gestionnaire de mots de passe dans Go

Créer un gestionnaire de mots de passe dans Go

Publié le 2024-11-08
Parcourir:979

En tant que développeur de logiciels, j'ai toujours été fasciné par l'intersection de la sécurité et de la convivialité. Récemment, j'ai décidé de me lancer dans un projet passionnant : créer un gestionnaire de mots de passe en ligne de commande à l'aide de Go. Je souhaite partager le début de ce voyage avec vous, en commençant par le tout premier commit.

La Genèse

Le 27 novembre 2023, j'ai pris l'engagement initial de mon projet, que j'ai nommé « dost » (ami en hindi, reflétant son rôle de compagnon utile pour la gestion des mots de passe). Cette première étape, bien que petite, jette les bases de ce qui, je l'espère, deviendra un outil robuste et convivial.

Inspiration et Vision

Building a Password Manager in Go

En me lançant dans ce projet, je me suis inspiré du populaire gestionnaire de mots de passe en ligne de commande. La simplicité et l'efficacité de pass ont attiré mon attention et j'ai décidé d'utiliser son API comme modèle pour créer mon propre gestionnaire de mots de passe dans Go.

Plonger dans le code source du pass a été une expérience révélatrice. J'ai été intrigué de découvrir que toutes les fonctionnalités de cet outil largement utilisé sont encapsulées dans un script Bash complet. Cette simplicité élégante est quelque chose que j'admire et que j'espère imiter dans mon propre projet, tout en utilisant les atouts de Go.

En étudiant pass, j'ai acquis des informations précieuses sur les fonctionnalités essentielles d'un gestionnaire de mots de passe en ligne de commande et sur l'expérience utilisateur qu'il devrait offrir. Alors que je continue à développer "dost", je garderai ces leçons à l'esprit, dans le but de créer un outil qui combine la simplicité de pass avec les avantages en termes de performances et de compatibilité multiplateforme de Go.

Cette exploration a non seulement fourni une feuille de route pour les fonctionnalités à implémenter, mais a également renforcé ma croyance dans la puissance d'outils bien conçus et ciblés. Je suis impatient de voir comment cette inspiration façonnera l'évolution de « dost » dans les prochaines étapes de développement.

Premières fonctionnalités

Le commit initial s'est concentré sur deux fonctionnalités principales :

  1. Génération de mot de passe : j'ai implémenté un générateur de mot de passe de base qui permet aux utilisateurs de spécifier la longueur de mot de passe souhaitée. Cette fonctionnalité vise à créer des mots de passe forts et aléatoires adaptés à diverses exigences de sécurité.

  2. Intégration du presse-papiers : pour améliorer l'expérience utilisateur, je me suis assuré que le mot de passe généré est automatiquement copié dans le presse-papiers. Cette fonctionnalité petite mais cruciale permet de gagner du temps et réduit le risque d'erreurs de transcription.

Informations techniques

Plongeons-nous dans certains des aspects techniques de cette première itération :

  • Version Go : le projet est construit à l'aide de Go 1.21.0, tirant parti de la simplicité et de l'efficacité du langage.
  • Dépendances externes : j'utilise le package github.com/atotto/clipboard pour gérer de manière transparente les opérations du presse-papiers sur différents systèmes d'exploitation.
  • Génération aléatoire : La génération de mots de passe utilise le package crypto/rand de Go pour la génération sécurisée de nombres aléatoires, cruciale pour créer des mots de passe imprévisibles et forts.
  • Jeu de caractères : le générateur de mots de passe comprend des lettres majuscules et minuscules, des chiffres et une variété de caractères spéciaux pour garantir la complexité.

Extraits de code

Examinons quelques éléments clés de la mise en œuvre :

  1. Fonction de génération de mot de passe :
func generatePassword(length int) (string, error) {
    const (
        uppercaseLetters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
        lowercaseLetters = "abcdefghijklmnopqrstuvwxyz"
        digits           = "0123456789"
        specialChars     = "!@#$%^&*()-_= []{}|;:'\",./?"
    )

    allChars := uppercaseLetters   lowercaseLetters   digits   specialChars

    var password string
    for i := 0; i 


Cette fonction crée un mot de passe en sélectionnant aléatoirement des caractères dans un ensemble prédéfini, garantissant un mélange de majuscules, de minuscules, de chiffres et de caractères spéciaux.

  1. Intégration du presse-papiers :
func writeToClipboard(text string) error {
    return clipboard.WriteAll(text)
}

Cette fonction simple utilise le package presse-papiers pour écrire le mot de passe généré dans le presse-papiers du système.

  1. Fonction principale :
func main() {
    passwordLength := flag.Int("length", 12, "length of your password")
    flag.Parse()

    password, err1 := generatePassword(*passwordLength)
    if err1 != nil {
        fmt.Println("Error generating password:", err1)
        return
    }

    fmt.Println("Generated Password:", password)

    err2 := writeToClipboard(password)
    if err2 != nil {
        fmt.Println("Error writing to clipboard:", err2)
        os.Exit(1)
    }

    fmt.Println("Copied to clipboard! ✅\n")
}

La fonction principale relie tout ensemble. Il utilise le package flag de Go pour permettre aux utilisateurs de spécifier la longueur du mot de passe, génère le mot de passe et le copie dans le presse-papiers.

Interface de ligne de commande

Comme vous pouvez le voir dans la fonction principale, j'ai implémenté une CLI simple en utilisant le package flag de Go. Les utilisateurs peuvent spécifier la longueur souhaitée du mot de passe à l'aide de l'indicateur -length, avec une valeur par défaut de 12 caractères si elle n'est pas spécifiée.

Regarder vers l'avenir

Ce premier commit n'est que le début. Au fur et à mesure que je continue à développer ce gestionnaire de mots de passe, je prévois d'ajouter des fonctionnalités telles que :

  • Stockage sécurisé des mots de passe
  • Cryptage des données stockées
  • Fonctionnalités de recherche et de récupération
  • Analyse de la force du mot de passe

Je suis enthousiasmé par le voyage à venir et les défis qu'il apportera. Construire un gestionnaire de mots de passe ne consiste pas seulement à coder ; il s'agit de comprendre les principes de sécurité, les besoins des utilisateurs et de créer un outil auquel les gens peuvent faire confiance avec leurs informations sensibles.

Restez à l'écoute pour plus de mises à jour à mesure que ce projet évolue. Je partagerai mes progrès, mes défis et mes apprentissages tout au long du parcours. Si vous souhaitez suivre ou contribuer, n'hésitez pas à consulter le projet sur GitHub.

Building a Password Manager in Go svemaraju / faire

gestionnaire de mots de passe en ligne de commande dost écrit en Go

faire

dost est un gestionnaire de mots de passe CLI écrit en Go.

Inspiré par (Pass)[https://www.passwordstore.org/]

Caractéristiques

  • Générer des mots de passe aléatoires de longueur configurable
  • Copier automatiquement les mots de passe générés dans le presse-papiers
  • Passer à l'aide de symboles

Usage

> go build -o dost main.go
Passer en mode plein écranQuitter le mode plein écran

Génération du mot de passe :

> ./dost generate email/[email protected]
Generated Password: );XE,7-Dv?)Aa &

Génération d'un mot de passe avec une longueur spécifiée (la valeur par défaut est 25) :

> ./dost generate email/[email protected] 12
Generated Password: si

Copier le mot de passe généré dans le presse-papiers sans imprimer :

> ./dost generate -c email/[email protected] 
Copied to clipboard! ✅

Évitez les symboles pour générer des mots de passe :

> ./dost generate -n email/[email protected] 
Generated Password: E2UST}^{Ac[Fb&D|cD%;Eij>H

En cours de développement

  • Insérer un nouveau mot de passe manuellement
  • Afficher un mot de passe existant
  • Liste de toutes les entrées
  • Stockage du mot de passe
  • Cryptage basé sur la clé GPG

Licence

MIT




Voir sur GitHub


Déclaration de sortie Cet article est reproduit sur : https://dev.to/svemaraju/building-a-password-manager-in-go-31jo?1 En cas d'infraction, veuillez contacter [email protected] pour le supprimer.
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3