betwixt-labs / dot-env-generator

A source generator for C# that turns .env files into runtime constants.
MIT License
32 stars 3 forks source link

dot-env-generator

A source generator for C# that turns .env files into runtime constants.

Basic Usage

NuGet DotEnvGenerator
Package Manager PM> Install-Package DotEnvGenerator -Version 0.1.0
.NET CLI > dotnet add package DotEnvGenerator --version 0.1.0
PackageReference <PackageReference Include="DotEnvGenerator" Version="0.1.0" />
Paket CLI > paket add DotEnvGenerator --version 0.1.0

After adding the source generator to your project add an item group to your project that references your .env file like so:

  <ItemGroup>
    <AdditionalFiles Include="example.env" />
  </ItemGroup>

The contents of your .env file would look something like this:

# A string literal
A_STRING="yep, that is a string."
# A string
ALSO_STRING=RANDOM_0026256698
# An array of string
STRING_ARRAY=one,two,three,four,five
# An array of numbers
INT_ARRAY=1, 2, 3, 4, 5, 6, 7
A_NUMBER=1000
A_BIGGER_NUMBER=10_000_000
A_GUID=de095b54-2082-40f8-a928-794da5675e7c
A_DATE_TIME=Tue, 1 Jan 2008 00:00:00Z
# A base64 encoded bytearray 
A_BYTE_ARRAY=d2hhdA==
A_DOUBLE=1.0
A_SCIENCE_DOUBLE=3.2e23
A_DOUBLE_LITERAL=1.0D
A_HEX=0xFF0000
A_UINT=2000U
A_LONG=2000L
A_ULONG=2000UL
A_NEGATIVE_LONG=-2000L

And the generator will turn it into this:

using System;
namespace DotEnv.Generated
{
    /// <summary>
    /// An auto-generated class which holds constants derived from 'example.env'
    /// </summary>
    public static class ExampleEnvironment
    {
       /// <summary> A string literal </summary>
       public const System.String AString = "yep, that is a string.";
       /// <summary> A string </summary>
       public const System.String AlsoString = "RANDOM_0026256698";
       /// <summary> An array of string </summary>
       public static readonly IReadOnlyList<System.String> StringArray = new string[] { "one", "two", "three", "four", "five" };
       /// <summary> An array of numbers </summary>
       public static readonly IReadOnlyList<System.Int32> IntArray = new System.Int32[] { 1, 2, 3, 4, 5, 6, 7 };
       public const System.Int32 ANumber = 1000;
       public const System.Int32 ABiggerNumber = 10_000_000;
       public static readonly System.Guid AGuid = Guid.Parse("de095b54-2082-40f8-a928-794da5675e7c");
       public static readonly System.DateTime ADateTime = DateTime.Parse("Tue, 1 Jan 2008 00:00:00Z");
       /// <summary> A base64 encoded bytearray </summary>
       public static ReadOnlySpan<byte> AByteArray => new byte[] { 0x77, 0x68, 0x61, 0x74 };
       public const System.Double ADouble = 1.0;
       public const System.Double AScienceDouble = 3.2e23;
       public const System.Double ADoubleLiteral = 1.0D;
       public const System.Int32 AHex = 0xFF0000;
       public const System.UInt32 AUint = 2000U;
       public const System.Int64 ALong = 2000L;
       public const System.UInt64 AUlong = 2000UL;
       public const System.Int64 ANegativeLong = -2000L;
    }
}

The source generator will use your .env file first as a lookup table. Using the left-hand declarations the generator will check for an environment variable with that name in descending order (machine, user, and finally the process.)

If the variable does not exist in any of these stores, the value on the right is used. If no default value is defined, an error is reported.

The value parsing rules are simple:

Known Issues