Skip to content
This repository was archived by the owner on Dec 8, 2021. It is now read-only.

Running Polaris from a Module exported function #178

Closed
bgelens opened this issue Mar 14, 2019 · 4 comments
Closed

Running Polaris from a Module exported function #178

bgelens opened this issue Mar 14, 2019 · 4 comments

Comments

@bgelens
Copy link
Contributor

bgelens commented Mar 14, 2019

When wrapping Polaris in a function which is part of a module, Polaris instance won't be able to see the other Module functions (non exported) due to scoping issues. How would I solve this?

The idea is to wrap a fully functioning api as a Module so someone can just run Start-MyApi -Port 8080 without having to see a big script or any of the implementation details

@Tiberriver256
Copy link
Contributor

Hi bgelens,

Unfortunely using classes along with the Register-ObjectEvent leaves us with some oddities here. The action block of the Register-ObjectEvent doesn't execute within the scope of the module.

This is why we have to include this section and create the Polaris classes outside the module scope.

Polaris/Polaris.psd1

Lines 48 to 55 in a0117af

ScriptsToProcess = @(
"Public\New-ScriptblockCallback.ps1",
"lib\MimeTypes.Class.ps1",
"lib\PolarisRequest.Class.ps1",
"lib\PolarisResponse.Class.ps1",
"lib\PolarisMiddleware.Class.ps1",
"lib\Polaris.Class.ps1"
)

So the only option I have for you at the moment is to export all functions that are executed within a Polaris scriptblock (which is less than ideal for sure)

Thoughts on Polaris here

I've been thinking about the value we're actually adding by having it execute asynchronously (i.e. keeping the terminal active and allowing changes in scope to directly affect the running web server) and wondering if it isn't better to just leave that off as a feature and just having it either run synchronously or in jobs / runspaces which would mean functions would no longer have access to variables declared outside the function scope or explicitly passed to Polaris as a shared memory variable. @TylerLeonhardt.

Unless someone is aware of a PowerShell method for executing asynchronously that keeps all scoping intact (which would be epic!) I think those would be our best options.

@Tiberriver256
Copy link
Contributor

Relevant discussion in #127

@bgelens
Copy link
Contributor Author

bgelens commented Mar 15, 2019

Thanks @Tiberriver256 for this great insight! I don't like the workaround (I had it parked it as last resort) but I can live with it for now.

My 2ct, I wouldn't mind if the terminal got locked, in my mind I wouldn't want to touch the PowerShell process that is hosting my app anyways. Plus, Wait-Debugger would work in that scenario as well right?

@Tiberriver256
Copy link
Contributor

Yeah, exactly. I'm going to close this one but feel free to weigh in on #127. I think we'll use that as our discussion on the asynchronous handling best future.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants