Common Utilities library for Go
Utils is a lightweight, flexible, and reusable library providing utility functions and helpers for common operations in Go applications. With packages designed for managing boolean conversions, handling context values, map operations, slice utilities, string manipulations, and struct comparison, utils enhances Go projects with optimized, clean, and practical solutions.
Go: The project is written in Golang, so you'll need Go installed (preferably Go 1.23.3 or later). You can download and install Go from here.
Git: For cloning the repository.
To use utils in your project, add it as a module dependency:
go get github.com/kashifkhan0771/utils
Alternatively, include it directly in your go.mod file (use the latest release):
require github.com/kashifkhan0771/utils v0.3.0
- IsTrue: Checks if the provided string represents a true value (e.g., "T", "1", "TRUE").
- Toggle: Toggles the given boolean value, returning its negation. (e.g.,
true
becomesfalse
and vice versa). - AllTrue: Checks if all the values in a slice of booleans are
true
. Returnsfalse
if the slice is empty. - AnyTrue: Checks if at least one value in a slice of booleans is
true
. Returnsfalse
if the slice is empty. - NoneTrue: Checks if none of the values in a slice of booleans are
true
. Returnstrue
if the slice is empty. - CountTrue: Counts the number of
true
values in a slice of booleans. Returns0
for an empty slice. - CountFalse: Counts the number of
false
values in a slice of booleans. Returns0
for an empty slice. - Equal: Checks if all the values in a variadic boolean argument are equal. Returns
true
if the slice contains only one or no elements. - And: Performs a logical AND operation on all the values in a slice of booleans. Returns
true
only if all values aretrue
. Returnsfalse
for an empty slice. - Or: Performs a logical OR operation on all the values in a slice of booleans. Returns
true
if at least one value istrue
. Returnsfalse
for an empty slice.
- SetStringValue: Sets a string value in the context with a custom key.
- GetStringValue: Retrieves a string value from the context using the specified key.
- SetIntValue: Sets an integer value in the context with a custom key.
- GetIntValue: Retrieves an integer value from the context using the specified key.
- NewErrorAggregator: Creates a new error aggregator to collect multiple errors.
- Add: Adds an error to the aggregator.
- Error: Retrieves the aggregated error message.
- HasErrors: Checks if there are any errors in the aggregator.
- NewStateMap: Creates a new map for managing state flags.
- SetState: Sets a specific state to true or false.
- IsState: Checks the current value of a state.
- ToggleState: Toggles the value of a state.
- HasState: Checks if a state exists in the map.
- NewMetadata: Creates a new metadata map for key-value storage.
- Update: Updates or adds a key-value pair to the metadata map.
- Value: Retrieves the value of a key from the metadata map.
- Has: Checks if a key exists in the metadata map.
- DefaultIfNil: Returns a default value if the pointer is nil.
- NullableBool: Returns the value of a boolean pointer or false if nil.
- NullableTime: Returns the value of a time pointer or a zero time value if nil.
- NullableInt: Returns the value of an integer pointer or zero if nil.
- NullableString: Returns the value of a string pointer or an empty string if nil.
- Number: Generates a random number.
- NumberInRange: Generates a random number within a specified range.
- String: Generates a random alphanumeric string.
- StringWithLength: Generates a random string of a custom length.
- StringWithCharset: Generates a random string using a custom character set.
- Pick: Picks a random element from a given slice.
- Shuffle: Shuffles the elements of a slice randomly.
- RemoveDuplicateStr: Removes duplicate values from a slice of strings.
- RemoveDuplicateInt: Removes duplicate values from a slice of integers.
- SubstringSearch: Searches for substrings in a string with customizable options.
- Title: Converts a string to title case (capitalizes the first letter of each word).
- ToTitle: Converts a string to title case, ignoring specified words.
- Tokenize: Splits a string into tokens using specified delimiters.
- Rot13Encode: Encodes a string using the ROT13 cipher.
- Rot13Decode: Decodes a string using the ROT13 cipher.
- CaesarEncrypt: Encrypts a string using the Caesar cipher with a given shift.
- CaesarDecrypt: Decrypts a string encrypted using the Caesar cipher.
- IsValidEmail: Checks if a string is a valid email address.
- SanitizeEmail: Removes leading and trailing spaces from an email string.
- Reverse: Reverses the characters in a string.
- CommonPrefix: Finds the longest common prefix of a set of strings.
- CommonSuffix: Finds the longest common suffix of a set of strings.
- RunLengthEncode Encodes a string using Run-length-encoding.
- RunLengthDecode Decodes a string that has been encoded using Run-length-encoding. Ruturns the original string and an error if the encoding failed
- CompareStructs: Compares two structs and returns the differences between them.
- RenderHTMLTemplate: Renders an HTML template with dynamic values.
- RenderText: Renders a text template with dynamic values.
-
Parse a URL: Parses a URL into its components like scheme, host, path, query, and fragment.
-
Build a URL from Components: Constructs a complete URL by combining base URL, path, and query parameters.
-
Resolve Relative URLs: Resolves a relative URL against a base URL to form an absolute URL.
-
URL Encoding: Encodes URL components to ensure they are properly formatted for inclusion in URLs.
-
Abs: Returns the absolute value of the given number. Works for both integers and floating-point numbers. If the input is negative, it returns its positive equivalent; otherwise, it returns the number as is.
-
Sign: Determines the sign of a signed number. Returns
1
if the number is positive,-1
if negative, and0
if the number is zero. -
Min: Returns the smaller of two numbers. Works for all number types including integers and floating-point numbers.
-
Max: Returns the larger of two numbers. Works for all number types including integers and floating-point numbers.
-
Clamp: Restricts a given value to be within a specified range. If the value is below the minimum, it returns the minimum; if above the maximum, it returns the maximum.
-
IntPow: Calculates base raised to the power of exp. Supports both positive and negative exponents. Returns float64 for fractional results.
-
IsEven: Checks if the given integer is even. Returns
true
for even numbers andfalse
otherwise. -
IsOdd: Checks if the given integer is odd. Returns
true
for odd numbers andfalse
otherwise. -
Swap: Swaps the values of two variables in place. It uses pointers to modify the original variables.
-
Factorial: Computes the factorial of a non-negative integer. Factorial of
n
is defined as the product of all integers from1
ton
. For0
and1
, the result is1
. Factorial returns an error on invalid input. -
GCD: Finds the greatest common divisor (GCD) of two integers using the Euclidean algorithm. If one of the inputs is
0
, the other input is returned. -
LCM: Finds the least common multiple (LCM) of two integers.
-
RandomUUID: Generates a random UUID of version 4 and variant 2.
-
RandomDate: Generates a random date between 1st January 1970 and the current date.
-
RandomPhoneNumber: Generates a random US phone number in the format (XXX) XXX-XXXX.
-
RandomAddress: Generates a random US address including street, city, state, and ZIP code.
-
StartOfDay: Returns a time.Time set to the beginning (00:00:00) of the given day.
-
EndOfDay: Returns a time.Time set to the last moment (23:59:59.999999999) of the given day.
-
AddBusinessDays: Adds specified number of business days (excluding weekends) to a given date.
-
IsWeekend: Determines if a given date falls on a weekend (Saturday or Sunday).
-
TimeDifferenceHumanReadable: Converts time difference between two dates into a human-friendly string (e.g., "in 2 days" or "3 hours ago").
-
DurationUntilNext: Calculates duration until the next occurrence of a specific weekday.
-
ConvertToTimeZone: Converts a time.Time to a different timezone based on location name.
-
HumanReadableDuration: Formats a duration into a human-readable string (e.g., "2h 30m 45s").
-
CalculateAge: Computes age in years given a birth date.
-
IsLeapYear: Checks if a given year is a leap year.
-
NextOccurrence: Finds the next occurrence of a specific time on the same or next day.
-
WeekNumber: Returns the ISO year and week number for a given date.
-
DaysBetween: Calculates the number of days between two dates.
-
IsTimeBetween: Checks if a time falls between two other times.
-
UnixMilliToTime: Converts Unix milliseconds timestamp to time.Time.
-
SplitDuration: Breaks down a duration into days, hours, minutes, and seconds.
-
GetMonthName: Returns the English name of a month given its number (1-12).
-
GetDayName: Returns the English name of a day given its number (0-6).
-
FormatForDisplay: Formats a date in a readable format (e.g., "Monday, 2 Jan 2006").
-
IsToday: Checks if a given date is today.
The logging
package provides a simple, flexible, and color-coded logging system for Golang. Below are the main features and methods of the package:
NewLogger(prefix string, minLevel LogLevel, output io.Writer) *Logger
:
Creates a new logger instance.prefix
: A string prefix added to all log messages.minLevel
: The minimum log level to output (DEBUG
,INFO
,WARN
,ERROR
). Messages below this level are ignored.output
: The destination for log output (e.g.,os.Stdout
,os.Stderr
, or anyio.Writer
). Defaults toos.Stdout
ifnil
.
- DEBUG: Used for detailed debug information.
- INFO: General informational messages.
- WARN: Warnings about potential issues.
- ERROR: Critical errors.
-
Info(message string)
:
Logs an informational message with the log level INFO. -
Debug(message string)
:
Logs a debug message with the log level DEBUG. -
Warn(message string)
:
Logs a warning message with the log level WARN. -
Error(message string)
:
Logs an error message with the log level ERROR.
-
Color-Coded Logs:
Log messages are color-coded based on the log level:- DEBUG: Green
- INFO: Blue
- WARN: Yellow
- ERROR: Red
-
Timestamped Logs:
Each log message includes a timestamp in the formatYYYY-MM-DD HH:MM:SS
. -
Log Filtering by Level:
Logs below the specified minimum level (minLevel
) are ignored. -
Custom Output:
Logs can be directed to anyio.Writer
, allowing flexible output destinations (e.g., files, network connections). -
Disable Colors:
ThedisableColors
field in theLogger
struct can be set totrue
to disable color codes (useful for testing or plain-text logs).
- If the
minLevel
is set toDEBUG
, all log messages will be displayed. - Logs are automatically flushed to the configured output as soon as they're written.
- To log without colors (e.g., for testing), set the
disableColors
field totrue
in theLogger
instance.
For examples of each function, please checkout EXAMPLES.md
Contributions to this project are welcome! If you would like to contribute, please feel free to open a PR.
Please read the Contribution Guide before opening any new pull request
Together, we can make Utils even better for the Go community!