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.
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.
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.
Le commit initial s'est concentré sur deux fonctionnalités principales :
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é.
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.
Plongeons-nous dans certains des aspects techniques de cette première itération :
Examinons quelques éléments clés de la mise en œuvre :
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; iCette 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.
- 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.
- 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 :
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.
dost est un gestionnaire de mots de passe CLI écrit en Go.
Inspiré par (Pass)[https://www.passwordstore.org/]
> go build -o dost main.go
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
MIT
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