|
| 1 | +# helperFunctions |
| 2 | +Miscellaneous helper functions |
| 3 | +___ |
| 4 | + |
| 5 | +This package provides functions that I have been using all over my various tools but the obvious struck: instead of ducplicating code on my filesystem, I should have a single source of truth. |
| 6 | + |
| 7 | +## Overview |
| 8 | + |
| 9 | +This package is currently divided in 3 files; if the scope of the project expands (and I expect it to expand, at some point), we might be talking about sub-packages here. |
| 10 | + |
| 11 | +For now, we have 3 files, with a specific area of responsibility: |
| 12 | + |
| 13 | +| File | Area / coverage | |
| 14 | +|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| |
| 15 | +| prompt4Type.go | Returns a value of a given type (string, bool, int, etc), with a prompt<br>This might seem useless, but I've needed something like that many times | |
| 16 | +| terminal.go | Terminal-related functions, such as colouring output, getting terminal size (WxH), etc | |
| 17 | +| encodeDecodePassword.go | Functions related to encoding/decoding strings, prompting for (non-echoed) passwords, etc) | |
| 18 | +| misc.go | Various minor functions | |
| 19 | + |
| 20 | +This is basic, for now. I really intend on expanding on this package, and eventually have it documented on pkg.go.dev/ |
| 21 | + |
| 22 | +## Installation |
| 23 | +A simple `go get github.com/jeanfrancoisgratton/functionHelpers` and we're done. |
| 24 | + |
| 25 | +## Usage, per file/package |
| 26 | +(it is "per file" for now, as I'm not dividing it in sub-packages) |
| 27 | + |
| 28 | +### FILE: misc.go |
| 29 | +Two functions, SI(), and ReverseString(). |
| 30 | + |
| 31 | +SI came from a need to have comma-separated number out of a number that wasn't. |
| 32 | + |
| 33 | +For instance, you have the number `123456789`. In a comma-separated format (SI-notation, SI for "Système International"); it becomes, in a string: `123,456,789` |
| 34 | + |
| 35 | +You input a uint64 number, it comes back as a SI-formatted string. |
| 36 | + |
| 37 | +I'm aware that having only a uint64 entrant is kind of a limitation; it'll be worked on. |
| 38 | + |
| 39 | +About ReverseString(), the name says it all: |
| 40 | + |
| 41 | +You input a string ("abcdef"), it returns its reverse ("fedcba"). |
| 42 | + |
| 43 | + |
| 44 | +### FILE: prompt4Type.go |
| 45 | +Many functions there, all following the same pattern... |
| 46 | + |
| 47 | +The functions: |
| 48 | + |
| 49 | +GetStringValFromPrompt()<br> |
| 50 | +GetIntValFromPrompt()<br> |
| 51 | +GetBoolValFromPrompt()<br> |
| 52 | +GetStringSliceFromPrompt()<br> |
| 53 | + |
| 54 | +The structure is intuitive: Get<DATATYPE><SCALAR/SLICE>FromPrompt() |
| 55 | + |
| 56 | +DATATYPE is either String, Int, Bool... for now |
| 57 | + |
| 58 | +SCALAR/SLICE is either Val (Scalar, single value) or Slice. This affects the return data type. |
| 59 | + |
| 60 | +All take a single parameter, the "prompt", ie "the message/question you want to pass to the user" |
| 61 | + |
| 62 | +### FILE: terminal.go |
| 63 | +This one is basically (for now) used to colour the output, or get the TTY size, or clear a TTY. |
| 64 | + |
| 65 | +To get the current TTY size, you call GetTerminalSize(), it'll return the WIDTHxHEIGHT (2 int values) |
| 66 | + |
| 67 | +To clear a terminal TTY is quite easy: just call ClearTTY(), no params. |
| 68 | + |
| 69 | +The next functions are "colour functions:"<br> |
| 70 | +Red(sentence)<br> |
| 71 | +Green(sentence)<br> |
| 72 | +White(sentence)<br> |
| 73 | +Yellow(sentence)<br> |
| 74 | +Blue(sentence)<br> |
| 75 | + |
| 76 | +Where "sentence" is a variable of type string that you want to return in the appropriate colour. |
| 77 | + |
| 78 | + |
| 79 | +### FILE: encodeDecodePassword.go |
| 80 | +3 functions in here : |
| 81 | + |
| 82 | +**GetPassword(sentence)** : you will be prompted (the sentence string type in parameters) to enter a password. __The password is not echoed on the TTY; it will be returned in a non-encoded form as a string_. If you wish to return it as an encoded form, you can use the next function... |
| 83 | + |
| 84 | +**EncodeString(string to be encoded, secret key)** |
| 85 | +The string to be encoded will be returned. If secret key is empty, a default secret key is provided. |
| 86 | +Of course, this is not the suggested behaviour... |
| 87 | + |
| 88 | +_Important note_: secret key has to be **exactly** 32 bytes long, otherwise the default key is used. |
| 89 | + |
| 90 | +**DecodeString(string to be decoded, secret key)** |
| 91 | +The string to be decoded will be returned. If secret key is empty, a default secret key is provided. |
| 92 | +Of course, this is not the suggested behaviour... |
| 93 | + |
| 94 | +_Important note_: secret key has to be **exactly** 32 bytes long, otherwise the default key is used. |
| 95 | + |
| 96 | + |
0 commit comments