I read a blog post or an article the other day (can't remember where) in which the author stated his belief that soon mashups would be the biggest job security threat to web application developers instead of outsourcing. His reasoning was that as IT departments leverage existing/external web services to compose their applications, they won't need as many internal developers.
There is some logic to that, but web services and mashups--heck, any existing code or algorithms--can only get you so far. If there's something out there that's exactly what you need, you just acquire it, and there's no need to do any programming of your own.
Recently a client and I discussed redoing an application for them in order to make it more flexible and open to expansion. They don't have any internal programmers, so I've been thinking about how to write administrative tools that would allow them to create new data sets and the interfaces to allow the users to enter data. After spending several hours over the past few days working out the different variations and the complexities involved, I realized today that it wasn't going to happen. There's a point of complexity and customization where no tool is going to let you cover all the bases: you need a programmer to deal with it.
So no matter how sophisticated and easy-to-use these web services and APIs become, someone with some programming-savvy will always be needed to fully leverage those assets and customize the end-result to the needs of their users.