...
- DDD Reference Notes:
- Bounded Context discussion (p2):
- Large codebase, multiple models is inevitable.
- Nimisha Asthagiri (Deactivated): Embrace this, but get clear on bounded contexts.
- Organization and Architecture reflect each other.
- Illustration:
- What is a course? What is a course run?
- LMS: XBlock content. Not strong association between runs.
- ECom/Discovery: What it calls a course and what it knows about a course is different.
- What is a course? What is a course run?
- Large codebase, multiple models is inevitable.
- Ubiquitous Language (p3?)
- Important that all stakeholders are involved.
- Language must be consistent within a bounded context.
- Hopefully, the same language will be used across contexts when and where a concept applies.
- Document this and help with onboarding: how and where is this captured?
- Someday get clear on how much we are willing to update code to match changes in Ubiquitous Language.
- Do not allow the same word to mean two different things in the same in the context.
- Core Domain (p40):
- We define Core as Core for today, and not necessarily the future. Could evolve as the company pivots. Might help us make faster progress on deciding.
- Questions about whether core could change? Or maybe the pure core would never change?
- Assign best developers here.
- Generic Subdomains (p41)
- Discern your core. Dusting off what you first think is core might end up being a generic subdomain, in which case you might choose something off-the-shelf.
- Notifications is an example. Payments is an example.
- Don't assign best developers here. They won't pick up core domain knowledge.
- Supporting
- Supports core but not generic.
- Example:
- Game Engines might be generic and you might be required to do your own specific game engine if your use cases are more specific and required.
- It doesn't make sense for a small company to make their own generic game engine. Can't compete on breadth of features.
- It may make sense for them to do something very specialized to their game.
- Game Engines might be generic and you might be required to do your own specific game engine if your use cases are more specific and required.
- Bounded Context discussion (p2):
- Review Domain Vision Statement
- Was made by Engineers
- Takes strong stances on revenue, open source (last two paragraphs)
- Reads as high level business strategy, not clear how it relates to arch in core
- According to DDD, this is appropriate, and there's another doc that goes with this to bridge the two.
- Trickiness of defining Core is understanding the business strategy better.
- What's the timeline of "Vision Statement"?
- Expectation that the Core will evolve over time.
- Do we focus on only what we're doing now instead? Example of revenue.
- There's still some core of edX that won't radically change regardless.
- The elevator pitch for edX doesn't need monetization details.
- Is Open Source core in that sense?
- Identify Domain Use Cases
- User types:
- Learners
- Educators
- Admins (wants reports on their students)
- Researchers
- Educators (what they need, from Shelby's presentation) + Researchers
- Support Educators
- Easy Authoring and Administration of Courses
- Communities of Practice
- Actionable Data and Feedback (Insights + Data package)
- Teaching at Scale
- Course Design
- Education Tools
- Supporting Learners (Community and Mentorship)
- Experimentation
- Support Educators
- Learners
- Discovery: Find the right course/program to help them achieve their goals
- Achieve Learning Outcomes
- Rigor/quality of instruction
- Support through their learning pathway – progress, messaging, social
- Proof of Learning, credentials/certifications
- Admins
- Actionable Data and Feedback
- What are my students doing
- Am I getting my money's worth
- Setting up edX for their org
- Curation
- Integration
- Actionable Data and Feedback
- User types: