It seems the more I know, the less I get to do. I'm currently a technical architect for 6 sprint teams - which is exciting and challenging but I'm getting less and less (read no) time at the coal face.
The pace of change in IT seems to be exponential and I like to keep my toes on the edge of the programming curve.
OK - so I'd love to get back into Unix, c++, java and all that stuff - but it's been 15 years or so so I'm going to stick with the Microsoft stack.
The Challenge
Deliver a user story in one hour. That's one hour to code, test and release.
"Give me six hours to chop down a tree and I will spend the first four sharpening the axe."
Abraham Lincoln
I am going to allow - outside of the hour - study and plan. Hopefully this will make the hour super productive.
The project
The project is simple - and combines programming with my other passion - cycling. You can read about some of my cycling here. Every year I organise a few "Brevets" - long distance cycle rides for Audax Ireland. There is a bit of admin involved:- Collect details of participants - currently they email or post a form with name, address etc.
- Collect money - I accept PayPal or cash on the day. Not all organisers accept cash and some push the PayPal through the clubs. Different events cost different amounts. Payment can be made in € or £.
- Print "Brevet Cards" with the event details, riders details and control points.
- Sign on sheet for Cycling Ireland (CI) with list of riders to collect signature at start.
- One day licence form for riders who aren't members of cycling Ireland.
- On completion - fill in finisher details on spreadsheet for Audax Club Parisien to homogolate the rides and order medals where required.
- Submit accounts and pay balance toe Audax Ireland (AI).
- When homogolation stickers and medals arrive, post with brevet cards to riders.
Currently I run all this using a spreadsheet to collect the rider info on. I then have a word mail merge for the Brevet cards and cut and paste onto the other documents.
The biggest pain is actually getting the data on the spreadsheet. It is either keyed or cut an pasted depending on how the application arrives. I can also sometimes cut and paste from an old spreadsheet - but the CI license numbers change every year and other details may change.
The tech
- SQL Azure - assuming a relational database - might need other azure tech around the outside for large data or whatever.
- C#.net for business object layer, processes etc.
- MVC for serving HTML to client
- WEB API - for services
- Angular
- Visual Studio
Entity framework or ADO.NET + Strongly typed stored procedures.
Its a question that's been worrying me for about 8 years!
Currently I have projects working with ADO.NET and stored procs (most), EF and unit of work, and EF over stored procedures. I'm still torn between development speed, security, maintanence and
Strongly Typed Stored Procedures
- Tick a big security box - giving lease privilege access to the database and strong type checking - a string is a string never a piece of sql, thus adding a layer of defence against many forms of attack, SQL injection being the most obvious. OK - O know EF will have vendor backing and is paramaterised etc. etc. but believe me, when some external auditor comes in and says what layers of defence do you have against attack, the strongly typed stored procedure with least privilege (i.e. connection can only execute stored procs) is king.
- Are fast
- Do set based operations where they belong - in an engine that has been optimised over about twenty five years for performing set based operations!
- Allow provide an encapsulation layer over your data model, allowing it to be changed and maintained independent(ish) of your code.
- Allow your database to be normalised and your object model to be de-normalised as. it should be.
- Allow your interactions with the database to be as they should i.e. full control over how much data is fetched when.
- Is stable with a very long support life ahead and behond - ADO.NET.
- Can lead to business logic being scattered across code and sql depending on who wrote it!
- Can result in stored procedure mountains.
- Offer a great maintainence fix.
Entity Framework
- Is quicker to develop - though I'd argue this might only be over the first few iterations of a project.
- Supports more flexible query functionality for the application e.g. sorting, querying multiple parameters etc. without additional effort.
- Can leave you fighting the framework.
- Is not as stable
- Is not as secure
- Through web services - offers a consistent business layer for other applications e.g. reporting etc.
- May lead to compromises in the data model (de-normalised) or the business object model (too normalised).
- Requires a full code deploy.
I'm going to put this decision off a bit longer!
Project management and tools
OK - so its agile, obviously.
Agile tool/work tracking
TBD - I have visual studio online/visual studio team system and this is the obvious choice but I might look at a more "open" product - after all I'm wearing shorts right!
I guess initially it'll be this blog as my Minimum Viable Product in an hour is going to be very minimum.
Source Code Repository
To open source or not to open source, that is the question - well - I really want to open source - not that I'm expecting a million IT pros to rock up and start working on this but, like I say, I wearing shorts. I thing I need to be careful of is ideally I'd use some of Stiona Software's utility and platform code but this has IPR wrapped in it and I'm not wearing sandals. Software is my living too.
Again - with my shorts on GIT - but frankly it's something else to learn at the moment.
So - probably codeplex. I have an account and it integrates with visual studio.
having been a DBA in a previous life i would have gone with stored procs, but do remember a decent entity framework will give you cacheing (although so will a DB probably), added fine grained security, circuit breaking, the ability to switch datastores. Plus, it always seem easier to handle failure in an EF (especially for distributed txns) then using sprocs.
ReplyDelete