-
Notifications
You must be signed in to change notification settings - Fork 117
Taffy1.1: Index of API Methods
This page is an alphabetical listing of all methods that Taffy exposes for you to use in your APIs, grouped by location that they are available. If a method is not included here, you should consider it un-documented, and as such it may change or be renamed at any time without notice. I will make a conscious effort not to break or rename any documented functions, though they may change with a major version if deemed an improvement to the framework.
- Application.cfc Methods
- applicationStartEvent
- configureTaffy
- enableCrossDomainAccess
- enableDashboard
- getPath
- getBeanFactory
- getGlobalHeaders
- newRepresentation
- onTaffyRequest
- requestStartEvent
- registerMimeType (deprecated as of 1.1)
- setBeanFactory
- setDashboardKey
- setDebugKey
- setDefaultMime (deprecated as of 1.1)
- setDefaultRepresentationClass
- setGloablHeaders
- setReloadKey
- setReloadPassword
- setUnhandledPaths
- Resource CFC Methods
- noData
- representationOf
- streamBinary
- streamFile
- streamImage
- withHeaders
- withMime
- withStatus
- Representation Class Methods
- ?
The following methods are available in your Application.cfc:
Use it inside: Application.cfc
Parameters: (none)
Since the framework takes over the onApplicationStart event of Application.cfc, it also exposes this methdod as a way for you to add logic to be executed when the event occurs. applicationStartEvent is called by onApplicationStart before the framework is initialized. It is recommended that your Application.cfc NOT implement onApplicationStart, and should instead use applicationStartEvent.
Use it inside: Application.cfc
Parameters: (none)
This is a special method called by the framework during initialization to get your APIs configuration. You must implement this method in your Application.cfc to override any framework setting defaults. All configuration methods should be used inside your implementation of configureTaffy, if you intend to use them.
Use it inside: configureTaffy
Parameters:
- enabled (boolean) - whether or not to allow cross-domain access to your api
Turning this on adds the header: <cfheader name="Access-Control-Allow-Origin" value="*" />
, which enables access from other domains.
Use it inside: configureTaffy
Parameters:
- enabled (boolean) - Whether or not Taffy will allow the dashboard to be displayed. If set to false, the dashboard key is simply ignored. Default value is TRUE.
You should probably set this to FALSE in production to prevent snooping around.
Use it inside: Application.cfc
Parameters: (none)
This method is provided as an extension point. On Adobe ColdFusion ("ACF") 9, installed in standard entire-server mode, no change should be necessary. However, if ACF is installed on another JEE app server (i.e. Tomcat, Glassfish, etc), or on JRun but using an EAR/WAR setup, then you may need to override this method to make Taffy work on your server. See GetPath Setups for more information.
Use it inside: Application.cfc
Parameters: (none)
Returns whatever bean factory you may have set into Taffy, if any.
Use it inside: Application.cfc
Parameters: (none)
Returns the structure of global headers that you have set using setGlobalHeaders()
, if any. If none, returns an empty structure.
Use it inside: onTaffyRequest
Parameters:
- class (string) - the dot-notation cfc path (or bean id if managing the class with a bean factory, including the built-in factory) for the representation class. Optional. Default value is the default representation class,
nativeJsonRepresentation
.
Use this method inside onTaffyRequest when you want to abort the request with some specific message or data. Use the setData
method on the returned representation class to put your data/message into it before returning it.
Use it inside: Application.cfc
Parameters:
- verb (string) - The HTTP request verb provided by the client
- cfc (string) - The CFC name (minus ".cfc") that would handle the request. (Bean Name, if using an external bean factory.)
- requestArguments (struct) - A structure containing all of the arguments of the request, including tokens from the URI as well as any query string parameters (defined after the ?, eg ?city=).
- mimeExt (string) - The mime extension (e.g. "json" - NOT the full mime type, e.g. "application/json")
- headers (struct) - A structure containing each header from the request, as sent by the client.
This method is optional, and allows you to inspect and potentially abort an API request in a way that adheres to the HTTP specification. If you choose not to override it (by implementing it in your Application.cfc), it will always return true, allowing the request to continue. If you implement it, you can check for things like an API key, or whether or not the customer has paid for your service, and return something other than the data that they are requesting.
If you do not return TRUE, allowing the request to continue as normal, then Taffy expects you to return a representation (either the default class, or a custom one) that it should immediately return to the consumer, serialized to the appropriate format. If you simply want to return with a status code of 403 (which indicates "Not Allowed"), you could do this:
return newRepresentation().noData().withStatus(403);
Alternately, you could return some data to indicate that they owe you money or something:
return newRepresentation("taffy.core.nativeJsonRepresentation")
.setData({error="Your account is past due. Please email accounts payable."})
.withStatus(403);
The options here are limited only by your imagination.
Use it inside: Application.cfc
Parameters: (none)
Since the framework takes over the onRequestStart event of Application.cfc, it also exposes this methdod as a way for you to add logic to be executed when the event occurs. requestStartEvent is called by onRequestStart after the framework is re-initialized (if requested). Your Application.cfc should NOT implement onRequestStart, and should instead use requestStartEvent.
This method is deprecated. It will likely be removed in a future update. Use metadata instead.
Use it inside: configureTaffy
Parameters:
- extension (string) - The url-extension that will invoke this mime type. (e.g. "xml" or "json")
- mimeType (string) - The mime type that should be set into the http headers when the corresponding extension is requested. (e.g. "application/xml" or "application/json")
Each mime type that your API is capable of returning needs to be registered with the framework, and the configureTaffy method is the most efficient place to do so.
Because the framework implements JSON by default, the JSON ("application/json") mime type is already registered, and you do not have to re-register it. (You can if you like, though. It won't hurt anything.)
Use it inside: configureTaffy
Parameters:
- beanFactory (object) - already instantiated and cached (e.g. in Application scope) object instance of your external bean factory.
- beanList (string) - a comma-delimited list of bean Id's that the bean factory is aware of. Optional, and only necessary if the beanFactory does not implement
getBeanList()
and is not ColdSpring. Tight ColdSpring integration is baked in.
While Taffy includes a very basic Bean Factory (used by default) and also has fairly tight integration with ColdSpring, other bean factories could be added. If your bean factory implements getBeanList()
, then Taffy will use that to get a list of beans that the factory knows about. However, if it does not, then Taffy will allow you to provide the bean list as a string in the optional second argument.
Use it inside: configureTaffy
Parameters:
- keyName (string) - Name of the url parameter that displays the dashboard. Default value is "dashboard".
The dashboard displays resources that your API is aware of, generates documentation about your API based on hint attributes, and contains a mock client to make testing your API easy.
Use it inside: configureTaffy
Parameters:
- keyName (string) - Name of the url parameter that enables CF Debug Output. (e.g. "debug")
Sometimes it's useful to see ColdFusion's debug output in the results of your API requests during testing. For that reason, you can include this query string parameter to enable debugging on a per-request basis.
If you do not change it, the default value is, "debug".
This method is deprecated. It will likely be removed in a future update. Use metadata instead.
Use it inside: configureTaffy
Parameters:
- DefaultMimeType (string) - The mime type that should be returned when none is specified by the consumer. (e.g. "json")
It is important to note the difference between the mime type and extension. Here, the extension is expected because of its brevity. While the mime type to be returned is "application/json", you should pass the string "json" to the function. If, for example, you registered the mime type of "xml" as "application/xml" (using registerMimeType), and you wanted XML to be the default format, you would pass the string "xml" to the setDefaultMime function; and it could be specified on the url by appending ".xml" to the URI, before any query string parameters, like so:
/artists.xml?city=Philadelphia
If not implemented, the framework default mime type is JSON ("application/json").
Use it inside: configureTaffy
Parameters:
- customClassDotPath (string) - Dot-notation path to the CFC to be used by default. Alternately, you can pass in a beanId and the class will be requested from the bean factory. This works with both the internal bean factory (your
/resources
folder) and if you are using an external bean factory.
When you change the default Representation Class, all responses will use your custom default class, unless you specifically override that request, using the (optional) second parameter to the representationOf function.
Use it inside: configureTaffy
Parameters:
- headers (struct) - A structure where each key is the name of a header you want to return, such as "X-MY-HEADER" and the structure value is the header value
Global headers are static. You set them on application initialization and they do not change. If you need dynamic headers, you can add them to each response at runtime using withHeaders()
.
Use it inside: configureTaffy
Parameters:
- keyName (string) - Name of the url parameter that requests the framework to be reloaded. (e.g. "reload")
Used in combination with the reload password (see: setReloadPassword), the framework will re-initialize itself. During re-initialization, all configuration settings are re-applied and all cached objects are cleared and reloaded. If the value of the key does not match the reload password, a reload will not be performed. This allows you to set a secret password to restrict control of reloading your API to trusted parties.
If you do not change it, the default value is "reload".
Use it inside: configureTaffy
Parameters:
- keyName (string) - Accepted value of the url parameter that requests the framework to be reloaded. (e.g. "true")
Used in combination with the reload key (see: setReloadKey), the framework will re-initialize itself. During re-initialization, all configuration settings are re-applied and all cached objects are cleared and reloaded. If the value of the key does not match the reload password, a reload will not be performed. This allows you to set a secret password to restrict control of reloading your API to trusted parties.
If you do not change it, the default value is, "true".
Use it inside: configureTaffy
Parameters:
- unhandledPaths (string) - new list of unhandled paths, comma-delimited (commas may not be part of any list item)
Use this method to set a list of paths (usually subfolders of the api) that you do not want Taffy to interfere with. Unless listed here, Taffy takes over the request lifecycle and does not execute the requested ColdFusion template.
Resource CFCs extend taffy.core.resource
. The following methods are available inside each of your Resource CFCs:
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters: (none)
This method allows you to specify that there is no data to be returned for the current request. Generally, you would use it in conjunction with the withStatus method to set a specific return status for the request. For example, if the requested resource doesn't exist, you could return a 404 error like so:
return noData().withStatus(404);
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- data (any) - The data to return to the consumer.
- optional customRepresentationClass (string) - Dot-notation path to a custom CFC, or bean name, that will serialize your results. Defaults to included generic serializer which supports JSON.
Data can be of any type, including complex data types like queries, structures, and arrays, as long as the serializer knows how to serialize them. For more information on using a custom representation class, see Using a custom Representation Class.
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- binaryData (any) - the binary data to be streamed back to the consumer
- optional customRepresentationClass (string) - Dot-notation path to a custom CFC, or bean name, that will serialize your results. Defaults to included generic serializer which supports JSON.
Use this method in place of representationOf()
to return a stream of binary data. Useful for streaming things like dynamically generated PDFs.
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- fileName (string) - fully qualified file path (eg c:\tmp\files.zip)
- optional customRepresentationClass (string) - Dot-notation path to a custom CFC, or bean name, that will serialize your results. Defaults to included generic serializer which supports JSON.
Use this method in place of representationOf()
to stream a file from disk (or VFS).
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- binaryData (any) - the binary, base64 encoded data of the image, to be streamed back to the consumer
- optional customRepresentationClass (string) - Dot-notation path to a custom CFC, or bean name, that will serialize your results. Defaults to included generic serializer which supports JSON.
Use this method in place of representationOf()
to stream an image from disk (or VFS).
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- headerStruct (struct) - A structure whose keys are desired header names ("x-powered-by") and whose associated values are the values for the corresponding headers ("Taffy 1.1!").
This special method requires the use of either noData or representationOf. It adds custom headers to the return. Additional use of withStatus optional.
Ex: return representationOf(myData).withHeaders({"X-POWERED-BY"="Taffy 1.1!"});
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- mime (string) - mime type (eg. "application/pdf") to be returned with the streamed file data
This special method requires the use of either streamFile or streamBinary. It overrides the default mime type header for the return.
Ex: return streamFile('kittens/cuteness.pdf').withMime('application/pdf');
Use it inside: responder methods inside your Resource CFCs (e.g. get, put, post, delete - as well as head, options, etc).
Parameters:
- statusCode (numeric) - the HTTP Status Code to return to the consumer.
This special method requires the use of either noData or representationOf. It sets the HTTP Status Code of the return. Additional use of withHeaders optional.
If you do not specify a return status code, Taffy will always return status code 200 (OK) by default.
Ex: return noData().withStatus(404);