flux/README.md
Michael RICOIS ebce960d0e Markdown
2016-01-29 18:00:45 +01:00

9.0 KiB
Raw Permalink Blame History

Flux : Mise à disposition fichier de télétransmission

Configuration pour les fichiers en entrées

'client' => array(
    'prestations' => array(
        array(
            'name' => Nom de la prestation pour référence (UPPERCASE)
            'type' => Type du dépot SFTP|FTP 
            'directory' => Répertoire de dépot (par defaut "send")
            'filemask' => Masque du fichier à récupérer ! not working
            'in' => array(
                --See the list of options--
            ),
            'out' => array(
                --See the list of options--
            ),
        ),
	),
),

Send Options list (in)

  • FilterName: Filtre par nom de prestation (true) ou par nom défini
  • CopyAddDate: Copy file and add a timestamp to the end of the filename
  • CopyDeleteAfter: After copying the file delete it in repository
  • RunWithEndFile: Only execute action when we receive file with extension .fin or .end
  • Log: Log transfert
  • Route: For each Route options (cp, ftp, sftp, mail) cp => realpath of dir ftp mail

Recv Options list (out)

  • Log: Log read disable by default

Tck Options list (Check Transfert - use with CFT and other transfert mode)

Envoi dans le repo du client fichier *.tck Recherche du fichier dans la table des flux et remplissage marqueur transfertDate

Crontab - incron

Exemple surveillance livraison de fichiers par le client

$fluxBasePath IN_CLOSE_WRITE php /home/batchFlux/fileSend.php --file $@/$# >> /home/log/send.log 2>&1

Exemple surveillance lecture du fichier mis en dépot

$fluxBasePath IN_CLOSE_NOWRITE,IN_ACCESS,IN_DELETE,IN_NO_LOOP php /home/batchFlux/fileRead.php --file $@/$# >> /home/log/read.log 2>&1

Exemple surveillance retour par autre programme de transmission

$fluxBasePath IN_CLOSE_WRITE php /home/batchFlux/fileTck.php --file $@/$# >> /home/log/tck.log 2>&1

Attention, une seule entrée de repertoire peut être saisie dans la incrontab. fileSend a été prévue pour gérer correctement les extension tck Sinon préférer l'utilisation de trigger.php

$fluxBasePath IN_CLOSE_WRITE,IN_CLOSE_NOWRITE,IN_ACCESS,IN_DELETE,IN_NO_LOOP /home/batchFlux/trigger.php --file $@/$# --event $%

TODO

Créer fileMail => Recupération element par mail, enregistrement Filtre sur email et/ou sujet Créer fileTransfert => envoi sur le FTP, SFTP du client

Note CFT

PARTNERS

	&PART 	Partner name (ID of CFTPART) 
	&GROUP	Group to which the partner belongs 
	&SPART	Sending partner name 
	&RPART	Receiving partner name 
	&IPART	Intermediate partner name 
	&NPART	Network name of partner sending data (NSPART or NRPART according to the transfer direction) 

TRANSFER

	&IDT		Transfer identifier 
	&NIDT		Protocol transfer identifier 
	&IDTU		Local transfer counter (unique)
	&PIDTU		Parent idtu of the child transfers
	&PHASE		Processing phases to help manage transfer flows
	&PHASESTEP	Step in processing phase
	&APPSTATE	State step for the processing script to restart if relaunched
	&NSUB 		Counter for the submitting of end-of-transfer procedures, error procedures and procedures submitted by SUBMIT.
				If 4 characters long, the counter is reset to 1 after 9999 
	&DIAGI		Internal diagnostic code value 
	&DIAGP		Protocol diagnostic code value 
	&COMP		Compression negotiated for the transfer
	&NBT 		Number of bytes transferred 
	&PRI		Transfer CFT priority for the transfer (0 to 255) 
	&QQ 		Number of the day in the year associated with the transfer identifier 
	&SELFNAME	Name of the generic transfer selection file 
	&FCODE 		Code for the data in a file 
	&TRTYPE		Available at the end of transfer to designate FILE, MESSAGE, REPLY, or NACK
	&NCODE 		Code for the data sent over the network 
	&EXITFREE	Free communication area between multiple exits
	&XLATE		Transcoding table used during transfer
	&MODE		Server mode = S transfer, Requester mode = R transfer

FILE

	&IDF		Model file identifier (logical name)  
	&FNAME		Physical file local name 
	&FKEYLEN	Length (received) of the indexed file key at the senders site 
	&FKEYPOS 	Position (received) of the indexed file key at the senders site 
	&NBR		Number of records in the file
	&BLKNUM 	Catalog block number 
	&XLATE 		Identifier of the translation table used 
	&NBC 		Number of bytes in the transferred file
	&NIDF 		Model file network identifier 
	&FDB 		Database name 
	&FCHARSET 	Local file encoding
	&NCHARSET 	Destination file encoding for network data
	Receiving
	&NFNAME 	Physical file network name 
	&UNIT 		Physical file volume name for received file (MVS, z/OS)
	&UNITC  	Physical file unit class for received file (MVS, z/OS)
	&PATH		Local file path of the received file
	&ROOT		Local file root for the received file
	&SUF		Local file suffix for the received file
	Sending
	&SFNAME 	Name of file to send
	&FUNIT		Physical file volume name for sending file (z/OS,MVS)
	&FUNITC  	Physical file unit for sending file (z/OS,MVS)
	&FPATH 		Prefix (file path) of the sending file
	&FROOT 		Root (actual file name) of the sending file
	&FSUF 		Suffix associated with file name of the sending file

DATE and TIME associated with a FILE

	&FDATE		Date associated with the file 
	&FTIME 		Time associated with the file 
	&FYEAR 		Year associated with the file 
	&FMONTH 	Month associated with the file 
	&FDAY 		Day associated with the file 

DATE and TIME associated with a CATALOG

	&CDATE 		Catalog entry date 
	&CTIME 		Transfer start date 
	&BTIME 		Transfer start time 
	&BYEAR 		Start year for the transfer
	&BMONTH 	Start month for the transfer
	&BDAY 		Transfer start day 
	&EDATE 		Transfer end date
	&ETIME 		Transfer end time f
	&EYEAR 		Transfer end year
	&EMONTH 	Transfer end month
	&EDAY		Transfer end day
	&TT 		Transmission duration in seconds (TIMES attribute in the Transfer CFT catalog)

CONTROL OUTPUT

	&FLOG 	Name of last log file used by Transfer CFT 
	&FACCNT Name of last statistics file used by Transfer CFT 
	&FCAT	Name of catalog used by Transfer CFT

Note INOTIFY

Utilisation des événements INOTIFY pour la surveillance des dossiers

The command may contain these wildcards:

    $$ - a dollar sign
    $@ - the watched filesystem path (see above)
    $# - the event-related file name
    $% - the event flags (textually)
    $& - the event flags (numerically)

Events

IN_ACCESS
File was accessed (read) (*).

IN_ATTRIB
Metadata changed, e.g., permissions, timestamps, extended attributes, link count (since Linux 2.6.25), UID, GID, etc. (*).

IN_CLOSE_WRITE
File opened for writing was closed (*).

IN_CLOSE_NOWRITE
File not opened for writing was closed (*).

IN_CREATE
File/directory created in watched directory (*).

IN_DELETE
File/directory deleted from watched directory (*).

IN_DELETE_SELF
Watched file/directory was itself deleted.

IN_MODIFY
File was modified (*).

IN_MOVE_SELF
Watched file/directory was itself moved.

IN_MOVED_FROM
File moved out of watched directory (*).

IN_MOVED_TO
File moved into watched directory (*).

IN_OPEN
File was opened (*). 
When monitoring a directory, the events marked with an asterisk (*) above can occur for files in the directory, 
in which case the name field in the returned inotify_event structure identifies the name of the file within the 
directory.

The IN_ALL_EVENTS macro is defined as a bit mask of all of the above events. This macro can be used as the mask 
argument when calling inotify_add_watch(2).

Two additional convenience macros are IN_MOVE, which equates to IN_MOVED_FROM|IN_MOVED_TO, and IN_CLOSE, which 
equates to IN_CLOSE_WRITE|IN_CLOSE_NOWRITE.

The following further bits can be specified in mask when calling inotify_add_watch(2):
IN_DONT_FOLLOW (since Linux 2.6.15) 
Don't dereference pathname if it is a symbolic link.

IN_EXCL_UNLINK (since Linux 2.6.36) 
By default, when watching events on the children of a directory, events are generated for children even after they have been unlinked from the directory. This can result in large numbers of uninteresting events for some applications (e.g., if watching /tmp, in which many applications create temporary files whose names are immediately unlinked). Specifying IN_EXCL_UNLINK changes the default behavior, so that events are not generated for children after they have been unlinked from the watched directory.

IN_MASK_ADD
Add (OR) events to watch mask for this pathname if it already exists (instead of replacing mask).

IN_ONESHOT
Monitor pathname for one event, then remove from watch list. 
IN_ONLYDIR (since Linux 2.6.15) 

Only watch pathname if it is a directory.

The following bits may be set in the mask field returned by read(2): IN_IGNORED Watch was removed explicitly (inotify_rm_watch(2)) or automatically (file was deleted, or file system was unmounted).

IN_ISDIR
Subject of this event is a directory.

IN_Q_OVERFLOW
Event queue overflowed (wd is -1 for this event).

IN_UNMOUNT
File system containing watched object was unmounted.