* Support tokens as a dynamic, generic construct
This new design will make it so a single client can be used with all sorts of API, even though the authorization requirements for different API versions require different tokens.
* update tokenprovider docs