-
Notifications
You must be signed in to change notification settings - Fork 2.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Replace ScriptsMiddleware(#15629) #16876
base: main
Are you sure you want to change the base?
Replace ScriptsMiddleware(#15629) #16876
Conversation
Thank you for submitting your first pull request, awesome! 🚀 If you haven't already, please take a moment to review our contribution guide. This guide provides helpful information to ensure your contribution aligns with our standards. A core team member will review your pull request. If you like Orchard Core, please star our repo and join our community channels. |
@dotnet-policy-service agree |
@DonaldDWebster what's the problem you are trying to solve or fix? |
I am trying to replace the middleware for the facebook & liquid modules for performance as part of issue #15629 |
I linked the issues in the description check #16876 (comment) Please fix the build |
Click the "Ready for Review" button once your PR is ready fro review |
111ed78
to
34b0355
Compare
34b0355
to
37dd66a
Compare
I’ve made the necessary fix and pushed the changes. It seems the workflow now requires your approval before it can run. If you could kindly approve the workflow at your convenience, that would be great. Thank you for the help today. |
This pull request has merge conflicts. Please resolve those before requesting a review. |
Tagged it for next triage because I think we can provide some feedback. |
@@ -21,7 +21,8 @@ public sealed class Startup : StartupBase | |||
{ | |||
public override void Configure(IApplicationBuilder builder, IEndpointRouteBuilder routes, IServiceProvider serviceProvider) | |||
{ | |||
builder.UseMiddleware<ScriptsMiddleware>(); | |||
routes.AddInitSdkEndpoint(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you make it a single method, like AddFacebookEndpoints()
?
{ | ||
ArgumentNullException.ThrowIfNull(httpContext); | ||
|
||
var script = await getLoadSdkScript(siteService); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can't this be cached and reused?
{ | ||
const string cacheKey = "LiquidIntellisenseScript"; | ||
|
||
var cacheControl = $"public, max-age={TimeSpan.FromDays(30).TotalSeconds}, s-max-age={TimeSpan.FromDays(365.25).TotalSeconds}"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can the etag and caching headers be configured on the MapGet
? So we don't have to handle the checks ourselves?
It seems that this pull request didn't really move for quite a while. Is this something you'd like to revisit any time soon or should we close? Please comment if you'd like to pick it up. |
return Results.Ok(script); | ||
} | ||
|
||
private static async Task<string> getInitSdkScript(ISiteService siteService) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This needs to be cached by culture (or split this script in two, one with culture and one using a variable name.).
return Results.NotFound(); | ||
} | ||
|
||
return Results.Ok(script); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this return a utf8 encoded byte[]
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If Results
is not powerful enough , maybe use the response writer directly (PipeWriter?, TextWriter?).
Fixes #15629
What is your input on what else to change? Thank you for the help.