Skip to content
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

Migrate to ZendFramework to Symfony #66

Draft
wants to merge 196 commits into
base: master
Choose a base branch
from
Draft

Migrate to ZendFramework to Symfony #66

wants to merge 196 commits into from

Conversation

adamfranco
Copy link
Member

Fixes #47.

@adamfranco adamfranco self-assigned this Sep 26, 2024
The use of '/' as a separator in subcomponents turned out to be a bad idea
because these slashes need to be escaped as %2F, but these escaped slashes
can interfere with some webserver configuration.

For example Apache redirects require the NE "No Escape" option to preserve
%2F slashes without double-escaping:

    # Redirect all traffic to https
    #
    # We're using mod_rewrite here rather than mod_alias's `Redirect`
    # because mod_alias doesn't allow the "NE" == "noescape" parameter
    # that allows URLs includinging encoded slashes (%2F) to be returned
    # without double-escaping.
    RewriteRule .* https://<%= node["app_domain"] %>$0 [L,R=301,NE]

Similarly, Symfony refuses to allow slashes in parameters passed as tokens
in routes.

To address this problematic choice, use '.' as a separator of
sub-components in identifiers. Periods don't require special escaping in
URLs or database queries, though they do in regular expressions.
Still more to do on the controller, but at least the first screen loads.
Note that this still includes Hub-specific menus that will need to be
reworked.
The midd-frontend's Mover class will operate on elements with
`data-move-at=*` attributes. If they don't have children then exceptions
will be thrown.
This is a bit of a work-around so that the external link style doesn't get
added to local paths when not hosted under middlebury.edu (such as in dev).
While the midd-frontend's typograpy styles could be updated to also
consider *.lndo.site a non-external link, using relative paths rather than
absolute URLs feels like good hygiene for links anyway to help with
portability.
This required creating our own RouteVoter that wouldn't fail on converting
phpkit_id_Id objects to strings.
Needed to remove built-in voter that doesn't support osid_id_Id objects.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Upgrade from ZendFramework 1
1 participant