-
Notifications
You must be signed in to change notification settings - Fork 15
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
docs: Add slot naming and life cycle ADR #99
base: master
Are you sure you want to change the base?
Conversation
062da41
to
a833874
Compare
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #99 +/- ##
=======================================
Coverage 97.81% 97.81%
=======================================
Files 10 10
Lines 229 229
Branches 59 59
=======================================
Hits 224 224
Misses 4 4
Partials 1 1 ☔ View full report in Codecov by Sentry. |
a833874
to
c404ef9
Compare
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.
Sounds good to me! Though I'd also propose adding a .beta
alternative to .v1
which indicates the plugin slot is unstable and can be changed anytime until stabilized as .v1
.
6174f34
to
cbecb49
Compare
Good idea, @bradenmacdonald! I added an explicit reference to the |
Okay, so my suggestion here is that we add a "slot type" to the naming scheme between Subdomain and Module:
The reason for this is that frontend-base has been designed to allow us to provide different types of slots, such as UI, services (logging, analytics, auth), scripts (GA), hooks (events), filters (functions), etc. Currently frontend-base has a robust UI slot system, but extending it to other types of slots will be relatively easy. Further, the TypeScript types in frontend-base is able to use the existence of "ui" in the slot ID to provide detailed type information for writing slot operations, which helps us keep the operation schema simpler with less boilerplate. Further, it means that the slot itself can enforce the types of operations by virtue of its naming scheme; operators and developers can't accidentally use a slot incorrectly because the type system is hooked into the slot ID itself. So adding this would provide:
And for what it's worth, frontend-base takes advantage of the type safety provided by the naming scheme, and it's really nice. :) |
That seems like a perfect spot for it! I'm 100% on board! Edit: I could see an argument for |
Good question, maybe some examples will help? We can imagine New Relic being added in two parts, the actual service implementation (NewRelicLoggingService) and the New Relic script. With the slot first:
Vs:
I don't know! It's a near thing; I'd likely be happy with either. :) |
More examples to throw into the fray Slot first
vs
|
Honestly think it flows better with the module first. (Brian's way) Put another way, a frontend will have modules which will have slots more than a frontend has slots which have... modules... yeah, I think I agree with Brian now. :) |
After seeing the examples I'm definitely on the
team. |
I can see the advantages of both. Since you both argued for module first, let me present two arguments for slot type first: one conceptual, one practical. Conceptual, from generic to specific: in the Practical: having the slot type come first makes it a tad easier to group/find all slots of a given type across the codebase, whether it be via grep/sed or via Github search box: you're searching for "frontend.ui" vs "frontend.*.ui" (not even sure the latter is possible via Github search). A conceivable counter-argument is that it makes it harder to search for all of a module's slots across the codebase... except that you're not going to be doing that (across the codebase) because all of a module's slots are (presumably) in a single repository. |
Operators can subsequently insert plugins into this slot by referencing | ||
"arbitrary_slot_name" in configuration as follows: | ||
|
||
pluginSlots: { |
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 we add an example of what this config would look like afterwards? Is only the id
changing?
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.
Yes, it's only the id
, and yes, it's worth adding a concluding example. On it.
@davidjoy, we discussed this internally at Axim, and it turns out there's consensus to keep the type out of the slot name, mostly out of concern that it's needlessly harder for both humans and computers to parse. We should just add a separate field in the slot definition for it. |
cbecb49
to
2d67f97
Compare
This adds an ADR to govern plugin slot naming and maintenance life cycle.