synapse 2.223.0__py311-none-any.whl → 2.224.0__py311-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of synapse might be problematic. Click here for more details.

synapse/common.py CHANGED
@@ -144,7 +144,7 @@ def flatten(item):
144
144
  item: The python primitive object to normalize.
145
145
 
146
146
  Notes:
147
- Only None, bool, int, bytes, strings, lists, tuples and dictionaries are acceptable input.
147
+ Only None, bool, int, bytes, strings, floats, lists, tuples and dictionaries are acceptable input.
148
148
  List objects will be converted to tuples.
149
149
  Dictionary objects must have keys which can be sorted.
150
150
 
@@ -155,7 +155,7 @@ def flatten(item):
155
155
  if item is None:
156
156
  return None
157
157
 
158
- if isinstance(item, (str, int, bytes)):
158
+ if isinstance(item, (str, int, bytes, float)):
159
159
  return item
160
160
 
161
161
  if isinstance(item, (tuple, list)):
synapse/cortex.py CHANGED
@@ -464,6 +464,15 @@ class CoreApi(s_cell.CellApi):
464
464
  '''
465
465
  return await self.cell.getTypeNorm(name, valu, typeopts=typeopts)
466
466
 
467
+ async def addType(self, typename, basetype, typeopts, typeinfo):
468
+ '''
469
+ Add an extended type to the data model.
470
+
471
+ Extended types must begin with _
472
+ '''
473
+ self.user.confirm(('model', 'type', 'add', typename))
474
+ return await self.cell.addType(typename, basetype, typeopts, typeinfo)
475
+
467
476
  async def addForm(self, formname, basetype, typeopts, typeinfo):
468
477
  '''
469
478
  Add an extended form to the data model.
@@ -535,6 +544,15 @@ class CoreApi(s_cell.CellApi):
535
544
  self.user.confirm(('model', 'tagprop', 'del'))
536
545
  return await self.cell.delTagProp(name)
537
546
 
547
+ async def addEdge(self, edge, edgeinfo):
548
+ '''
549
+ Add an extended edge definition to the data model.
550
+
551
+ Extended edge definitions must use a verb which begins with _
552
+ '''
553
+ self.user.confirm(('model', 'edge', 'add'))
554
+ return await self.cell.addEdge(edge, edgeinfo)
555
+
538
556
  async def addStormPkg(self, pkgdef, verify=False):
539
557
  self.user.confirm(('pkg', 'add'))
540
558
  return await self.cell.addStormPkg(pkgdef, verify=verify)
@@ -1440,6 +1458,11 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
1440
1458
  {'perm': ('model', 'univ', 'del'), 'gate': 'cortex',
1441
1459
  'desc': 'Controls access to deleting extended model universal properties and values.'},
1442
1460
 
1461
+ {'perm': ('model', 'edge', 'add'), 'gate': 'cortex',
1462
+ 'desc': 'Controls access to adding extended model edges.'},
1463
+ {'perm': ('model', 'edge', 'del'), 'gate': 'cortex',
1464
+ 'desc': 'Controls access to deleting extended model edges.'},
1465
+
1443
1466
  {'perm': ('node',), 'gate': 'layer',
1444
1467
  'desc': 'Controls all node edits in a layer.'},
1445
1468
  {'perm': ('node', 'add'), 'gate': 'layer',
@@ -2568,6 +2591,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
2568
2591
  ctor.pkgname = cdef.get('pkgname')
2569
2592
  ctor.svciden = cdef.get('cmdconf', {}).get('svciden', '')
2570
2593
  ctor.forms = cdef.get('forms', {})
2594
+ ctor.deprecated = cdef.get('deprecated', {})
2571
2595
 
2572
2596
  def getStorNode(form):
2573
2597
  ndef = (form.name, form.type.norm(cdef.get('name'))[0])
@@ -2596,6 +2620,18 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
2596
2620
  if ctor.pkgname:
2597
2621
  props['package'] = ctor.pkgname
2598
2622
 
2623
+ if ctor.deprecated:
2624
+ props['deprecated'] = True
2625
+
2626
+ if (eolvers := ctor.deprecated.get('eolvers')) is not None:
2627
+ props['deprecated:version'] = eolvers
2628
+
2629
+ if (eoldate := ctor.deprecated.get('eoldate')) is not None:
2630
+ props['deprecated:date'] = eoldate
2631
+
2632
+ if (mesg := ctor.deprecated.get('mesg')) is not None:
2633
+ props['deprecated:mesg'] = mesg
2634
+
2599
2635
  pnorms = {}
2600
2636
  for prop, valu in props.items():
2601
2637
  formprop = form.props.get(prop)
@@ -3662,6 +3698,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3662
3698
 
3663
3699
  return True
3664
3700
 
3701
+ @s_cell.from_leader
3665
3702
  async def addUnivProp(self, name, tdef, info):
3666
3703
  if not isinstance(tdef, tuple):
3667
3704
  mesg = 'Universal property type definitions should be a tuple.'
@@ -3676,6 +3713,8 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3676
3713
  mesg = 'ext univ name must start with "_"'
3677
3714
  raise s_exc.BadPropDef(name=name, mesg=mesg)
3678
3715
 
3716
+ self.model.getTypeClone(tdef)
3717
+
3679
3718
  base = '.' + name
3680
3719
  if base in self.model.props:
3681
3720
  raise s_exc.DupPropName(mesg=f'Cannot add duplicate universal property {base}',
@@ -3697,6 +3736,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3697
3736
  if univ:
3698
3737
  await self.feedBeholder('model:univ:add', univ.pack())
3699
3738
 
3739
+ @s_cell.from_leader
3700
3740
  async def addForm(self, formname, basetype, typeopts, typeinfo):
3701
3741
  if not isinstance(typeopts, dict):
3702
3742
  mesg = 'Form type options should be a dict.'
@@ -3718,6 +3758,8 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3718
3758
  mesg = f'Type already exists: {formname}'
3719
3759
  raise s_exc.DupTypeName.init(formname)
3720
3760
 
3761
+ self.model.getTypeClone((basetype, typeopts))
3762
+
3721
3763
  return await self._push('model:form:add', formname, basetype, typeopts, typeinfo)
3722
3764
 
3723
3765
  @s_nexus.Pusher.onPush('model:form:add')
@@ -3772,6 +3814,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3772
3814
  await self.fire('core:extmodel:change', form=formname, act='del', type='form')
3773
3815
  await self.feedBeholder('model:form:del', {'form': formname})
3774
3816
 
3817
+ @s_cell.from_leader
3775
3818
  async def addType(self, typename, basetype, typeopts, typeinfo):
3776
3819
  if not isinstance(typeopts, dict):
3777
3820
  mesg = 'Type options should be a dict.'
@@ -3840,6 +3883,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3840
3883
  await self.fire('core:extmodel:change', name=typename, act='del', type='type')
3841
3884
  await self.feedBeholder('model:type:del', {'type': typename})
3842
3885
 
3886
+ @s_cell.from_leader
3843
3887
  async def addFormProp(self, form, prop, tdef, info):
3844
3888
  if not isinstance(tdef, tuple):
3845
3889
  mesg = 'Form property type definitions should be a tuple.'
@@ -3858,6 +3902,9 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
3858
3902
  if _form.prop(prop):
3859
3903
  raise s_exc.DupPropName(mesg=f'Cannot add duplicate form prop {form} {prop}',
3860
3904
  form=form, prop=prop)
3905
+
3906
+ self.model.getTypeClone(tdef)
3907
+
3861
3908
  await self._push('model:prop:add', form, prop, tdef, info)
3862
3909
 
3863
3910
  @s_nexus.Pusher.onPush('model:prop:add')
@@ -4039,6 +4086,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
4039
4086
  await self.fire('core:extmodel:change', name=prop, act='del', type='univ')
4040
4087
  await self.feedBeholder('model:univ:del', {'prop': univname})
4041
4088
 
4089
+ @s_cell.from_leader
4042
4090
  async def addTagProp(self, name, tdef, info):
4043
4091
  if not isinstance(tdef, tuple):
4044
4092
  mesg = 'Tag property type definitions should be a tuple.'
@@ -4051,6 +4099,8 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
4051
4099
  if self.exttagprops.get(name) is not None:
4052
4100
  raise s_exc.DupPropName(name=name)
4053
4101
 
4102
+ self.model.getTypeClone(tdef)
4103
+
4054
4104
  return await self._push('model:tagprop:add', name, tdef, info)
4055
4105
 
4056
4106
  @s_nexus.Pusher.onPush('model:tagprop:add')
@@ -4088,6 +4138,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
4088
4138
  await self.fire('core:tagprop:change', name=name, act='del')
4089
4139
  await self.feedBeholder('model:tagprop:del', {'tagprop': name})
4090
4140
 
4141
+ @s_cell.from_leader
4091
4142
  async def addEdge(self, edge, edgeinfo):
4092
4143
  if not isinstance(edgeinfo, dict):
4093
4144
  mesg = 'Edge info should be a dict.'
@@ -4667,6 +4718,7 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
4667
4718
  s_stormlib_macro,
4668
4719
  s_stormlib_model,
4669
4720
  s_stormlib_pkg,
4721
+ s_stormlib_task,
4670
4722
  s_stormlib_vault,
4671
4723
  ]
4672
4724
 
@@ -4674,9 +4726,6 @@ class Cortex(s_oauth.OAuthMixin, s_cell.Cell): # type: ignore
4674
4726
  for cdef in cmod.stormcmds:
4675
4727
  await self._trySetStormCmd(cdef.get('name'), cdef)
4676
4728
 
4677
- for cdef in s_stormlib_task.stormcmds:
4678
- await self._trySetStormCmd(cdef.get('name'), cdef)
4679
-
4680
4729
  async def _initPureStormCmds(self):
4681
4730
  oldcmds = []
4682
4731
  for name, cdef in self.cmddefs.items():
synapse/datamodel.py CHANGED
@@ -738,7 +738,7 @@ class Model:
738
738
 
739
739
  base = self.types.get(typedef[0])
740
740
  if base is None:
741
- raise s_exc.NoSuchType(name=typedef[0])
741
+ raise s_exc.NoSuchType.init(typedef[0])
742
742
 
743
743
  return base.clone(typedef[1])
744
744
 
synapse/lib/layer.py CHANGED
@@ -127,7 +127,7 @@ class LayerApi(s_cell.CellApi):
127
127
  Scan the full layer and yield artificial nodeedit sets.
128
128
  '''
129
129
 
130
- if not self.allowed(self.liftperm):
130
+ if not await self.allowed(self.liftperm):
131
131
  await self._reqUserAllowed(self.readperm)
132
132
  async for item in self.layr.iterLayerNodeEdits():
133
133
  yield item
@@ -167,14 +167,14 @@ class LayerApi(s_cell.CellApi):
167
167
 
168
168
  Once caught up with storage, yield them in realtime.
169
169
  '''
170
- if not self.allowed(self.liftperm):
170
+ if not await self.allowed(self.liftperm):
171
171
  await self._reqUserAllowed(self.readperm)
172
172
  async for item in self.layr.syncNodeEdits(offs, wait=wait, reverse=reverse):
173
173
  yield item
174
174
  await asyncio.sleep(0)
175
175
 
176
176
  async def syncNodeEdits2(self, offs, wait=True):
177
- if not self.allowed(self.liftperm):
177
+ if not await self.allowed(self.liftperm):
178
178
  await self._reqUserAllowed(self.readperm)
179
179
  async for item in self.layr.syncNodeEdits2(offs, wait=wait):
180
180
  yield item
@@ -184,7 +184,7 @@ class LayerApi(s_cell.CellApi):
184
184
  '''
185
185
  Returns what will be the *next* nodeedit log index.
186
186
  '''
187
- if not self.allowed(self.liftperm):
187
+ if not await self.allowed(self.liftperm):
188
188
  await self._reqUserAllowed(self.readperm)
189
189
  return await self.layr.getEditIndx()
190
190
 
@@ -192,12 +192,12 @@ class LayerApi(s_cell.CellApi):
192
192
  '''
193
193
  Return the total number of (edits, meta) pairs in the layer changelog.
194
194
  '''
195
- if not self.allowed(self.liftperm):
195
+ if not await self.allowed(self.liftperm):
196
196
  await self._reqUserAllowed(self.readperm)
197
197
  return await self.layr.getEditSize()
198
198
 
199
199
  async def getIden(self):
200
- if not self.allowed(self.liftperm):
200
+ if not await self.allowed(self.liftperm):
201
201
  await self._reqUserAllowed(self.readperm)
202
202
  return self.layr.iden
203
203
 
synapse/lib/schemas.py CHANGED
@@ -954,6 +954,7 @@ _reqValidPkgdefSchema = {
954
954
  'items': {'type': 'array',
955
955
  'items': {'type': 'string'}},
956
956
  },
957
+ 'deprecated': {'$ref': '#/definitions/deprecatedItem'},
957
958
  },
958
959
  'additionalProperties': True,
959
960
  'required': ['name', 'storm']
@@ -980,6 +981,7 @@ _reqValidPkgdefSchema = {
980
981
  'type': 'string',
981
982
  'enum': s_msgpack.deepcopy(datamodel_basetypes),
982
983
  },
984
+ 'deprecated': {'$ref': '#/definitions/deprecatedItem'},
983
985
  },
984
986
  }
985
987
  ],
synapse/lib/storm.py CHANGED
@@ -932,6 +932,7 @@ stormcmds = (
932
932
  },
933
933
  {
934
934
  'name': 'ps.list',
935
+ 'deprecated': {'eolvers': 'v3.0.0', 'mesg': 'Use ``task.list`` instead.'},
935
936
  'descr': 'List running tasks in the cortex.',
936
937
  'cmdargs': (
937
938
  ('--verbose', {'default': False, 'action': 'store_true', 'help': 'Enable verbose output.'}),
@@ -958,6 +959,7 @@ stormcmds = (
958
959
  },
959
960
  {
960
961
  'name': 'ps.kill',
962
+ 'deprecated': {'eolvers': 'v3.0.0', 'mesg': 'Use ``task.kill`` instead.'},
961
963
  'descr': 'Kill a running task/query within the cortex.',
962
964
  'cmdargs': (
963
965
  ('iden', {'help': 'Any prefix that matches exactly one valid process iden is accepted.'}),
@@ -1111,6 +1113,16 @@ stormcmds = (
1111
1113
  },
1112
1114
  )
1113
1115
 
1116
+ def deprmesg(name, depritem):
1117
+ if (mesg := depritem.get('mesg')) is not None:
1118
+ return f'"{name}" is deprecated: {mesg}'
1119
+
1120
+ if (eolvers := depritem.get('eolvers')) is not None:
1121
+ return f'"{name}" is deprecated and will be removed in {eolvers}.'
1122
+
1123
+ eoldate = depritem.get('eoldate')
1124
+ return f'"{name}" is deprecated and will be removed on {eoldate}.'
1125
+
1114
1126
  @s_cache.memoize(size=1024)
1115
1127
  def queryhash(text):
1116
1128
  return s_common.queryhash(text)
@@ -1906,6 +1918,7 @@ class Parser:
1906
1918
  self.root = root
1907
1919
  self.exited = False
1908
1920
  self.mesgs = []
1921
+ self.deprs = {}
1909
1922
 
1910
1923
  self.optargs = {}
1911
1924
  self.posargs = []
@@ -1931,7 +1944,7 @@ class Parser:
1931
1944
 
1932
1945
  choices = opts.get('choices')
1933
1946
  if choices is not None and opts.get('action') in ('store_true', 'store_false'):
1934
- mesg = f'Argument choices are not supported when action is store_true or store_false'
1947
+ mesg = 'Argument choices are not supported when action is store_true or store_false'
1935
1948
  raise s_exc.BadArg(mesg=mesg, argtype=str(argtype))
1936
1949
 
1937
1950
  dest = self._get_dest(names)
@@ -1988,6 +2001,9 @@ class Parser:
1988
2001
 
1989
2002
  dest = argdef.get('dest')
1990
2003
 
2004
+ if (deprecated := argdef.get('deprecated')) is not None:
2005
+ self.deprs[item] = deprecated
2006
+
1991
2007
  oact = argdef.get('action', 'store')
1992
2008
  if oact == 'store_true':
1993
2009
  opts[dest] = True
@@ -2177,6 +2193,12 @@ class Parser:
2177
2193
 
2178
2194
  self._printf(f'Usage: {self.prog} [options] {posargs}')
2179
2195
 
2196
+ if self.cdef is not None and (deprecated := self.cdef.get('deprecated')) is not None:
2197
+ dmsg = deprmesg(self.prog, deprecated)
2198
+ self._printf('')
2199
+ self._printf(f'Deprecated: {dmsg}')
2200
+ self._printf('')
2201
+
2180
2202
  if self.cdef is not None and (endpoints := self.cdef.get('endpoints')):
2181
2203
  self._printf('')
2182
2204
  self._printf('Endpoints:')
@@ -2286,6 +2308,10 @@ class Parser:
2286
2308
  wrap_first = self._wrap_text(first, wrap_w)
2287
2309
  self._printf(f'{base:<{base_w-2}}: {wrap_first[0]}')
2288
2310
 
2311
+ if (deprecated := argdef.get('deprecated')) is not None:
2312
+ mesg = deprmesg(names[0], deprecated)
2313
+ self._printf(f'{"":<{base_w-2}} Deprecated: {mesg}')
2314
+
2289
2315
  for ln in wrap_first[1:]: self._printf(f'{"":<{base_w}}{ln}')
2290
2316
  for ln in helplst[1:]:
2291
2317
  lead_s = len(ln) - len(ln.lstrip())
@@ -2401,6 +2427,10 @@ class Cmd:
2401
2427
  except s_exc.BadSyntax: # pragma: no cover
2402
2428
  pass
2403
2429
 
2430
+ for item, depr in self.pars.deprs.items():
2431
+ mesg = deprmesg(item, depr)
2432
+ await self.runt.snap.warnonce(mesg)
2433
+
2404
2434
  for line in self.pars.mesgs:
2405
2435
  await self.runt.snap.printf(line)
2406
2436
 
@@ -2522,6 +2552,10 @@ class PureCmd(Cmd):
2522
2552
  }
2523
2553
  }
2524
2554
 
2555
+ if (deprecated := self.cdef.get('deprecated')) is not None:
2556
+ mesg = deprmesg(name, deprecated)
2557
+ await self.runt.warnonce(mesg)
2558
+
2525
2559
  if self.runtsafe:
2526
2560
  data = {'pathvars': {}}
2527
2561
  async def genx():
@@ -526,14 +526,22 @@ class ImapLib(s_stormtypes.Lib):
526
526
 
527
527
  try:
528
528
  imap = await s_common.wait_for(coro, timeout)
529
- except asyncio.TimeoutError:
529
+ except TimeoutError:
530
530
  raise s_exc.TimeOut(mesg='Timed out waiting for IMAP server hello.') from None
531
531
 
532
532
  async def fini():
533
- async def _logout():
534
- await s_common.wait_for(imap.logout(), 5)
533
+ async def imapfini():
534
+ if imap.isfini:
535
+ return
536
+
537
+ try:
538
+ await s_common.wait_for(imap.logout(), 5)
539
+ except TimeoutError:
540
+ pass # pragma: no cover
541
+
535
542
  await imap.fini()
536
- s_coro.create_task(_logout())
543
+
544
+ self.runt.snap.core.schedCoro(imapfini())
537
545
 
538
546
  self.runt.snap.onfini(fini)
539
547
 
@@ -1,4 +1,3 @@
1
- import asyncio
2
1
  import logging
3
2
 
4
3
  import synapse.exc as s_exc
synapse/lib/stormtypes.py CHANGED
@@ -1910,6 +1910,7 @@ class LibPs(Lib):
1910
1910
  'type': {'type': 'function', '_funcname': '_list',
1911
1911
  'returns': {'type': 'list', 'desc': 'A list of task definitions.', }}},
1912
1912
  )
1913
+ _storm_lib_deprecation = {'eolvers': 'v3.0.0', 'mesg': 'Use the corresponding ``$lib.task`` function.'}
1913
1914
  _storm_lib_path = ('ps',)
1914
1915
 
1915
1916
  def getObjLocals(self):
@@ -2968,7 +2969,13 @@ class LibTime(Lib):
2968
2969
 
2969
2970
  storm> $now=$lib.time.now() $str=$lib.time.format($now, '%A %d, %B %Y') $lib.print($str)
2970
2971
 
2971
- Tuesday 14, July 2020''',
2972
+ Tuesday 14, July 2020
2973
+
2974
+ Format a timestamp into a string using included format string::
2975
+
2976
+ storm> $now=$lib.time.now() $str=$lib.time.format($now, $lib.time.formats.iso8601) $lib.print($str)
2977
+
2978
+ 2025-10-02T09:34:00Z''',
2972
2979
  'type': {'type': 'function', '_funcname': '_format',
2973
2980
  'args': (
2974
2981
  {'name': 'valu', 'type': 'int', 'desc': 'A timestamp in epoch milliseconds.', },
@@ -3103,6 +3110,10 @@ class LibTime(Lib):
3103
3110
  {'name': 'timezone', 'desc': 'A timezone name. See python pytz docs for options.', 'type': 'str'},
3104
3111
  ),
3105
3112
  'returns': {'type': 'list', 'desc': 'An ($ok, $valu) tuple.', }}},
3113
+ {'name': 'formats.iso8601', 'desc': 'ISO8601 time format string in UTC timezone (Z).', 'type': 'str'},
3114
+ {'name': 'formats.iso8601us', 'desc': 'ISO8601 time format string (with microseconds) in UTC timezone (Z).', 'type': 'str'},
3115
+ {'name': 'formats.rfc2822', 'desc': 'RFC 2822 time format string in UT timezone.', 'type': 'str'},
3116
+ {'name': 'formats.synapse', 'desc': 'Synapse time format string.', 'type': 'str'},
3106
3117
  )
3107
3118
  _storm_lib_path = ('time',)
3108
3119
 
@@ -3127,6 +3138,13 @@ class LibTime(Lib):
3127
3138
  'dayofyear': self.dayofyear,
3128
3139
  'dayofmonth': self.dayofmonth,
3129
3140
  'monthofyear': self.monthofyear,
3141
+
3142
+ 'formats': {
3143
+ 'iso8601': '%Y-%m-%dT%H:%M:%SZ',
3144
+ 'iso8601us': '%Y-%m-%dT%H:%M:%S.%fZ',
3145
+ 'rfc2822': '%d %b %Y %H:%M:%S UT',
3146
+ 'synapse': '%Y/%m/%d %H:%M:%S.%f',
3147
+ },
3130
3148
  }
3131
3149
 
3132
3150
  @stormfunc(readonly=True)
synapse/lib/version.py CHANGED
@@ -223,6 +223,6 @@ def reqVersion(valu, reqver,
223
223
  ##############################################################################
224
224
  # The following are touched during the release process by bumpversion.
225
225
  # Do not modify these directly.
226
- version = (2, 223, 0)
226
+ version = (2, 224, 0)
227
227
  verstring = '.'.join([str(x) for x in version])
228
- commit = 'b40e64b75fa2820856ad138b8ad9f8c4b6e9547e'
228
+ commit = '7c6e619bf5fd9c5801891b489b11bbee7fdbebd0'
synapse/models/inet.py CHANGED
@@ -3700,6 +3700,9 @@ class InetModule(s_module.CoreModule):
3700
3700
  )),
3701
3701
  ('inet:service:platform', {}, (
3702
3702
 
3703
+ ('id', ('str', {'strip': True}), {
3704
+ 'doc': 'An ID which identifies the platform.'}),
3705
+
3703
3706
  ('url', ('inet:url', {}), {
3704
3707
  'ex': 'https://twitter.com',
3705
3708
  'alts': ('urls',),
@@ -3708,6 +3711,13 @@ class InetModule(s_module.CoreModule):
3708
3711
  ('urls', ('array', {'type': 'inet:url', 'sorted': True, 'uniq': True}), {
3709
3712
  'doc': 'An array of alternate URLs for the platform.'}),
3710
3713
 
3714
+ ('zone', ('inet:fqdn', {}), {
3715
+ 'alts': ('zones',),
3716
+ 'doc': 'The primary zone for the platform.'}),
3717
+
3718
+ ('zones', ('array', {'type': 'inet:fqdn', 'sorted': True, 'uniq': True}), {
3719
+ 'doc': 'An array of alternate zones for the platform.'}),
3720
+
3711
3721
  ('name', ('str', {'onespace': True, 'lower': True}), {
3712
3722
  'ex': 'twitter',
3713
3723
  'alts': ('names',),
@@ -3722,6 +3732,21 @@ class InetModule(s_module.CoreModule):
3722
3732
  'disp': {'hint': 'text'},
3723
3733
  'doc': 'A description of the service platform.'}),
3724
3734
 
3735
+ ('parent', ('inet:service:platform', {}), {
3736
+ 'doc': 'A parent platform which owns this platform.'}),
3737
+
3738
+ ('status', ('inet:service:object:status', {}), {
3739
+ 'doc': 'The status of the platform.'}),
3740
+
3741
+ ('period', ('ival', {}), {
3742
+ 'doc': 'The period when the platform existed.'}),
3743
+
3744
+ ('creator', ('inet:service:account', {}), {
3745
+ 'doc': 'The service account which created the platform.'}),
3746
+
3747
+ ('remover', ('inet:service:account', {}), {
3748
+ 'doc': 'The service account which removed or decommissioned the platform.'}),
3749
+
3725
3750
  ('provider', ('ou:org', {}), {
3726
3751
  'doc': 'The organization which operates the platform.'}),
3727
3752
 
synapse/models/proj.py CHANGED
@@ -166,6 +166,9 @@ class ProjectModule(s_module.CoreModule):
166
166
  ('created', ('time', {}), {
167
167
  'doc': 'The time the comment was added.'}),
168
168
 
169
+ ('ext:creator', ('ps:contact', {}), {
170
+ 'doc': 'The contact information of the creator from an external system.'}),
171
+
169
172
  ('updated', ('time', {'ismax': True}), {
170
173
  'doc': 'The last time the comment was updated.'}),
171
174
 
synapse/models/risk.py CHANGED
@@ -269,6 +269,9 @@ class RiskModule(s_module.CoreModule):
269
269
 
270
270
  (('risk:outage', 'impacted', None), {
271
271
  'doc': 'The outage event impacted the availability of the target node.'}),
272
+
273
+ (('risk:alert', 'about', None), {
274
+ 'doc': 'The alert is about the target node.'}),
272
275
  ),
273
276
  'forms': (
274
277
 
@@ -800,6 +803,9 @@ class RiskModule(s_module.CoreModule):
800
803
  ('detected', ('time', {}), {
801
804
  'doc': 'The time the alerted condition was detected.'}),
802
805
 
806
+ ('updated', ('time', {}), {
807
+ 'doc': 'The time the alert was most recently modified.'}),
808
+
803
809
  ('vuln', ('risk:vuln', {}), {
804
810
  'doc': 'The optional vulnerability that the alert indicates.'}),
805
811
 
synapse/models/syn.py CHANGED
@@ -365,6 +365,14 @@ class SynModule(s_module.CoreModule):
365
365
  ('nodedata', ('array', {'type': 'syn:nodedata'}), {
366
366
  'deprecated': True,
367
367
  'doc': 'The list of nodedata that may be added by the command.', 'uniq': True, 'sorted': True, 'ro': True}),
368
+ ('deprecated', ('bool', {}), {
369
+ 'doc': 'Set to true if this command is scheduled to be removed.'}),
370
+ ('deprecated:version', ('it:semver', {}), {
371
+ 'doc': 'The Synapse version when this command will be removed.'}),
372
+ ('deprecated:date', ('time', {}), {
373
+ 'doc': 'The date when this command will be removed.'}),
374
+ ('deprecated:mesg', ('str', {}), {
375
+ 'doc': 'Optional description of this deprecation.'}),
368
376
  )),
369
377
  ),
370
378
  }),)
@@ -75,6 +75,10 @@ class CommonTest(s_t_utils.SynTest):
75
75
  self.ne('15c8a3727942fa01e04d6a7a525666a2', s_common.guid(item))
76
76
  self.eq('15c8a3727942fa01e04d6a7a525666a2', s_common.guid(s_common.flatten(item)))
77
77
 
78
+ item = {'foo': 'bar', 'baz': 10, 'gronk': True, 'hehe': ['ha', 'ha'], 'tupl': (1, 'two', 1.23), 'newp': None}
79
+ self.ne('02efa9b7612f371dbb65a596cd303d9a', s_common.guid(item))
80
+ self.eq('02efa9b7612f371dbb65a596cd303d9a', s_common.guid(s_common.flatten(item)))
81
+
78
82
  def test_common_vertup(self):
79
83
  self.eq(s_common.vertup('1.3.30'), (1, 3, 30))
80
84
  self.true(s_common.vertup('30.40.50') > (9, 0))
@@ -6650,6 +6650,57 @@ class CortexBasicTest(s_t_utils.SynTest):
6650
6650
  with self.raises(s_exc.BadPropDef):
6651
6651
  await prox.addTagProp('_blah:blah^blah', ('int', {}), {})
6652
6652
 
6653
+ # Mirrors on newer model versions should not be able to add extended model elements
6654
+ # based on model elements the leader doesn't have
6655
+ async with self.getTestAha() as aha:
6656
+
6657
+ conf = {'aha:provision': await aha.addAhaSvcProv('00.cortex')}
6658
+ core00 = await aha.enter_context(self.getTestCore(conf=conf))
6659
+
6660
+ conf = {'aha:provision': await aha.addAhaSvcProv('01.cortex', {'mirror': 'cortex'})}
6661
+ core01 = await aha.enter_context(self.getTestCore(conf=conf))
6662
+
6663
+ # Add a type directly to the mirror's model to simulate different model version
6664
+ core01.model.addType('_newmodel:type', 'str', {}, {})
6665
+
6666
+ with self.raises(s_exc.NoSuchType):
6667
+ await core01.addType('_test:type', '_newmodel:type', {}, {})
6668
+
6669
+ await core01.sync()
6670
+ self.none(core01.model.type('_test:type'))
6671
+
6672
+ with self.raises(s_exc.NoSuchType):
6673
+ await core01.addUnivProp('_woot', ('_newmodel:type', {}), {})
6674
+
6675
+ await core01.sync()
6676
+ self.none(core01.model.prop('._woot'))
6677
+
6678
+ with self.raises(s_exc.NoSuchType):
6679
+ await core01.addForm('_hehe:haha', '_newmodel:type', {}, {})
6680
+
6681
+ await core01.sync()
6682
+ self.none(core01.model.form('_hehe:haha'))
6683
+
6684
+ with self.raises(s_exc.NoSuchType):
6685
+ await core01.addFormProp('inet:asn', '_newer', ('_newmodel:type', {}), {})
6686
+
6687
+ await core01.sync()
6688
+ self.none(core01.model.prop('inet:asn:_newer'))
6689
+
6690
+ with self.raises(s_exc.NoSuchType):
6691
+ await core01.addTagProp('user', ('_newmodel:type', {}), {})
6692
+
6693
+ await core01.sync()
6694
+ self.none(core01.model.tagprop('user'))
6695
+
6696
+ core01.model.addForm('_newmodel:type', {}, {})
6697
+
6698
+ with self.raises(s_exc.NoSuchForm):
6699
+ await core01.addEdge(('_newmodel:type', '_foo', None), {})
6700
+
6701
+ await core01.sync()
6702
+ self.none(core01.model.edge(('_newmodel:type', '_foo', None)))
6703
+
6653
6704
  async def test_cortex_axon(self):
6654
6705
  async with self.getTestCore() as core:
6655
6706
  # By default, a cortex has a local Axon instance available
@@ -4627,6 +4627,103 @@ class StormTest(s_t_utils.SynTest):
4627
4627
  self.stormIsInPrint('$lib.bytes.hashset`` has been deprecated and will be removed in version v3.0.0', msgs)
4628
4628
  self.stormIsInPrint('Use the corresponding ``$lib.axon`` function.', msgs)
4629
4629
 
4630
+ async def test_storm_cmd_deprecations(self):
4631
+
4632
+ async with self.getTestCore() as core:
4633
+
4634
+ deprpkg = {
4635
+ 'name': 'testdepr',
4636
+ 'version': '0.0.1',
4637
+ 'synapse_version': '>=2.8.0,<3.0.0',
4638
+ 'commands': (
4639
+ {
4640
+ 'name': 'deprmesg',
4641
+ 'descr': 'deprecated command',
4642
+ 'deprecated': {'eolvers': 'v3.0.0', 'mesg': 'Please use something else.'},
4643
+ 'storm': '[ inet:ipv4=1.2.3.4 ]',
4644
+ },
4645
+ {
4646
+ 'name': 'deprnomesg',
4647
+ 'descr': 'deprecated command',
4648
+ 'deprecated': {'eoldate': '2099-01-01'},
4649
+ 'storm': '[ inet:ipv4=1.2.3.4 ]',
4650
+ },
4651
+ {
4652
+ 'name': 'deprargs',
4653
+ 'descr': 'deprecated command',
4654
+ 'storm': '[ inet:ipv4=1.2.3.4 ]',
4655
+ 'cmdargs': (
4656
+ ('--start-time', {
4657
+ 'type': 'time',
4658
+ 'deprecated': {'eolvers': 'v3.0.0', 'mesg': 'Use --period instead.'},
4659
+ }),
4660
+ ('--end-time', {
4661
+ 'type': 'time',
4662
+ 'deprecated': {'eolvers': 'v3.0.0'},
4663
+ }),
4664
+ ('--period', {
4665
+ 'type': 'time',
4666
+ }),
4667
+ ),
4668
+ },
4669
+ ),
4670
+ }
4671
+
4672
+ self.none(await core.addStormPkg(deprpkg))
4673
+
4674
+ # Deprecation message shows up in command help
4675
+ deprmesg = '"deprmesg" is deprecated: Please use something else.'
4676
+ msgs = await core.stormlist('deprmesg -h')
4677
+ self.stormIsInPrint(f'Deprecated: {deprmesg}', msgs)
4678
+ self.stormHasNoWarnErr(msgs)
4679
+
4680
+ # Deprecation message shows up in command execution as warning
4681
+ msgs = await core.stormlist('deprmesg')
4682
+ self.stormIsInWarn(deprmesg, msgs)
4683
+
4684
+ # Deprecation message shows up in command help (with no message specified)
4685
+ deprmesg = '"deprnomesg" is deprecated and will be removed on 2099-01-01.'
4686
+ msgs = await core.stormlist('deprnomesg -h')
4687
+ self.stormIsInPrint(f'Deprecated: {deprmesg}', msgs)
4688
+ self.stormHasNoWarnErr(msgs)
4689
+
4690
+ # Deprecation message shows up in command execution as warning (with no message specified)
4691
+ msgs = await core.stormlist('deprnomesg')
4692
+ self.stormIsInWarn(deprmesg, msgs)
4693
+
4694
+ # Deprecation message shows up in help for command args
4695
+ msgs = await core.stormlist('deprargs -h')
4696
+ self.stormIsInPrint(' Deprecated: "--start-time" is deprecated: Use --period instead.', msgs)
4697
+ self.stormIsInPrint(' Deprecated: "--end-time" is deprecated and will be removed in v3.0.0.', msgs)
4698
+ self.stormHasNoWarnErr(msgs)
4699
+
4700
+ # Deprecation message doesn't show up in command execution when not using deprecated args
4701
+ msgs = await core.stormlist('deprargs')
4702
+ self.stormHasNoWarnErr(msgs)
4703
+
4704
+ # Deprecation message shows up in command execution as warning
4705
+ msgs = await core.stormlist('deprargs --start-time now')
4706
+ self.stormIsInWarn('"--start-time" is deprecated: Use --period instead.', msgs)
4707
+ self.stormNotInWarn('"--end-time" is deprecated and will be removed in v3.0.0.', msgs)
4708
+
4709
+ msgs = await core.stormlist('deprargs --end-time now')
4710
+ self.stormNotInWarn('"--start-time" is deprecated: Use --period instead.', msgs)
4711
+ self.stormIsInWarn('"--end-time" is deprecated and will be removed in v3.0.0.', msgs)
4712
+
4713
+ msgs = await core.stormlist('deprargs --start-time now --end-time now')
4714
+ self.stormIsInWarn('"--start-time" is deprecated: Use --period instead.', msgs)
4715
+ self.stormIsInWarn('"--end-time" is deprecated and will be removed in v3.0.0.', msgs)
4716
+
4717
+ # Deprecation message only appears once per runtime
4718
+ msgs = await core.stormlist('[ inet:ipv4=10.0.0.0/28 ] | deprmesg')
4719
+ self.stormIsInWarn('"deprmesg" is deprecated: Please use something else.', msgs)
4720
+ self.len(1, [m for m in msgs if m[0] == 'warn'])
4721
+
4722
+ msgs = await core.stormlist('[ inet:ipv4=10.0.0.0/28 ] | deprargs --start-time now --end-time now')
4723
+ self.stormIsInWarn('"--start-time" is deprecated: Use --period instead.', msgs)
4724
+ self.stormIsInWarn('"--end-time" is deprecated and will be removed in v3.0.0.', msgs)
4725
+ self.len(2, [m for m in msgs if m[0] == 'warn'])
4726
+
4630
4727
  async def test_liftby_edge(self):
4631
4728
  async with self.getTestCore() as core:
4632
4729
 
@@ -445,6 +445,8 @@ class ImapTest(s_test.SynTest):
445
445
 
446
446
  while not link.isfini:
447
447
  mesg = await link.rx()
448
+ if mesg is None:
449
+ break
448
450
 
449
451
  # Receive commands from client
450
452
  command = mesg.get('command')
@@ -854,6 +856,8 @@ class ImapTest(s_test.SynTest):
854
856
  self.stormIsInErr('Cannot process EXPUNGE command.', mesgs)
855
857
 
856
858
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
859
+ core.onfini(imap)
860
+
857
861
  await imap.login('user01@vertex.link', 'spaces lol')
858
862
  await imap.select('INBOX')
859
863
  self.eq(
@@ -868,6 +872,8 @@ class ImapTest(s_test.SynTest):
868
872
 
869
873
  # Normal response
870
874
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
875
+ core.onfini(imap)
876
+
871
877
  await imap.login(user, 'pass00')
872
878
  await imap.select('INBOX')
873
879
  ret = await imap.uid_fetch('1', '(RFC822 BODY[HEADER])')
@@ -884,6 +890,8 @@ class ImapTest(s_test.SynTest):
884
890
 
885
891
  # Normal response
886
892
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
893
+ core.onfini(imap)
894
+
887
895
  await imap.login(user, 'pass00')
888
896
  self.eq(
889
897
  await imap.logout(),
@@ -897,6 +905,8 @@ class ImapTest(s_test.SynTest):
897
905
 
898
906
  with mock.patch.object(IMAPServer, 'logout', logout_no):
899
907
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
908
+ core.onfini(imap)
909
+
900
910
  await imap.login(user, 'pass00')
901
911
  self.eq(
902
912
  await imap.logout(),
@@ -910,6 +920,8 @@ class ImapTest(s_test.SynTest):
910
920
 
911
921
  with mock.patch.object(IMAPServer, 'logout', logout_nobye):
912
922
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
923
+ core.onfini(imap)
924
+
913
925
  await imap.login(user, 'pass00')
914
926
  self.eq(
915
927
  await imap.logout(),
@@ -932,6 +944,8 @@ class ImapTest(s_test.SynTest):
932
944
 
933
945
  # Check command validation
934
946
  imap = await s_link.connect('127.0.0.1', port, linkcls=s_imap.IMAPClient)
947
+ core.onfini(imap)
948
+
935
949
  with self.raises(s_exc.ImapError) as exc:
936
950
  tag = imap._genTag()
937
951
  await imap._command(tag, 'NEWP')
@@ -3297,6 +3297,18 @@ class StormTypesTest(s_test.SynTest):
3297
3297
  self.false(mesgs[0])
3298
3298
  self.isin('Ambiguous time', mesgs[1]['errinfo']['mesg'])
3299
3299
 
3300
+ valu = await core.callStorm('return($lib.time.format($lib.cast(time, 20251002), $lib.time.formats.iso8601))')
3301
+ self.eq(valu, '2025-10-02T00:00:00Z')
3302
+
3303
+ valu = await core.callStorm('return($lib.time.format($lib.cast(time, 20251002), $lib.time.formats.iso8601us))')
3304
+ self.eq(valu, '2025-10-02T00:00:00.000000Z')
3305
+
3306
+ valu = await core.callStorm('return($lib.time.format($lib.cast(time, 20251002), $lib.time.formats.rfc2822))')
3307
+ self.eq(valu, '02 Oct 2025 00:00:00 UT')
3308
+
3309
+ valu = await core.callStorm('return($lib.time.format($lib.cast(time, 20251002), $lib.time.formats.synapse))')
3310
+ self.eq(valu, '2025/10/02 00:00:00.000000')
3311
+
3300
3312
  async def test_storm_lib_time_ticker(self):
3301
3313
 
3302
3314
  async with self.getTestCore() as core:
@@ -2991,10 +2991,17 @@ class InetModelTest(s_t_utils.SynTest):
2991
2991
 
2992
2992
  q = '''
2993
2993
  [ inet:service:platform=(slack,)
2994
+ :id=foo
2994
2995
  :url="https://slack.com"
2995
2996
  :urls=(https://slacker.com,)
2997
+ :zones=(slack.com, slacker.com)
2996
2998
  :name=Slack
2997
2999
  :names=("slack chat",)
3000
+ :parent={[ inet:service:platform=({"name": "salesforce"}) ]}
3001
+ :status=available
3002
+ :period=(2022, 2023)
3003
+ :creator={[ inet:service:account=({"id": "bar"}) ]}
3004
+ :remover={[ inet:service:account=({"id": "baz"}) ]}
2998
3005
  :provider={ ou:org:name=$provname }
2999
3006
  :provider:name=$provname
3000
3007
  ]
@@ -3002,20 +3009,36 @@ class InetModelTest(s_t_utils.SynTest):
3002
3009
  nodes = await core.nodes(q, opts=opts)
3003
3010
  self.len(1, nodes)
3004
3011
  self.eq(nodes[0].ndef, ('inet:service:platform', s_common.guid(('slack',))))
3012
+ self.eq('foo', nodes[0].get('id'))
3005
3013
  self.eq(nodes[0].get('url'), 'https://slack.com')
3006
3014
  self.eq(nodes[0].get('urls'), ('https://slacker.com',))
3015
+ self.eq(nodes[0].get('zones'), ('slack.com', 'slacker.com'))
3007
3016
  self.eq(nodes[0].get('name'), 'slack')
3008
3017
  self.eq(nodes[0].get('names'), ('slack chat',))
3018
+ self.eq(nodes[0].repr('status'), 'available')
3019
+ self.eq(nodes[0].repr('period'), ('2022/01/01 00:00:00.000', '2023/01/01 00:00:00.000'))
3009
3020
  self.eq(nodes[0].get('provider'), provider.ndef[1])
3010
3021
  self.eq(nodes[0].get('provider:name'), provname.lower())
3011
3022
  platform = nodes[0]
3012
3023
 
3024
+ nodes = await core.nodes('inet:service:platform=(slack,) :parent -> *')
3025
+ self.eq(['salesforce'], [n.get('name') for n in nodes])
3026
+
3027
+ nodes = await core.nodes('inet:service:platform=(slack,) :creator -> *')
3028
+ self.eq(['bar'], [n.get('id') for n in nodes])
3029
+
3030
+ nodes = await core.nodes('inet:service:platform=(slack,) :remover -> *')
3031
+ self.eq(['baz'], [n.get('id') for n in nodes])
3032
+
3013
3033
  nodes = await core.nodes('[ inet:service:platform=({"name": "slack chat"}) ]')
3014
3034
  self.eq(nodes[0].ndef, platform.ndef)
3015
3035
 
3016
3036
  nodes = await core.nodes('[ inet:service:platform=({"url": "https://slacker.com"}) ]')
3017
3037
  self.eq(nodes[0].ndef, platform.ndef)
3018
3038
 
3039
+ nodes = await core.nodes('[ inet:service:platform=({"zone": "slacker.com"}) ]')
3040
+ self.eq(nodes[0].ndef, platform.ndef)
3041
+
3019
3042
  q = '''
3020
3043
  [ inet:service:instance=(vertex, slack)
3021
3044
  :id='T2XK1223Y'
@@ -1,4 +1,5 @@
1
1
  import synapse.exc as s_exc
2
+ import synapse.common as s_common
2
3
  import synapse.tests.utils as s_test
3
4
 
4
5
  class ProjModelTest(s_test.SynTest):
@@ -256,13 +257,14 @@ class ProjModelTest(s_test.SynTest):
256
257
  self.eq('highest', nodes[0].repr('priority'))
257
258
  self.eq(proj, nodes[0].get('project'))
258
259
 
259
- nodes = await core.nodes('proj:comment')
260
+ nodes = await core.nodes('proj:comment [ :ext:creator={[ps:contact=(visi,) :name=visi ]} ]')
260
261
  self.len(1, nodes)
261
262
  self.nn(nodes[0].get('created'))
262
263
  self.nn(nodes[0].get('updated'))
263
264
  self.eq(tick, nodes[0].get('ticket'))
264
265
  self.eq('hithere', nodes[0].get('text'))
265
266
  self.eq(visi.iden, nodes[0].get('creator'))
267
+ self.eq(s_common.guid(('visi',)), nodes[0].get('ext:creator'))
266
268
 
267
269
  self.eq('foo', await core.callStorm('return($lib.projects.get($proj).name)', opts=opts))
268
270
  self.eq('bar', await core.callStorm('return($lib.projects.get($proj).epics.get($epic).name)', opts=opts))
@@ -3,6 +3,7 @@ import logging
3
3
  import synapse.exc as s_exc
4
4
  import synapse.common as s_common
5
5
  import synapse.lib.chop as s_chop
6
+ import synapse.lib.time as s_time
6
7
  import synapse.tests.utils as s_t_utils
7
8
 
8
9
  logger = logging.getLogger(__name__)
@@ -325,6 +326,15 @@ class RiskModelTest(s_t_utils.SynTest):
325
326
  self.len(1, await core.nodes('risk:alert :service:platform -> inet:service:platform'))
326
327
  self.len(1, await core.nodes('risk:alert :service:instance -> inet:service:instance'))
327
328
 
329
+ opts = {'vars': {'ndef': nodes[0].ndef[1]}}
330
+ nodes = await core.nodes('risk:alert=$ndef [ :updated=20251003 ]', opts=opts)
331
+ self.len(1, nodes)
332
+ self.eq(s_time.parse('20251003'), nodes[0].get('updated'))
333
+
334
+ self.len(1, await core.nodes('[ risk:alert=({"name": "bazfaz"}) +(about)> {[ file:bytes=* :name=alert.txt]} ]'))
335
+ self.len(1, fnode := await core.nodes('risk:alert=({"name": "bazfaz"}) -(about)> file:bytes'))
336
+ self.eq(fnode[0].get('name'), 'alert.txt')
337
+
328
338
  nodes = await core.nodes('''[
329
339
  risk:compromise=*
330
340
  :vector=*
@@ -1,8 +1,9 @@
1
1
  import synapse.exc as s_exc
2
2
  import synapse.common as s_common
3
3
  import synapse.cortex as s_cortex
4
- import synapse.datamodel as s_datamodel
5
4
 
5
+ import synapse.lib.time as s_time
6
+ import synapse.lib.version as s_version
6
7
  import synapse.lib.stormsvc as s_stormsvc
7
8
 
8
9
  import synapse.tests.utils as s_t_utils
@@ -42,6 +43,21 @@ class TestService(s_stormsvc.StormSvc):
42
43
  },
43
44
  'storm': '',
44
45
  },
46
+ {
47
+ 'name': 'deprvers',
48
+ 'storm': '',
49
+ 'deprecated': {'eolvers': 'v3.0.0'},
50
+ },
51
+ {
52
+ 'name': 'deprdate',
53
+ 'storm': '',
54
+ 'deprecated': {'eoldate': '2099-01-01'},
55
+ },
56
+ {
57
+ 'name': 'deprmesg',
58
+ 'storm': '',
59
+ 'deprecated': {'eoldate': '2099-01-01', 'mesg': 'Please use ``ohhai``.'},
60
+ },
45
61
  )
46
62
  },
47
63
  )
@@ -683,7 +699,7 @@ class SynModelTest(s_t_utils.SynTest):
683
699
 
684
700
  # check that runt nodes for new commands are created
685
701
  nodes = await core.nodes('syn:cmd +:package')
686
- self.len(2, nodes)
702
+ self.len(5, nodes)
687
703
 
688
704
  self.eq(nodes[0].ndef, ('syn:cmd', 'foobar'))
689
705
  self.eq(nodes[0].get('doc'), 'foobar is a great service')
@@ -692,6 +708,7 @@ class SynModelTest(s_t_utils.SynTest):
692
708
  self.eq(nodes[0].get('nodedata'), (('foo', 'inet:ipv4'), ('bar', 'inet:fqdn')))
693
709
  self.eq(nodes[0].get('package'), 'foo')
694
710
  self.eq(nodes[0].get('svciden'), iden)
711
+ self.none(nodes[0].get('deprecated'))
695
712
 
696
713
  self.eq(nodes[1].ndef, ('syn:cmd', 'ohhai'))
697
714
  self.eq(nodes[1].get('doc'), 'No description')
@@ -700,6 +717,41 @@ class SynModelTest(s_t_utils.SynTest):
700
717
  self.none(nodes[1].get('nodedata'))
701
718
  self.eq(nodes[1].get('package'), 'foo')
702
719
  self.eq(nodes[1].get('svciden'), iden)
720
+ self.none(nodes[1].get('deprecated'))
721
+
722
+ self.eq(nodes[2].ndef, ('syn:cmd', 'deprvers'))
723
+ self.true(nodes[2].get('deprecated'))
724
+ self.eq(nodes[2].get('deprecated:version'), s_version.packVersion(3, 0, 0))
725
+ self.none(nodes[2].get('deprecated:date'))
726
+ self.none(nodes[2].get('deprecated:mesg'))
727
+
728
+ self.eq(nodes[3].ndef, ('syn:cmd', 'deprdate'))
729
+ self.true(nodes[3].get('deprecated'))
730
+ self.none(nodes[3].get('deprecated:version'))
731
+ self.eq(nodes[3].get('deprecated:date'), s_time.parse('2099-01-01'))
732
+ self.none(nodes[3].get('deprecated:mesg'))
733
+
734
+ self.eq(nodes[4].ndef, ('syn:cmd', 'deprmesg'))
735
+ self.true(nodes[4].get('deprecated'))
736
+ self.none(nodes[4].get('deprecated:version'))
737
+ self.eq(nodes[4].get('deprecated:date'), s_time.parse('2099-01-01'))
738
+ self.eq(nodes[4].get('deprecated:mesg'), 'Please use ``ohhai``.')
739
+
740
+ nodes = await core.nodes('syn:cmd:deprecated')
741
+ self.len(5, nodes)
742
+ self.sorteq(['deprvers', 'deprdate', 'deprmesg', 'ps.list', 'ps.kill'], [k.ndef[1] for k in nodes])
743
+
744
+ nodes = await core.nodes('syn:cmd:deprecated:version')
745
+ self.len(3, nodes)
746
+ self.sorteq(['deprvers', 'ps.list', 'ps.kill'], [k.ndef[1] for k in nodes])
747
+
748
+ nodes = await core.nodes('syn:cmd:deprecated:date')
749
+ self.len(2, nodes)
750
+ self.sorteq(['deprdate', 'deprmesg'], [k.ndef[1] for k in nodes])
751
+
752
+ nodes = await core.nodes('syn:cmd:deprecated:mesg')
753
+ self.len(3, nodes)
754
+ self.sorteq(['deprmesg', 'ps.list', 'ps.kill'], [k.ndef[1] for k in nodes])
703
755
 
704
756
  # Pivot from cmds to their forms
705
757
  nodes = await core.nodes('syn:cmd=foobar -> *')
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: synapse
3
- Version: 2.223.0
3
+ Version: 2.224.0
4
4
  Summary: Synapse Intelligence Analysis Framework
5
5
  Author-email: The Vertex Project LLC <root@vertex.link>
6
6
  License-Expression: Apache-2.0
@@ -1,11 +1,11 @@
1
1
  synapse/__init__.py,sha256=R2kOXlF5j-8m6G0JkHuN7rXRPg_tHLmbMxr__94mHQk,1145
2
2
  synapse/axon.py,sha256=HtKPfSDNt3ltOaQC2P_7satXhgdxf7fO2mGAioF78Iw,66029
3
3
  synapse/cells.py,sha256=eNvdglfAoTURVhGOLGcgMXCGpfsIX1a02SQnyiklo3E,308
4
- synapse/common.py,sha256=j8b3lrZ7O-utkjJswSf_kx1nySmKRTCNsk6I8bfNPGA,37880
5
- synapse/cortex.py,sha256=FLJbgqj1vZhoo5dHLnATHogPSgZK8RrRV1BLE7NFO7s,273040
4
+ synapse/common.py,sha256=h2ZPK9xNnKcZ4uOxfGzfr70OnzP3ldZZojM8ZAev7kA,37895
5
+ synapse/cortex.py,sha256=XuInelqcWjR8dF-5NKF4RwlCcDZ1pEz0lFQFOzw1Qtg,274705
6
6
  synapse/cryotank.py,sha256=C747V7mCSmLUMwy3niEPl6_4wuXaYKHJdm5wB-o1MMQ,12202
7
7
  synapse/daemon.py,sha256=CllFBFGcZ8aI5jOmAu-7AQRXExjhojmq4saUE7uFOAQ,17171
8
- synapse/datamodel.py,sha256=Lc8PF4tapY6leXv35M1UZHNQ3nDLxEWbfwS4crGNTV0,40347
8
+ synapse/datamodel.py,sha256=aoxZlYbp4QevIwMC_JkdzFUXq_d302Cy2q6z5_jEqpI,40347
9
9
  synapse/exc.py,sha256=vZlFz9gbK9ZIjye_VhMKpHeGoB1HSdP9POzDx-qXnQo,9971
10
10
  synapse/glob.py,sha256=tb6NPtK6Jp6YES9sB1AQi26HP6f-BcEiHrZz2yEyZ90,3210
11
11
  synapse/mindmeld.py,sha256=TiijGH7wX2zdXIFSBUlN40CPOvYaFlw6Wxi66XZuB_M,26
@@ -119,7 +119,7 @@ synapse/lib/ingest.py,sha256=HNW1xs215c_UXVjKaxjipKBmVL4ujrjmarHBRvLPLkE,40
119
119
  synapse/lib/interval.py,sha256=PqpEhMGG6LD9mJxEms0oQWC-NB01H6gwsmLSc5LrDFk,1175
120
120
  synapse/lib/json.py,sha256=s5ULBdrpQ5lMy7DIUFvqwukEkrG8taH1kzHx7sxCE8s,8268
121
121
  synapse/lib/jsonstor.py,sha256=GAzIEqYszPkInIOHTfjPQbhXU1vo6GDNfalyNSgdaLo,19595
122
- synapse/lib/layer.py,sha256=Xk5NObx8I7ynWjlMn235XZ1Znt6RzeVtLh2cvkkwxRo,160457
122
+ synapse/lib/layer.py,sha256=HAG_TbTTpqO8CAwzfLXGE99k80enDLJOJSPZSyVjC54,160493
123
123
  synapse/lib/link.py,sha256=qv1NK1TguHiqOlOHSsqVamhRn-WdQY1vc1gorMsLhmo,10657
124
124
  synapse/lib/lmdbslab.py,sha256=PcOUL1FeC5464MwYMWd9GbGv-xksfVu-KPgr9-QtO9M,61069
125
125
  synapse/lib/modelrev.py,sha256=bSBKjKjOeXJ2ZZYa0w4KSFLOz3J_HxBCww1l0_5DoRg,72568
@@ -136,7 +136,7 @@ synapse/lib/queue.py,sha256=omMtqD4HWg2mLOhhtIe4pA_evz234lJ9uhlAhC_xbW4,3879
136
136
  synapse/lib/ratelimit.py,sha256=BIeFPZb9Bk5GFIVvhM43Uw1s0abY6z7NgTuBorVajz4,1124
137
137
  synapse/lib/reflect.py,sha256=j7Y522UzAwNswUehyfi9kHFNkTxuHXsFuEKY4ATXWTQ,2783
138
138
  synapse/lib/rstorm.py,sha256=VgxWBpTmOSYPEsgpB-zFVaDOrGH3otiq70aYVjn-to8,22608
139
- synapse/lib/schemas.py,sha256=gn2XoiWZVbR2HmeZYGlhAflAc5d0SgBrBXYXKnyIDuI,42301
139
+ synapse/lib/schemas.py,sha256=xWSuZXio5F6i7A95yQAScj1D-QNZlbtmDU0jOYAhibg,42453
140
140
  synapse/lib/scope.py,sha256=0CuSXLG_7pNleC1BcJ8_WbA50DswrX4DNjW5MyGGGNo,5496
141
141
  synapse/lib/scrape.py,sha256=ppUUkobkITN7n2gFov0nfzV3sVKpyPNrZKPtt1zwjjU,23979
142
142
  synapse/lib/share.py,sha256=wE0WE77QxJTbfcZmVLn_9hHbXMsptj6e2I4KbTho9_Q,605
@@ -144,12 +144,12 @@ synapse/lib/slaboffs.py,sha256=Fd0RrIRBMjh159aQz5y1ONmzw0NvV040kVX_jZjQW6I,815
144
144
  synapse/lib/slabseqn.py,sha256=LJ2SZEsZlROBAD3mdS-3JxNVVPXXkBW8GIJXsW0OGG8,10287
145
145
  synapse/lib/snap.py,sha256=3yG69MYqbju8eROoW65cAlwt-ksL7FYPN9ezxp-UL3o,64871
146
146
  synapse/lib/spooled.py,sha256=BQHIW-qZvEcvhEf8PpXhbDDGzq1go4TH63D6kn-1anM,6021
147
- synapse/lib/storm.py,sha256=nvRTc3HdBCjz1pCundWPKjOsbg5-IxBGz6BjKNLdoM8,199503
147
+ synapse/lib/storm.py,sha256=PUHQ8XgZ8sUhhAMkDNqqRBl44yk61bEPgE5qTeBmgnc,200914
148
148
  synapse/lib/storm_format.py,sha256=9cE8WNPYTcqgRakIqkmIQzOr16Hqbj_sM1QabHug3i0,4908
149
149
  synapse/lib/stormctrl.py,sha256=3UC2LOHClC17JwYNuo8NeyntuAvIXphjenXEzVP33mY,2523
150
150
  synapse/lib/stormhttp.py,sha256=hy87c76CqMqplv9gLB5_P032uvZ2Cggp4IC27QzhRjY,28907
151
151
  synapse/lib/stormsvc.py,sha256=FURIsQUVNJmY8Z5TmhTF1O__DGXPiVg5pUiOoPM8r3g,7573
152
- synapse/lib/stormtypes.py,sha256=INiTDl7ufPIEXJB-NI_d7lj1A1nxLRAlWx_gLbcuV4M,411124
152
+ synapse/lib/stormtypes.py,sha256=eAUuHxnWzy75V5KLmo-39J7O5RBiPWWsgrwy9qPLwaE,412164
153
153
  synapse/lib/stormwhois.py,sha256=w7N2oCyMljNvi_sRt_bZb5BJwWwYkVGcRd7H_0oHY8Q,2554
154
154
  synapse/lib/structlog.py,sha256=v5MK5jtJIRSF-E4y4fQuzEVKmbocu8ByFLDTY8Ybjpk,1336
155
155
  synapse/lib/task.py,sha256=LVVM7Yr0VPUihIH6N_CrMHm3GHZR3bu-dw05SkG8zFE,6267
@@ -160,7 +160,7 @@ synapse/lib/time.py,sha256=bk_1F6_MDuCWJ1ToPJ-XHkeTWVw5b4SE7cCixBqVxXo,9435
160
160
  synapse/lib/trigger.py,sha256=jxNZRcCw5OLpugyQOo64vIigisTDzDk7feWEfazBMwk,20985
161
161
  synapse/lib/types.py,sha256=0ILS8netSELraSJu1YfPyQf3P-bVbevYkVzSC-WigsU,70917
162
162
  synapse/lib/urlhelp.py,sha256=ljhnF91z9ihyOLdZZ6OoQYCN1WYjOj1imukD45xiKU0,3320
163
- synapse/lib/version.py,sha256=GkkDQFutyUFrnF9F78bPbloDpjcFOaYmomGYIJt-Elk,7162
163
+ synapse/lib/version.py,sha256=FI-I1ZjM6YCtzmQQkGHNc5w-1m0oTXPuUIYVGv2uDD4,7162
164
164
  synapse/lib/view.py,sha256=yzN5MKN9A4NMeVrB_ZSIIFAoVygNXni27F2S4-QhTZQ,63301
165
165
  synapse/lib/crypto/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
166
166
  synapse/lib/crypto/coin.py,sha256=_dhlkzIrHT8BvHdJOWK7PDThz3sK3dDRnWAUqjRpZJc,4910
@@ -191,7 +191,7 @@ synapse/lib/stormlib/gis.py,sha256=LUsFcPn0g3Y23lMDpKveegT2SwoOSAwkgmifpXpm23c,1
191
191
  synapse/lib/stormlib/graph.py,sha256=6ZDZlpV-OznhK2jTRiMBAYN2qrOIG6ZQWvRCDrrnnWw,7699
192
192
  synapse/lib/stormlib/hashes.py,sha256=h0gtVLiC70FZboJH8gPSR9G53i8-T6WNCFjVfXAH4ig,4751
193
193
  synapse/lib/stormlib/hex.py,sha256=6sGOvkCFwvpOngF4sfeDpXm0-ujnw2Hc8BMMe2ZpUOI,5855
194
- synapse/lib/stormlib/imap.py,sha256=C7X7J-uz6EjEdq3SSsVS2T-2qxR4hwsW-i5W2ZSQutQ,27089
194
+ synapse/lib/stormlib/imap.py,sha256=MJyDg7oxYrY_aTc2Le0syIpf4mfr6tEw1E2SF66fXsw,27262
195
195
  synapse/lib/stormlib/index.py,sha256=f92Yn3nhojFhxbp7SUu9T-lRTGw-_miazfwMqG7QO14,1514
196
196
  synapse/lib/stormlib/infosec.py,sha256=QBIaXVFgly8-DeNpTft0h-BMhCJemhQ_q-61vKjb0OA,30376
197
197
  synapse/lib/stormlib/ipv6.py,sha256=Ik50Hpd6T-XCc7gVzJqmYqGQF8jfIwFIQvNCDPCMtLs,1557
@@ -216,7 +216,7 @@ synapse/lib/stormlib/stats.py,sha256=aRm-kf5ZKp0_czKiujtH8quO6XuxrIRsHjMfPlCRc-o
216
216
  synapse/lib/stormlib/stix.py,sha256=ZSIb2U1PmjmkbPJE1zUhyk2TZGPIEZtm9khMKu07898,53550
217
217
  synapse/lib/stormlib/storm.py,sha256=dnPwH6p3DaOaKXfagqu-9szqr1wNzmCySDyzGJ77n74,6246
218
218
  synapse/lib/stormlib/tabular.py,sha256=jZ-BvzwQONmDL5hvZoxZNBhdz8KPCiZv_pS8kTYyiKg,7374
219
- synapse/lib/stormlib/task.py,sha256=B_SrNTT7iixBd0fjJc6FpniabFSIUfP8AksJ5JAd5PE,4394
219
+ synapse/lib/stormlib/task.py,sha256=4VzDadM4Z6AWPRB9wh2Y9ZnngVQwMOzxJT1WRJc5MzI,4379
220
220
  synapse/lib/stormlib/utils.py,sha256=ju3_RqnzpSUI5beCJCVG1ZBxLrBm1OIU6OEVCbD3XxU,1991
221
221
  synapse/lib/stormlib/vault.py,sha256=MjFxmsDnQqL2uWDTdjNdlm1xwfbA8Vzqdp7Lxti5-V0,30586
222
222
  synapse/lib/stormlib/version.py,sha256=FHWLsU6qy--iFfuN_2ZFDpwFzkqKL4b3ESLZ9ByUXak,2431
@@ -243,7 +243,7 @@ synapse/models/entity.py,sha256=loHKByGwv2xyz6cYWWUpwk12mxWNzC06BKgDgWfX6ek,1617
243
243
  synapse/models/files.py,sha256=H_149eOWirYEPvFxDjhxQkc4VInocifcjQMmjGvtR3U,34444
244
244
  synapse/models/geopol.py,sha256=1DGxLJ60QlnSIe3WxxViYQ3KFSwm89vvGc534bbSNBo,11304
245
245
  synapse/models/geospace.py,sha256=Ix54xGdGRZNqLI0r6r9OA1t6vqB3XM1lkoy86Vjt5XA,21155
246
- synapse/models/inet.py,sha256=ufjSaLjBYHkkM_F6oUN4w1x1u1FzJdh9D3Tt_odyLLs,181816
246
+ synapse/models/inet.py,sha256=bCKYzMQVw5jGzytO_sbrwoxhKSD7uHp0ZnUK3bph-Oo,183075
247
247
  synapse/models/infotech.py,sha256=IfxcD3Ap9W4jrBGkI55kej6UOdnTE2ZL3dH4R9f3MbI,155406
248
248
  synapse/models/language.py,sha256=hBVVIf5kc_FSIV7HZhWnberoc9ssxuqeff4fqC9iz4o,3640
249
249
  synapse/models/material.py,sha256=UvmnBEkbhBbdbnvWtTlgGJAJlKDrx9E-YSQ3K49ws5M,5405
@@ -252,10 +252,10 @@ synapse/models/media.py,sha256=wdXNzLrHb4YYRZ3NlGombNwZsphwfH20oZQQ9ICq7ZQ,3604
252
252
  synapse/models/orgs.py,sha256=leQKO9NP3bl2-iikScd62kYiehAWqGVaKqwPgOVD4qE,71755
253
253
  synapse/models/person.py,sha256=HiZy_zT0Q1AoeXbpogEJWuJe436bOo_Ai4kkmA9c2ZU,28568
254
254
  synapse/models/planning.py,sha256=vmrY4d3WRxizrNU1YBe36NGZTuuu4lhGS8KI5lCZ5yQ,7302
255
- synapse/models/proj.py,sha256=vl-2uZouiWSey8t4lTNA4BxUKhX94rqm3SuLrodQUP8,9904
256
- synapse/models/risk.py,sha256=7b7VUeWWKjJl3VfHhfv3tnu2FTlGMEKhZfo7LBPOta4,58269
255
+ synapse/models/proj.py,sha256=ISMnL9ppme36Ymxe1FbfD4WxmAW5AXpe0697xUPEni8,10071
256
+ synapse/models/risk.py,sha256=nwIRQbAZYbi6Xh6Y9PaTgJ2hiGqa4wgQBUCoQudMb8k,58520
257
257
  synapse/models/science.py,sha256=oSkKbjmVncYcVkVgx8rhM08XtcsgDgjf3mpunz5kL30,4329
258
- synapse/models/syn.py,sha256=u6-EB_2nMCD2LEo3Ir5Iduay2JBl2a2TF1TE26jmr1c,14789
258
+ synapse/models/syn.py,sha256=tH9Rf99pNCdY0NM4_H5QR2O3XQOuhIL9e5L2nbK8jM0,15356
259
259
  synapse/models/telco.py,sha256=h6fx2ScjniS1Gvtcz3-n989SPcH6bavRDnDatL0dH1w,16530
260
260
  synapse/models/transport.py,sha256=GVyytNyhp6sB28x1x0bUBETaOXpWyR_JawVvMTlmz5M,29757
261
261
  synapse/models/gov/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -276,8 +276,8 @@ synapse/tests/test_axon.py,sha256=aBjvNB4M0jqDHJ7zHNgsp8V-CpJuSpHyrGnRk1RcKDQ,50
276
276
  synapse/tests/test_cmds_boss.py,sha256=SdBwM2qJHFzzfrjWYiZOLBKeye8uru7KeJ3NU_YSkWw,4718
277
277
  synapse/tests/test_cmds_cortex.py,sha256=hVe4xxp14vFHbJywnWxFLkDvbxyc_XHBcP6HOUA85Ag,17187
278
278
  synapse/tests/test_cmds_hive.py,sha256=YospZkpYj3kjSFxpY_BwSbWLSU200AX1uYJzgi_wtb4,5904
279
- synapse/tests/test_common.py,sha256=h9qBJmIc0EA70OIFVsBEGL8mZ4M7IkEBdWbhBNxGzMQ,17093
280
- synapse/tests/test_cortex.py,sha256=axk_Pm_-AQObP52fZisx77AZO2W12CQz8U544sSGxG0,381559
279
+ synapse/tests/test_common.py,sha256=viVCDLV7PbyFSNDzc-9kYJzkfYzia03SFrnkcn2aBBk,17376
280
+ synapse/tests/test_cortex.py,sha256=1CSQmBStuECkAK8YCKQBk84QgAv7-O78ESCgdkMBcV8,383610
281
281
  synapse/tests/test_cryotank.py,sha256=ms2VkL0aUskMi-LArTzRt8LUYw0z_y8nQfOOBDiCkvI,12027
282
282
  synapse/tests/test_daemon.py,sha256=uwb3dK8Xx-49EAjxKCjLY0nXZwiE-GNKmc5spzxV5z0,7729
283
283
  synapse/tests/test_data.py,sha256=f8L-q6kpMq8XPG3hq1jwlyaFRQEinSBf7ZlsRFeCuoM,196
@@ -338,7 +338,7 @@ synapse/tests/test_lib_slaboffs.py,sha256=FHQ8mGZ27dGqVwGk6q2UJ4gkPRZN22eIVzS8hM
338
338
  synapse/tests/test_lib_slabseqn.py,sha256=74V6jU7DRTsy_hqUFDuT4C6dPlJ6ObNnjmI9qhbbyVc,5230
339
339
  synapse/tests/test_lib_snap.py,sha256=OviJtj9N5LhBV-56TySkWvRly7f8VH9d-VBcNFLAtmg,27805
340
340
  synapse/tests/test_lib_spooled.py,sha256=Ki9UnzTPUtw7devwN_M0a8uwOst81fGQtGSVqSSh1u8,4002
341
- synapse/tests/test_lib_storm.py,sha256=CBN4Tg-MiNAP-NfjxEsGOpjm-iZHvDv8981CnK5sjOI,257092
341
+ synapse/tests/test_lib_storm.py,sha256=YmF3sJTKHckZ3agh-ZI2EWgEbQ6v37z33zDQWZTFCfM,261972
342
342
  synapse/tests/test_lib_storm_format.py,sha256=tEZgQMmKAeG8FQZE5HUjOT7bnKawVTpNaVQh_3Wa630,277
343
343
  synapse/tests/test_lib_stormctrl.py,sha256=1vY7PGjgmz3AibgSiGcp_G4NSYl9YNifWdjPB0CDf1g,2877
344
344
  synapse/tests/test_lib_stormhttp.py,sha256=rhZ9xLTIzLm4GlJUFDieFqAcrhE0EFTDi2erGltPm0I,46056
@@ -357,7 +357,7 @@ synapse/tests/test_lib_stormlib_gen.py,sha256=Hb0GHe3jr7IYb6bYnDKqAc4-ZgRIjYEcT2
357
357
  synapse/tests/test_lib_stormlib_gis.py,sha256=uG1QQ0wqO-0tSzCnQZv1Ex_NbnabKEbZTlXcpCm8snE,767
358
358
  synapse/tests/test_lib_stormlib_hashes.py,sha256=rgty98QcyuOCXH699V7Vd3q7cFNa5I9HSJ5WeBajZB4,6015
359
359
  synapse/tests/test_lib_stormlib_hex.py,sha256=TqYZYQR6GxV4k5uYTVMCLYIUJiio_SoB1WZB6fYzHB4,3701
360
- synapse/tests/test_lib_stormlib_imap.py,sha256=4WCJ5JFKi1gi5PESec3gP_rPmMjPDUGdpCMXIFbTotg,48905
360
+ synapse/tests/test_lib_stormlib_imap.py,sha256=bMg_DOGNBsNZiHEt4oR-d0vjr9H6o8HAoaDbV-IkT8c,49150
361
361
  synapse/tests/test_lib_stormlib_index.py,sha256=qz2pIJ1oZAyN3IEpIqYewiB4FVvKSfVLz27K24iAa_k,1672
362
362
  synapse/tests/test_lib_stormlib_infosec.py,sha256=uDaJ5WjTsujvALShSf-RDAOP4HhuddQcXfANTyIJkp4,27375
363
363
  synapse/tests/test_lib_stormlib_ipv6.py,sha256=sJDIM4lKayYct2qAGjRwgadmxzgegzSn8I3UxNRFF4M,877
@@ -385,7 +385,7 @@ synapse/tests/test_lib_stormlib_vault.py,sha256=pE_nDisXiyb-4Zm1hOrfsuEz3bjYwR8c
385
385
  synapse/tests/test_lib_stormlib_xml.py,sha256=asF-Y1LVpLoqHRK71_LWy727XJvsTNpf8qRSK-CynMM,3659
386
386
  synapse/tests/test_lib_stormlib_yaml.py,sha256=egTVXk8wW31V2msF__9WxP3THcqfysG1mYhc7hQG8rw,1358
387
387
  synapse/tests/test_lib_stormsvc.py,sha256=XeUQo6GzIdwV3EZJv8lU3sR4MpJY3iY90fahb9zsfa4,43972
388
- synapse/tests/test_lib_stormtypes.py,sha256=w-Vn3ujIApFQq_eivWpgIyoRbWr4R9m2wYQN9g-Bcyg,347751
388
+ synapse/tests/test_lib_stormtypes.py,sha256=W9WyJ1fmMJUQnAFZIJiXEyk_wNrJ4SOzwtbwSEd3zvo,348461
389
389
  synapse/tests/test_lib_stormwhois.py,sha256=AWMUYEgZ5yqvDfPC_rM4evmhgfOA_Fv5aoTjmKmN1_0,4818
390
390
  synapse/tests/test_lib_structlog.py,sha256=BxglFqOsJFPE2RsZ8dQyTBCEe1frQrHWWXmUBO2fPJs,3898
391
391
  synapse/tests/test_lib_task.py,sha256=UQi14LdQ0rxDRCSy4TAxyq2OXDOXPQqnvp-nCK_aoBE,2454
@@ -414,7 +414,7 @@ synapse/tests/test_model_geospace.py,sha256=8ATsx662mrcKzurMpQGbshnQPYOWqO7wxOWp
414
414
  synapse/tests/test_model_gov_cn.py,sha256=FnfKNM_wnvmScLm4cYFSQXZ21kVaTPPDusiCD79awBA,675
415
415
  synapse/tests/test_model_gov_intl.py,sha256=mHYK056C2R0aDH-5-TnUxtH0ZlKnEOoSd9ODIMasmow,780
416
416
  synapse/tests/test_model_gov_us.py,sha256=kvZ9DudBrbKtZmqGm8X-b_IOw4oJ7XZMnvTgiDkzsrY,1525
417
- synapse/tests/test_model_inet.py,sha256=Vgy1BjDMl1CS3lRUooVWzdsG6mdhuVkdTMKHShnRKtI,160850
417
+ synapse/tests/test_model_inet.py,sha256=7a4bCbx3v8aStZB6NFLnJpciBPnucBNuFFwVPnWujSw,162071
418
418
  synapse/tests/test_model_infotech.py,sha256=Haf6au6ZX97cZF5x4fm5c5vbQDuloWRHkTvVYu-CPJ8,115679
419
419
  synapse/tests/test_model_language.py,sha256=49stF1B8_EwWJB67Xa5VXCG563Zfbr6S85iKN9Iom48,3046
420
420
  synapse/tests/test_model_material.py,sha256=Hkd8BJh6FdQE0RuFMV2NO6fGqw9kOCb5AeIuTYtwCEM,2723
@@ -423,10 +423,10 @@ synapse/tests/test_model_media.py,sha256=OhMb3OwmZ7hXfoQYGeUBlnsqIk0sAohSodCLML2
423
423
  synapse/tests/test_model_orgs.py,sha256=YuKmjO7c6kzrydEwiVtmEdpZpSVlPfN_aCx_yqbKXDE,47881
424
424
  synapse/tests/test_model_person.py,sha256=CKfOtp7iCPAHQEfjlduDxPXLbFbi2LdVqExRyVwoxAc,19170
425
425
  synapse/tests/test_model_planning.py,sha256=U2kkE0uBO6CqtTfy7wlnhEIu_NFdSri4I_I5b-mRjBE,5615
426
- synapse/tests/test_model_proj.py,sha256=hCuM-CTyCAvqVPy7klP6NXOEtgJ61OyyT0x8mcJsjns,23238
427
- synapse/tests/test_model_risk.py,sha256=t2IVWF8h1Kj7hERUZR_wqMikFJl63m9yz_ZYB60z1O4,31543
426
+ synapse/tests/test_model_proj.py,sha256=BYqM7p9_NEoiPk39R2irjIVn4HSfUvcbNvka25saVPk,23399
427
+ synapse/tests/test_model_risk.py,sha256=tqvwXVHKuhNHJmkYJ6c7EqmWyXrFGRn07qjEHcE_vBg,32114
428
428
  synapse/tests/test_model_science.py,sha256=2T9VxdzpltDufgjkUB95q97TQP9AxH2-T_sBbHfPDRk,2450
429
- synapse/tests/test_model_syn.py,sha256=Air11lZMj6D6A5BDOMQV5mjcI873gNyUmfK5WMua5Cg,31900
429
+ synapse/tests/test_model_syn.py,sha256=rrcKwhxwGuYRDc7EmyvbhUcL0wrcFRKyZH1yg_-kp0M,34382
430
430
  synapse/tests/test_model_telco.py,sha256=34PpU2-gxk8jT9EuTKcFbYgBw4q6kUDtdZUgMsn7jHg,13455
431
431
  synapse/tests/test_model_transport.py,sha256=kAR16Uc6szPZj3AN_sIjaHf3O0st_oV9bXixfF1QRGk,16308
432
432
  synapse/tests/test_servers_axon.py,sha256=x7NT6F32yuqP1RNwz1kUHWKg-zewL3Zt3N5a-kMbBG8,1098
@@ -649,8 +649,8 @@ synapse/vendor/xrpl/tests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJW
649
649
  synapse/vendor/xrpl/tests/test_codec.py,sha256=Zwq6A5uZUK_FWDL3BA932c5b-rL3hnC6efobWHSLC4o,6651
650
650
  synapse/vendor/xrpl/tests/test_main.py,sha256=kZQwWk7I6HrP-PMvLdsUUN4POvWD9I-iXDHOwdeF090,4299
651
651
  synapse/vendor/xrpl/tests/test_main_test_cases.py,sha256=vTlUM4hJD2Hd2wCIdd9rfsvcMZZZQmNHWdCTTFeGz2Y,4221
652
- synapse-2.223.0.dist-info/licenses/LICENSE,sha256=xllut76FgcGL5zbIRvuRc7aezPbvlMUTWJPsVr2Sugg,11358
653
- synapse-2.223.0.dist-info/METADATA,sha256=nPPIqal-uRmuXAIFsfR9UtlJ7FZUxWkxqLVbmIHhh24,4583
654
- synapse-2.223.0.dist-info/WHEEL,sha256=cRWFNt_CJSuf6BnJKAdKunDXUJxjAbWvbt_kstDCs1I,93
655
- synapse-2.223.0.dist-info/top_level.txt,sha256=v_1YsqjmoSCzCKs7oIhzTNmWtSYoORiBMv1TJkOhx8A,8
656
- synapse-2.223.0.dist-info/RECORD,,
652
+ synapse-2.224.0.dist-info/licenses/LICENSE,sha256=xllut76FgcGL5zbIRvuRc7aezPbvlMUTWJPsVr2Sugg,11358
653
+ synapse-2.224.0.dist-info/METADATA,sha256=ecnwoeHtVokG3Uwrs2Y5a2dLj6UzisHEV6bHLz9YyA8,4583
654
+ synapse-2.224.0.dist-info/WHEEL,sha256=cRWFNt_CJSuf6BnJKAdKunDXUJxjAbWvbt_kstDCs1I,93
655
+ synapse-2.224.0.dist-info/top_level.txt,sha256=v_1YsqjmoSCzCKs7oIhzTNmWtSYoORiBMv1TJkOhx8A,8
656
+ synapse-2.224.0.dist-info/RECORD,,