One of many great things about Zato is the fact how easy it is to plug into it new data sources and input methods triggering one's SOA/API services.
For instance, Zato 2.0 does not have a web-admin GUI for file notifications but it is still possible to listen for new or updated files in directories of choice and invoke services each time a new event arrives, e.g. when a new file is dropped into a directory, effectively creating a new channel type in addition to what Zato comes with out of the box.
This is exactly what the script below does - it uses watchmedo, part of the watchdog package, to listen for events in a given directory. Each time anything of interest happens in that directory (here - in /tmp/data) a Zato service defined below is invoked with a path to that item of interest provided on input.
#!/bin/bash
watchmedo shell-command \
--patterns="*"\
--command='curl localhost:11223/file.notifications?path=${watch_src_path}; echo'\
/tmp/data
It's entirely up to that service to decide how to handle the data in each file - one can decide to deliver it to any of outgoing connections in Zato using, for instance, AMQP, SMTP, FTP, ElasticSearch, Solr or do anything else that is required in a given integration scenario.
data:image/s3,"s3://crabby-images/e6e82/e6e82b9bcaebcf189458946d21ed19d86d708b3a" alt="Screenshots"
Just to exemplify the idea, in this blog post the data is simply stored in server.log:
# -*- coding: utf-8 -*-from__future__importabsolute_import,division,print_function,unicode_literals# Zatofromzato.server.serviceimportServiceclassFileNotifications(Service):name='file.notifications'classSimpleIO(object):input_required=('path',)defhandle(self):# Read data indata=open(self.request.input.path).read().strip()# Since this is just an example, only log the contents of what was read inself.logger.info('Data from %s is `%s`',self.request.input.path,data)
Such a service needs to be mounted on an HTTP channel, as below.
data:image/s3,"s3://crabby-images/84872/84872390487491be4b3e403b63462035ee8c4eb5" alt="Screenshots"
If you have not done it yet, create a directory /tmp/data and start the watchmedo script above before continuing with the next steps.
Now we can create a new file and observe in server.log what happens, how the service reacts to it:
data:image/s3,"s3://crabby-images/c05ff/c05ff852ba383bcd46b5344b1f6fd7c2c3f61f18" alt="Screenshots"
Sure enough, server.log confirms that everything works as expected:
data:image/s3,"s3://crabby-images/16e91/16e910381bb1a1e40b7227af4826fe68e1af455f" alt="Screenshots"