~ubuntuone-control-tower/ubuntuone-client/trunk

« back to all changes in this revision

Viewing changes to canonical/ubuntuone/storage/syncdaemon/u1fsfsm.py

  • Committer: Rodney Dawes
  • Date: 2009-05-12 13:36:05 UTC
  • Revision ID: rodney.dawes@canonical.com-20090512133605-6aqs6e8xnnmp5u1p
        Import the code
        Hook up lint/trial tests in setup.py
        Use icontool now instead of including the render script
        Add missing python-gnome2-desktop to package dependencies
        Update debian/rules to fix the icon cache issue

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
"""This is a generated python file"""
 
2
# make pylint accept this
 
3
# pylint: disable-msg=C0301
 
4
state_machine = {'events': {u'AQ_DIR_DELETE_ERROR': [{'ACTION': u'md.create(path=path, uuid=uuid, type=type) aq.query(uuid=uuid)',
 
5
                                      'ACTION_FUNC': u'',
 
6
                                      'COMMENTS': u'the user deleted something we couldnt delete from the server. Re create.',
 
7
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
8
                                                     u'hash_eq_server_hash': u'NA',
 
9
                                                     u'not_authorized': u'T',
 
10
                                                     u'not_available': u'F'},
 
11
                                      'STATE': {u'changed': u'NA',
 
12
                                                u'has_metadata': u'F',
 
13
                                                u'is_directory': u'NA'},
 
14
                                      'STATE_OUT': {u'changed': u'NONE',
 
15
                                                    u'has_metadata': u'T',
 
16
                                                    u'is_directory': u'T'}},
 
17
                                     {'ACTION': u'md.create(path=path, uuid=uuid, type=type) aq.query(uuid=uuid)',
 
18
                                      'ACTION_FUNC': u'',
 
19
                                      'COMMENTS': u'the user deleted something we couldnt delete from the server. Re create.',
 
20
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
21
                                                     u'hash_eq_server_hash': u'NA',
 
22
                                                     u'not_authorized': u'F',
 
23
                                                     u'not_available': u'T'},
 
24
                                      'STATE': {u'changed': u'NA',
 
25
                                                u'has_metadata': u'F',
 
26
                                                u'is_directory': u'NA'},
 
27
                                      'STATE_OUT': {u'changed': u'NONE',
 
28
                                                    u'has_metadata': u'T',
 
29
                                                    u'is_directory': u'T'}},
 
30
                                     {'ACTION': u'NA',
 
31
                                      'ACTION_FUNC': u'',
 
32
                                      'COMMENTS': u'',
 
33
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
34
                                                     u'hash_eq_server_hash': u'NA',
 
35
                                                     u'not_authorized': u'NA',
 
36
                                                     u'not_available': u'*'},
 
37
                                      'STATE': {u'changed': u'NA',
 
38
                                                u'has_metadata': u'F',
 
39
                                                u'is_directory': u'NA'},
 
40
                                      'STATE_OUT': {u'changed': u'*',
 
41
                                                    u'has_metadata': u'*',
 
42
                                                    u'is_directory': u'*'}},
 
43
                                     {'ACTION': u'NA',
 
44
                                      'ACTION_FUNC': u'',
 
45
                                      'COMMENTS': u'',
 
46
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
47
                                                     u'hash_eq_server_hash': u'NA',
 
48
                                                     u'not_authorized': u'*',
 
49
                                                     u'not_available': u'NA'},
 
50
                                      'STATE': {u'changed': u'NA',
 
51
                                                u'has_metadata': u'F',
 
52
                                                u'is_directory': u'NA'},
 
53
                                      'STATE_OUT': {u'changed': u'*',
 
54
                                                    u'has_metadata': u'*',
 
55
                                                    u'is_directory': u'*'}},
 
56
                                     {'ACTION': u'NA',
 
57
                                      'ACTION_FUNC': u'',
 
58
                                      'COMMENTS': u'',
 
59
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
60
                                                     u'hash_eq_server_hash': u'NA',
 
61
                                                     u'not_authorized': u'*',
 
62
                                                     u'not_available': u'NA'},
 
63
                                      'STATE': {u'changed': u'*',
 
64
                                                u'has_metadata': u'T',
 
65
                                                u'is_directory': u'*'},
 
66
                                      'STATE_OUT': {u'changed': u'*',
 
67
                                                    u'has_metadata': u'*',
 
68
                                                    u'is_directory': u'*'}},
 
69
                                     {'ACTION': u'NA',
 
70
                                      'ACTION_FUNC': u'',
 
71
                                      'COMMENTS': u'',
 
72
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
73
                                                     u'hash_eq_server_hash': u'NA',
 
74
                                                     u'not_authorized': u'NA',
 
75
                                                     u'not_available': u'*'},
 
76
                                      'STATE': {u'changed': u'*',
 
77
                                                u'has_metadata': u'T',
 
78
                                                u'is_directory': u'*'},
 
79
                                      'STATE_OUT': {u'changed': u'*',
 
80
                                                    u'has_metadata': u'*',
 
81
                                                    u'is_directory': u'*'}},
 
82
                                     {'ACTION': u'CONFLICT, recreate from deleted uuid',
 
83
                                      'ACTION_FUNC': u'',
 
84
                                      'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
85
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
86
                                                     u'hash_eq_server_hash': u'NA',
 
87
                                                     u'not_authorized': u'F',
 
88
                                                     u'not_available': u'T'},
 
89
                                      'STATE': {u'changed': u'!SERVER',
 
90
                                                u'has_metadata': u'T',
 
91
                                                u'is_directory': u'*'},
 
92
                                      'STATE_OUT': {u'changed': u'NONE',
 
93
                                                    u'has_metadata': u'T',
 
94
                                                    u'is_directory': u'T'}},
 
95
                                     {'ACTION': u'DESPAIR',
 
96
                                      'ACTION_FUNC': u'',
 
97
                                      'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
98
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
99
                                                     u'hash_eq_server_hash': u'NA',
 
100
                                                     u'not_authorized': u'F',
 
101
                                                     u'not_available': u'T'},
 
102
                                      'STATE': {u'changed': u'SERVER',
 
103
                                                u'has_metadata': u'T',
 
104
                                                u'is_directory': u'*'},
 
105
                                      'STATE_OUT': {u'changed': u'*',
 
106
                                                    u'has_metadata': u'*',
 
107
                                                    u'is_directory': u'*'}},
 
108
                                     {'ACTION': u'CONFLICT',
 
109
                                      'ACTION_FUNC': u'',
 
110
                                      'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
111
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
112
                                                     u'hash_eq_server_hash': u'NA',
 
113
                                                     u'not_authorized': u'T',
 
114
                                                     u'not_available': u'F'},
 
115
                                      'STATE': {u'changed': u'*',
 
116
                                                u'has_metadata': u'T',
 
117
                                                u'is_directory': u'*'},
 
118
                                      'STATE_OUT': {u'changed': u'NONE',
 
119
                                                    u'has_metadata': u'T',
 
120
                                                    u'is_directory': u'T'}},
 
121
                                     {'ACTION': u'PANIC',
 
122
                                      'ACTION_FUNC': u'',
 
123
                                      'COMMENTS': u'',
 
124
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
125
                                                     u'hash_eq_server_hash': u'NA',
 
126
                                                     u'not_authorized': u'F',
 
127
                                                     u'not_available': u'F'},
 
128
                                      'STATE': {u'changed': u'*',
 
129
                                                u'has_metadata': u'*',
 
130
                                                u'is_directory': u'*'},
 
131
                                      'STATE_OUT': {u'changed': u'NONE',
 
132
                                                    u'has_metadata': u'T',
 
133
                                                    u'is_directory': u'T'}},
 
134
                                     {'ACTION': u'NA',
 
135
                                      'ACTION_FUNC': u'',
 
136
                                      'COMMENTS': u'',
 
137
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
138
                                                     u'hash_eq_server_hash': u'NA',
 
139
                                                     u'not_authorized': u'T',
 
140
                                                     u'not_available': u'T'},
 
141
                                      'STATE': {u'changed': u'*',
 
142
                                                u'has_metadata': u'*',
 
143
                                                u'is_directory': u'*'},
 
144
                                      'STATE_OUT': {u'changed': u'*',
 
145
                                                    u'has_metadata': u'*',
 
146
                                                    u'is_directory': u'*'}}],
 
147
            u'AQ_DIR_DELETE_OK': [{'ACTION': u'pass',
 
148
                                   'ACTION_FUNC': u'nothing',
 
149
                                   'COMMENTS': u'vanilla case',
 
150
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
151
                                                  u'hash_eq_server_hash': u'NA',
 
152
                                                  u'not_authorized': u'NA',
 
153
                                                  u'not_available': u'NA'},
 
154
                                   'STATE': {u'changed': u'NA',
 
155
                                             u'has_metadata': u'F',
 
156
                                             u'is_directory': u'NA'},
 
157
                                   'STATE_OUT': {u'changed': u'=',
 
158
                                                 u'has_metadata': u'=',
 
159
                                                 u'is_directory': u'='}},
 
160
                                  {'ACTION': u'pass',
 
161
                                   'ACTION_FUNC': u'nothing',
 
162
                                   'COMMENTS': u'we deleted something the user recreated, someone else is taking care of uploading this changes',
 
163
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
164
                                                  u'hash_eq_server_hash': u'NA',
 
165
                                                  u'not_authorized': u'NA',
 
166
                                                  u'not_available': u'NA'},
 
167
                                   'STATE': {u'changed': u'NONE',
 
168
                                             u'has_metadata': u'T',
 
169
                                             u'is_directory': u'T'},
 
170
                                   'STATE_OUT': {u'changed': u'=',
 
171
                                                 u'has_metadata': u'=',
 
172
                                                 u'is_directory': u'='}},
 
173
                                  {'ACTION': u'pass',
 
174
                                   'ACTION_FUNC': u'nothing',
 
175
                                   'COMMENTS': u'we deleted something the user recreated, someone else is taking care of uploading this changes',
 
176
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
177
                                                  u'hash_eq_server_hash': u'NA',
 
178
                                                  u'not_authorized': u'NA',
 
179
                                                  u'not_available': u'NA'},
 
180
                                   'STATE': {u'changed': u'LOCAL',
 
181
                                             u'has_metadata': u'T',
 
182
                                             u'is_directory': u'T'},
 
183
                                   'STATE_OUT': {u'changed': u'=',
 
184
                                                 u'has_metadata': u'=',
 
185
                                                 u'is_directory': u'='}},
 
186
                                  {'ACTION': u'DESPAIR',
 
187
                                   'ACTION_FUNC': u'DESPAIR',
 
188
                                   'COMMENTS': u'somehow we lost ordering of stuff and we got a new file and changes since we tried to delete this file',
 
189
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
190
                                                  u'hash_eq_server_hash': u'NA',
 
191
                                                  u'not_authorized': u'NA',
 
192
                                                  u'not_available': u'NA'},
 
193
                                   'STATE': {u'changed': u'SERVER',
 
194
                                             u'has_metadata': u'T',
 
195
                                             u'is_directory': u'*'},
 
196
                                   'STATE_OUT': {u'changed': u'*',
 
197
                                                 u'has_metadata': u'*',
 
198
                                                 u'is_directory': u'*'}},
 
199
                                  {'ACTION': u'pass',
 
200
                                   'ACTION_FUNC': u'nothing',
 
201
                                   'COMMENTS': u'',
 
202
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
203
                                                  u'hash_eq_server_hash': u'NA',
 
204
                                                  u'not_authorized': u'NA',
 
205
                                                  u'not_available': u'NA'},
 
206
                                   'STATE': {u'changed': u'!SERVER',
 
207
                                             u'has_metadata': u'T',
 
208
                                             u'is_directory': u'F'},
 
209
                                   'STATE_OUT': {u'changed': u'=',
 
210
                                                 u'has_metadata': u'=',
 
211
                                                 u'is_directory': u'='}}],
 
212
            u'AQ_DIR_NEW_ERROR': [{'ACTION': u'pass',
 
213
                                   'ACTION_FUNC': u'nothing',
 
214
                                   'COMMENTS': u'',
 
215
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
216
                                                  u'hash_eq_server_hash': u'NA',
 
217
                                                  u'not_authorized': u'*',
 
218
                                                  u'not_available': u'*'},
 
219
                                   'STATE': {u'changed': u'*',
 
220
                                             u'has_metadata': u'F',
 
221
                                             u'is_directory': u'*'},
 
222
                                   'STATE_OUT': {u'changed': u'=',
 
223
                                                 u'has_metadata': u'=',
 
224
                                                 u'is_directory': u'='}},
 
225
                                  {'ACTION': u'log warning\nmd.remove(mdid)',
 
226
                                   'ACTION_FUNC': u'file_not_created_remove',
 
227
                                   'COMMENTS': u'',
 
228
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
229
                                                  u'hash_eq_server_hash': u'NA',
 
230
                                                  u'not_authorized': u'T',
 
231
                                                  u'not_available': u'*'},
 
232
                                   'STATE': {u'changed': u'*',
 
233
                                             u'has_metadata': u'*',
 
234
                                             u'is_directory': u'T'},
 
235
                                   'STATE_OUT': {u'changed': u'NA',
 
236
                                                 u'has_metadata': u'F',
 
237
                                                 u'is_directory': u'NA'}},
 
238
                                  {'ACTION': u'log warning (changes that will appear later should fix this)',
 
239
                                   'ACTION_FUNC': u'file_not_created_remove',
 
240
                                   'COMMENTS': u'',
 
241
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
242
                                                  u'hash_eq_server_hash': u'NA',
 
243
                                                  u'not_authorized': u'F',
 
244
                                                  u'not_available': u'*'},
 
245
                                   'STATE': {u'changed': u'*',
 
246
                                             u'has_metadata': u'*',
 
247
                                             u'is_directory': u'T'},
 
248
                                   'STATE_OUT': {u'changed': u'NA',
 
249
                                                 u'has_metadata': u'F',
 
250
                                                 u'is_directory': u'NA'}},
 
251
                                  {'ACTION': u'pass',
 
252
                                   'ACTION_FUNC': u'nothing',
 
253
                                   'COMMENTS': u'',
 
254
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
255
                                                  u'hash_eq_server_hash': u'NA',
 
256
                                                  u'not_authorized': u'*',
 
257
                                                  u'not_available': u'*'},
 
258
                                   'STATE': {u'changed': u'*',
 
259
                                             u'has_metadata': u'*',
 
260
                                             u'is_directory': u'F'},
 
261
                                   'STATE_OUT': {u'changed': u'=',
 
262
                                                 u'has_metadata': u'=',
 
263
                                                 u'is_directory': u'='}},
 
264
                                  {'ACTION': u'NA',
 
265
                                   'ACTION_FUNC': u'',
 
266
                                   'COMMENTS': u'',
 
267
                                   'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
268
                                                  u'hash_eq_server_hash': u'NA',
 
269
                                                  u'not_authorized': u'NA',
 
270
                                                  u'not_available': u'*'},
 
271
                                   'STATE': {u'changed': u'*',
 
272
                                             u'has_metadata': u'*',
 
273
                                             u'is_directory': u'T'},
 
274
                                   'STATE_OUT': {u'changed': u'=',
 
275
                                                 u'has_metadata': u'=',
 
276
                                                 u'is_directory': u'='}}],
 
277
            u'AQ_DIR_NEW_OK': [{'ACTION': u'',
 
278
                                'ACTION_FUNC': u'nothing',
 
279
                                'COMMENTS': u'',
 
280
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
281
                                               u'hash_eq_server_hash': u'NA',
 
282
                                               u'not_authorized': u'NA',
 
283
                                               u'not_available': u'NA'},
 
284
                                'STATE': {u'changed': u'NONE',
 
285
                                          u'has_metadata': u'T',
 
286
                                          u'is_directory': u'F'},
 
287
                                'STATE_OUT': {u'changed': u'=',
 
288
                                              u'has_metadata': u'=',
 
289
                                              u'is_directory': u'='}},
 
290
                               {'ACTION': u'pass',
 
291
                                'ACTION_FUNC': u'nothing',
 
292
                                'COMMENTS': u'we got IN_FILE_CHANGED and HQ_HASH_NEW between IN_FILE_NEW and AQ_FILE_NEW_OK',
 
293
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
294
                                               u'hash_eq_server_hash': u'NA',
 
295
                                               u'not_authorized': u'NA',
 
296
                                               u'not_available': u'NA'},
 
297
                                'STATE': {u'changed': u'LOCAL',
 
298
                                          u'has_metadata': u'T',
 
299
                                          u'is_directory': u'F'},
 
300
                                'STATE_OUT': {u'changed': u'=',
 
301
                                              u'has_metadata': u'=',
 
302
                                              u'is_directory': u'='}},
 
303
                               {'ACTION': u'',
 
304
                                'ACTION_FUNC': u'nothing',
 
305
                                'COMMENTS': u'the dir was now gone',
 
306
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
307
                                               u'hash_eq_server_hash': u'NA',
 
308
                                               u'not_authorized': u'NA',
 
309
                                               u'not_available': u'NA'},
 
310
                                'STATE': {u'changed': u'NA',
 
311
                                          u'has_metadata': u'F',
 
312
                                          u'is_directory': u'NA'},
 
313
                                'STATE_OUT': {u'changed': u'=',
 
314
                                              u'has_metadata': u'=',
 
315
                                              u'is_directory': u'='}},
 
316
                               {'ACTION': u'md.set(mdid, server_uuid=server_uuid)\nPANIC',
 
317
                                'ACTION_FUNC': u'DESPAIR',
 
318
                                'COMMENTS': u'',
 
319
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
320
                                               u'hash_eq_server_hash': u'NA',
 
321
                                               u'not_authorized': u'NA',
 
322
                                               u'not_available': u'NA'},
 
323
                                'STATE': {u'changed': u'SERVER',
 
324
                                          u'has_metadata': u'T',
 
325
                                          u'is_directory': u'*'},
 
326
                                'STATE_OUT': {u'changed': u'NONE',
 
327
                                              u'has_metadata': u'T',
 
328
                                              u'is_directory': u'='}},
 
329
                               {'ACTION': u'md.set(mdid, server_uuid=server_uuid)\nRESCAN',
 
330
                                'ACTION_FUNC': u'new_local_dir_created',
 
331
                                'COMMENTS': u'',
 
332
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
333
                                               u'hash_eq_server_hash': u'NA',
 
334
                                               u'not_authorized': u'NA',
 
335
                                               u'not_available': u'NA'},
 
336
                                'STATE': {u'changed': u'NONE',
 
337
                                          u'has_metadata': u'T',
 
338
                                          u'is_directory': u'T'},
 
339
                                'STATE_OUT': {u'changed': u'=',
 
340
                                              u'has_metadata': u'=',
 
341
                                              u'is_directory': u'='}}],
 
342
            u'AQ_DOWNLOAD_ERROR': [{'ACTION': u'pass',
 
343
                                    'ACTION_FUNC': u'nothing',
 
344
                                    'COMMENTS': u'',
 
345
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
346
                                                   u'hash_eq_server_hash': u'*',
 
347
                                                   u'not_authorized': u'T',
 
348
                                                   u'not_available': u'F'},
 
349
                                    'STATE': {u'changed': u'*',
 
350
                                              u'has_metadata': u'T',
 
351
                                              u'is_directory': u'*'},
 
352
                                    'STATE_OUT': {u'changed': u'=',
 
353
                                                  u'has_metadata': u'=',
 
354
                                                  u'is_directory': u'='}},
 
355
                                   {'ACTION': u'pass',
 
356
                                    'ACTION_FUNC': u'nothing',
 
357
                                    'COMMENTS': u'',
 
358
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
359
                                                   u'hash_eq_server_hash': u'*',
 
360
                                                   u'not_authorized': u'F',
 
361
                                                   u'not_available': u'T'},
 
362
                                    'STATE': {u'changed': u'*',
 
363
                                              u'has_metadata': u'T',
 
364
                                              u'is_directory': u'*'},
 
365
                                    'STATE_OUT': {u'changed': u'=',
 
366
                                                  u'has_metadata': u'=',
 
367
                                                  u'is_directory': u'='}},
 
368
                                   {'ACTION': u'NA',
 
369
                                    'ACTION_FUNC': u'',
 
370
                                    'COMMENTS': u'',
 
371
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
372
                                                   u'hash_eq_server_hash': u'*',
 
373
                                                   u'not_authorized': u'T',
 
374
                                                   u'not_available': u'T'},
 
375
                                    'STATE': {u'changed': u'*',
 
376
                                              u'has_metadata': u'T',
 
377
                                              u'is_directory': u'*'},
 
378
                                    'STATE_OUT': {u'changed': u'*',
 
379
                                                  u'has_metadata': u'*',
 
380
                                                  u'is_directory': u'*'}},
 
381
                                   {'ACTION': u'PANIC',
 
382
                                    'ACTION_FUNC': u'DESPAIR',
 
383
                                    'COMMENTS': u'',
 
384
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
385
                                                   u'hash_eq_server_hash': u'*',
 
386
                                                   u'not_authorized': u'F',
 
387
                                                   u'not_available': u'F'},
 
388
                                    'STATE': {u'changed': u'*',
 
389
                                              u'has_metadata': u'T',
 
390
                                              u'is_directory': u'*'},
 
391
                                    'STATE_OUT': {u'changed': u'=',
 
392
                                                  u'has_metadata': u'=',
 
393
                                                  u'is_directory': u'='}},
 
394
                                   {'ACTION': u'NA',
 
395
                                    'ACTION_FUNC': u'',
 
396
                                    'COMMENTS': u'',
 
397
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
398
                                                   u'hash_eq_server_hash': u'*',
 
399
                                                   u'not_authorized': u'*',
 
400
                                                   u'not_available': u'NA'},
 
401
                                    'STATE': {u'changed': u'*',
 
402
                                              u'has_metadata': u'T',
 
403
                                              u'is_directory': u'*'},
 
404
                                    'STATE_OUT': {u'changed': u'*',
 
405
                                                  u'has_metadata': u'*',
 
406
                                                  u'is_directory': u'*'}},
 
407
                                   {'ACTION': u'NA',
 
408
                                    'ACTION_FUNC': u'',
 
409
                                    'COMMENTS': u'',
 
410
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
411
                                                   u'hash_eq_server_hash': u'*',
 
412
                                                   u'not_authorized': u'NA',
 
413
                                                   u'not_available': u'*'},
 
414
                                    'STATE': {u'changed': u'*',
 
415
                                              u'has_metadata': u'T',
 
416
                                              u'is_directory': u'*'},
 
417
                                    'STATE_OUT': {u'changed': u'*',
 
418
                                                  u'has_metadata': u'*',
 
419
                                                  u'is_directory': u'*'}},
 
420
                                   {'ACTION': u'pass',
 
421
                                    'ACTION_FUNC': u'nothing',
 
422
                                    'COMMENTS': u'',
 
423
                                    'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
424
                                                   u'hash_eq_server_hash': u'*',
 
425
                                                   u'not_authorized': u'*',
 
426
                                                   u'not_available': u'*'},
 
427
                                    'STATE': {u'changed': u'*',
 
428
                                              u'has_metadata': u'F',
 
429
                                              u'is_directory': u'*'},
 
430
                                    'STATE_OUT': {u'changed': u'=',
 
431
                                                  u'has_metadata': u'=',
 
432
                                                  u'is_directory': u'='}}],
 
433
            u'AQ_DOWNLOAD_FINISHED': [{'ACTION': u'NA',
 
434
                                       'ACTION_FUNC': u'',
 
435
                                       'COMMENTS': u'',
 
436
                                       'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
437
                                                      u'hash_eq_server_hash': u'NA',
 
438
                                                      u'not_authorized': u'NA',
 
439
                                                      u'not_available': u'NA'},
 
440
                                       'STATE': {u'changed': u'*',
 
441
                                                 u'has_metadata': u'T',
 
442
                                                 u'is_directory': u'*'},
 
443
                                       'STATE_OUT': {u'changed': u'=',
 
444
                                                     u'has_metadata': u'=',
 
445
                                                     u'is_directory': u'='}},
 
446
                                      {'ACTION': u'NA',
 
447
                                       'ACTION_FUNC': u'',
 
448
                                       'COMMENTS': u'',
 
449
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
450
                                                      u'hash_eq_server_hash': u'*',
 
451
                                                      u'not_authorized': u'NA',
 
452
                                                      u'not_available': u'NA'},
 
453
                                       'STATE': {u'changed': u'*',
 
454
                                                 u'has_metadata': u'T',
 
455
                                                 u'is_directory': u'*'},
 
456
                                       'STATE_OUT': {u'changed': u'=',
 
457
                                                     u'has_metadata': u'=',
 
458
                                                     u'is_directory': u'='}},
 
459
                                      {'ACTION': u'pass',
 
460
                                       'ACTION_FUNC': u'nothing',
 
461
                                       'COMMENTS': u'file was removed while we where downloading',
 
462
                                       'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
463
                                                      u'hash_eq_server_hash': u'*',
 
464
                                                      u'not_authorized': u'NA',
 
465
                                                      u'not_available': u'NA'},
 
466
                                       'STATE': {u'changed': u'NA',
 
467
                                                 u'has_metadata': u'F',
 
468
                                                 u'is_directory': u'*'},
 
469
                                       'STATE_OUT': {u'changed': u'=',
 
470
                                                     u'has_metadata': u'=',
 
471
                                                     u'is_directory': u'='}},
 
472
                                      {'ACTION': u'pass',
 
473
                                       'ACTION_FUNC': u'nothing',
 
474
                                       'COMMENTS': u'cancelled by e.g. SV_HASH_NEW',
 
475
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
476
                                                      u'hash_eq_server_hash': u'T',
 
477
                                                      u'not_authorized': u'NA',
 
478
                                                      u'not_available': u'NA'},
 
479
                                       'STATE': {u'changed': u'NONE',
 
480
                                                 u'has_metadata': u'T',
 
481
                                                 u'is_directory': u'F'},
 
482
                                       'STATE_OUT': {u'changed': u'=',
 
483
                                                     u'has_metadata': u'=',
 
484
                                                     u'is_directory': u'='}},
 
485
                                      {'ACTION': u'NA',
 
486
                                       'ACTION_FUNC': u'',
 
487
                                       'COMMENTS': u'NONE, T, F is a falacy (NONE implies server_hash == local_hash)',
 
488
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
489
                                                      u'hash_eq_server_hash': u'T',
 
490
                                                      u'not_authorized': u'NA',
 
491
                                                      u'not_available': u'NA'},
 
492
                                       'STATE': {u'changed': u'NONE',
 
493
                                                 u'has_metadata': u'T',
 
494
                                                 u'is_directory': u'F'},
 
495
                                       'STATE_OUT': {u'changed': u'*',
 
496
                                                     u'has_metadata': u'*',
 
497
                                                     u'is_directory': u'*'}},
 
498
                                      {'ACTION': u'NA',
 
499
                                       'ACTION_FUNC': u'',
 
500
                                       'COMMENTS': u'NONE, F, T is a falacy (NONE implies server_hash == local_hash)',
 
501
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
502
                                                      u'hash_eq_server_hash': u'F',
 
503
                                                      u'not_authorized': u'NA',
 
504
                                                      u'not_available': u'NA'},
 
505
                                       'STATE': {u'changed': u'NONE',
 
506
                                                 u'has_metadata': u'T',
 
507
                                                 u'is_directory': u'F'},
 
508
                                       'STATE_OUT': {u'changed': u'*',
 
509
                                                     u'has_metadata': u'*',
 
510
                                                     u'is_directory': u'*'}},
 
511
                                      {'ACTION': u'pass',
 
512
                                       'ACTION_FUNC': u'nothing',
 
513
                                       'COMMENTS': u'cancelled by e.g. SV_HASH_NEW',
 
514
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
515
                                                      u'hash_eq_server_hash': u'F',
 
516
                                                      u'not_authorized': u'NA',
 
517
                                                      u'not_available': u'NA'},
 
518
                                       'STATE': {u'changed': u'NONE',
 
519
                                                 u'has_metadata': u'T',
 
520
                                                 u'is_directory': u'F'},
 
521
                                       'STATE_OUT': {u'changed': u'=',
 
522
                                                     u'has_metadata': u'=',
 
523
                                                     u'is_directory': u'='}},
 
524
                                      {'ACTION': u'NA',
 
525
                                       'ACTION_FUNC': u'',
 
526
                                       'COMMENTS': u'SERVER, T, T is a falacy (SERVER implies server_hash != local_hash)',
 
527
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
528
                                                      u'hash_eq_server_hash': u'T',
 
529
                                                      u'not_authorized': u'NA',
 
530
                                                      u'not_available': u'NA'},
 
531
                                       'STATE': {u'changed': u'SERVER',
 
532
                                                 u'has_metadata': u'T',
 
533
                                                 u'is_directory': u'F'},
 
534
                                       'STATE_OUT': {u'changed': u'*',
 
535
                                                     u'has_metadata': u'*',
 
536
                                                     u'is_directory': u'*'}},
 
537
                                      {'ACTION': u'md.commit_partial(uuid, local_hash=hash)',
 
538
                                       'ACTION_FUNC': u'commit_file',
 
539
                                       'COMMENTS': u'this is the vainilla case',
 
540
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
541
                                                      u'hash_eq_server_hash': u'T',
 
542
                                                      u'not_authorized': u'NA',
 
543
                                                      u'not_available': u'NA'},
 
544
                                       'STATE': {u'changed': u'SERVER',
 
545
                                                 u'has_metadata': u'T',
 
546
                                                 u'is_directory': u'F'},
 
547
                                       'STATE_OUT': {u'changed': u'NONE',
 
548
                                                     u'has_metadata': u'=',
 
549
                                                     u'is_directory': u'='}},
 
550
                                      {'ACTION': u'',
 
551
                                       'ACTION_FUNC': u'nothing',
 
552
                                       'COMMENTS': u'not what we want',
 
553
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
554
                                                      u'hash_eq_server_hash': u'F',
 
555
                                                      u'not_authorized': u'NA',
 
556
                                                      u'not_available': u'NA'},
 
557
                                       'STATE': {u'changed': u'SERVER',
 
558
                                                 u'has_metadata': u'T',
 
559
                                                 u'is_directory': u'F'},
 
560
                                       'STATE_OUT': {u'changed': u'LOCAL',
 
561
                                                     u'has_metadata': u'=',
 
562
                                                     u'is_directory': u'='}},
 
563
                                      {'ACTION': u'pass',
 
564
                                       'ACTION_FUNC': u'nothing',
 
565
                                       'COMMENTS': u'another download is already in progress',
 
566
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
567
                                                      u'hash_eq_server_hash': u'F',
 
568
                                                      u'not_authorized': u'NA',
 
569
                                                      u'not_available': u'NA'},
 
570
                                       'STATE': {u'changed': u'SERVER',
 
571
                                                 u'has_metadata': u'T',
 
572
                                                 u'is_directory': u'F'},
 
573
                                       'STATE_OUT': {u'changed': u'=',
 
574
                                                     u'has_metadata': u'=',
 
575
                                                     u'is_directory': u'='}},
 
576
                                      {'ACTION': u'NA',
 
577
                                       'ACTION_FUNC': u'',
 
578
                                       'COMMENTS': u'LOCAL, T, T is a falacy (LOCAL implies server_hash != local_hash)',
 
579
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
580
                                                      u'hash_eq_server_hash': u'T',
 
581
                                                      u'not_authorized': u'NA',
 
582
                                                      u'not_available': u'NA'},
 
583
                                       'STATE': {u'changed': u'LOCAL',
 
584
                                                 u'has_metadata': u'T',
 
585
                                                 u'is_directory': u'F'},
 
586
                                       'STATE_OUT': {u'changed': u'*',
 
587
                                                     u'has_metadata': u'*',
 
588
                                                     u'is_directory': u'*'}},
 
589
                                      {'ACTION': u'pass',
 
590
                                       'ACTION_FUNC': u'nothing',
 
591
                                       'COMMENTS': u'cancelled by e.g. SV_HASH_NEW',
 
592
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
593
                                                      u'hash_eq_server_hash': u'T',
 
594
                                                      u'not_authorized': u'NA',
 
595
                                                      u'not_available': u'NA'},
 
596
                                       'STATE': {u'changed': u'LOCAL',
 
597
                                                 u'has_metadata': u'T',
 
598
                                                 u'is_directory': u'F'},
 
599
                                       'STATE_OUT': {u'changed': u'=',
 
600
                                                     u'has_metadata': u'=',
 
601
                                                     u'is_directory': u'='}},
 
602
                                      {'ACTION': u'pass',
 
603
                                       'ACTION_FUNC': u'nothing',
 
604
                                       'COMMENTS': u'cancelled by e.g. SV_HASH_NEW',
 
605
                                       'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
606
                                                      u'hash_eq_server_hash': u'F',
 
607
                                                      u'not_authorized': u'NA',
 
608
                                                      u'not_available': u'NA'},
 
609
                                       'STATE': {u'changed': u'LOCAL',
 
610
                                                 u'has_metadata': u'T',
 
611
                                                 u'is_directory': u'F'},
 
612
                                       'STATE_OUT': {u'changed': u'=',
 
613
                                                     u'has_metadata': u'=',
 
614
                                                     u'is_directory': u'='}},
 
615
                                      {'ACTION': u'pass',
 
616
                                       'ACTION_FUNC': u'nothing',
 
617
                                       'COMMENTS': u'cancelled by e.g. SV_HASH_NEW',
 
618
                                       'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
619
                                                      u'hash_eq_server_hash': u'F',
 
620
                                                      u'not_authorized': u'NA',
 
621
                                                      u'not_available': u'NA'},
 
622
                                       'STATE': {u'changed': u'LOCAL',
 
623
                                                 u'has_metadata': u'T',
 
624
                                                 u'is_directory': u'F'},
 
625
                                       'STATE_OUT': {u'changed': u'=',
 
626
                                                     u'has_metadata': u'=',
 
627
                                                     u'is_directory': u'='}},
 
628
                                      {'ACTION': u'pass',
 
629
                                       'ACTION_FUNC': u'nothing',
 
630
                                       'COMMENTS': u'spurius download finished, ignore',
 
631
                                       'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
632
                                                      u'hash_eq_server_hash': u'!NA',
 
633
                                                      u'not_authorized': u'NA',
 
634
                                                      u'not_available': u'NA'},
 
635
                                       'STATE': {u'changed': u'NONE',
 
636
                                                 u'has_metadata': u'T',
 
637
                                                 u'is_directory': u'T'},
 
638
                                       'STATE_OUT': {u'changed': u'=',
 
639
                                                     u'has_metadata': u'=',
 
640
                                                     u'is_directory': u'='}},
 
641
                                      {'ACTION': u'merge_from_partial(uuid)',
 
642
                                       'ACTION_FUNC': u'merge_directory',
 
643
                                       'COMMENTS': u'this is the vanilla case, call merge directories',
 
644
                                       'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
645
                                                      u'hash_eq_server_hash': u'T',
 
646
                                                      u'not_authorized': u'NA',
 
647
                                                      u'not_available': u'NA'},
 
648
                                       'STATE': {u'changed': u'SERVER',
 
649
                                                 u'has_metadata': u'T',
 
650
                                                 u'is_directory': u'T'},
 
651
                                       'STATE_OUT': {u'changed': u'NONE',
 
652
                                                     u'has_metadata': u'=',
 
653
                                                     u'is_directory': u'='}},
 
654
                                      {'ACTION': u'pass',
 
655
                                       'ACTION_FUNC': u'nothing',
 
656
                                       'COMMENTS': u'download we are not interested in',
 
657
                                       'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
658
                                                      u'hash_eq_server_hash': u'F',
 
659
                                                      u'not_authorized': u'NA',
 
660
                                                      u'not_available': u'NA'},
 
661
                                       'STATE': {u'changed': u'SERVER',
 
662
                                                 u'has_metadata': u'T',
 
663
                                                 u'is_directory': u'T'},
 
664
                                       'STATE_OUT': {u'changed': u'SERVER',
 
665
                                                     u'has_metadata': u'=',
 
666
                                                     u'is_directory': u'='}}],
 
667
            u'AQ_FILE_DELETE_ERROR': [{'ACTION': u'md.create(path=path, uuid=uuid, type=type) aq.query(uuid=uuid)',
 
668
                                       'ACTION_FUNC': u'',
 
669
                                       'COMMENTS': u'the user deleted something we couldnt delete from the server. Re create.',
 
670
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
671
                                                      u'hash_eq_server_hash': u'NA',
 
672
                                                      u'not_authorized': u'T',
 
673
                                                      u'not_available': u'F'},
 
674
                                       'STATE': {u'changed': u'NA',
 
675
                                                 u'has_metadata': u'F',
 
676
                                                 u'is_directory': u'NA'},
 
677
                                       'STATE_OUT': {u'changed': u'NONE',
 
678
                                                     u'has_metadata': u'T',
 
679
                                                     u'is_directory': u'F'}},
 
680
                                      {'ACTION': u'md.create(path=path, uuid=uuid, type=type) aq.query(uuid=uuid)',
 
681
                                       'ACTION_FUNC': u'',
 
682
                                       'COMMENTS': u'the user deleted something we couldnt delete from the server. Re create.',
 
683
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
684
                                                      u'hash_eq_server_hash': u'NA',
 
685
                                                      u'not_authorized': u'F',
 
686
                                                      u'not_available': u'T'},
 
687
                                       'STATE': {u'changed': u'NA',
 
688
                                                 u'has_metadata': u'F',
 
689
                                                 u'is_directory': u'NA'},
 
690
                                       'STATE_OUT': {u'changed': u'NONE',
 
691
                                                     u'has_metadata': u'T',
 
692
                                                     u'is_directory': u'='}},
 
693
                                      {'ACTION': u'NA',
 
694
                                       'ACTION_FUNC': u'',
 
695
                                       'COMMENTS': u'',
 
696
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
697
                                                      u'hash_eq_server_hash': u'NA',
 
698
                                                      u'not_authorized': u'NA',
 
699
                                                      u'not_available': u'*'},
 
700
                                       'STATE': {u'changed': u'NA',
 
701
                                                 u'has_metadata': u'F',
 
702
                                                 u'is_directory': u'NA'},
 
703
                                       'STATE_OUT': {u'changed': u'*',
 
704
                                                     u'has_metadata': u'*',
 
705
                                                     u'is_directory': u'*'}},
 
706
                                      {'ACTION': u'NA',
 
707
                                       'ACTION_FUNC': u'',
 
708
                                       'COMMENTS': u'',
 
709
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
710
                                                      u'hash_eq_server_hash': u'NA',
 
711
                                                      u'not_authorized': u'*',
 
712
                                                      u'not_available': u'NA'},
 
713
                                       'STATE': {u'changed': u'NA',
 
714
                                                 u'has_metadata': u'F',
 
715
                                                 u'is_directory': u'NA'},
 
716
                                       'STATE_OUT': {u'changed': u'*',
 
717
                                                     u'has_metadata': u'*',
 
718
                                                     u'is_directory': u'*'}},
 
719
                                      {'ACTION': u'NA',
 
720
                                       'ACTION_FUNC': u'',
 
721
                                       'COMMENTS': u'',
 
722
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
723
                                                      u'hash_eq_server_hash': u'NA',
 
724
                                                      u'not_authorized': u'*',
 
725
                                                      u'not_available': u'NA'},
 
726
                                       'STATE': {u'changed': u'*',
 
727
                                                 u'has_metadata': u'T',
 
728
                                                 u'is_directory': u'*'},
 
729
                                       'STATE_OUT': {u'changed': u'*',
 
730
                                                     u'has_metadata': u'*',
 
731
                                                     u'is_directory': u'*'}},
 
732
                                      {'ACTION': u'NA',
 
733
                                       'ACTION_FUNC': u'',
 
734
                                       'COMMENTS': u'',
 
735
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
736
                                                      u'hash_eq_server_hash': u'NA',
 
737
                                                      u'not_authorized': u'NA',
 
738
                                                      u'not_available': u'*'},
 
739
                                       'STATE': {u'changed': u'*',
 
740
                                                 u'has_metadata': u'T',
 
741
                                                 u'is_directory': u'*'},
 
742
                                       'STATE_OUT': {u'changed': u'*',
 
743
                                                     u'has_metadata': u'*',
 
744
                                                     u'is_directory': u'*'}},
 
745
                                      {'ACTION': u'CONFLICT, recreate from deleted uuid',
 
746
                                       'ACTION_FUNC': u'',
 
747
                                       'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
748
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
749
                                                      u'hash_eq_server_hash': u'NA',
 
750
                                                      u'not_authorized': u'F',
 
751
                                                      u'not_available': u'T'},
 
752
                                       'STATE': {u'changed': u'!SERVER',
 
753
                                                 u'has_metadata': u'T',
 
754
                                                 u'is_directory': u'*'},
 
755
                                       'STATE_OUT': {u'changed': u'NONE',
 
756
                                                     u'has_metadata': u'T',
 
757
                                                     u'is_directory': u'F'}},
 
758
                                      {'ACTION': u'DESPAIR',
 
759
                                       'ACTION_FUNC': u'DESPAIR',
 
760
                                       'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
761
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
762
                                                      u'hash_eq_server_hash': u'NA',
 
763
                                                      u'not_authorized': u'F',
 
764
                                                      u'not_available': u'T'},
 
765
                                       'STATE': {u'changed': u'SERVER',
 
766
                                                 u'has_metadata': u'T',
 
767
                                                 u'is_directory': u'*'},
 
768
                                       'STATE_OUT': {u'changed': u'*',
 
769
                                                     u'has_metadata': u'*',
 
770
                                                     u'is_directory': u'*'}},
 
771
                                      {'ACTION': u'CONFLICT',
 
772
                                       'ACTION_FUNC': u'',
 
773
                                       'COMMENTS': u'the user deleted something we could not delete from the server and replaced it with stuff. Move user files to conflict and re download stuff from the server',
 
774
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
775
                                                      u'hash_eq_server_hash': u'NA',
 
776
                                                      u'not_authorized': u'T',
 
777
                                                      u'not_available': u'F'},
 
778
                                       'STATE': {u'changed': u'*',
 
779
                                                 u'has_metadata': u'T',
 
780
                                                 u'is_directory': u'*'},
 
781
                                       'STATE_OUT': {u'changed': u'NONE',
 
782
                                                     u'has_metadata': u'T',
 
783
                                                     u'is_directory': u'T'}},
 
784
                                      {'ACTION': u'PANIC',
 
785
                                       'ACTION_FUNC': u'',
 
786
                                       'COMMENTS': u'',
 
787
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
788
                                                      u'hash_eq_server_hash': u'NA',
 
789
                                                      u'not_authorized': u'F',
 
790
                                                      u'not_available': u'F'},
 
791
                                       'STATE': {u'changed': u'*',
 
792
                                                 u'has_metadata': u'*',
 
793
                                                 u'is_directory': u'*'},
 
794
                                       'STATE_OUT': {u'changed': u'NONE',
 
795
                                                     u'has_metadata': u'T',
 
796
                                                     u'is_directory': u'F'}},
 
797
                                      {'ACTION': u'NA',
 
798
                                       'ACTION_FUNC': u'',
 
799
                                       'COMMENTS': u'',
 
800
                                       'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
801
                                                      u'hash_eq_server_hash': u'NA',
 
802
                                                      u'not_authorized': u'T',
 
803
                                                      u'not_available': u'T'},
 
804
                                       'STATE': {u'changed': u'*',
 
805
                                                 u'has_metadata': u'*',
 
806
                                                 u'is_directory': u'*'},
 
807
                                       'STATE_OUT': {u'changed': u'*',
 
808
                                                     u'has_metadata': u'*',
 
809
                                                     u'is_directory': u'*'}}],
 
810
            u'AQ_FILE_DELETE_OK': [{'ACTION': u'pass',
 
811
                                    'ACTION_FUNC': u'nothing',
 
812
                                    'COMMENTS': u'vanilla case',
 
813
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
814
                                                   u'hash_eq_server_hash': u'NA',
 
815
                                                   u'not_authorized': u'NA',
 
816
                                                   u'not_available': u'NA'},
 
817
                                    'STATE': {u'changed': u'NA',
 
818
                                              u'has_metadata': u'F',
 
819
                                              u'is_directory': u'NA'},
 
820
                                    'STATE_OUT': {u'changed': u'=',
 
821
                                                  u'has_metadata': u'=',
 
822
                                                  u'is_directory': u'='}},
 
823
                                   {'ACTION': u'pass',
 
824
                                    'ACTION_FUNC': u'nothing',
 
825
                                    'COMMENTS': u'/c',
 
826
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
827
                                                   u'hash_eq_server_hash': u'NA',
 
828
                                                   u'not_authorized': u'NA',
 
829
                                                   u'not_available': u'NA'},
 
830
                                    'STATE': {u'changed': u'NONE',
 
831
                                              u'has_metadata': u'T',
 
832
                                              u'is_directory': u'F'},
 
833
                                    'STATE_OUT': {u'changed': u'=',
 
834
                                                  u'has_metadata': u'=',
 
835
                                                  u'is_directory': u'='}},
 
836
                                   {'ACTION': u'pass',
 
837
                                    'ACTION_FUNC': u'nothing',
 
838
                                    'COMMENTS': u'we deleted something the user recreated, someone else is taking care of uploading this changes',
 
839
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
840
                                                   u'hash_eq_server_hash': u'NA',
 
841
                                                   u'not_authorized': u'NA',
 
842
                                                   u'not_available': u'NA'},
 
843
                                    'STATE': {u'changed': u'LOCAL',
 
844
                                              u'has_metadata': u'T',
 
845
                                              u'is_directory': u'F'},
 
846
                                    'STATE_OUT': {u'changed': u'=',
 
847
                                                  u'has_metadata': u'=',
 
848
                                                  u'is_directory': u'='}},
 
849
                                   {'ACTION': u'DESPAIR',
 
850
                                    'ACTION_FUNC': u'DESPAIR',
 
851
                                    'COMMENTS': u'somehow we lost ordering of stuff and we got a new file and changes since we tried to delete this file',
 
852
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
853
                                                   u'hash_eq_server_hash': u'NA',
 
854
                                                   u'not_authorized': u'NA',
 
855
                                                   u'not_available': u'NA'},
 
856
                                    'STATE': {u'changed': u'SERVER',
 
857
                                              u'has_metadata': u'T',
 
858
                                              u'is_directory': u'*'},
 
859
                                    'STATE_OUT': {u'changed': u'*',
 
860
                                                  u'has_metadata': u'*',
 
861
                                                  u'is_directory': u'*'}},
 
862
                                   {'ACTION': u'pass',
 
863
                                    'ACTION_FUNC': u'nothing',
 
864
                                    'COMMENTS': u'',
 
865
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
866
                                                   u'hash_eq_server_hash': u'NA',
 
867
                                                   u'not_authorized': u'NA',
 
868
                                                   u'not_available': u'NA'},
 
869
                                    'STATE': {u'changed': u'!SERVER',
 
870
                                              u'has_metadata': u'T',
 
871
                                              u'is_directory': u'T'},
 
872
                                    'STATE_OUT': {u'changed': u'=',
 
873
                                                  u'has_metadata': u'=',
 
874
                                                  u'is_directory': u'='}}],
 
875
            u'AQ_FILE_MOVE_OK': [{'ACTION': u'',
 
876
                                  'ACTION_FUNC': u'nothing',
 
877
                                  'COMMENTS': u'deleted locally',
 
878
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
879
                                                 u'hash_eq_server_hash': u'NA',
 
880
                                                 u'not_authorized': u'NA',
 
881
                                                 u'not_available': u'NA'},
 
882
                                  'STATE': {u'changed': u'NA',
 
883
                                            u'has_metadata': u'F',
 
884
                                            u'is_directory': u'NA'},
 
885
                                  'STATE_OUT': {u'changed': u'*',
 
886
                                                u'has_metadata': u'*',
 
887
                                                u'is_directory': u'*'}},
 
888
                                 {'ACTION': u'',
 
889
                                  'ACTION_FUNC': u'nothing',
 
890
                                  'COMMENTS': u'vanilla case',
 
891
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
892
                                                 u'hash_eq_server_hash': u'NA',
 
893
                                                 u'not_authorized': u'NA',
 
894
                                                 u'not_available': u'NA'},
 
895
                                  'STATE': {u'changed': u'*',
 
896
                                            u'has_metadata': u'T',
 
897
                                            u'is_directory': u'*'},
 
898
                                  'STATE_OUT': {u'changed': u'=',
 
899
                                                u'has_metadata': u'T',
 
900
                                                u'is_directory': u'='}}],
 
901
            u'AQ_FILE_NEW_ERROR': [{'ACTION': u'pass',
 
902
                                    'ACTION_FUNC': u'nothing',
 
903
                                    'COMMENTS': u'',
 
904
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
905
                                                   u'hash_eq_server_hash': u'NA',
 
906
                                                   u'not_authorized': u'*',
 
907
                                                   u'not_available': u'*'},
 
908
                                    'STATE': {u'changed': u'NA',
 
909
                                              u'has_metadata': u'F',
 
910
                                              u'is_directory': u'NA'},
 
911
                                    'STATE_OUT': {u'changed': u'=',
 
912
                                                  u'has_metadata': u'=',
 
913
                                                  u'is_directory': u'='}},
 
914
                                   {'ACTION': u'CONFLICT',
 
915
                                    'ACTION_FUNC': u'file_not_created_remove',
 
916
                                    'COMMENTS': u'',
 
917
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
918
                                                   u'hash_eq_server_hash': u'NA',
 
919
                                                   u'not_authorized': u'T',
 
920
                                                   u'not_available': u'*'},
 
921
                                    'STATE': {u'changed': u'*',
 
922
                                              u'has_metadata': u'*',
 
923
                                              u'is_directory': u'F'},
 
924
                                    'STATE_OUT': {u'changed': u'NA',
 
925
                                                  u'has_metadata': u'F',
 
926
                                                  u'is_directory': u'NA'}},
 
927
                                   {'ACTION': u'CONFLICT',
 
928
                                    'ACTION_FUNC': u'file_not_created_remove',
 
929
                                    'COMMENTS': u'',
 
930
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
931
                                                   u'hash_eq_server_hash': u'NA',
 
932
                                                   u'not_authorized': u'F',
 
933
                                                   u'not_available': u'*'},
 
934
                                    'STATE': {u'changed': u'*',
 
935
                                              u'has_metadata': u'*',
 
936
                                              u'is_directory': u'F'},
 
937
                                    'STATE_OUT': {u'changed': u'NA',
 
938
                                                  u'has_metadata': u'F',
 
939
                                                  u'is_directory': u'NA'}},
 
940
                                   {'ACTION': u'pass',
 
941
                                    'ACTION_FUNC': u'nothing',
 
942
                                    'COMMENTS': u'',
 
943
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
944
                                                   u'hash_eq_server_hash': u'NA',
 
945
                                                   u'not_authorized': u'*',
 
946
                                                   u'not_available': u'*'},
 
947
                                    'STATE': {u'changed': u'*',
 
948
                                              u'has_metadata': u'*',
 
949
                                              u'is_directory': u'T'},
 
950
                                    'STATE_OUT': {u'changed': u'=',
 
951
                                                  u'has_metadata': u'=',
 
952
                                                  u'is_directory': u'='}},
 
953
                                   {'ACTION': u'NA',
 
954
                                    'ACTION_FUNC': u'',
 
955
                                    'COMMENTS': u'',
 
956
                                    'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
957
                                                   u'hash_eq_server_hash': u'NA',
 
958
                                                   u'not_authorized': u'NA',
 
959
                                                   u'not_available': u'*'},
 
960
                                    'STATE': {u'changed': u'*',
 
961
                                              u'has_metadata': u'*',
 
962
                                              u'is_directory': u'F'},
 
963
                                    'STATE_OUT': {u'changed': u'=',
 
964
                                                  u'has_metadata': u'=',
 
965
                                                  u'is_directory': u'='}}],
 
966
            u'AQ_FILE_NEW_OK': [{'ACTION': u'md.set(mdid, server_uuid=server_uuid)',
 
967
                                 'ACTION_FUNC': u'new_local_file_created',
 
968
                                 'COMMENTS': u'',
 
969
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
970
                                                u'hash_eq_server_hash': u'NA',
 
971
                                                u'not_authorized': u'NA',
 
972
                                                u'not_available': u'NA'},
 
973
                                 'STATE': {u'changed': u'NONE',
 
974
                                           u'has_metadata': u'T',
 
975
                                           u'is_directory': u'F'},
 
976
                                 'STATE_OUT': {u'changed': u'=',
 
977
                                               u'has_metadata': u'=',
 
978
                                               u'is_directory': u'='}},
 
979
                                {'ACTION': u'md.set(mdid, server_uuid=server_uuid)',
 
980
                                 'ACTION_FUNC': u'new_local_file_created',
 
981
                                 'COMMENTS': u'we got IN_FILE_CHANGED and HQ_HASH_NEW between IN_FILE_NEW and AQ_FILE_NEW_OK',
 
982
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
983
                                                u'hash_eq_server_hash': u'NA',
 
984
                                                u'not_authorized': u'NA',
 
985
                                                u'not_available': u'NA'},
 
986
                                 'STATE': {u'changed': u'LOCAL',
 
987
                                           u'has_metadata': u'T',
 
988
                                           u'is_directory': u'F'},
 
989
                                 'STATE_OUT': {u'changed': u'=',
 
990
                                               u'has_metadata': u'=',
 
991
                                               u'is_directory': u'='}},
 
992
                                {'ACTION': u'pass',
 
993
                                 'ACTION_FUNC': u'nothing',
 
994
                                 'COMMENTS': u'file deleted locally',
 
995
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
996
                                                u'hash_eq_server_hash': u'NA',
 
997
                                                u'not_authorized': u'NA',
 
998
                                                u'not_available': u'NA'},
 
999
                                 'STATE': {u'changed': u'NA',
 
1000
                                           u'has_metadata': u'F',
 
1001
                                           u'is_directory': u'NA'},
 
1002
                                 'STATE_OUT': {u'changed': u'=',
 
1003
                                               u'has_metadata': u'=',
 
1004
                                               u'is_directory': u'='}},
 
1005
                                {'ACTION': u'md.set(mdid, server_uuid=server_uuid)\nPANIC',
 
1006
                                 'ACTION_FUNC': u'DESPAIR',
 
1007
                                 'COMMENTS': u'',
 
1008
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1009
                                                u'hash_eq_server_hash': u'NA',
 
1010
                                                u'not_authorized': u'NA',
 
1011
                                                u'not_available': u'NA'},
 
1012
                                 'STATE': {u'changed': u'SERVER',
 
1013
                                           u'has_metadata': u'T',
 
1014
                                           u'is_directory': u'*'},
 
1015
                                 'STATE_OUT': {u'changed': u'NONE',
 
1016
                                               u'has_metadata': u'T',
 
1017
                                               u'is_directory': u'='}},
 
1018
                                {'ACTION': u'pass',
 
1019
                                 'ACTION_FUNC': u'nothing',
 
1020
                                 'COMMENTS': u'',
 
1021
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1022
                                                u'hash_eq_server_hash': u'NA',
 
1023
                                                u'not_authorized': u'NA',
 
1024
                                                u'not_available': u'NA'},
 
1025
                                 'STATE': {u'changed': u'NONE',
 
1026
                                           u'has_metadata': u'T',
 
1027
                                           u'is_directory': u'T'},
 
1028
                                 'STATE_OUT': {u'changed': u'=',
 
1029
                                               u'has_metadata': u'=',
 
1030
                                               u'is_directory': u'='}}],
 
1031
            u'AQ_MOVE_ERROR': [{'ACTION': u'md.create(path=path, uuid=target_uuid, type=type)\naq.query(uuid=target_uuid)',
 
1032
                                'ACTION_FUNC': u'',
 
1033
                                'COMMENTS': u'deleted after local move and move failed on server. ',
 
1034
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1035
                                               u'hash_eq_server_hash': u'NA',
 
1036
                                               u'not_authorized': u'NA',
 
1037
                                               u'not_available': u'NA'},
 
1038
                                'STATE': {u'changed': u'NA',
 
1039
                                          u'has_metadata': u'F',
 
1040
                                          u'is_directory': u'NA'},
 
1041
                                'STATE_OUT': {u'changed': u'NONE',
 
1042
                                              u'has_metadata': u'T',
 
1043
                                              u'is_directory': u'='}},
 
1044
                               {'ACTION': u'move file to conflict\nquery(uuid=source.parent)\nquery(uuid=dest.parent)\n',
 
1045
                                'ACTION_FUNC': u'',
 
1046
                                'COMMENTS': u'something bad happened. Conflict and rescan',
 
1047
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1048
                                               u'hash_eq_server_hash': u'NA',
 
1049
                                               u'not_authorized': u'NA',
 
1050
                                               u'not_available': u'NA'},
 
1051
                                'STATE': {u'changed': u'*',
 
1052
                                          u'has_metadata': u'T',
 
1053
                                          u'is_directory': u'*'},
 
1054
                                'STATE_OUT': {u'changed': u'NONE',
 
1055
                                              u'has_metadata': u'T',
 
1056
                                              u'is_directory': u'='}}],
 
1057
            u'AQ_MOVE_OK': [{'ACTION': u'pass',
 
1058
                             'ACTION_FUNC': u'nothing',
 
1059
                             'COMMENTS': u'deleted after move',
 
1060
                             'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1061
                                            u'hash_eq_server_hash': u'NA',
 
1062
                                            u'not_authorized': u'NA',
 
1063
                                            u'not_available': u'NA'},
 
1064
                             'STATE': {u'changed': u'NA',
 
1065
                                       u'has_metadata': u'F',
 
1066
                                       u'is_directory': u'NA'},
 
1067
                             'STATE_OUT': {u'changed': u'=',
 
1068
                                           u'has_metadata': u'=',
 
1069
                                           u'is_directory': u'='}},
 
1070
                            {'ACTION': u'pass',
 
1071
                             'ACTION_FUNC': u'nothing',
 
1072
                             'COMMENTS': u'everything good',
 
1073
                             'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1074
                                            u'hash_eq_server_hash': u'NA',
 
1075
                                            u'not_authorized': u'NA',
 
1076
                                            u'not_available': u'NA'},
 
1077
                             'STATE': {u'changed': u'*',
 
1078
                                       u'has_metadata': u'T',
 
1079
                                       u'is_directory': u'*'},
 
1080
                             'STATE_OUT': {u'changed': u'=',
 
1081
                                           u'has_metadata': u'=',
 
1082
                                           u'is_directory': u'='}}],
 
1083
            u'AQ_UPLOAD_ERROR': [{'ACTION': u'pass',
 
1084
                                  'ACTION_FUNC': u'nothing',
 
1085
                                  'COMMENTS': u'',
 
1086
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1087
                                                 u'hash_eq_server_hash': u'*',
 
1088
                                                 u'not_authorized': u'*',
 
1089
                                                 u'not_available': u'*'},
 
1090
                                  'STATE': {u'changed': u'NA',
 
1091
                                            u'has_metadata': u'F',
 
1092
                                            u'is_directory': u'NA'},
 
1093
                                  'STATE_OUT': {u'changed': u'=',
 
1094
                                                u'has_metadata': u'=',
 
1095
                                                u'is_directory': u'='}},
 
1096
                                 {'ACTION': u'NA',
 
1097
                                  'ACTION_FUNC': u'',
 
1098
                                  'COMMENTS': u'',
 
1099
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1100
                                                 u'hash_eq_server_hash': u'*',
 
1101
                                                 u'not_authorized': u'*',
 
1102
                                                 u'not_available': u'NA'},
 
1103
                                  'STATE': {u'changed': u'*',
 
1104
                                            u'has_metadata': u'T',
 
1105
                                            u'is_directory': u'*'},
 
1106
                                  'STATE_OUT': {u'changed': u'*',
 
1107
                                                u'has_metadata': u'*',
 
1108
                                                u'is_directory': u'*'}},
 
1109
                                 {'ACTION': u'NA',
 
1110
                                  'ACTION_FUNC': u'',
 
1111
                                  'COMMENTS': u'',
 
1112
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1113
                                                 u'hash_eq_server_hash': u'*',
 
1114
                                                 u'not_authorized': u'NA',
 
1115
                                                 u'not_available': u'*'},
 
1116
                                  'STATE': {u'changed': u'*',
 
1117
                                            u'has_metadata': u'T',
 
1118
                                            u'is_directory': u'*'},
 
1119
                                  'STATE_OUT': {u'changed': u'*',
 
1120
                                                u'has_metadata': u'*',
 
1121
                                                u'is_directory': u'*'}},
 
1122
                                 {'ACTION': u'',
 
1123
                                  'ACTION_FUNC': u'nothing',
 
1124
                                  'COMMENTS': u'',
 
1125
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1126
                                                 u'hash_eq_server_hash': u'*',
 
1127
                                                 u'not_authorized': u'F',
 
1128
                                                 u'not_available': u'F'},
 
1129
                                  'STATE': {u'changed': u'*',
 
1130
                                            u'has_metadata': u'T',
 
1131
                                            u'is_directory': u'F'},
 
1132
                                  'STATE_OUT': {u'changed': u'=',
 
1133
                                                u'has_metadata': u'=',
 
1134
                                                u'is_directory': u'='}},
 
1135
                                 {'ACTION': u'NA',
 
1136
                                  'ACTION_FUNC': u'',
 
1137
                                  'COMMENTS': u'',
 
1138
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1139
                                                 u'hash_eq_server_hash': u'*',
 
1140
                                                 u'not_authorized': u'T',
 
1141
                                                 u'not_available': u'T'},
 
1142
                                  'STATE': {u'changed': u'*',
 
1143
                                            u'has_metadata': u'T',
 
1144
                                            u'is_directory': u'F'},
 
1145
                                  'STATE_OUT': {u'changed': u'*',
 
1146
                                                u'has_metadata': u'*',
 
1147
                                                u'is_directory': u'*'}},
 
1148
                                 {'ACTION': u'pass',
 
1149
                                  'ACTION_FUNC': u'nothing',
 
1150
                                  'COMMENTS': u'',
 
1151
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1152
                                                 u'hash_eq_server_hash': u'*',
 
1153
                                                 u'not_authorized': u'F',
 
1154
                                                 u'not_available': u'T'},
 
1155
                                  'STATE': {u'changed': u'*',
 
1156
                                            u'has_metadata': u'T',
 
1157
                                            u'is_directory': u'F'},
 
1158
                                  'STATE_OUT': {u'changed': u'=',
 
1159
                                                u'has_metadata': u'=',
 
1160
                                                u'is_directory': u'='}},
 
1161
                                 {'ACTION': u'pass',
 
1162
                                  'ACTION_FUNC': u'nothing',
 
1163
                                  'COMMENTS': u'',
 
1164
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1165
                                                 u'hash_eq_server_hash': u'*',
 
1166
                                                 u'not_authorized': u'T',
 
1167
                                                 u'not_available': u'F'},
 
1168
                                  'STATE': {u'changed': u'*',
 
1169
                                            u'has_metadata': u'T',
 
1170
                                            u'is_directory': u'F'},
 
1171
                                  'STATE_OUT': {u'changed': u'=',
 
1172
                                                u'has_metadata': u'=',
 
1173
                                                u'is_directory': u'='}},
 
1174
                                 {'ACTION': u'DESPAIR',
 
1175
                                  'ACTION_FUNC': u'DESPAIR',
 
1176
                                  'COMMENTS': u'we never try to upload directories',
 
1177
                                  'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1178
                                                 u'hash_eq_server_hash': u'*',
 
1179
                                                 u'not_authorized': u'!NA',
 
1180
                                                 u'not_available': u'!NA'},
 
1181
                                  'STATE': {u'changed': u'*',
 
1182
                                            u'has_metadata': u'T',
 
1183
                                            u'is_directory': u'T'},
 
1184
                                  'STATE_OUT': {u'changed': u'*',
 
1185
                                                u'has_metadata': u'*',
 
1186
                                                u'is_directory': u'*'}}],
 
1187
            u'AQ_UPLOAD_FINISHED': [{'ACTION': u'pass',
 
1188
                                     'ACTION_FUNC': u'nothing',
 
1189
                                     'COMMENTS': u'',
 
1190
                                     'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1191
                                                    u'hash_eq_server_hash': u'*',
 
1192
                                                    u'not_authorized': u'NA',
 
1193
                                                    u'not_available': u'NA'},
 
1194
                                     'STATE': {u'changed': u'NA',
 
1195
                                               u'has_metadata': u'F',
 
1196
                                               u'is_directory': u'NA'},
 
1197
                                     'STATE_OUT': {u'changed': u'=',
 
1198
                                                   u'has_metadata': u'=',
 
1199
                                                   u'is_directory': u'='}},
 
1200
                                    {'ACTION': u'NA',
 
1201
                                     'ACTION_FUNC': u'',
 
1202
                                     'COMMENTS': u'',
 
1203
                                     'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1204
                                                    u'hash_eq_server_hash': u'*',
 
1205
                                                    u'not_authorized': u'NA',
 
1206
                                                    u'not_available': u'NA'},
 
1207
                                     'STATE': {u'changed': u'*',
 
1208
                                               u'has_metadata': u'T',
 
1209
                                               u'is_directory': u'F'},
 
1210
                                     'STATE_OUT': {u'changed': u'*',
 
1211
                                                   u'has_metadata': u'*',
 
1212
                                                   u'is_directory': u'*'}},
 
1213
                                    {'ACTION': u'NA',
 
1214
                                     'ACTION_FUNC': u'',
 
1215
                                     'COMMENTS': u'',
 
1216
                                     'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1217
                                                    u'hash_eq_server_hash': u'NA',
 
1218
                                                    u'not_authorized': u'NA',
 
1219
                                                    u'not_available': u'NA'},
 
1220
                                     'STATE': {u'changed': u'*',
 
1221
                                               u'has_metadata': u'T',
 
1222
                                               u'is_directory': u'F'},
 
1223
                                     'STATE_OUT': {u'changed': u'*',
 
1224
                                                   u'has_metadata': u'*',
 
1225
                                                   u'is_directory': u'*'}},
 
1226
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1227
                                     'ACTION_FUNC': u'commit_upload',
 
1228
                                     'COMMENTS': u'',
 
1229
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1230
                                                    u'hash_eq_server_hash': u'T',
 
1231
                                                    u'not_authorized': u'NA',
 
1232
                                                    u'not_available': u'NA'},
 
1233
                                     'STATE': {u'changed': u'NONE',
 
1234
                                               u'has_metadata': u'T',
 
1235
                                               u'is_directory': u'F'},
 
1236
                                     'STATE_OUT': {u'changed': u'=',
 
1237
                                                   u'has_metadata': u'=',
 
1238
                                                   u'is_directory': u'='}},
 
1239
                                    {'ACTION': u'NA',
 
1240
                                     'ACTION_FUNC': u'',
 
1241
                                     'COMMENTS': u'',
 
1242
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1243
                                                    u'hash_eq_server_hash': u'T',
 
1244
                                                    u'not_authorized': u'NA',
 
1245
                                                    u'not_available': u'NA'},
 
1246
                                     'STATE': {u'changed': u'NONE',
 
1247
                                               u'has_metadata': u'T',
 
1248
                                               u'is_directory': u'F'},
 
1249
                                     'STATE_OUT': {u'changed': u'*',
 
1250
                                                   u'has_metadata': u'*',
 
1251
                                                   u'is_directory': u'*'}},
 
1252
                                    {'ACTION': u'NA',
 
1253
                                     'ACTION_FUNC': u'',
 
1254
                                     'COMMENTS': u'',
 
1255
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1256
                                                    u'hash_eq_server_hash': u'F',
 
1257
                                                    u'not_authorized': u'NA',
 
1258
                                                    u'not_available': u'NA'},
 
1259
                                     'STATE': {u'changed': u'NONE',
 
1260
                                               u'has_metadata': u'T',
 
1261
                                               u'is_directory': u'F'},
 
1262
                                     'STATE_OUT': {u'changed': u'*',
 
1263
                                                   u'has_metadata': u'*',
 
1264
                                                   u'is_directory': u'*'}},
 
1265
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1266
                                     'ACTION_FUNC': u'commit_upload',
 
1267
                                     'COMMENTS': u'',
 
1268
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1269
                                                    u'hash_eq_server_hash': u'F',
 
1270
                                                    u'not_authorized': u'NA',
 
1271
                                                    u'not_available': u'NA'},
 
1272
                                     'STATE': {u'changed': u'NONE',
 
1273
                                               u'has_metadata': u'T',
 
1274
                                               u'is_directory': u'F'},
 
1275
                                     'STATE_OUT': {u'changed': u'LOCAL',
 
1276
                                                   u'has_metadata': u'=',
 
1277
                                                   u'is_directory': u'='}},
 
1278
                                    {'ACTION': u'NA',
 
1279
                                     'ACTION_FUNC': u'',
 
1280
                                     'COMMENTS': u'',
 
1281
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1282
                                                    u'hash_eq_server_hash': u'T',
 
1283
                                                    u'not_authorized': u'NA',
 
1284
                                                    u'not_available': u'NA'},
 
1285
                                     'STATE': {u'changed': u'SERVER',
 
1286
                                               u'has_metadata': u'T',
 
1287
                                               u'is_directory': u'F'},
 
1288
                                     'STATE_OUT': {u'changed': u'*',
 
1289
                                                   u'has_metadata': u'*',
 
1290
                                                   u'is_directory': u'*'}},
 
1291
                                    {'ACTION': u'NA',
 
1292
                                     'ACTION_FUNC': u'',
 
1293
                                     'COMMENTS': u'',
 
1294
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1295
                                                    u'hash_eq_server_hash': u'T',
 
1296
                                                    u'not_authorized': u'NA',
 
1297
                                                    u'not_available': u'NA'},
 
1298
                                     'STATE': {u'changed': u'LOCAL',
 
1299
                                               u'has_metadata': u'T',
 
1300
                                               u'is_directory': u'F'},
 
1301
                                     'STATE_OUT': {u'changed': u'*',
 
1302
                                                   u'has_metadata': u'*',
 
1303
                                                   u'is_directory': u'*'}},
 
1304
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1305
                                     'ACTION_FUNC': u'commit_upload',
 
1306
                                     'COMMENTS': u'',
 
1307
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1308
                                                    u'hash_eq_server_hash': u'T',
 
1309
                                                    u'not_authorized': u'NA',
 
1310
                                                    u'not_available': u'NA'},
 
1311
                                     'STATE': {u'changed': u'SERVER',
 
1312
                                               u'has_metadata': u'T',
 
1313
                                               u'is_directory': u'F'},
 
1314
                                     'STATE_OUT': {u'changed': u'=',
 
1315
                                                   u'has_metadata': u'=',
 
1316
                                                   u'is_directory': u'='}},
 
1317
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1318
                                     'ACTION_FUNC': u'reput_file_from_ok',
 
1319
                                     'COMMENTS': u'we finished a download, but this download should have been cancelled. So the real upload will conflict. Reschedule upload.',
 
1320
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1321
                                                    u'hash_eq_server_hash': u'T',
 
1322
                                                    u'not_authorized': u'NA',
 
1323
                                                    u'not_available': u'NA'},
 
1324
                                     'STATE': {u'changed': u'LOCAL',
 
1325
                                               u'has_metadata': u'T',
 
1326
                                               u'is_directory': u'F'},
 
1327
                                     'STATE_OUT': {u'changed': u'NONE',
 
1328
                                                   u'has_metadata': u'=',
 
1329
                                                   u'is_directory': u'='}},
 
1330
                                    {'ACTION': u'cancel download; commit upload',
 
1331
                                     'ACTION_FUNC': u'cancel_and_commit',
 
1332
                                     'COMMENTS': u'we couldnt cancel an upload and we overwrote what was on the server',
 
1333
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1334
                                                    u'hash_eq_server_hash': u'F',
 
1335
                                                    u'not_authorized': u'NA',
 
1336
                                                    u'not_available': u'NA'},
 
1337
                                     'STATE': {u'changed': u'SERVER',
 
1338
                                               u'has_metadata': u'T',
 
1339
                                               u'is_directory': u'F'},
 
1340
                                     'STATE_OUT': {u'changed': u'NONE',
 
1341
                                                   u'has_metadata': u'T',
 
1342
                                                   u'is_directory': u'='}},
 
1343
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1344
                                     'ACTION_FUNC': u'commit_upload',
 
1345
                                     'COMMENTS': u'',
 
1346
                                     'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1347
                                                    u'hash_eq_server_hash': u'F',
 
1348
                                                    u'not_authorized': u'NA',
 
1349
                                                    u'not_available': u'NA'},
 
1350
                                     'STATE': {u'changed': u'LOCAL',
 
1351
                                               u'has_metadata': u'T',
 
1352
                                               u'is_directory': u'F'},
 
1353
                                     'STATE_OUT': {u'changed': u'NONE',
 
1354
                                                   u'has_metadata': u'=',
 
1355
                                                   u'is_directory': u'='}},
 
1356
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1357
                                     'ACTION_FUNC': u'commit_upload',
 
1358
                                     'COMMENTS': u'',
 
1359
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1360
                                                    u'hash_eq_server_hash': u'F',
 
1361
                                                    u'not_authorized': u'NA',
 
1362
                                                    u'not_available': u'NA'},
 
1363
                                     'STATE': {u'changed': u'SERVER',
 
1364
                                               u'has_metadata': u'T',
 
1365
                                               u'is_directory': u'F'},
 
1366
                                     'STATE_OUT': {u'changed': u'SERVER',
 
1367
                                                   u'has_metadata': u'=',
 
1368
                                                   u'is_directory': u'='}},
 
1369
                                    {'ACTION': u'md.upload_finished(mdid, server_hash=hash)',
 
1370
                                     'ACTION_FUNC': u'reput_file_from_ok',
 
1371
                                     'COMMENTS': u'',
 
1372
                                     'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1373
                                                    u'hash_eq_server_hash': u'F',
 
1374
                                                    u'not_authorized': u'NA',
 
1375
                                                    u'not_available': u'NA'},
 
1376
                                     'STATE': {u'changed': u'LOCAL',
 
1377
                                               u'has_metadata': u'T',
 
1378
                                               u'is_directory': u'F'},
 
1379
                                     'STATE_OUT': {u'changed': u'NONE',
 
1380
                                                   u'has_metadata': u'=',
 
1381
                                                   u'is_directory': u'='}},
 
1382
                                    {'ACTION': u'DESPAIR',
 
1383
                                     'ACTION_FUNC': u'DESPAIR',
 
1384
                                     'COMMENTS': u'we never try to upload directories',
 
1385
                                     'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1386
                                                    u'hash_eq_server_hash': u'*',
 
1387
                                                    u'not_authorized': u'NA',
 
1388
                                                    u'not_available': u'NA'},
 
1389
                                     'STATE': {u'changed': u'*',
 
1390
                                               u'has_metadata': u'T',
 
1391
                                               u'is_directory': u'T'},
 
1392
                                     'STATE_OUT': {u'changed': u'*',
 
1393
                                                   u'has_metadata': u'*',
 
1394
                                                   u'is_directory': u'*'}}],
 
1395
            u'FS_DIR_CREATE': [{'ACTION': u'mdid = md.create(path=path)\naq.makefile(mdid)',
 
1396
                                'ACTION_FUNC': u'new_local_dir',
 
1397
                                'COMMENTS': u'',
 
1398
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1399
                                               u'hash_eq_server_hash': u'NA',
 
1400
                                               u'not_authorized': u'NA',
 
1401
                                               u'not_available': u'NA'},
 
1402
                                'STATE': {u'changed': u'NA',
 
1403
                                          u'has_metadata': u'F',
 
1404
                                          u'is_directory': u'NA'},
 
1405
                                'STATE_OUT': {u'changed': u'NONE',
 
1406
                                              u'has_metadata': u'T',
 
1407
                                              u'is_directory': u'T'}},
 
1408
                               {'ACTION': u'pass',
 
1409
                                'ACTION_FUNC': u'nothing',
 
1410
                                'COMMENTS': u'duplicate IN_DIRECTORY_NEW',
 
1411
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1412
                                               u'hash_eq_server_hash': u'NA',
 
1413
                                               u'not_authorized': u'NA',
 
1414
                                               u'not_available': u'NA'},
 
1415
                                'STATE': {u'changed': u'SERVER',
 
1416
                                          u'has_metadata': u'T',
 
1417
                                          u'is_directory': u'*'},
 
1418
                                'STATE_OUT': {u'changed': u'=',
 
1419
                                              u'has_metadata': u'=',
 
1420
                                              u'is_directory': u'='}},
 
1421
                               {'ACTION': u'pass',
 
1422
                                'ACTION_FUNC': u'nothing',
 
1423
                                'COMMENTS': u'duplicate IN_DIRECTORY_NEW',
 
1424
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1425
                                               u'hash_eq_server_hash': u'NA',
 
1426
                                               u'not_authorized': u'NA',
 
1427
                                               u'not_available': u'NA'},
 
1428
                                'STATE': {u'changed': u'NONE',
 
1429
                                          u'has_metadata': u'T',
 
1430
                                          u'is_directory': u'F'},
 
1431
                                'STATE_OUT': {u'changed': u'NONE',
 
1432
                                              u'has_metadata': u'T',
 
1433
                                              u'is_directory': u'F'}},
 
1434
                               {'ACTION': u'DESPAIR',
 
1435
                                'ACTION_FUNC': u'DESPAIR',
 
1436
                                'COMMENTS': u'...?',
 
1437
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1438
                                               u'hash_eq_server_hash': u'NA',
 
1439
                                               u'not_authorized': u'NA',
 
1440
                                               u'not_available': u'NA'},
 
1441
                                'STATE': {u'changed': u'LOCAL',
 
1442
                                          u'has_metadata': u'T',
 
1443
                                          u'is_directory': u'F'},
 
1444
                                'STATE_OUT': {u'changed': u'*',
 
1445
                                              u'has_metadata': u'*',
 
1446
                                              u'is_directory': u'*'}},
 
1447
                               {'ACTION': u'pass',
 
1448
                                'ACTION_FUNC': u'nothing',
 
1449
                                'COMMENTS': u'duplicate IN_DIRECTORY_NEW',
 
1450
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1451
                                               u'hash_eq_server_hash': u'NA',
 
1452
                                               u'not_authorized': u'NA',
 
1453
                                               u'not_available': u'NA'},
 
1454
                                'STATE': {u'changed': u'NONE',
 
1455
                                          u'has_metadata': u'T',
 
1456
                                          u'is_directory': u'T'},
 
1457
                                'STATE_OUT': {u'changed': u'NONE',
 
1458
                                              u'has_metadata': u'T',
 
1459
                                              u'is_directory': u'T'}}],
 
1460
            u'FS_DIR_DELETE': [{'ACTION': u'pass',
 
1461
                                'ACTION_FUNC': u'nothing',
 
1462
                                'COMMENTS': u'this is the result of a delete we did',
 
1463
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1464
                                               u'hash_eq_server_hash': u'NA',
 
1465
                                               u'not_authorized': u'NA',
 
1466
                                               u'not_available': u'NA'},
 
1467
                                'STATE': {u'changed': u'NA',
 
1468
                                          u'has_metadata': u'F',
 
1469
                                          u'is_directory': u'NA'},
 
1470
                                'STATE_OUT': {u'changed': u'=',
 
1471
                                              u'has_metadata': u'=',
 
1472
                                              u'is_directory': u'='}},
 
1473
                               {'ACTION': u'aq.delete_file(uuid, type=type); md.remove(uuid)',
 
1474
                                'ACTION_FUNC': u'delete_on_server',
 
1475
                                'COMMENTS': u'when deleting files we remove the metadata, server rescan will find this again and downloadi it if we are shutdown before this delete has gone up. Generations may break this. ',
 
1476
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1477
                                               u'hash_eq_server_hash': u'NA',
 
1478
                                               u'not_authorized': u'NA',
 
1479
                                               u'not_available': u'NA'},
 
1480
                                'STATE': {u'changed': u'NONE',
 
1481
                                          u'has_metadata': u'T',
 
1482
                                          u'is_directory': u'*'},
 
1483
                                'STATE_OUT': {u'changed': u'NA',
 
1484
                                              u'has_metadata': u'F',
 
1485
                                              u'is_directory': u'NA'}},
 
1486
                               {'ACTION': u'',
 
1487
                                'ACTION_FUNC': u'DESPAIR',
 
1488
                                'COMMENTS': u'delete of file when it should be a dir is bad',
 
1489
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1490
                                               u'hash_eq_server_hash': u'NA',
 
1491
                                               u'not_authorized': u'NA',
 
1492
                                               u'not_available': u'NA'},
 
1493
                                'STATE': {u'changed': u'LOCAL',
 
1494
                                          u'has_metadata': u'T',
 
1495
                                          u'is_directory': u'F'},
 
1496
                                'STATE_OUT': {u'changed': u'NA',
 
1497
                                              u'has_metadata': u'F',
 
1498
                                              u'is_directory': u'NA'}},
 
1499
                               {'ACTION': u'',
 
1500
                                'ACTION_FUNC': u'DESPAIR',
 
1501
                                'COMMENTS': u'delete of file when it should be a dir is bad',
 
1502
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1503
                                               u'hash_eq_server_hash': u'NA',
 
1504
                                               u'not_authorized': u'NA',
 
1505
                                               u'not_available': u'NA'},
 
1506
                                'STATE': {u'changed': u'SERVER',
 
1507
                                          u'has_metadata': u'T',
 
1508
                                          u'is_directory': u'F'},
 
1509
                                'STATE_OUT': {u'changed': u'NA',
 
1510
                                              u'has_metadata': u'F',
 
1511
                                              u'is_directory': u'NA'}},
 
1512
                               {'ACTION': u'md.cancel_download(md); md.remove(uuid)',
 
1513
                                'ACTION_FUNC': u'deleted_dir_while_downloading',
 
1514
                                'COMMENTS': u'',
 
1515
                                'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1516
                                               u'hash_eq_server_hash': u'NA',
 
1517
                                               u'not_authorized': u'NA',
 
1518
                                               u'not_available': u'NA'},
 
1519
                                'STATE': {u'changed': u'SERVER',
 
1520
                                          u'has_metadata': u'T',
 
1521
                                          u'is_directory': u'T'},
 
1522
                                'STATE_OUT': {u'changed': u'NA',
 
1523
                                              u'has_metadata': u'F',
 
1524
                                              u'is_directory': u'NA'}}],
 
1525
            u'FS_FILE_CLOSE_WRITE': [{'ACTION': u'DESPAIR',
 
1526
                                      'ACTION_FUNC': u'DESPAIR',
 
1527
                                      'COMMENTS': u'changes from a file that does not exists',
 
1528
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1529
                                                     u'hash_eq_server_hash': u'NA',
 
1530
                                                     u'not_authorized': u'NA',
 
1531
                                                     u'not_available': u'NA'},
 
1532
                                      'STATE': {u'changed': u'NA',
 
1533
                                                u'has_metadata': u'F',
 
1534
                                                u'is_directory': u'*'},
 
1535
                                      'STATE_OUT': {u'changed': u'*',
 
1536
                                                    u'has_metadata': u'*',
 
1537
                                                    u'is_directory': u'*'}},
 
1538
                                     {'ACTION': u'DESPAIR',
 
1539
                                      'ACTION_FUNC': u'DESPAIR',
 
1540
                                      'COMMENTS': u'event cant happen in directories',
 
1541
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1542
                                                     u'hash_eq_server_hash': u'NA',
 
1543
                                                     u'not_authorized': u'NA',
 
1544
                                                     u'not_available': u'NA'},
 
1545
                                      'STATE': {u'changed': u'*',
 
1546
                                                u'has_metadata': u'T',
 
1547
                                                u'is_directory': u'T'},
 
1548
                                      'STATE_OUT': {u'changed': u'*',
 
1549
                                                    u'has_metadata': u'*',
 
1550
                                                    u'is_directory': u'*'}},
 
1551
                                     {'ACTION': u'hq.insert(path)',
 
1552
                                      'ACTION_FUNC': u'calculate_hash',
 
1553
                                      'COMMENTS': u'',
 
1554
                                      'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1555
                                                     u'hash_eq_server_hash': u'NA',
 
1556
                                                     u'not_authorized': u'NA',
 
1557
                                                     u'not_available': u'NA'},
 
1558
                                      'STATE': {u'changed': u'*',
 
1559
                                                u'has_metadata': u'T',
 
1560
                                                u'is_directory': u'F'},
 
1561
                                      'STATE_OUT': {u'changed': u'=',
 
1562
                                                    u'has_metadata': u'=',
 
1563
                                                    u'is_directory': u'='}}],
 
1564
            u'FS_FILE_CREATE': [{'ACTION': u'mdid = md.create(path=path)\naq.makefile(mdid)',
 
1565
                                 'ACTION_FUNC': u'new_local_file',
 
1566
                                 'COMMENTS': u'',
 
1567
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1568
                                                u'hash_eq_server_hash': u'NA',
 
1569
                                                u'not_authorized': u'NA',
 
1570
                                                u'not_available': u'NA'},
 
1571
                                 'STATE': {u'changed': u'NA',
 
1572
                                           u'has_metadata': u'F',
 
1573
                                           u'is_directory': u'NA'},
 
1574
                                 'STATE_OUT': {u'changed': u'NONE',
 
1575
                                               u'has_metadata': u'T',
 
1576
                                               u'is_directory': u'F'}},
 
1577
                                {'ACTION': u'rename to .conflict.n',
 
1578
                                 'ACTION_FUNC': u'new_while_server',
 
1579
                                 'COMMENTS': u'this action sounds resonable. But I dont know how to get to this state+message',
 
1580
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1581
                                                u'hash_eq_server_hash': u'NA',
 
1582
                                                u'not_authorized': u'NA',
 
1583
                                                u'not_available': u'NA'},
 
1584
                                 'STATE': {u'changed': u'SERVER',
 
1585
                                           u'has_metadata': u'T',
 
1586
                                           u'is_directory': u'*'},
 
1587
                                 'STATE_OUT': {u'changed': u'=',
 
1588
                                               u'has_metadata': u'=',
 
1589
                                               u'is_directory': u'='}},
 
1590
                                {'ACTION': u'log warning',
 
1591
                                 'ACTION_FUNC': u'nothing',
 
1592
                                 'COMMENTS': u'duplicate IN_FILE_NEW',
 
1593
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1594
                                                u'hash_eq_server_hash': u'NA',
 
1595
                                                u'not_authorized': u'NA',
 
1596
                                                u'not_available': u'NA'},
 
1597
                                 'STATE': {u'changed': u'NONE',
 
1598
                                           u'has_metadata': u'T',
 
1599
                                           u'is_directory': u'F'},
 
1600
                                 'STATE_OUT': {u'changed': u'NONE',
 
1601
                                               u'has_metadata': u'T',
 
1602
                                               u'is_directory': u'F'}},
 
1603
                                {'ACTION': u'DESPAIR',
 
1604
                                 'ACTION_FUNC': u'DESPAIR',
 
1605
                                 'COMMENTS': u'...?',
 
1606
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1607
                                                u'hash_eq_server_hash': u'NA',
 
1608
                                                u'not_authorized': u'NA',
 
1609
                                                u'not_available': u'NA'},
 
1610
                                 'STATE': {u'changed': u'LOCAL',
 
1611
                                           u'has_metadata': u'T',
 
1612
                                           u'is_directory': u'F'},
 
1613
                                 'STATE_OUT': {u'changed': u'*',
 
1614
                                               u'has_metadata': u'*',
 
1615
                                               u'is_directory': u'*'}},
 
1616
                                {'ACTION': u'log warning',
 
1617
                                 'ACTION_FUNC': u'nothing',
 
1618
                                 'COMMENTS': u'duplicate IN_FILE_NEW',
 
1619
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1620
                                                u'hash_eq_server_hash': u'NA',
 
1621
                                                u'not_authorized': u'NA',
 
1622
                                                u'not_available': u'NA'},
 
1623
                                 'STATE': {u'changed': u'NONE',
 
1624
                                           u'has_metadata': u'T',
 
1625
                                           u'is_directory': u'T'},
 
1626
                                 'STATE_OUT': {u'changed': u'NONE',
 
1627
                                               u'has_metadata': u'T',
 
1628
                                               u'is_directory': u'F'}}],
 
1629
            u'FS_FILE_DELETE': [{'ACTION': u'pass',
 
1630
                                 'ACTION_FUNC': u'nothing',
 
1631
                                 'COMMENTS': u'this is the result of a delete we did',
 
1632
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1633
                                                u'hash_eq_server_hash': u'NA',
 
1634
                                                u'not_authorized': u'NA',
 
1635
                                                u'not_available': u'NA'},
 
1636
                                 'STATE': {u'changed': u'NA',
 
1637
                                           u'has_metadata': u'F',
 
1638
                                           u'is_directory': u'NA'},
 
1639
                                 'STATE_OUT': {u'changed': u'=',
 
1640
                                               u'has_metadata': u'=',
 
1641
                                               u'is_directory': u'='}},
 
1642
                                {'ACTION': u'aq.delete_file(uuid, type=type); md.remove(uuid)',
 
1643
                                 'ACTION_FUNC': u'delete_on_server',
 
1644
                                 'COMMENTS': u'when deleting files we remove the metadata, server rescan will find this again and downloadi it if we are shutdown before this delete has gone up. Generations may break this. ',
 
1645
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1646
                                                u'hash_eq_server_hash': u'NA',
 
1647
                                                u'not_authorized': u'NA',
 
1648
                                                u'not_available': u'NA'},
 
1649
                                 'STATE': {u'changed': u'NONE',
 
1650
                                           u'has_metadata': u'T',
 
1651
                                           u'is_directory': u'*'},
 
1652
                                 'STATE_OUT': {u'changed': u'NA',
 
1653
                                               u'has_metadata': u'F',
 
1654
                                               u'is_directory': u'NA'}},
 
1655
                                {'ACTION': u'aq.cancel_upload(uuid); aq.delete_file(uuid); md.remove(uuid)',
 
1656
                                 'ACTION_FUNC': u'cancel_upload_and_delete_on_server',
 
1657
                                 'COMMENTS': u'',
 
1658
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1659
                                                u'hash_eq_server_hash': u'NA',
 
1660
                                                u'not_authorized': u'NA',
 
1661
                                                u'not_available': u'NA'},
 
1662
                                 'STATE': {u'changed': u'LOCAL',
 
1663
                                           u'has_metadata': u'T',
 
1664
                                           u'is_directory': u'F'},
 
1665
                                 'STATE_OUT': {u'changed': u'NA',
 
1666
                                               u'has_metadata': u'F',
 
1667
                                               u'is_directory': u'NA'}},
 
1668
                                {'ACTION': u'aq.cancel_download(uuid); aq.delete_file(uuid)\n md.remove(uuid)',
 
1669
                                 'ACTION_FUNC': u'cancel_download_and_delete_on_server',
 
1670
                                 'COMMENTS': u'This is policy. We could declare this to be a conflict. But we should assume that the client knows what he is doing',
 
1671
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1672
                                                u'hash_eq_server_hash': u'NA',
 
1673
                                                u'not_authorized': u'NA',
 
1674
                                                u'not_available': u'NA'},
 
1675
                                 'STATE': {u'changed': u'SERVER',
 
1676
                                           u'has_metadata': u'T',
 
1677
                                           u'is_directory': u'F'},
 
1678
                                 'STATE_OUT': {u'changed': u'NA',
 
1679
                                               u'has_metadata': u'F',
 
1680
                                               u'is_directory': u'NA'}},
 
1681
                                {'ACTION': u'',
 
1682
                                 'ACTION_FUNC': u'DESPAIR',
 
1683
                                 'COMMENTS': u'',
 
1684
                                 'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1685
                                                u'hash_eq_server_hash': u'NA',
 
1686
                                                u'not_authorized': u'NA',
 
1687
                                                u'not_available': u'NA'},
 
1688
                                 'STATE': {u'changed': u'SERVER',
 
1689
                                           u'has_metadata': u'T',
 
1690
                                           u'is_directory': u'T'},
 
1691
                                 'STATE_OUT': {u'changed': u'NA',
 
1692
                                               u'has_metadata': u'F',
 
1693
                                               u'is_directory': u'NA'}}],
 
1694
            u'FS_FILE_MOVE': [{'ACTION': u'',
 
1695
                               'ACTION_FUNC': u'nothing',
 
1696
                               'COMMENTS': u'side efect of local move',
 
1697
                               'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1698
                                              u'hash_eq_server_hash': u'NA',
 
1699
                                              u'not_authorized': u'NA',
 
1700
                                              u'not_available': u'NA'},
 
1701
                               'STATE': {u'changed': u'NA',
 
1702
                                         u'has_metadata': u'F',
 
1703
                                         u'is_directory': u'NA'},
 
1704
                               'STATE_OUT': {u'changed': u'NA',
 
1705
                                             u'has_metadata': u'F',
 
1706
                                             u'is_directory': u'NA'}},
 
1707
                              {'ACTION': u'aq.move()',
 
1708
                               'ACTION_FUNC': u'client_moved',
 
1709
                               'COMMENTS': u'vanilla case',
 
1710
                               'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1711
                                              u'hash_eq_server_hash': u'NA',
 
1712
                                              u'not_authorized': u'NA',
 
1713
                                              u'not_available': u'NA'},
 
1714
                               'STATE': {u'changed': u'NONE',
 
1715
                                         u'has_metadata': u'T',
 
1716
                                         u'is_directory': u'*'},
 
1717
                               'STATE_OUT': {u'changed': u'=',
 
1718
                                             u'has_metadata': u'T',
 
1719
                                             u'is_directory': u'='}},
 
1720
                              {'ACTION': u'cancel upload; move; restart upload',
 
1721
                               'ACTION_FUNC': u'moved_dirty_local',
 
1722
                               'COMMENTS': u'we got a move while we were downloading it',
 
1723
                               'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1724
                                              u'hash_eq_server_hash': u'NA',
 
1725
                                              u'not_authorized': u'NA',
 
1726
                                              u'not_available': u'NA'},
 
1727
                               'STATE': {u'changed': u'LOCAL',
 
1728
                                         u'has_metadata': u'T',
 
1729
                                         u'is_directory': u'F'},
 
1730
                               'STATE_OUT': {u'changed': u'NONE',
 
1731
                                             u'has_metadata': u'T',
 
1732
                                             u'is_directory': u'F'}},
 
1733
                              {'ACTION': u'cancel_download; move; query',
 
1734
                               'ACTION_FUNC': u'moved_dirty_server',
 
1735
                               'COMMENTS': u'we got a move while we were downloading it',
 
1736
                               'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1737
                                              u'hash_eq_server_hash': u'NA',
 
1738
                                              u'not_authorized': u'NA',
 
1739
                                              u'not_available': u'NA'},
 
1740
                               'STATE': {u'changed': u'SERVER',
 
1741
                                         u'has_metadata': u'T',
 
1742
                                         u'is_directory': u'*'},
 
1743
                               'STATE_OUT': {u'changed': u'NONE',
 
1744
                                             u'has_metadata': u'T',
 
1745
                                             u'is_directory': u'='}}],
 
1746
            u'HQ_HASH_NEW': [{'ACTION': u'NA',
 
1747
                              'ACTION_FUNC': u'',
 
1748
                              'COMMENTS': u'',
 
1749
                              'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1750
                                             u'hash_eq_server_hash': u'NA',
 
1751
                                             u'not_authorized': u'NA',
 
1752
                                             u'not_available': u'NA'},
 
1753
                              'STATE': {u'changed': u'*',
 
1754
                                        u'has_metadata': u'T',
 
1755
                                        u'is_directory': u'*'},
 
1756
                              'STATE_OUT': {u'changed': u'=',
 
1757
                                            u'has_metadata': u'=',
 
1758
                                            u'is_directory': u'='}},
 
1759
                             {'ACTION': u'NA',
 
1760
                              'ACTION_FUNC': u'',
 
1761
                              'COMMENTS': u'',
 
1762
                              'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1763
                                             u'hash_eq_server_hash': u'*',
 
1764
                                             u'not_authorized': u'NA',
 
1765
                                             u'not_available': u'NA'},
 
1766
                              'STATE': {u'changed': u'*',
 
1767
                                        u'has_metadata': u'T',
 
1768
                                        u'is_directory': u'*'},
 
1769
                              'STATE_OUT': {u'changed': u'=',
 
1770
                                            u'has_metadata': u'=',
 
1771
                                            u'is_directory': u'='}},
 
1772
                             {'ACTION': u'pass',
 
1773
                              'ACTION_FUNC': u'nothing',
 
1774
                              'COMMENTS': u'hash == local_hash == server_hash; nothing changed!',
 
1775
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1776
                                             u'hash_eq_server_hash': u'T',
 
1777
                                             u'not_authorized': u'NA',
 
1778
                                             u'not_available': u'NA'},
 
1779
                              'STATE': {u'changed': u'NONE',
 
1780
                                        u'has_metadata': u'T',
 
1781
                                        u'is_directory': u'F'},
 
1782
                              'STATE_OUT': {u'changed': u'=',
 
1783
                                            u'has_metadata': u'=',
 
1784
                                            u'is_directory': u'='}},
 
1785
                             {'ACTION': u'md.set(mdid, local_hash=hash)\naq.cancel_upload(mdid) or aq.putfile(*mdid)',
 
1786
                              'ACTION_FUNC': u'clean_download',
 
1787
                              'COMMENTS': u'There is an upload in progress, but the new file is the same as the old one on the server. If cancel_upload returns False it means that the upload was no longer in progress (ie the upload finished but the notification is presumably still to be processed). So, we need to upload the new version.',
 
1788
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1789
                                             u'hash_eq_server_hash': u'T',
 
1790
                                             u'not_authorized': u'NA',
 
1791
                                             u'not_available': u'NA'},
 
1792
                              'STATE': {u'changed': u'LOCAL',
 
1793
                                        u'has_metadata': u'T',
 
1794
                                        u'is_directory': u'F'},
 
1795
                              'STATE_OUT': {u'changed': u'NONE',
 
1796
                                            u'has_metadata': u'=',
 
1797
                                            u'is_directory': u'='}},
 
1798
                             {'ACTION': u'md.set(mdid, local_hash=hash)\naq.putfile(*mdid)',
 
1799
                              'ACTION_FUNC': u'put_file',
 
1800
                              'COMMENTS': u'plain \u201cuser modified the file on this machine\u201d case',
 
1801
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1802
                                             u'hash_eq_server_hash': u'F',
 
1803
                                             u'not_authorized': u'NA',
 
1804
                                             u'not_available': u'NA'},
 
1805
                              'STATE': {u'changed': u'NONE',
 
1806
                                        u'has_metadata': u'T',
 
1807
                                        u'is_directory': u'F'},
 
1808
                              'STATE_OUT': {u'changed': u'LOCAL',
 
1809
                                            u'has_metadata': u'=',
 
1810
                                            u'is_directory': u'='}},
 
1811
                             {'ACTION': u'',
 
1812
                              'ACTION_FUNC': u'nothing',
 
1813
                              'COMMENTS': u'we dont send directories to hq. This is old. Ignore.',
 
1814
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
1815
                                             u'hash_eq_server_hash': u'F',
 
1816
                                             u'not_authorized': u'NA',
 
1817
                                             u'not_available': u'NA'},
 
1818
                              'STATE': {u'changed': u'NONE',
 
1819
                                        u'has_metadata': u'T',
 
1820
                                        u'is_directory': u'T'},
 
1821
                              'STATE_OUT': {u'changed': u'SERVER',
 
1822
                                            u'has_metadata': u'=',
 
1823
                                            u'is_directory': u'='}},
 
1824
                             {'ACTION': u'NA',
 
1825
                              'ACTION_FUNC': u'nothing',
 
1826
                              'COMMENTS': u'',
 
1827
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
1828
                                             u'hash_eq_server_hash': u'F',
 
1829
                                             u'not_authorized': u'NA',
 
1830
                                             u'not_available': u'NA'},
 
1831
                              'STATE': {u'changed': u'NONE',
 
1832
                                        u'has_metadata': u'T',
 
1833
                                        u'is_directory': u'T'},
 
1834
                              'STATE_OUT': {u'changed': u'*',
 
1835
                                            u'has_metadata': u'*',
 
1836
                                            u'is_directory': u'*'}},
 
1837
                             {'ACTION': u'pass',
 
1838
                              'ACTION_FUNC': u'nothing',
 
1839
                              'COMMENTS': u'the directories are the same',
 
1840
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1841
                                             u'hash_eq_server_hash': u'T',
 
1842
                                             u'not_authorized': u'NA',
 
1843
                                             u'not_available': u'NA'},
 
1844
                              'STATE': {u'changed': u'NONE',
 
1845
                                        u'has_metadata': u'T',
 
1846
                                        u'is_directory': u'T'},
 
1847
                              'STATE_OUT': {u'changed': u'=',
 
1848
                                            u'has_metadata': u'=',
 
1849
                                            u'is_directory': u'='}},
 
1850
                             {'ACTION': u'md.set(mdid, local_hash=hash)\naq.putfile(*mdid)',
 
1851
                              'ACTION_FUNC': u'reput_file',
 
1852
                              'COMMENTS': u'another upload is in progress',
 
1853
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1854
                                             u'hash_eq_server_hash': u'F',
 
1855
                                             u'not_authorized': u'NA',
 
1856
                                             u'not_available': u'NA'},
 
1857
                              'STATE': {u'changed': u'LOCAL',
 
1858
                                        u'has_metadata': u'T',
 
1859
                                        u'is_directory': u'F'},
 
1860
                              'STATE_OUT': {u'changed': u'LOCAL',
 
1861
                                            u'has_metadata': u'=',
 
1862
                                            u'is_directory': u'='}},
 
1863
                             {'ACTION': u'md.set(mdid, local_hash=hash)\naq.cancel_download(mdid)',
 
1864
                              'ACTION_FUNC': u'converges_to_server',
 
1865
                              'COMMENTS': u'local file already has server changes that are being downloaded',
 
1866
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1867
                                             u'hash_eq_server_hash': u'T',
 
1868
                                             u'not_authorized': u'NA',
 
1869
                                             u'not_available': u'NA'},
 
1870
                              'STATE': {u'changed': u'SERVER',
 
1871
                                        u'has_metadata': u'T',
 
1872
                                        u'is_directory': u'F'},
 
1873
                              'STATE_OUT': {u'changed': u'NONE',
 
1874
                                            u'has_metadata': u'=',
 
1875
                                            u'is_directory': u'='}},
 
1876
                             {'ACTION': u'CONFLICT',
 
1877
                              'ACTION_FUNC': u'file_conflict',
 
1878
                              'COMMENTS': u'local file was modified by the user while download of next version was in progress',
 
1879
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1880
                                             u'hash_eq_server_hash': u'F',
 
1881
                                             u'not_authorized': u'NA',
 
1882
                                             u'not_available': u'NA'},
 
1883
                              'STATE': {u'changed': u'SERVER',
 
1884
                                        u'has_metadata': u'T',
 
1885
                                        u'is_directory': u'F'},
 
1886
                              'STATE_OUT': {u'changed': u'SERVER',
 
1887
                                            u'has_metadata': u'T',
 
1888
                                            u'is_directory': u'='}},
 
1889
                             {'ACTION': u'',
 
1890
                              'ACTION_FUNC': u'nothing',
 
1891
                              'COMMENTS': u'we dont send directories to hq. This is old. Ignore.',
 
1892
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1893
                                             u'hash_eq_server_hash': u'T',
 
1894
                                             u'not_authorized': u'NA',
 
1895
                                             u'not_available': u'NA'},
 
1896
                              'STATE': {u'changed': u'SERVER',
 
1897
                                        u'has_metadata': u'T',
 
1898
                                        u'is_directory': u'T'},
 
1899
                              'STATE_OUT': {u'changed': u'NONE',
 
1900
                                            u'has_metadata': u'=',
 
1901
                                            u'is_directory': u'='}},
 
1902
                             {'ACTION': u'',
 
1903
                              'ACTION_FUNC': u'nothing',
 
1904
                              'COMMENTS': u'we dont send directories to hq. This is old. Ignore.',
 
1905
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
1906
                                             u'hash_eq_server_hash': u'F',
 
1907
                                             u'not_authorized': u'NA',
 
1908
                                             u'not_available': u'NA'},
 
1909
                              'STATE': {u'changed': u'SERVER',
 
1910
                                        u'has_metadata': u'T',
 
1911
                                        u'is_directory': u'T'},
 
1912
                              'STATE_OUT': {u'changed': u'=',
 
1913
                                            u'has_metadata': u'=',
 
1914
                                            u'is_directory': u'='}},
 
1915
                             {'ACTION': u'pass',
 
1916
                              'ACTION_FUNC': u'nothing',
 
1917
                              'COMMENTS': u'',
 
1918
                              'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
1919
                                             u'hash_eq_server_hash': u'*',
 
1920
                                             u'not_authorized': u'NA',
 
1921
                                             u'not_available': u'NA'},
 
1922
                              'STATE': {u'changed': u'*',
 
1923
                                        u'has_metadata': u'F',
 
1924
                                        u'is_directory': u'*'},
 
1925
                              'STATE_OUT': {u'changed': u'=',
 
1926
                                            u'has_metadata': u'=',
 
1927
                                            u'is_directory': u'='}}],
 
1928
            u'SV_DIR_NEW': [{'ACTION': u'md.create(path=path, uuid=uuid, type=type)\naq.query(uuid=uuid)',
 
1929
                             'ACTION_FUNC': u'new_dir',
 
1930
                             'COMMENTS': u'good case, we send a query to see if there are anychanges we need to merge',
 
1931
                             'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1932
                                            u'hash_eq_server_hash': u'NA',
 
1933
                                            u'not_authorized': u'NA',
 
1934
                                            u'not_available': u'NA'},
 
1935
                             'STATE': {u'changed': u'NA',
 
1936
                                       u'has_metadata': u'F',
 
1937
                                       u'is_directory': u'NA'},
 
1938
                             'STATE_OUT': {u'changed': u'NONE',
 
1939
                                           u'has_metadata': u'T',
 
1940
                                           u'is_directory': u'T'}},
 
1941
                            {'ACTION': u'CONFLICT',
 
1942
                             'ACTION_FUNC': u'new_dir_on_server_with_local',
 
1943
                             'COMMENTS': u'',
 
1944
                             'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1945
                                            u'hash_eq_server_hash': u'NA',
 
1946
                                            u'not_authorized': u'NA',
 
1947
                                            u'not_available': u'NA'},
 
1948
                             'STATE': {u'changed': u'*',
 
1949
                                       u'has_metadata': u'T',
 
1950
                                       u'is_directory': u'*'},
 
1951
                             'STATE_OUT': {u'changed': u'NONE',
 
1952
                                           u'has_metadata': u'T',
 
1953
                                           u'is_directory': u'T'}}],
 
1954
            u'SV_FILE_DELETED': [{'ACTION': u'pass',
 
1955
                                  'ACTION_FUNC': u'nothing',
 
1956
                                  'COMMENTS': u'we deleted something and the server did the same',
 
1957
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1958
                                                 u'hash_eq_server_hash': u'NA',
 
1959
                                                 u'not_authorized': u'NA',
 
1960
                                                 u'not_available': u'NA'},
 
1961
                                  'STATE': {u'changed': u'NA',
 
1962
                                            u'has_metadata': u'F',
 
1963
                                            u'is_directory': u'NA'},
 
1964
                                  'STATE_OUT': {u'changed': u'=',
 
1965
                                                u'has_metadata': u'=',
 
1966
                                                u'is_directory': u'='}},
 
1967
                                 {'ACTION': u'md.remove(uuid)',
 
1968
                                  'ACTION_FUNC': u'delete_file',
 
1969
                                  'COMMENTS': u'',
 
1970
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1971
                                                 u'hash_eq_server_hash': u'NA',
 
1972
                                                 u'not_authorized': u'NA',
 
1973
                                                 u'not_available': u'NA'},
 
1974
                                  'STATE': {u'changed': u'NONE',
 
1975
                                            u'has_metadata': u'T',
 
1976
                                            u'is_directory': u'*'},
 
1977
                                  'STATE_OUT': {u'changed': u'NA',
 
1978
                                                u'has_metadata': u'F',
 
1979
                                                u'is_directory': u'NA'}},
 
1980
                                 {'ACTION': u'CONFLICT; md.remove(uuid)',
 
1981
                                  'ACTION_FUNC': u'conflict_and_delete',
 
1982
                                  'COMMENTS': u'',
 
1983
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1984
                                                 u'hash_eq_server_hash': u'NA',
 
1985
                                                 u'not_authorized': u'NA',
 
1986
                                                 u'not_available': u'NA'},
 
1987
                                  'STATE': {u'changed': u'LOCAL',
 
1988
                                            u'has_metadata': u'T',
 
1989
                                            u'is_directory': u'F'},
 
1990
                                  'STATE_OUT': {u'changed': u'NA',
 
1991
                                                u'has_metadata': u'F',
 
1992
                                                u'is_directory': u'NA'}},
 
1993
                                 {'ACTION': u'md.cancel_download(uuid); md.remove(uuid)',
 
1994
                                  'ACTION_FUNC': u'file_gone_wile_downloading',
 
1995
                                  'COMMENTS': u'we are still downloading some content we dont care about anymore',
 
1996
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
1997
                                                 u'hash_eq_server_hash': u'NA',
 
1998
                                                 u'not_authorized': u'NA',
 
1999
                                                 u'not_available': u'NA'},
 
2000
                                  'STATE': {u'changed': u'SERVER',
 
2001
                                            u'has_metadata': u'T',
 
2002
                                            u'is_directory': u'F'},
 
2003
                                  'STATE_OUT': {u'changed': u'NA',
 
2004
                                                u'has_metadata': u'F',
 
2005
                                                u'is_directory': u'NA'}},
 
2006
                                 {'ACTION': u'md.cancel_download(md); md.remove(uuid)',
 
2007
                                  'ACTION_FUNC': u'file_gone_wile_downloading',
 
2008
                                  'COMMENTS': u'we are still downloading some content we dont care about anymore',
 
2009
                                  'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2010
                                                 u'hash_eq_server_hash': u'NA',
 
2011
                                                 u'not_authorized': u'NA',
 
2012
                                                 u'not_available': u'NA'},
 
2013
                                  'STATE': {u'changed': u'SERVER',
 
2014
                                            u'has_metadata': u'T',
 
2015
                                            u'is_directory': u'T'},
 
2016
                                  'STATE_OUT': {u'changed': u'NA',
 
2017
                                                u'has_metadata': u'F',
 
2018
                                                u'is_directory': u'NA'}}],
 
2019
            u'SV_FILE_NEW': [{'ACTION': u'md.create(path=path, uuid=uuid, type=type)\naq.query(uuid=uuid)',
 
2020
                              'ACTION_FUNC': u'new_file',
 
2021
                              'COMMENTS': u'good case, we send a query to see if there are anychanges we need to merge',
 
2022
                              'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2023
                                             u'hash_eq_server_hash': u'NA',
 
2024
                                             u'not_authorized': u'NA',
 
2025
                                             u'not_available': u'NA'},
 
2026
                              'STATE': {u'changed': u'NA',
 
2027
                                        u'has_metadata': u'F',
 
2028
                                        u'is_directory': u'NA'},
 
2029
                              'STATE_OUT': {u'changed': u'NONE',
 
2030
                                            u'has_metadata': u'T',
 
2031
                                            u'is_directory': u'F'}},
 
2032
                             {'ACTION': u'CONFLICT',
 
2033
                              'ACTION_FUNC': u'new_file_on_server_with_local',
 
2034
                              'COMMENTS': u'',
 
2035
                              'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2036
                                             u'hash_eq_server_hash': u'NA',
 
2037
                                             u'not_authorized': u'NA',
 
2038
                                             u'not_available': u'NA'},
 
2039
                              'STATE': {u'changed': u'*',
 
2040
                                        u'has_metadata': u'T',
 
2041
                                        u'is_directory': u'*'},
 
2042
                              'STATE_OUT': {u'changed': u'NONE',
 
2043
                                            u'has_metadata': u'T',
 
2044
                                            u'is_directory': u'F'}}],
 
2045
            u'SV_HASH_NEW': [{'ACTION': u'NA',
 
2046
                              'ACTION_FUNC': u'',
 
2047
                              'COMMENTS': u'',
 
2048
                              'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
2049
                                             u'hash_eq_server_hash': u'NA',
 
2050
                                             u'not_authorized': u'NA',
 
2051
                                             u'not_available': u'NA'},
 
2052
                              'STATE': {u'changed': u'*',
 
2053
                                        u'has_metadata': u'T',
 
2054
                                        u'is_directory': u'*'},
 
2055
                              'STATE_OUT': {u'changed': u'=',
 
2056
                                            u'has_metadata': u'=',
 
2057
                                            u'is_directory': u'='}},
 
2058
                             {'ACTION': u'NA',
 
2059
                              'ACTION_FUNC': u'',
 
2060
                              'COMMENTS': u'',
 
2061
                              'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2062
                                             u'hash_eq_server_hash': u'*',
 
2063
                                             u'not_authorized': u'NA',
 
2064
                                             u'not_available': u'NA'},
 
2065
                              'STATE': {u'changed': u'*',
 
2066
                                        u'has_metadata': u'T',
 
2067
                                        u'is_directory': u'*'},
 
2068
                              'STATE_OUT': {u'changed': u'=',
 
2069
                                            u'has_metadata': u'=',
 
2070
                                            u'is_directory': u'='}},
 
2071
                             {'ACTION': u'pass',
 
2072
                              'ACTION_FUNC': u'nothing',
 
2073
                              'COMMENTS': u'server side changes while trying to delete something',
 
2074
                              'PARAMETERS': {u'hash_eq_local_hash': u'*',
 
2075
                                             u'hash_eq_server_hash': u'*',
 
2076
                                             u'not_authorized': u'NA',
 
2077
                                             u'not_available': u'NA'},
 
2078
                              'STATE': {u'changed': u'NA',
 
2079
                                        u'has_metadata': u'F',
 
2080
                                        u'is_directory': u'*'},
 
2081
                              'STATE_OUT': {u'changed': u'NA',
 
2082
                                            u'has_metadata': u'=',
 
2083
                                            u'is_directory': u'='}},
 
2084
                             {'ACTION': u'pass',
 
2085
                              'ACTION_FUNC': u'nothing',
 
2086
                              'COMMENTS': u'no news is good news',
 
2087
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2088
                                             u'hash_eq_server_hash': u'T',
 
2089
                                             u'not_authorized': u'NA',
 
2090
                                             u'not_available': u'NA'},
 
2091
                              'STATE': {u'changed': u'NONE',
 
2092
                                        u'has_metadata': u'T',
 
2093
                                        u'is_directory': u'F'},
 
2094
                              'STATE_OUT': {u'changed': u'=',
 
2095
                                            u'has_metadata': u'=',
 
2096
                                            u'is_directory': u'='}},
 
2097
                             {'ACTION': u'NA',
 
2098
                              'ACTION_FUNC': u'',
 
2099
                              'COMMENTS': u'NONE, T, F is a falacy (NONE implies server_hash == local_hash)',
 
2100
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2101
                                             u'hash_eq_server_hash': u'T',
 
2102
                                             u'not_authorized': u'NA',
 
2103
                                             u'not_available': u'NA'},
 
2104
                              'STATE': {u'changed': u'NONE',
 
2105
                                        u'has_metadata': u'T',
 
2106
                                        u'is_directory': u'F'},
 
2107
                              'STATE_OUT': {u'changed': u'*',
 
2108
                                            u'has_metadata': u'*',
 
2109
                                            u'is_directory': u'*'}},
 
2110
                             {'ACTION': u'NA',
 
2111
                              'ACTION_FUNC': u'',
 
2112
                              'COMMENTS': u'NONE, F, T is a falacy (NONE implies server_hash == local_hash)',
 
2113
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2114
                                             u'hash_eq_server_hash': u'F',
 
2115
                                             u'not_authorized': u'NA',
 
2116
                                             u'not_available': u'NA'},
 
2117
                              'STATE': {u'changed': u'NONE',
 
2118
                                        u'has_metadata': u'T',
 
2119
                                        u'is_directory': u'F'},
 
2120
                              'STATE_OUT': {u'changed': u'*',
 
2121
                                            u'has_metadata': u'*',
 
2122
                                            u'is_directory': u'*'}},
 
2123
                             {'ACTION': u'md.set(uuid, server_hash=hash)\npartial = md.create_partial(uuid)\naq.getcontent(*partial)',
 
2124
                              'ACTION_FUNC': u'get_file',
 
2125
                              'COMMENTS': u'',
 
2126
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2127
                                             u'hash_eq_server_hash': u'F',
 
2128
                                             u'not_authorized': u'NA',
 
2129
                                             u'not_available': u'NA'},
 
2130
                              'STATE': {u'changed': u'NONE',
 
2131
                                        u'has_metadata': u'T',
 
2132
                                        u'is_directory': u'F'},
 
2133
                              'STATE_OUT': {u'changed': u'SERVER',
 
2134
                                            u'has_metadata': u'=',
 
2135
                                            u'is_directory': u'='}},
 
2136
                             {'ACTION': u'NA',
 
2137
                              'ACTION_FUNC': u'',
 
2138
                              'COMMENTS': u'SERVER, T, T is a impossible (SERVER implies server_hash != local_hash)',
 
2139
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2140
                                             u'hash_eq_server_hash': u'T',
 
2141
                                             u'not_authorized': u'NA',
 
2142
                                             u'not_available': u'NA'},
 
2143
                              'STATE': {u'changed': u'SERVER',
 
2144
                                        u'has_metadata': u'T',
 
2145
                                        u'is_directory': u'F'},
 
2146
                              'STATE_OUT': {u'changed': u'*',
 
2147
                                            u'has_metadata': u'*',
 
2148
                                            u'is_directory': u'*'}},
 
2149
                             {'ACTION': u'pass',
 
2150
                              'ACTION_FUNC': u'nothing',
 
2151
                              'COMMENTS': u'A download for a content object with the same hash is already in progress',
 
2152
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2153
                                             u'hash_eq_server_hash': u'T',
 
2154
                                             u'not_authorized': u'NA',
 
2155
                                             u'not_available': u'NA'},
 
2156
                              'STATE': {u'changed': u'SERVER',
 
2157
                                        u'has_metadata': u'T',
 
2158
                                        u'is_directory': u'F'},
 
2159
                              'STATE_OUT': {u'changed': u'=',
 
2160
                                            u'has_metadata': u'=',
 
2161
                                            u'is_directory': u'='}},
 
2162
                             {'ACTION': u'md.remove_partial(uuid)\nmd.set(uuid, server_hash=hash)\naq.cancel_download(uuid)',
 
2163
                              'ACTION_FUNC': u'server_file_changed_back',
 
2164
                              'COMMENTS': u"the local file is equal to the file that is now on the server, but a download is in progress from an older version of the server. Removing the partial ensures that we never complete the download (thus we avoid the dreaded !!! state) Note that this makes it important for AQ_DOWNLOAD_FINISHED to 'pass' on downloads that aren't partials",
 
2165
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2166
                                             u'hash_eq_server_hash': u'F',
 
2167
                                             u'not_authorized': u'NA',
 
2168
                                             u'not_available': u'NA'},
 
2169
                              'STATE': {u'changed': u'SERVER',
 
2170
                                        u'has_metadata': u'T',
 
2171
                                        u'is_directory': u'F'},
 
2172
                              'STATE_OUT': {u'changed': u'NONE',
 
2173
                                            u'has_metadata': u'=',
 
2174
                                            u'is_directory': u'='}},
 
2175
                             {'ACTION': u'aq.cancel_download(uuid)\nmd.set(uuid, server_hash=hash)\npartial = md.get_partial(uuid)\naq.getcontent(*partial)',
 
2176
                              'ACTION_FUNC': u'reget_file',
 
2177
                              'COMMENTS': u'a download was in progress but the server changed again. Note that this makes it important for AQ_DOWNLOAD_FINISHED to check the server hash.',
 
2178
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2179
                                             u'hash_eq_server_hash': u'F',
 
2180
                                             u'not_authorized': u'NA',
 
2181
                                             u'not_available': u'NA'},
 
2182
                              'STATE': {u'changed': u'SERVER',
 
2183
                                        u'has_metadata': u'T',
 
2184
                                        u'is_directory': u'F'},
 
2185
                              'STATE_OUT': {u'changed': u'SERVER',
 
2186
                                            u'has_metadata': u'=',
 
2187
                                            u'is_directory': u'='}},
 
2188
                             {'ACTION': u'NA',
 
2189
                              'ACTION_FUNC': u'',
 
2190
                              'COMMENTS': u'LOCAL, T, T is a impossible (LOCAL implies server_hash != local_hash)',
 
2191
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2192
                                             u'hash_eq_server_hash': u'T',
 
2193
                                             u'not_authorized': u'NA',
 
2194
                                             u'not_available': u'NA'},
 
2195
                              'STATE': {u'changed': u'LOCAL',
 
2196
                                        u'has_metadata': u'T',
 
2197
                                        u'is_directory': u'F'},
 
2198
                              'STATE_OUT': {u'changed': u'*',
 
2199
                                            u'has_metadata': u'*',
 
2200
                                            u'is_directory': u'*'}},
 
2201
                             {'ACTION': u'CONFLICT',
 
2202
                              'ACTION_FUNC': u'nothing',
 
2203
                              'COMMENTS': u'',
 
2204
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2205
                                             u'hash_eq_server_hash': u'T',
 
2206
                                             u'not_authorized': u'NA',
 
2207
                                             u'not_available': u'NA'},
 
2208
                              'STATE': {u'changed': u'LOCAL',
 
2209
                                        u'has_metadata': u'T',
 
2210
                                        u'is_directory': u'F'},
 
2211
                              'STATE_OUT': {u'changed': u'=',
 
2212
                                            u'has_metadata': u'=',
 
2213
                                            u'is_directory': u'='}},
 
2214
                             {'ACTION': u'aq.cancel_upload(uuid)\nmd.set(uuid, server_hash=hash)',
 
2215
                              'ACTION_FUNC': u'server_file_now_matches',
 
2216
                              'COMMENTS': u"there's a small chance that the cancel fails, in which case we're simply redundant",
 
2217
                              'PARAMETERS': {u'hash_eq_local_hash': u'T',
 
2218
                                             u'hash_eq_server_hash': u'F',
 
2219
                                             u'not_authorized': u'NA',
 
2220
                                             u'not_available': u'NA'},
 
2221
                              'STATE': {u'changed': u'LOCAL',
 
2222
                                        u'has_metadata': u'T',
 
2223
                                        u'is_directory': u'F'},
 
2224
                              'STATE_OUT': {u'changed': u'NONE',
 
2225
                                            u'has_metadata': u'=',
 
2226
                                            u'is_directory': u'='}},
 
2227
                             {'ACTION': u'CONFLICT',
 
2228
                              'ACTION_FUNC': u'local_file_conflict',
 
2229
                              'COMMENTS': u'',
 
2230
                              'PARAMETERS': {u'hash_eq_local_hash': u'F',
 
2231
                                             u'hash_eq_server_hash': u'F',
 
2232
                                             u'not_authorized': u'NA',
 
2233
                                             u'not_available': u'NA'},
 
2234
                              'STATE': {u'changed': u'LOCAL',
 
2235
                                        u'has_metadata': u'T',
 
2236
                                        u'is_directory': u'F'},
 
2237
                              'STATE_OUT': {u'changed': u'SERVER',
 
2238
                                            u'has_metadata': u'T',
 
2239
                                            u'is_directory': u'='}},
 
2240
                             {'ACTION': u'pass',
 
2241
                              'ACTION_FUNC': u'nothing',
 
2242
                              'COMMENTS': u'no news is good news',
 
2243
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
2244
                                             u'hash_eq_server_hash': u'T',
 
2245
                                             u'not_authorized': u'NA',
 
2246
                                             u'not_available': u'NA'},
 
2247
                              'STATE': {u'changed': u'NONE',
 
2248
                                        u'has_metadata': u'T',
 
2249
                                        u'is_directory': u'T'},
 
2250
                              'STATE_OUT': {u'changed': u'=',
 
2251
                                            u'has_metadata': u'=',
 
2252
                                            u'is_directory': u'='}},
 
2253
                             {'ACTION': u'md.set(uuid, server_hash=hash)\npartial = md.create_partial(uuid)\naq.getcontent(*partial)',
 
2254
                              'ACTION_FUNC': u'get_dir',
 
2255
                              'COMMENTS': u'normal case',
 
2256
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
2257
                                             u'hash_eq_server_hash': u'F',
 
2258
                                             u'not_authorized': u'NA',
 
2259
                                             u'not_available': u'NA'},
 
2260
                              'STATE': {u'changed': u'NONE',
 
2261
                                        u'has_metadata': u'T',
 
2262
                                        u'is_directory': u'T'},
 
2263
                              'STATE_OUT': {u'changed': u'SERVER',
 
2264
                                            u'has_metadata': u'=',
 
2265
                                            u'is_directory': u'='}},
 
2266
                             {'ACTION': u'aq.cancel_download(uuid) \nmd.set(uuid, server_hash=hash)',
 
2267
                              'ACTION_FUNC': u'nothing',
 
2268
                              'COMMENTS': u'A download for a content object with the same hash is already in progress',
 
2269
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
2270
                                             u'hash_eq_server_hash': u'T',
 
2271
                                             u'not_authorized': u'NA',
 
2272
                                             u'not_available': u'NA'},
 
2273
                              'STATE': {u'changed': u'SERVER',
 
2274
                                        u'has_metadata': u'T',
 
2275
                                        u'is_directory': u'T'},
 
2276
                              'STATE_OUT': {u'changed': u'SERVER',
 
2277
                                            u'has_metadata': u'=',
 
2278
                                            u'is_directory': u'='}},
 
2279
                             {'ACTION': u'aq.cancel_download(uuid)\nmd.set(uuid, server_hash=hash)\npartial = md.get_partial(uuid)\naq.getcontent(*partial)',
 
2280
                              'ACTION_FUNC': u'reget_dir',
 
2281
                              'COMMENTS': u'a download was in progress but the server changed again. Note that this makes it important for AQ_DOWNLOAD_FINISHED to check the server hash.',
 
2282
                              'PARAMETERS': {u'hash_eq_local_hash': u'!NA',
 
2283
                                             u'hash_eq_server_hash': u'F',
 
2284
                                             u'not_authorized': u'NA',
 
2285
                                             u'not_available': u'NA'},
 
2286
                              'STATE': {u'changed': u'SERVER',
 
2287
                                        u'has_metadata': u'T',
 
2288
                                        u'is_directory': u'T'},
 
2289
                              'STATE_OUT': {u'changed': u'NONE',
 
2290
                                            u'has_metadata': u'=',
 
2291
                                            u'is_directory': u'='}}],
 
2292
            u'SV_MOVED': [{'ACTION': u'DESPAIR',
 
2293
                           'ACTION_FUNC': u'DESPAIR',
 
2294
                           'COMMENTS': u'',
 
2295
                           'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2296
                                          u'hash_eq_server_hash': u'NA',
 
2297
                                          u'not_authorized': u'NA',
 
2298
                                          u'not_available': u'NA'},
 
2299
                           'STATE': {u'changed': u'NA',
 
2300
                                     u'has_metadata': u'F',
 
2301
                                     u'is_directory': u'NA'},
 
2302
                           'STATE_OUT': {u'changed': u'*',
 
2303
                                         u'has_metadata': u'*',
 
2304
                                         u'is_directory': u'*'}},
 
2305
                          {'ACTION': u'md.move(uuid)',
 
2306
                           'ACTION_FUNC': u'server_moved',
 
2307
                           'COMMENTS': u'all pending changes should arrive to the moved file\naq should remove the destination if its there',
 
2308
                           'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2309
                                          u'hash_eq_server_hash': u'NA',
 
2310
                                          u'not_authorized': u'NA',
 
2311
                                          u'not_available': u'NA'},
 
2312
                           'STATE': {u'changed': u'!SERVER',
 
2313
                                     u'has_metadata': u'T',
 
2314
                                     u'is_directory': u'*'},
 
2315
                           'STATE_OUT': {u'changed': u'=',
 
2316
                                         u'has_metadata': u'T',
 
2317
                                         u'is_directory': u'='}},
 
2318
                          {'ACTION': u'cancel_download; move; query',
 
2319
                           'ACTION_FUNC': u'server_moved_dirty',
 
2320
                           'COMMENTS': u'we got a move while we were downloading it',
 
2321
                           'PARAMETERS': {u'hash_eq_local_hash': u'NA',
 
2322
                                          u'hash_eq_server_hash': u'NA',
 
2323
                                          u'not_authorized': u'NA',
 
2324
                                          u'not_available': u'NA'},
 
2325
                           'STATE': {u'changed': u'SERVER',
 
2326
                                     u'has_metadata': u'T',
 
2327
                                     u'is_directory': u'*'},
 
2328
                           'STATE_OUT': {u'changed': u'=',
 
2329
                                         u'has_metadata': u'T',
 
2330
                                         u'is_directory': u'='}}]},
 
2331
 'invalid': [{u'changed': u'NONE',
 
2332
              u'has_metadata': u'F',
 
2333
              u'is_directory': u'T'},
 
2334
             {u'changed': u'SERVER',
 
2335
              u'has_metadata': u'F',
 
2336
              u'is_directory': u'T'},
 
2337
             {u'changed': u'LOCAL',
 
2338
              u'has_metadata': u'F',
 
2339
              u'is_directory': u'T'},
 
2340
             {u'changed': u'NONE',
 
2341
              u'has_metadata': u'F',
 
2342
              u'is_directory': u'F'},
 
2343
             {u'changed': u'SERVER',
 
2344
              u'has_metadata': u'F',
 
2345
              u'is_directory': u'F'},
 
2346
             {u'changed': u'LOCAL',
 
2347
              u'has_metadata': u'F',
 
2348
              u'is_directory': u'F'},
 
2349
             {u'changed': u'NONE',
 
2350
              u'has_metadata': u'F',
 
2351
              u'is_directory': u'NA'},
 
2352
             {u'changed': u'SERVER',
 
2353
              u'has_metadata': u'F',
 
2354
              u'is_directory': u'NA'},
 
2355
             {u'changed': u'LOCAL',
 
2356
              u'has_metadata': u'F',
 
2357
              u'is_directory': u'NA'},
 
2358
             {u'changed': u'NONE',
 
2359
              u'has_metadata': u'T',
 
2360
              u'is_directory': u'NA'},
 
2361
             {u'changed': u'SERVER',
 
2362
              u'has_metadata': u'T',
 
2363
              u'is_directory': u'NA'},
 
2364
             {u'changed': u'LOCAL',
 
2365
              u'has_metadata': u'T',
 
2366
              u'is_directory': u'NA'},
 
2367
             {u'changed': u'NA',
 
2368
              u'has_metadata': u'T',
 
2369
              u'is_directory': u'NA'},
 
2370
             {u'changed': u'NA',
 
2371
              u'has_metadata': u'T',
 
2372
              u'is_directory': u'F'},
 
2373
             {u'changed': u'NA',
 
2374
              u'has_metadata': u'T',
 
2375
              u'is_directory': u'T'},
 
2376
             {u'changed': u'LOCAL',
 
2377
              u'has_metadata': u'T',
 
2378
              u'is_directory': u'T'},
 
2379
             {u'changed': u'NA',
 
2380
              u'has_metadata': u'F',
 
2381
              u'is_directory': u'T'},
 
2382
             {u'changed': u'NA',
 
2383
              u'has_metadata': u'F',
 
2384
              u'is_directory': u'F'}],
 
2385
 'parameters': {u'hash_eq_local_hash': u'hash == md.local_hash',
 
2386
                u'hash_eq_server_hash': u'hash == md.server_hash',
 
2387
                u'not_authorized': u'error == not authorized',
 
2388
                u'not_available': u'error == not available'},
 
2389
 'state_vars': {u'changed': u'changed',
 
2390
                u'has_metadata': u'\u2203 md',
 
2391
                u'is_directory': u'isDirectory'}}
 
 
b'\\ No newline at end of file'