-
Notifications
You must be signed in to change notification settings - Fork 12
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
Define Project Goals and Purpose #1
Comments
I am a big fan of the "Contract" concept when it comes to solving the separation of concerns problem that you have outlined in great detail. It's easy to separate the concerns, but immediately after separating, now you have to define the boundaries and rules of interaction between those concerns. You must define those boundaries and rules with a contract, or chaos ensues. Contracts are generally tedious and contentious negotiations. The bigger the deal, the bigger the contract, the longer the negotiation. In technology, it is easy to skip this step and start writing code. The challenge, I believe, is to find a way to make this contract negotiation as painless as possible, to prevent the team, especially the developers, from skipping this crucial step. Just like in many areas of personal and professional lives, once a contract is complete, the real work can begin, with all parties involved having had their opportunity to fight for what is important to them, and compromise where necessary to get the deal done. Types, classes, interface, schemas, signatures... all of these programming concepts are a form of contract between developers and their code and between applications and their local or remote resources. Defining and configuring these can present the team with considerable overhead and makes this step susceptible to being skipped. It can come in the form of pressure to deliver, laziness, tediousness, etc. Overcoming the pressure to deliver functionality early, and allowing the technical "contracts" to develop can pay huge dividends almost immediately, most of which are outlined in the original post. |
@MrMaz I think you are hitting on some very important things. The contract piece if implemented correctly creates a lot of room for value add. From scaffolding to validation and error logging. I already have a plan to tackle this initial piece. Will probably be using JSON Schema for it. Also, I have explored auto-generated documentation for that. I think it's a fine line, that we will have to walk on this, so the tool does not become the handicap of a project. I will be opening a new issue to talk about particulars fo the project. |
…s-local-auth feat: local-auth doc improvements
Why does this project exist or should this project even exist?
As we go forward to define what this project is. I thought it would be important for us to break this down into some high-level pain points which we are trying to solve.
The technology landscape is getting more and more complex. However, I believe that we are in a great moment in which things can be simplified in many ways. One of the reasons the landscape is so complicated is due to the fact that we have so many build targets. Server, Web, Mobile, Desktop, and we continue to see even more use cases.
However, there has been a push for consolidation but in many ways, I feel were never fulfilled to its promise. For many reasons the technology industry has followed what some people have referenced as HDD, Hype Driven Development.
This has created a cycle which very few tech companies especially the ones that are outside the Top 100 big names have been able to solve. In my opinion agencies, startups, and smaller business suffer the most, as they are stuck implementing solutions that are not mature by the time they go live, or maybe never mature at all.
This project is an acknowledgement of the following:
What this project is not pushing for
What this project does believe in is at the following
PS. At any point, we might lose track of these priorities and get caught up. It's important we keep this in mind as we move forward.
Foundational Concepts and Infrastructure
I will probably continue to edit this issue as new items come up. Also, new issues will be created to address project architecture and organization.
The text was updated successfully, but these errors were encountered: