开发者

what is the conventional way of providing config information to a custom Powershell cmdlet

开发者 https://www.devze.com 2023-02-16 19:37 出处:网络
Given that custom PS cmdlets are assemblies I can\'t provide them config information via the normal 开发者_如何学PythonApp.config route. What is the conventional way of providing config info to a cust

Given that custom PS cmdlets are assemblies I can't provide them config information via the normal 开发者_如何学PythonApp.config route. What is the conventional way of providing config info to a custom cmdlet?


PowerShell is a shell. The normal way of passing information between parts of the shell are shell variables. For powershell that would look like:

$global:MyComponent_MySetting = '12'
# i.e. 
$PSDefaultParameterValues
$ErrorActionPreference

If settings is expected to be inherited across processes boundaries the convention is to use environment variables. I extend this to settings that cross C# / PowerShell boundary. A couple of examples:

$env:PATH
$env:PSModulePath

If you think this is an anti-pattern for .NET you might want to reconsider. This is the norm for PAAS hosted apps, and is going to be the new default for ASP.NET running on server-optimized CLR (ASP.NET v5).

See https://github.com/JabbR/JabbRv2/blob/dev/src/JabbR/Startup.cs#L21
Note: at time of writing I'm linking to .AddEnvironmentVariables()

I've revisited this question a few times, including asking it myself. I wanted to put a stake in the ground to say PowerShell stuff doesn't work well with <appSettings>. IMO it is much better to embrace the shell aspect of PS over the .NET aspect in this regards.

If you need complex configuration take a JSON string. POSH v3+ has ConvertFrom-JSON built-in. If everything in your process uses the same complex configuration put it in a .json file and point to that file from an environment variable.

If a single file doesn't suffice there are well established solutions like the PATH pattern, GIT .gitignore resolution, or ASP.NET web.config resolution (which I won't repeat here).


Normally i would suggest just using parameters for passing data.

Get-MyData -connectionstring $connectionString -table Test ...

When that is not practical (too many parameters, etc..), then you can always provide the path to a configuration file by a parameter:

Get-MyData -Config .\My.config

You can then read the specified configuration file from inside the cmdlet.

This allows users of the cmdlet to define their own configuration files to use.

0

精彩评论

暂无评论...
验证码 换一张
取 消