Kyunki SaaS ab HOT hai !!

translated literally it would be: Because SaaS is HOT now !!

& before the Indian channel surfers & Ekta-logy lovers interpret it differently, let me clarify I am only refering to Software as a Service, the flavor of the season with the IT industry. Infact the word seems to be hotter than Web 2.0 these days.

So the blog is not about explaining the concept of SaaS or 'On Demand Software' but to ofcourse rant about the typical IT Services Companies take on it. The interesting question is how should a services company capitalize on SaaS, given that it does not want to go creative and launch its own product offering, which will ofcourse require a bigger investment with the associated risk.

The SaaS phenomenon has been brewing for last couple of years, the Services industry has only got tuned to it since Bill Gates issued a memo last October acknowledging the Disruptive power of the On Demand Software and its possible impact on traditional software business. In fact Microsoft realigning itself with Ray Ozzie as its CTO has been essentially to be able to leverage this concept and not be left behind. Infact Larry Ellison had recognized the power earlier and thus angel funded SaaS startups like Netsuite, SalesForce

So how does a Services company leverage SaaS? IMO there are 2 very simple approaches. One obviously is to hone, build and showcase expertise in technologies involved in any SaaS application.
The second & an interesting approach is to grow expertise in taking SaaS to the end client. This would mean partnering with the SaaS providers in educating end clients, implementing - configuring & customizing it for their use, integrating it with other end client apps & processes. This obviously requires a Services company to go in as Consultant who can help redefine the end client processes, application portfolio in order to leverage On Demand Softwares.
To get into SaaS based Consulting we will need to be thought leaders in SaaS which definitely will be a tall claim for any services company. So the other entry criteria is being a reliable business consultant experienced in process and portfolio reengineering who is very well aware of SaaS options available to solve a particular problem. Lot of my previous blogs mention various SaaS apps available in different domains particularly useful for any startup. A good place to look at new and established on demand players and offerings is this.

Bar Camp Anyone ?

A bar camp is being organized in Noida. When I first heard about it, it souded more like a self organizing conference that Martin Fowler talks about. Also it happens to be on Web 2.0 and similar cool stuff. Though i am not qualified enough on either web 2.0 or open spaces, I am keen to attend this one & hopefully it turns out to be as exciting & vibrant as it sounds.

Also hoping to learn a lot, meet like minded great people and figure out how these concepts can be levaraged in my organization. Will update on how it went.

Beyond Bullet Points

One thing I have realized over the past few years is that creating an wonderful technical design - architecture is fun & important for a successful techie project but more important & tricky is to be able to present it to not so geeky management people and get them excited about it.

This is where all of us end up working & cursing powerpoints: the necessary evil. & unfortunately create it like Gates does instead of adopting the Jobs style. Read this blog to figure out who are you closer to atleast in presentation styles. after reading it, i certainly need to re-visit my presentations & think beyond bullets !!

Starting a Start-up - III (Software Infrastructure)

Continuing from my previous post on why we are seeing more and more start-ups these days, I mentioned the fact that lower entry barriers are also due to host of software infrastructure needs that can be addressed by open source or very economical but mature options.

So here is my list of softwares (mostly collaboration ones) that any start-up should consider:

PBX:
  • asterisk: complete telephony solutions including conferencing, call queuing etc
Voip:
Document Sharing:
Wiki:
Full Collaboration:
  • different teams & cos have different collaboration needs but if one is looking for a suite .. then one should look at zimbra and qnext and of course erstwhile groove
Let me know what kind os softwares you find useful in a startup.

Dreambook

Just adding this little work of art to my wishlist would not have done justice to it !!!

Indian Services Companies and Open Source

An interesting thought on Why Indian Services companies do not seem excited or interested in investing in open-source? IMO this is due to the following reasons:
  • Being services companies, they have always been reacting to customer demands and industry trends, rather than proactively being thought leaders. (This is specifically about technology trends & thought leaders, rather than outsourcing leadership). This is also a reason why the services companies are not hugely succesful in Technology Consulting and traditionally focused just on Application Development.
  • Indian services companies usually have no clue about product management, and creating innovative products. After-all how many Indian software products do you see in the market. The entrepreneurship skill and courage is usually not encouraged or cultivated in Indian services companies esp at the techonology developer level, and that skill is definitely required to be able to bring a product idea to life. If Indian services cannot come up with commercial products, why should we expect them to come up with open source ones
while these are the core reasons, there will be host of other reasons especially the fact that very minuscule percentage of technology thought leaders in the world today are from India inspite of India being Software development workshop of the world for quite some time now.

Design : Changing Definitions

When I started working, software design used to be a phase where all senior ppl in team worked on trying to define what needs to be coded. The idea of this phase was to create an artifact which detailed the design to such a level that it could be given to the developer, who in turn would just code as per the design and everything will be great.
This process & steps are exactly how things would happen in any other engineering domain like construction, electrical engineering with the architects and engineers deciding on the design & workers creating the product from the blueprint.
BUT what promoters of such design phase and distinction forgot was that software industry is different. Here we dont have dumb workers in software, infact this distinction is not necessary as all are knowledge workers. Thus came the problems of changing design or code being different than the design. Secondly what the above approach forgets is that software development is not yet a defined or a predictive process but rather an empirical one and thus cannot be approached in the same way.

What I feel is that design should be evolutionary rather than planned and thus should be taken as part of coding and refactoring phase done by the developers. I am not totally declaring the design as a dead and redundant phase.. but only trying to change its definition and scope. As a phase, there should be design in each iteration where we identify the contracts (UI, interfaces with external applications, Business Interfaces) with their Api and its behavior. Also we should have robust coding and architecture guidelines specific to the project besides the generic ones.

The contract - behavior information along with project specific development guidelines are sufficient for the developer to create a code-base meeting the needs and infact there are high chances that they will discover a new Api or a need to modify one to address the needs better. That is the time they should help evolve the design in consultation with the design authority rather than avoiding following the design which is the usual stance. Infact the design should be expected to evolve over time & iterations and the code-base expected to become more robust with refactorings during the iterations. Also the development guidelines should keep getting evolved.

Infact one of the better ways to ensure a living development guideline is having it on the wiki instead of word document :). Infact same holds true for the design also ... it should be an artifact which is available in developers IDE itself allowing him to evolve it rather than as a separate UML diagram :)

If this appears greek mumbo-jumbo .. some of my thoughts are better explained by Martin Fowler in his article - Is Design Dead?

Software Entrepreneurs

Jotspot's Joe Kraus blogs about why everyone is so excited about being an Entrepreneur these days and why do we see so many new Start-ups. So my blogging series about Starting an start-up in India seems to be very nicely timed. Sometime I plan to blog about the Infrastructure Software that is now available Open Source and can form the basis of any Start-up