synapse package
The synapse intelligence analysis framework.
Subpackages
- synapse.cmds package
- synapse.data package
- synapse.lib package
- Subpackages
- synapse.lib.crypto package
- synapse.lib.platforms package
- synapse.lib.stormlib package
- Submodules
- synapse.lib.stormlib.aha module
- synapse.lib.stormlib.auth module
- synapse.lib.stormlib.backup module
- synapse.lib.stormlib.basex module
- synapse.lib.stormlib.cache module
- synapse.lib.stormlib.cell module
- synapse.lib.stormlib.compression module
- synapse.lib.stormlib.cortex module
- synapse.lib.stormlib.easyperm module
- synapse.lib.stormlib.env module
- synapse.lib.stormlib.ethereum module
- synapse.lib.stormlib.gen module
- synapse.lib.stormlib.gis module
- synapse.lib.stormlib.graph module
- synapse.lib.stormlib.hashes module
- synapse.lib.stormlib.hex module
- synapse.lib.stormlib.imap module
- synapse.lib.stormlib.infosec module
- synapse.lib.stormlib.ipv6 module
- synapse.lib.stormlib.iters module
- synapse.lib.stormlib.json module
- synapse.lib.stormlib.log module
- synapse.lib.stormlib.macro module
- synapse.lib.stormlib.math module
- synapse.lib.stormlib.mime module
- synapse.lib.stormlib.model module
- synapse.lib.stormlib.modelext module
- synapse.lib.stormlib.notifications module
- synapse.lib.stormlib.oauth module
- synapse.lib.stormlib.pack module
- synapse.lib.stormlib.project module
- synapse.lib.stormlib.random module
- synapse.lib.stormlib.scrape module
- synapse.lib.stormlib.smtp module
- synapse.lib.stormlib.spooled module
- synapse.lib.stormlib.stats module
- synapse.lib.stormlib.stix module
- synapse.lib.stormlib.storm module
- synapse.lib.stormlib.tabular module
- synapse.lib.stormlib.vault module
- synapse.lib.stormlib.version module
- synapse.lib.stormlib.xml module
- synapse.lib.stormlib.yaml module
- Submodules
- synapse.lib.agenda module
- synapse.lib.aha module
AhaApi
AhaApi.addAhaClone()
AhaApi.addAhaPool()
AhaApi.addAhaPoolSvc()
AhaApi.addAhaServer()
AhaApi.addAhaSvc()
AhaApi.addAhaSvcProv()
AhaApi.addAhaUserEnroll()
AhaApi.clearAhaClones()
AhaApi.clearAhaSvcProvs()
AhaApi.clearAhaUserEnrolls()
AhaApi.delAhaPool()
AhaApi.delAhaPoolSvc()
AhaApi.delAhaServer()
AhaApi.delAhaSvc()
AhaApi.delAhaSvcProv()
AhaApi.delAhaUserEnroll()
AhaApi.genCaCert()
AhaApi.getAhaPool()
AhaApi.getAhaPools()
AhaApi.getAhaServer()
AhaApi.getAhaServers()
AhaApi.getAhaSvc()
AhaApi.getAhaSvcMirrors()
AhaApi.getAhaSvcs()
AhaApi.getAhaUrls()
AhaApi.getCaCert()
AhaApi.iterPoolTopo()
AhaApi.modAhaSvcInfo()
AhaApi.signHostCsr()
AhaApi.signUserCsr()
AhaCell
AhaCell.addAhaClone()
AhaCell.addAhaPool()
AhaCell.addAhaPoolSvc()
AhaCell.addAhaServer()
AhaCell.addAhaSvc()
AhaCell.addAhaSvcProv()
AhaCell.addAhaUserEnroll()
AhaCell.cellapi
AhaCell.clearAhaClones()
AhaCell.clearAhaSvcProvs()
AhaCell.clearAhaUserEnrolls()
AhaCell.confbase
AhaCell.confdefs
AhaCell.delAhaPool()
AhaCell.delAhaPoolSvc()
AhaCell.delAhaServer()
AhaCell.delAhaSvc()
AhaCell.delAhaSvcProv()
AhaCell.delAhaUserEnroll()
AhaCell.genCaCert()
AhaCell.getAhaClone()
AhaCell.getAhaPool()
AhaCell.getAhaPools()
AhaCell.getAhaServer()
AhaCell.getAhaServers()
AhaCell.getAhaSvc()
AhaCell.getAhaSvcMirrors()
AhaCell.getAhaSvcProv()
AhaCell.getAhaSvcs()
AhaCell.getAhaUrls()
AhaCell.getAhaUserEnroll()
AhaCell.getCaCert()
AhaCell.getEnvPrefix()
AhaCell.getMyUrl()
AhaCell.initServiceNetwork()
AhaCell.initServiceRuntime()
AhaCell.initServiceStorage()
AhaCell.iterPoolTopo()
AhaCell.modAhaSvcInfo()
AhaCell.saveCaCert()
AhaCell.saveHostCert()
AhaCell.saveUserCert()
AhaCell.setAhaSvcDown()
AhaCell.signHostCsr()
AhaCell.signUserCsr()
AhaProvisionServiceV1
AhaServicesV1
CloneApi
EnrollApi
ProvApi
ProvDmon
- synapse.lib.ast module
AbsPropCond
AndCond
ArgvQuery
ArrayCond
AstNode
AstNode.addExcInfo()
AstNode.addKid()
AstNode.format()
AstNode.getAstText()
AstNode.getPosInfo()
AstNode.getRuntVars()
AstNode.hasAstClass()
AstNode.hasVarName()
AstNode.init()
AstNode.isRuntSafe()
AstNode.isRuntSafeAtom()
AstNode.iterright()
AstNode.optimize()
AstNode.prepare()
AstNode.repr()
AstNode.reqNotReadOnly()
AstNode.reqRuntSafe()
AstNode.runtopaque
AstNode.sibling()
AstNode.validate()
Bool
BreakOper
CallArgs
CallKwarg
CallKwargs
CaseEntry
CatchBlock
CmdOper
Cmpr
Cond
CondSetOper
Const
ContinueOper
DollarExpr
Edit
EditCondPropSet
EditEdgeAdd
EditEdgeDel
EditNodeAdd
EditParens
EditPropDel
EditPropSet
EditTagAdd
EditTagDel
EditTagPropDel
EditTagPropSet
EditUnivDel
EmbedQuery
Emit
EmptyBlock
ExprAndNode
ExprDict
ExprList
ExprNode
ExprOrNode
FiltByArray
FiltOper
FiniBlock
ForLoop
FormName
FormPivot
FormTagProp
FormatString
FuncArgs
FuncCall
Function
HasAbsPropCond
HasRelPropCond
HasTagPropCond
IfClause
IfStmt
InitBlock
LiftByArray
LiftFormTag
LiftFormTagProp
LiftOper
LiftProp
LiftPropBy
LiftTag
LiftTagProp
LiftTagTag
List
LookList
Lookup
N1Walk
N1WalkNPivo
N2Walk
N2WalkNPivo
NotCond
Oper
OrCond
PivotIn
PivotInFrom
PivotOper
PivotOut
PivotToTags
PropName
PropPivot
PropPivotOut
PropValue
Query
RawPivot
RelProp
RelPropCond
RelPropValue
Return
Search
SetItemOper
SetVarOper
Stop
SubGraph
SubQuery
SubqCond
SwitchCase
TagCond
TagMatch
TagName
TagProp
TagPropCond
TagPropValue
TagValuCond
TagValue
TryCatch
UnaryExprNode
UnivProp
UnivPropValue
Value
VarDeref
VarEvalOper
VarList
VarListSetOper
VarValue
WhileLoop
YieldValu
expr_add()
expr_div()
expr_eq()
expr_ge()
expr_gt()
expr_le()
expr_lt()
expr_mod()
expr_mul()
expr_ne()
expr_neg()
expr_not()
expr_pow()
expr_prefix()
expr_re()
expr_sub()
parseNumber()
pullone()
- synapse.lib.auth module
Auth
Auth.addAuthGate()
Auth.addRole()
Auth.addUser()
Auth.checkUserLimit()
Auth.delAuthGate()
Auth.delRole()
Auth.delUser()
Auth.feedBeholder()
Auth.getAuthGate()
Auth.getAuthGates()
Auth.getRoleByName()
Auth.getUserByName()
Auth.getUserIdenByName()
Auth.popUserProfileValu()
Auth.popUserVarValu()
Auth.reqAuthGate()
Auth.reqNoAuthGate()
Auth.reqRole()
Auth.reqRoleByName()
Auth.reqUser()
Auth.reqUserByName()
Auth.reqUserByNameOrIden()
Auth.role()
Auth.roles()
Auth.setRoleInfo()
Auth.setRoleName()
Auth.setUserInfo()
Auth.setUserName()
Auth.setUserProfileValu()
Auth.setUserVarValu()
Auth.user()
Auth.users()
AuthGate
Role
Ruler
User
User.allow()
User.allowed()
User.clearAuthCache()
User.confirm()
User.genGateInfo()
User.getAllowedReason()
User.getRoles()
User.grant()
User.hasRole()
User.isAdmin()
User.isArchived()
User.isLocked()
User.pack()
User.popProfileValu()
User.popVarValu()
User.raisePermDeny()
User.reqAdmin()
User.revoke()
User.setAdmin()
User.setArchived()
User.setLocked()
User.setName()
User.setPasswd()
User.setProfileValu()
User.setRoles()
User.setVarValu()
User.tryPasswd()
getShadow()
textFromRule()
- synapse.lib.autodoc module
- synapse.lib.base module
Base
Base.addSignalHandlers()
Base.anit()
Base.dist()
Base.enter_context()
Base.fini()
Base.fire()
Base.incref()
Base.link()
Base.main()
Base.off()
Base.on()
Base.onWith()
Base.onfini()
Base.postAnit()
Base.schedCallSafe()
Base.schedCoro()
Base.schedCoroSafe()
Base.schedCoroSafePend()
Base.unlink()
Base.waiter()
Base.waitfini()
BaseRef
Waiter
main()
schedGenr()
- synapse.lib.boss module
- synapse.lib.cache module
- synapse.lib.cell module
Cell
Cell.BACKUP_SPAWN_TIMEOUT
Cell.COMMIT
Cell.FREE_SPACE_CHECK_FREQ
Cell.LOGGED_HTTPAPI_HEADERS
Cell.SYSCTL_CHECK_FREQ
Cell.SYSCTL_VALS
Cell.VERSION
Cell.VERSTRING
Cell.addActiveCoro()
Cell.addDriveItem()
Cell.addDrivePath()
Cell.addHealthFunc()
Cell.addHttpApi()
Cell.addHttpSess()
Cell.addHttpsPort()
Cell.addReloadableSystem()
Cell.addRole()
Cell.addRoleRule()
Cell.addSignalHandlers()
Cell.addUser()
Cell.addUserApiKey()
Cell.addUserRole()
Cell.addUserRule()
Cell.behold()
Cell.beholder()
Cell.cellapi
Cell.checkFreeSpace()
Cell.checkUserApiKey()
Cell.confbase
Cell.confdefs
Cell.configNexsVers()
Cell.cullNexsLog()
Cell.delActiveCoro()
Cell.delBackup()
Cell.delDriveData()
Cell.delDriveInfo()
Cell.delHttpSess()
Cell.delRole()
Cell.delRoleRule()
Cell.delUser()
Cell.delUserApiKey()
Cell.delUserRole()
Cell.delUserRule()
Cell.dyncall()
Cell.dyniter()
Cell.execmain()
Cell.feedBeholder()
Cell.fini()
Cell.freeze()
Cell.genHttpSess()
Cell.genUserOnepass()
Cell.getAhaInfo()
Cell.getApiKeys()
Cell.getArgParser()
Cell.getAuthGate()
Cell.getAuthGates()
Cell.getAuthRoles()
Cell.getAuthUsers()
Cell.getBackupInfo()
Cell.getBackups()
Cell.getCachedSslCtx()
Cell.getCellApi()
Cell.getCellIden()
Cell.getCellInfo()
Cell.getCellNexsRoot()
Cell.getCellRunId()
Cell.getCellType()
Cell.getConfOpt()
Cell.getDmonSessions()
Cell.getDmonUser()
Cell.getDriveData()
Cell.getDriveDataVersions()
Cell.getDriveInfo()
Cell.getDriveKids()
Cell.getDrivePath()
Cell.getEnvPrefix()
Cell.getHealthCheck()
Cell.getHiveKey()
Cell.getHiveKeys()
Cell.getHttpSessDict()
Cell.getLocalProxy()
Cell.getLocalUrl()
Cell.getLogExtra()
Cell.getMirrorUrls()
Cell.getMyUrl()
Cell.getNexsIndx()
Cell.getNexusChanges()
Cell.getPermDef()
Cell.getPermDefs()
Cell.getReloadableSystems()
Cell.getRoleDef()
Cell.getRoleDefByName()
Cell.getRoleDefs()
Cell.getSpooledDict()
Cell.getSpooledSet()
Cell.getSystemInfo()
Cell.getTeleApi()
Cell.getTempDir()
Cell.getUserApiKey()
Cell.getUserDef()
Cell.getUserDefByName()
Cell.getUserDefs()
Cell.getUserName()
Cell.getUserProfInfo()
Cell.getUserProfile()
Cell.getUserVarValu()
Cell.handoff()
Cell.hasHttpSess()
Cell.initCellConf()
Cell.initCellStorage()
Cell.initFromArgv()
Cell.initNexusSubsystem()
Cell.initServiceActive()
Cell.initServiceEarly()
Cell.initServiceNetwork()
Cell.initServicePassive()
Cell.initServiceRuntime()
Cell.initServiceStorage()
Cell.initSslCtx()
Cell.isActiveCoro()
Cell.isCellActive()
Cell.isRoleAllowed()
Cell.isUserAllowed()
Cell.iterBackupArchive()
Cell.iterNewBackupArchive()
Cell.iterSlabData()
Cell.iterUserProfInfo()
Cell.iterUserVars()
Cell.kill()
Cell.listHiveKey()
Cell.listUserApiKeys()
Cell.loadHiveTree()
Cell.modCellConf()
Cell.modUserApiKey()
Cell.popCellConf()
Cell.popHiveKey()
Cell.popUserProfInfo()
Cell.popUserVarValu()
Cell.promote()
Cell.ps()
Cell.readyToMirror()
Cell.reload()
Cell.reqAhaProxy()
Cell.reqDriveInfo()
Cell.reqGateKeys()
Cell.resume()
Cell.rotateNexsLog()
Cell.runActiveTask()
Cell.runBackup()
Cell.saveHiveTree()
Cell.setCellActive()
Cell.setCellVers()
Cell.setDriveData()
Cell.setDriveInfoPath()
Cell.setDriveInfoPerm()
Cell.setHiveKey()
Cell.setHttpSessInfo()
Cell.setNexsIndx()
Cell.setNexsVers()
Cell.setRoleName()
Cell.setRoleRules()
Cell.setUserAdmin()
Cell.setUserArchived()
Cell.setUserEmail()
Cell.setUserLocked()
Cell.setUserName()
Cell.setUserPasswd()
Cell.setUserProfInfo()
Cell.setUserRoles()
Cell.setUserRules()
Cell.setUserVarValu()
Cell.sync()
Cell.trimNexsLog()
Cell.tryUserPasswd()
Cell.updateHttpSessInfo()
Cell.waitNexsOffs()
CellApi
CellApi.addAuthRole()
CellApi.addAuthRule()
CellApi.addRole()
CellApi.addRoleRule()
CellApi.addUser()
CellApi.addUserApiKey()
CellApi.addUserRole()
CellApi.addUserRule()
CellApi.allowed()
CellApi.behold()
CellApi.checkUserApiKey()
CellApi.cullNexsLog()
CellApi.delAuthRole()
CellApi.delAuthRule()
CellApi.delAuthUser()
CellApi.delBackup()
CellApi.delRole()
CellApi.delRoleRule()
CellApi.delUser()
CellApi.delUserApiKey()
CellApi.delUserRole()
CellApi.delUserRule()
CellApi.dyncall()
CellApi.dyniter()
CellApi.freeze()
CellApi.genUserOnepass()
CellApi.getAuthGate()
CellApi.getAuthGates()
CellApi.getAuthInfo()
CellApi.getAuthRoles()
CellApi.getAuthUsers()
CellApi.getBackupInfo()
CellApi.getBackups()
CellApi.getCellIden()
CellApi.getCellInfo()
CellApi.getCellRunId()
CellApi.getCellType()
CellApi.getCellUser()
CellApi.getDiagInfo()
CellApi.getDmonSessions()
CellApi.getGcInfo()
CellApi.getHealthCheck()
CellApi.getHiveKey()
CellApi.getHiveKeys()
CellApi.getMirrorUrls()
CellApi.getNexsIndx()
CellApi.getNexusChanges()
CellApi.getPermDef()
CellApi.getPermDefs()
CellApi.getReloadableSystems()
CellApi.getRoleDef()
CellApi.getRoleDefByName()
CellApi.getRoleDefs()
CellApi.getRoleInfo()
CellApi.getSystemInfo()
CellApi.getUserDef()
CellApi.getUserDefByName()
CellApi.getUserDefs()
CellApi.getUserInfo()
CellApi.getUserProfInfo()
CellApi.getUserProfile()
CellApi.handoff()
CellApi.initCellApi()
CellApi.isCellActive()
CellApi.isRoleAllowed()
CellApi.isUserAllowed()
CellApi.issue()
CellApi.iterBackupArchive()
CellApi.iterNewBackupArchive()
CellApi.kill()
CellApi.listHiveKey()
CellApi.listUserApiKeys()
CellApi.popHiveKey()
CellApi.popUserProfInfo()
CellApi.promote()
CellApi.ps()
CellApi.readyToMirror()
CellApi.reload()
CellApi.resume()
CellApi.rotateNexsLog()
CellApi.runBackup()
CellApi.runGcCollect()
CellApi.saveHiveTree()
CellApi.setAuthAdmin()
CellApi.setCellUser()
CellApi.setHiveKey()
CellApi.setRoleRules()
CellApi.setUserAdmin()
CellApi.setUserArchived()
CellApi.setUserEmail()
CellApi.setUserLocked()
CellApi.setUserPasswd()
CellApi.setUserProfInfo()
CellApi.setUserRoles()
CellApi.setUserRules()
CellApi.trimNexsLog()
CellApi.tryUserPasswd()
CellApi.waitNexsOffs()
SSLCTX_CACHE_SIZE
adminapi()
from_leader()
- synapse.lib.certdir module
CertDir
CertDir.addCertPath()
CertDir.delCertPath()
CertDir.genCaCert()
CertDir.genCaCrl()
CertDir.genClientCert()
CertDir.genCodeCert()
CertDir.genCrlPath()
CertDir.genHostCert()
CertDir.genHostCsr()
CertDir.genUserCert()
CertDir.genUserCsr()
CertDir.getCaCert()
CertDir.getCaCertBytes()
CertDir.getCaCertPath()
CertDir.getCaCerts()
CertDir.getCaKey()
CertDir.getCaKeyPath()
CertDir.getClientCert()
CertDir.getClientCertPath()
CertDir.getClientSSLContext()
CertDir.getCodeCert()
CertDir.getCodeCertPath()
CertDir.getCodeKey()
CertDir.getCodeKeyPath()
CertDir.getCrlPath()
CertDir.getHostCaPath()
CertDir.getHostCert()
CertDir.getHostCertHash()
CertDir.getHostCertPath()
CertDir.getHostCsrPath()
CertDir.getHostKey()
CertDir.getHostKeyPath()
CertDir.getServerSSLContext()
CertDir.getUserCaPath()
CertDir.getUserCert()
CertDir.getUserCertPath()
CertDir.getUserCsrPath()
CertDir.getUserForHost()
CertDir.getUserKey()
CertDir.getUserKeyPath()
CertDir.importFile()
CertDir.isCaCert()
CertDir.isClientCert()
CertDir.isCodeCert()
CertDir.isHostCert()
CertDir.isUserCert()
CertDir.loadCertByts()
CertDir.saveCaCertByts()
CertDir.saveCertPem()
CertDir.saveCodeCertBytes()
CertDir.saveHostCertByts()
CertDir.savePkeyPem()
CertDir.saveUserCertByts()
CertDir.selfSignCert()
CertDir.signCertAs()
CertDir.signHostCsr()
CertDir.signUserCsr()
CertDir.valCodeCert()
CertDir.valUserCert()
Crl
addCertPath()
delCertPath()
getCertDir()
getCertDirn()
getServerSSLContext()
iterFqdnUp()
- synapse.lib.chop module
- synapse.lib.cli module
- synapse.lib.cmd module
- synapse.lib.cmdr module
- synapse.lib.config module
- synapse.lib.const module
- synapse.lib.coro module
- synapse.lib.datfile module
- synapse.lib.drive module
Drive
Drive.addItemInfo()
Drive.delItemData()
Drive.delItemInfo()
Drive.getItemData()
Drive.getItemDataVersions()
Drive.getItemInfo()
Drive.getItemKids()
Drive.getItemPath()
Drive.getItemsByType()
Drive.getPathInfo()
Drive.getPathNorm()
Drive.getStepInfo()
Drive.getTypeSchema()
Drive.getTypeSchemaVersion()
Drive.getTypeValidator()
Drive.hasItemInfo()
Drive.hasPathInfo()
Drive.reqFreeStep()
Drive.reqItemInfo()
Drive.reqTypeValidator()
Drive.reqValidData()
Drive.setItemData()
Drive.setItemPath()
Drive.setItemPerm()
Drive.setTypeSchema()
Drive.walkItemInfo()
Drive.walkPathInfo()
getVersIndx()
reqValidName()
- synapse.lib.dyndeps module
- synapse.lib.encoding module
- synapse.lib.gis module
- synapse.lib.grammar module
- synapse.lib.hashitem module
- synapse.lib.hashset module
- synapse.lib.health module
- synapse.lib.hive module
- synapse.lib.hiveauth module
Auth
Auth.addAuthGate()
Auth.addRole()
Auth.addUser()
Auth.checkUserLimit()
Auth.delAuthGate()
Auth.delRole()
Auth.delUser()
Auth.feedBeholder()
Auth.getAuthGate()
Auth.getAuthGates()
Auth.getRoleByName()
Auth.getUserByName()
Auth.getUserIdenByName()
Auth.reqAuthGate()
Auth.reqRole()
Auth.reqRoleByName()
Auth.reqUser()
Auth.reqUserByName()
Auth.reqUserByNameOrIden()
Auth.role()
Auth.roles()
Auth.setRoleInfo()
Auth.setRoleName()
Auth.setUserInfo()
Auth.setUserName()
Auth.user()
Auth.users()
AuthGate
HiveRole
HiveRuler
HiveUser
HiveUser.allow()
HiveUser.allowed()
HiveUser.clearAuthCache()
HiveUser.confirm()
HiveUser.genGateInfo()
HiveUser.getAllowedReason()
HiveUser.getRoles()
HiveUser.grant()
HiveUser.hasRole()
HiveUser.isAdmin()
HiveUser.isArchived()
HiveUser.isLocked()
HiveUser.pack()
HiveUser.raisePermDeny()
HiveUser.reqAdmin()
HiveUser.revoke()
HiveUser.setAdmin()
HiveUser.setArchived()
HiveUser.setLocked()
HiveUser.setName()
HiveUser.setPasswd()
HiveUser.setRoles()
HiveUser.tryPasswd()
getShadow()
textFromRule()
- synapse.lib.httpapi module
ActiveV1
AuthAddRoleV1
AuthAddUserV1
AuthDelRoleV1
AuthGrantV1
AuthRevokeV1
AuthRoleV1
AuthRolesV1
AuthUserPasswdV1
AuthUserV1
AuthUsersV1
BeholdSockV1
CoreInfoV1
ExtApiHandler
FeedV1
Handler
HandlerBase
HandlerBase.allowed()
HandlerBase.authenticated()
HandlerBase.check_origin()
HandlerBase.getAuthCell()
HandlerBase.getCustomHeaders()
HandlerBase.getJsonBody()
HandlerBase.getUseridenBody()
HandlerBase.handleApiKeyAuth()
HandlerBase.handleBasicAuth()
HandlerBase.initialize()
HandlerBase.isOrigHost()
HandlerBase.isUserAdmin()
HandlerBase.loadJsonMesg()
HandlerBase.logAuthIssue()
HandlerBase.options()
HandlerBase.reqAuthAdmin()
HandlerBase.reqAuthUser()
HandlerBase.sendAuthRequired()
HandlerBase.sendRestErr()
HandlerBase.sendRestExc()
HandlerBase.sendRestRetn()
HandlerBase.sess()
HandlerBase.set_default_headers()
HandlerBase.useriden()
HealthCheckV1
LoginV1
LogoutV1
ModelNormV1
ModelV1
OnePassIssueV1
ReqValidStormV1
RobotHandler
Sess
StormCallV1
StormExportV1
StormHandler
StormNodesV1
StormV1
StormVarsGetV1
StormVarsPopV1
StormVarsSetV1
StreamHandler
WebSocket
- synapse.lib.ingest module
- synapse.lib.interval module
- synapse.lib.jsonstor module
JsonStor
JsonStor.cmpDelPathObjProp()
JsonStor.copyPathObj()
JsonStor.copyPathObjs()
JsonStor.delPathObj()
JsonStor.delPathObjProp()
JsonStor.getPathList()
JsonStor.getPathObj()
JsonStor.getPathObjProp()
JsonStor.getPathObjs()
JsonStor.hasPathObj()
JsonStor.popPathObjProp()
JsonStor.setPathLink()
JsonStor.setPathObj()
JsonStor.setPathObjProp()
JsonStorApi
JsonStorApi.addQueue()
JsonStorApi.addUserNotif()
JsonStorApi.cmpDelPathObjProp()
JsonStorApi.copyPathObj()
JsonStorApi.copyPathObjs()
JsonStorApi.cullQueue()
JsonStorApi.delPathObj()
JsonStorApi.delPathObjProp()
JsonStorApi.delQueue()
JsonStorApi.delUserNotif()
JsonStorApi.getPathList()
JsonStorApi.getPathObj()
JsonStorApi.getPathObjProp()
JsonStorApi.getPathObjs()
JsonStorApi.getUserNotif()
JsonStorApi.getsQueue()
JsonStorApi.hasPathObj()
JsonStorApi.iterUserNotifs()
JsonStorApi.popPathObjProp()
JsonStorApi.putsQueue()
JsonStorApi.setPathLink()
JsonStorApi.setPathObj()
JsonStorApi.setPathObjProp()
JsonStorApi.watchAllUserNotifs()
JsonStorCell
JsonStorCell.addQueue()
JsonStorCell.addUserNotif()
JsonStorCell.cellapi
JsonStorCell.cmpDelPathObjProp()
JsonStorCell.copyPathObj()
JsonStorCell.copyPathObjs()
JsonStorCell.cullQueue()
JsonStorCell.delPathObj()
JsonStorCell.delPathObjProp()
JsonStorCell.delQueue()
JsonStorCell.delUserNotif()
JsonStorCell.getEnvPrefix()
JsonStorCell.getPathList()
JsonStorCell.getPathObj()
JsonStorCell.getPathObjProp()
JsonStorCell.getPathObjs()
JsonStorCell.getUserNotif()
JsonStorCell.getsQueue()
JsonStorCell.hasPathObj()
JsonStorCell.initServiceStorage()
JsonStorCell.iterUserNotifs()
JsonStorCell.popPathObjProp()
JsonStorCell.putsQueue()
JsonStorCell.setPathLink()
JsonStorCell.setPathObj()
JsonStorCell.setPathObjProp()
JsonStorCell.watchAllUserNotifs()
- synapse.lib.layer module
IndxBy
IndxBy.buidsByDups()
IndxBy.buidsByPref()
IndxBy.buidsByRange()
IndxBy.buidsByRangeBack()
IndxBy.getNodeValu()
IndxBy.hasIndxBuid()
IndxBy.keyBuidsByDups()
IndxBy.keyBuidsByDupsBack()
IndxBy.keyBuidsByPref()
IndxBy.keyBuidsByPrefBack()
IndxBy.keyBuidsByRange()
IndxBy.keyBuidsByRangeBack()
IndxBy.scanByDups()
IndxBy.scanByPref()
IndxBy.scanByPrefBack()
IndxBy.scanByRange()
IndxBy.scanByRangeBack()
IndxByForm
IndxByProp
IndxByPropArray
IndxByTag
IndxByTagProp
Layer
Layer.clone()
Layer.confirmLayerEditPerms()
Layer.delete()
Layer.getAbrvProp()
Layer.getEdgeVerbs()
Layer.getEdges()
Layer.getEditIndx()
Layer.getEditOffs()
Layer.getEditSize()
Layer.getFormCounts()
Layer.getFormProps()
Layer.getIdenFutu()
Layer.getLayerSize()
Layer.getMirrorStatus()
Layer.getModelVers()
Layer.getNdefRefs()
Layer.getNodeData()
Layer.getNodeEditWindow()
Layer.getNodeForm()
Layer.getNodeTag()
Layer.getNodeValu()
Layer.getPropAbrv()
Layer.getPropArrayCount()
Layer.getPropArrayValuCount()
Layer.getPropCount()
Layer.getPropValuCount()
Layer.getStorIndx()
Layer.getStorNode()
Layer.getStorNodeCount()
Layer.getStorNodes()
Layer.getStorNodesByForm()
Layer.getTagCount()
Layer.getTagPropAbrv()
Layer.getTagPropCount()
Layer.getTagPropValuCount()
Layer.getTagProps()
Layer.getUnivPropCount()
Layer.hasNodeData()
Layer.hasNodeEdge()
Layer.hasTagProp()
Layer.initLayerActive()
Layer.initLayerPassive()
Layer.initUpstreamSync()
Layer.iterEdgeVerbs()
Layer.iterFormRows()
Layer.iterLayerNodeEdits()
Layer.iterNodeData()
Layer.iterNodeDataKeys()
Layer.iterNodeEdgeVerbsN1()
Layer.iterNodeEdgesN1()
Layer.iterNodeEdgesN2()
Layer.iterNodeEditLog()
Layer.iterNodeEditLogBack()
Layer.iterPropIndxBuids()
Layer.iterPropRows()
Layer.iterPropValues()
Layer.iterTagPropRows()
Layer.iterTagRows()
Layer.iterUnivRows()
Layer.iterWipeNodeEdits()
Layer.liftByDataName()
Layer.liftByFormValu()
Layer.liftByProp()
Layer.liftByPropArray()
Layer.liftByPropValu()
Layer.liftByTag()
Layer.liftByTagProp()
Layer.liftByTagPropValu()
Layer.liftByTagValu()
Layer.liftByTags()
Layer.liftTagProp()
Layer.mayDelBuid()
Layer.nodeeditctor
Layer.pack()
Layer.saveNodeEdits()
Layer.setLayerInfo()
Layer.setModelVers()
Layer.setPropAbrv()
Layer.setSodeDirty()
Layer.setTagPropAbrv()
Layer.stat()
Layer.storNodeEdits()
Layer.storNodeEditsNoLift()
Layer.syncIndexEvents()
Layer.syncNodeEdits()
Layer.syncNodeEdits2()
Layer.verify()
Layer.verifyAllBuids()
Layer.verifyAllProps()
Layer.verifyAllTagProps()
Layer.verifyAllTags()
Layer.verifyBuidTag()
Layer.verifyByBuid()
Layer.verifyByProp()
Layer.verifyByPropArray()
Layer.verifyByTag()
Layer.verifyByTagProp()
Layer.waitEditOffs()
Layer.waitForHot()
Layer.waitUpstreamOffs()
LayerApi
StorType
StorTypeFloat
StorTypeFqdn
StorTypeGuid
StorTypeHier
StorTypeHugeNum
StorTypeInt
StorTypeIpv6
StorTypeIval
StorTypeLatLon
StorTypeLoc
StorTypeMsgp
StorTypeNdef
StorTypeTag
StorTypeTime
StorTypeUtf8
getFlatEdits()
- synapse.lib.link module
- synapse.lib.lmdbslab module
GuidStor
Hist
HotCount
HotKeyVal
LmdbBackup
MultiQueue
SafeKeyVal
Scan
ScanBack
ScanKeys
Slab
Slab.COMMIT_PERIOD
Slab.DEFAULT_GROWSIZE
Slab.DEFAULT_MAPSIZE
Slab.WARN_COMMIT_TIME_MS
Slab.addResizeCallback()
Slab.allslabs
Slab.copydb()
Slab.copyslab()
Slab.count()
Slab.countByPref()
Slab.dbexists()
Slab.delete()
Slab.dropdb()
Slab.fini()
Slab.firstkey()
Slab.forcecommit()
Slab.get()
Slab.getHotCount()
Slab.getMultiQueue()
Slab.getNameAbrv()
Slab.getSafeKeyVal()
Slab.getSeqn()
Slab.getSlabStats()
Slab.getSlabsInDir()
Slab.has()
Slab.hasdup()
Slab.initSyncLoop()
Slab.initdb()
Slab.last()
Slab.lastkey()
Slab.pop()
Slab.prefexists()
Slab.put()
Slab.putmulti()
Slab.rangeexists()
Slab.replace()
Slab.scanByDups()
Slab.scanByDupsBack()
Slab.scanByFull()
Slab.scanByFullBack()
Slab.scanByPref()
Slab.scanByPrefBack()
Slab.scanByRange()
Slab.scanByRangeBack()
Slab.scanKeys()
Slab.scanKeysByPref()
Slab.stat()
Slab.statinfo()
Slab.sync()
Slab.syncLoopOnce()
Slab.syncLoopTask()
Slab.syncevnt
Slab.synctask
Slab.trash()
SlabAbrv
SlabDict
- synapse.lib.modelrev module
ModelMigration_0_2_31
ModelMigration_0_2_31.anit()
ModelMigration_0_2_31.delNode()
ModelMigration_0_2_31.editEdgeAdd()
ModelMigration_0_2_31.editEdgeDel()
ModelMigration_0_2_31.editNodeAdd()
ModelMigration_0_2_31.editNodeDel()
ModelMigration_0_2_31.editNodedataDel()
ModelMigration_0_2_31.editNodedataSet()
ModelMigration_0_2_31.editPropDel()
ModelMigration_0_2_31.editPropSet()
ModelMigration_0_2_31.editTagDel()
ModelMigration_0_2_31.editTagSet()
ModelMigration_0_2_31.editTagpropDel()
ModelMigration_0_2_31.editTagpropSet()
ModelMigration_0_2_31.getNode()
ModelMigration_0_2_31.getRefInfo()
ModelMigration_0_2_31.getRoProps()
ModelMigration_0_2_31.getSodeByPropValuNoNorm()
ModelMigration_0_2_31.moveNode()
ModelMigration_0_2_31.removeNode()
ModelMigration_0_2_31.revModel_0_2_31()
ModelMigration_0_2_31.storeNode()
ModelRev
ModelRev.revCoreLayers()
ModelRev.revModel20210126()
ModelRev.revModel20210312()
ModelRev.revModel20210528()
ModelRev.revModel20210801()
ModelRev.revModel20211112()
ModelRev.revModel20220307()
ModelRev.revModel20220315()
ModelRev.revModel20220509()
ModelRev.revModel20220706()
ModelRev.revModel20220803()
ModelRev.revModel20220901()
ModelRev.revModel20221025()
ModelRev.revModel20221123()
ModelRev.revModel20221212()
ModelRev.revModel20221220()
ModelRev.revModel20230209()
ModelRev.revModel_0_2_18()
ModelRev.revModel_0_2_19()
ModelRev.revModel_0_2_20()
ModelRev.revModel_0_2_21()
ModelRev.revModel_0_2_22()
ModelRev.revModel_0_2_23()
ModelRev.revModel_0_2_24()
ModelRev.revModel_0_2_25()
ModelRev.revModel_0_2_26()
ModelRev.revModel_0_2_27()
ModelRev.revModel_0_2_29()
ModelRev.revModel_0_2_30()
ModelRev.revModel_0_2_31()
ModelRev.runStorm()
- synapse.lib.module module
- synapse.lib.modules module
- synapse.lib.msgpack module
- synapse.lib.multislabseqn module
- synapse.lib.nexus module
ChangeDist
NexsRoot
NexsRoot.addWriteHold()
NexsRoot.cull()
NexsRoot.delWriteHold()
NexsRoot.eat()
NexsRoot.enNexsLog()
NexsRoot.getChangeDist()
NexsRoot.getNexsKids()
NexsRoot.index()
NexsRoot.isNexsReady()
NexsRoot.issue()
NexsRoot.iter()
NexsRoot.promote()
NexsRoot.recover()
NexsRoot.reqNotReadOnly()
NexsRoot.rotate()
NexsRoot.runMirrorLoop()
NexsRoot.setNexsReady()
NexsRoot.setindex()
NexsRoot.startup()
NexsRoot.waitOffs()
Pusher
RegMethType
- synapse.lib.node module
Node
Node.addEdge()
Node.addTag()
Node.delEdge()
Node.delTag()
Node.delTagProp()
Node.delete()
Node.filter()
Node.get()
Node.getByLayer()
Node.getData()
Node.getEmbeds()
Node.getNodeRefs()
Node.getStorNodes()
Node.getTag()
Node.getTagProp()
Node.getTagProps()
Node.getTags()
Node.has()
Node.hasData()
Node.hasTag()
Node.hasTagProp()
Node.iden()
Node.iterData()
Node.iterDataKeys()
Node.iterEdgeVerbs()
Node.iterEdgesN1()
Node.iterEdgesN2()
Node.pack()
Node.pop()
Node.popData()
Node.repr()
Node.reprs()
Node.set()
Node.setData()
Node.setTagProp()
Node.storm()
Node.tagpropreprs()
Path
iden()
ndef()
prop()
props()
reprNdef()
reprProp()
reprTag()
reprTagProps()
tagged()
tags()
tagsnice()
- synapse.lib.oauth module
- synapse.lib.output module
- synapse.lib.parser module
AstConverter
AstConverter.caseentry()
AstConverter.cmdrargs()
AstConverter.embedquery()
AstConverter.evalvalu()
AstConverter.exprdict()
AstConverter.exprlist()
AstConverter.funcargs()
AstConverter.funccall()
AstConverter.liftreverse()
AstConverter.metaToAstInfo()
AstConverter.operrelprop_join()
AstConverter.operrelprop_pivot()
AstConverter.raiseBadSyntax()
AstConverter.stormcmdargs()
AstConverter.subquery()
AstConverter.switchcase()
AstConverter.varderef()
AstConverter.varlist()
AstConverter.yieldvalu()
AstInfo
CmdStringer
Parser
format_unescape()
massage_vartokn()
parseEval()
parseQuery()
parse_cmd_string()
unescape()
- synapse.lib.queue module
- synapse.lib.ratelimit module
- synapse.lib.reflect module
- synapse.lib.rstorm module
- synapse.lib.schemas module
- synapse.lib.scope module
- synapse.lib.scrape module
- synapse.lib.share module
- synapse.lib.slaboffs module
- synapse.lib.slabseqn module
SlabSeqn
SlabSeqn.add()
SlabSeqn.aiter()
SlabSeqn.cull()
SlabSeqn.first()
SlabSeqn.get()
SlabSeqn.getByIndxByts()
SlabSeqn.getOffsetEvent()
SlabSeqn.getraw()
SlabSeqn.gets()
SlabSeqn.index()
SlabSeqn.iter()
SlabSeqn.iterBack()
SlabSeqn.last()
SlabSeqn.nextindx()
SlabSeqn.pop()
SlabSeqn.rows()
SlabSeqn.save()
SlabSeqn.slice()
SlabSeqn.sliceBack()
SlabSeqn.stat()
SlabSeqn.trim()
SlabSeqn.waitForOffset()
- synapse.lib.snap module
ProtoNode
ProtoNode.addEdge()
ProtoNode.addTag()
ProtoNode.delEdge()
ProtoNode.get()
ProtoNode.getData()
ProtoNode.getNodeEdit()
ProtoNode.getSetOps()
ProtoNode.getTag()
ProtoNode.getTagProp()
ProtoNode.hasData()
ProtoNode.hasTagProp()
ProtoNode.iden()
ProtoNode.set()
ProtoNode.setData()
ProtoNode.setTagProp()
Scrubber
Snap
Snap.addFeedData()
Snap.addFeedNodes()
Snap.addNode()
Snap.addNodes()
Snap.addStormRuntime()
Snap.applyNodeEdit()
Snap.applyNodeEdits()
Snap.buidcachesize
Snap.clearCache()
Snap.clearCachedNode()
Snap.eval()
Snap.getEditor()
Snap.getNdefRefs()
Snap.getNodeByBuid()
Snap.getNodeByNdef()
Snap.getNodeData()
Snap.getNodeEditor()
Snap.getRuntNodes()
Snap.getSnapMeta()
Snap.getStormRuntime()
Snap.getTagNode()
Snap.getTagNorm()
Snap.hasNodeData()
Snap.hasNodeEdge()
Snap.iterEdgeVerbs()
Snap.iterNodeData()
Snap.iterNodeDataKeys()
Snap.iterNodeEdgesN1()
Snap.iterNodeEdgesN2()
Snap.iterStormPodes()
Snap.keepalive()
Snap.nodes()
Snap.nodesByDataName()
Snap.nodesByProp()
Snap.nodesByPropArray()
Snap.nodesByPropTypeValu()
Snap.nodesByPropValu()
Snap.nodesByTag()
Snap.nodesByTagProp()
Snap.nodesByTagPropValu()
Snap.nodesByTagValu()
Snap.printf()
Snap.saveNodeEdits()
Snap.storm()
Snap.tagcachesize
Snap.warn()
Snap.warnonce()
SnapEditor
- synapse.lib.spooled module
- synapse.lib.storm module
BackgroundCmd
BatchCmd
Cmd
CopyToCmd
CountCmd
DelNodeCmd
DiffCmd
DivertCmd
DmonManager
EdgesDelCmd
GraphCmd
HelpCmd
IdenCmd
IntersectCmd
LiftByVerb
LimitCmd
MaxCmd
MergeCmd
MinCmd
MoveNodesCmd
MoveTagCmd
OnceCmd
ParallelCmd
Parser
PureCmd
ReIndexCmd
RunAsCmd
Runtime
Runtime.addInput()
Runtime.allowed()
Runtime.allowedEasyPerm()
Runtime.allowedReason()
Runtime.cancel()
Runtime.confirm()
Runtime.confirmEasyPerm()
Runtime.confirmPropDel()
Runtime.confirmPropSet()
Runtime.coreDynCall()
Runtime.dyncall()
Runtime.dyniter()
Runtime.emit()
Runtime.emitter()
Runtime.execute()
Runtime.getCmdRuntime()
Runtime.getGraph()
Runtime.getInput()
Runtime.getModRuntime()
Runtime.getOneNode()
Runtime.getOpt()
Runtime.getScopeVars()
Runtime.getStormQuery()
Runtime.getSubRuntime()
Runtime.getTeleProxy()
Runtime.getVar()
Runtime.initPath()
Runtime.initSubRuntime()
Runtime.isAdmin()
Runtime.isRuntVar()
Runtime.layerConfirm()
Runtime.popVar()
Runtime.printf()
Runtime.reqAdmin()
Runtime.reqGateKeys()
Runtime.reqUserCanReadLayer()
Runtime.setGraph()
Runtime.setOpt()
Runtime.setVar()
Runtime.storm()
Runtime.tick()
Runtime.warn()
Runtime.warnonce()
ScrapeCmd
SleepCmd
SpinCmd
StormDmon
TagPruneCmd
TeeCmd
TreeCmd
UniqCmd
ViewExecCmd
queryhash()
- synapse.lib.storm_format module
- synapse.lib.stormctrl module
- synapse.lib.stormhttp module
- synapse.lib.stormsvc module
- synapse.lib.stormtypes module
Bool
Bytes
CmdOpts
CronJob
Dict
Layer
Lib
LibAxon
LibBase
LibBase64
LibBytes
LibCron
LibCsv
LibDict
LibDmon
LibExport
LibFeed
LibGlobals
LibJsonStor
LibLayer
LibLift
LibPipe
LibPkg
LibPs
LibQueue
LibRegx
LibService
LibStr
LibTags
LibTelepath
LibTime
LibTrigger
LibVars
LibView
List
Node
NodeData
NodeProps
Number
Path
PathMeta
PathVars
Pipe
Prim
Proxy
ProxyGenrMethod
ProxyMethod
Query
Queue
Service
Set
StormHiveDict
StormType
StormTypesRegistry
StormTypesRegistry.addStormLib()
StormTypesRegistry.addStormType()
StormTypesRegistry.base_undefined_types
StormTypesRegistry.delStormLib()
StormTypesRegistry.delStormType()
StormTypesRegistry.getLibDocs()
StormTypesRegistry.getTypeDocs()
StormTypesRegistry.iterLibs()
StormTypesRegistry.iterTypes()
StormTypesRegistry.known_types
StormTypesRegistry.registerLib()
StormTypesRegistry.registerType()
StormTypesRegistry.rtypes
StormTypesRegistry.undefined_types
Str
Text
Trigger
Undef
View
View.addNode()
View.delMergeRequest()
View.delMergeVote()
View.detach()
View.getMergeRequest()
View.getMergeRequestSummary()
View.getMerges()
View.getMergingViews()
View.getObjLocals()
View.setMergeComment()
View.setMergeRequest()
View.setMergeVote()
View.setMergeVoteComment()
View.viewDynCall()
View.viewDynIter()
allowed()
allowedEasyPerm()
confirm()
confirmEasyPerm()
fromprim()
getCallSig()
getDoc()
intify()
ismutable()
kwarg_format()
resolveAxonProxyArg()
resolveCoreProxyUrl()
stormfunc()
strifyHttpArg()
tobool()
tobuidhex()
tocmprvalu()
toint()
toiter()
tonumber()
toprim()
torepr()
tostor()
tostr()
totype()
typeerr()
- synapse.lib.stormwhois module
- synapse.lib.structlog module
- synapse.lib.task module
- synapse.lib.thishost module
- synapse.lib.thisplat module
- synapse.lib.threads module
- synapse.lib.time module
- synapse.lib.trigger module
- synapse.lib.types module
Array
Bool
Comp
Data
Duration
Edge
FieldHelper
Float
Guid
Hex
HugeNum
Int
IntBase
Ival
Loc
Ndef
NodeProp
Range
Str
Tag
TagPart
Taxon
Taxonomy
Time
TimeEdge
Type
Type.clone()
Type.cmpr()
Type.extend()
Type.getCmprCtor()
Type.getCompOffs()
Type.getLiftHintCmpr()
Type.getLiftHintCmprCtor()
Type.getStorCmprs()
Type.getStorNode()
Type.getTypeDef()
Type.getTypeVals()
Type.isarray
Type.merge()
Type.norm()
Type.pack()
Type.postTypeInit()
Type.repr()
Type.setCmprCtor()
Type.setLiftHintCmprCtor()
Type.setNormFunc()
Type.stortype
Velocity
- synapse.lib.urlhelp module
- synapse.lib.version module
- synapse.lib.view module
View
View.addLayer()
View.addNode()
View.addNodeEdits()
View.addTrigQueue()
View.addTrigger()
View.callStorm()
View.callStormIface()
View.children()
View.delMergeRequest()
View.delMergeVote()
View.delTrigQueue()
View.delTrigger()
View.delete()
View.detach()
View.eval()
View.finiMergeTask()
View.finiTrigTask()
View.fork()
View.getEdgeVerbs()
View.getEdges()
View.getFormCounts()
View.getMergeRequest()
View.getMergeVotes()
View.getMerges()
View.getMergingViews()
View.getPropArrayCount()
View.getPropCount()
View.getStorNodes()
View.getTagPropCount()
View.getTrigger()
View.hasKids()
View.init2()
View.initMergeTask()
View.initTrigTask()
View.insertParentFork()
View.isForkOf()
View.isMergeReady()
View.isafork()
View.iterPropValues()
View.iterStormPodes()
View.listTriggers()
View.merge()
View.mergeAllowed()
View.mergeStormIface()
View.nodes()
View.pack()
View.reqNoParentQuorum()
View.reqParentQuorum()
View.reqValidVoter()
View.runEdgeAdd()
View.runEdgeDel()
View.runNodeAdd()
View.runNodeDel()
View.runPropSet()
View.runTagAdd()
View.runTagDel()
View.runViewMerge()
View.scrapeIface()
View.setLayers()
View.setMergeComment()
View.setMergeRequest()
View.setMergeVote()
View.setMergeVoteComment()
View.setTriggerInfo()
View.setViewInfo()
View.snap()
View.snapctor()
View.storNodeEdits()
View.storm()
View.stormlist()
View.swapLayer()
View.tryToMerge()
View.wipeAllowed()
View.wipeLayer()
ViewApi
- Subpackages
- synapse.lookup package
- synapse.models package
- Subpackages
- Submodules
- synapse.models.auth module
- synapse.models.base module
- synapse.models.belief module
- synapse.models.biz module
- synapse.models.crypto module
- synapse.models.dns module
- synapse.models.doc module
- synapse.models.economic module
- synapse.models.entity module
- synapse.models.files module
- synapse.models.geopol module
- synapse.models.geospace module
- synapse.models.inet module
- synapse.models.infotech module
- synapse.models.language module
- synapse.models.material module
- synapse.models.math module
- synapse.models.media module
- synapse.models.orgs module
- synapse.models.person module
- synapse.models.planning module
- synapse.models.proj module
- synapse.models.risk module
- synapse.models.science module
- synapse.models.syn module
- synapse.models.telco module
- synapse.models.transport module
- synapse.servers package
- synapse.tests package
- Submodules
- synapse.tests.nopmod module
- synapse.tests.utils module
AsyncStreamEvent
CmdGenerator
DeprModule
HttpReflector
LibDepr
LibTst
PickleableMagicMock
ReloadCell
StormPkgTest
StreamEvent
SynTest
SynTest.addCreatorDeleterRoles()
SynTest.addSvcToAha()
SynTest.addSvcToCore()
SynTest.agenlen()
SynTest.agenraises()
SynTest.asyncraises()
SynTest.checkNode()
SynTest.checkNodes()
SynTest.eq()
SynTest.eqOrNan()
SynTest.eqish()
SynTest.execToolMain()
SynTest.extendOutpFromPatch()
SynTest.false()
SynTest.ge()
SynTest.genraises()
SynTest.getAsyncLoggerStream()
SynTest.getCellConf()
SynTest.getHttpSess()
SynTest.getLoggerStream()
SynTest.getMagicPromptColors()
SynTest.getMagicPromptLines()
SynTest.getRegrAxon()
SynTest.getRegrCore()
SynTest.getRegrDir()
SynTest.getStructuredAsyncLoggerStream()
SynTest.getTestAha()
SynTest.getTestAxon()
SynTest.getTestCell()
SynTest.getTestCertDir()
SynTest.getTestConfDir()
SynTest.getTestCore()
SynTest.getTestCoreAndProxy()
SynTest.getTestCoreProxSvc()
SynTest.getTestCryo()
SynTest.getTestCryoAndProxy()
SynTest.getTestDir()
SynTest.getTestDmon()
SynTest.getTestFilePath()
SynTest.getTestHive()
SynTest.getTestHiveDmon()
SynTest.getTestHiveFromDirn()
SynTest.getTestJsonStor()
SynTest.getTestOutp()
SynTest.getTestProxy()
SynTest.getTestReadWriteCores()
SynTest.getTestSynDir()
SynTest.getTestTeleHive()
SynTest.getTestUrl()
SynTest.gt()
SynTest.isin()
SynTest.isinstance()
SynTest.istufo()
SynTest.le()
SynTest.len()
SynTest.lt()
SynTest.mayTestDir()
SynTest.ne()
SynTest.nn()
SynTest.none()
SynTest.noprop()
SynTest.notin()
SynTest.printed()
SynTest.raises()
SynTest.redirectStdin()
SynTest.runCoreNodes()
SynTest.setSynDir()
SynTest.setTstEnvars()
SynTest.skip()
SynTest.skipIfNexusReplay()
SynTest.skipIfNoInternet()
SynTest.skipIfNoPath()
SynTest.skipLongTest()
SynTest.sorteq()
SynTest.stormHasNoErr()
SynTest.stormHasNoWarnErr()
SynTest.stormIsInErr()
SynTest.stormIsInPrint()
SynTest.stormIsInWarn()
SynTest.stormNotInPrint()
SynTest.stormNotInWarn()
SynTest.thisEnvMust()
SynTest.thisEnvMustNot()
SynTest.thisHostMust()
SynTest.thisHostMustNot()
SynTest.true()
SynTest.withCliPromptMock()
SynTest.withCliPromptMockExtendOutp()
SynTest.withNexusReplay()
SynTest.withSetLoggingMock()
SynTest.withTestCmdr()
TestCmd
TestModule
TestRunt
TestSubType
TestType
ThreeType
TstEnv
TstOutPut
alist()
deguidify()
jsonlines()
matchContexts()
norm()
waitForBehold()
- synapse.tools package
- Subpackages
- Submodules
- synapse.tools.apikey module
- synapse.tools.autodoc module
- synapse.tools.axon2axon module
- synapse.tools.backup module
- synapse.tools.cellauth module
- synapse.tools.changelog module
- synapse.tools.cmdr module
- synapse.tools.csvtool module
- synapse.tools.easycert module
- synapse.tools.feed module
- synapse.tools.genpkg module
- synapse.tools.guid module
- synapse.tools.healthcheck module
- synapse.tools.json2mpk module
- synapse.tools.livebackup module
- synapse.tools.modrole module
- synapse.tools.moduser module
- synapse.tools.promote module
- synapse.tools.pullfile module
- synapse.tools.pushfile module
- synapse.tools.reload module
- synapse.tools.rstorm module
- synapse.tools.snapshot module
- synapse.tools.storm module
- synapse.utils package
Submodules
synapse.axon module
- class synapse.axon.Axon[source]
Bases:
Cell
- byterange = False
- confdefs = {'http:proxy': {'description': 'An aiohttp-socks compatible proxy URL to use in the wget API.', 'type': 'string'}, 'max:bytes': {'description': 'The maximum number of bytes that can be stored in the Axon.', 'hidecmdl': True, 'minimum': 1, 'type': 'integer'}, 'max:count': {'description': 'The maximum number of files that can be stored in the Axon.', 'hidecmdl': True, 'minimum': 1, 'type': 'integer'}, 'tls:ca:dir': {'description': 'An optional directory of CAs which are added to the TLS CA chain for wget and wput APIs.', 'type': 'string'}}
- async del_(sha256)[source]
Remove the given bytes from the Axon by sha256.
- Parameters:
sha256 (bytes) – The sha256, in bytes, to remove from the Axon.
- Returns:
True if the file is removed; false if the file is not present.
- Return type:
boolean
- async dels(sha256s)[source]
Given a list of sha256 hashes, delete the files from the Axon.
- Parameters:
sha256s (list) – A list of sha256 hashes in bytes form.
- Returns:
A list of booleans, indicating if the file was deleted or not.
- Return type:
list
- async get(sha256, offs=None, size=None)[source]
Get bytes of a file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
offs (int) – The offset to start reading from.
size (int) – The total number of bytes to read.
Examples
Get the bytes from an Axon and process them:
buf = b'' async for bytz in axon.get(sha256): buf =+ bytz await dostuff(buf)
- Yields:
bytes – Chunks of the file bytes.
- Raises:
synapse.exc.NoSuchFile – If the file does not exist.
- async getCellInfo()[source]
Return metadata specific for the Cell.
Notes
By default, this function returns information about the base Cell implementation, which reflects the base information in the Synapse Cell.
It is expected that implementers override the following Class attributes in order to provide meaningful version information:
COMMIT
- A Git CommitVERSION
- A Version tuple.VERSTRING
- A Version string.- Returns:
A Dictionary of metadata.
- Return type:
- async has(sha256)[source]
Check if the Axon has a file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
True if the Axon has the file; false otherwise.
- Return type:
boolean
- async hashes(offs, wait=False, timeout=None)[source]
Yield hash rows for files that exist in the Axon in added order starting at an offset.
- Parameters:
offs (int) – The index offset.
wait (boolean) – Wait for new results and yield them in realtime.
timeout (int) – Max time to wait for new results.
- Yields:
(int, (bytes, int)) – An index offset and the file SHA-256 and size.
Note
If the same hash was deleted and then added back, the same hash will be yielded twice.
- async hashset(sha256)[source]
Calculate additional hashes for a file in the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
A dictionary containing hashes of the file.
- Return type:
dict
- async history(tick, tock=None)[source]
Yield hash rows for files that existing in the Axon after a given point in time.
- Parameters:
tick (int) – The starting time (in epoch milliseconds).
tock (int) – The ending time to stop iterating at (in epoch milliseconds).
- Yields:
(int, (bytes, int)) – A tuple containing time of the hash was added and the file SHA-256 and size.
- holdHashLock(hashbyts)[source]
A context manager that synchronizes edit access to a blob.
- Parameters:
hashbyts (bytes) – The blob to hold the lock for.
- async iterMpkFile(sha256)[source]
Yield items from a MsgPack (.mpk) file in the Axon.
- Parameters:
sha256 (str) – The sha256 hash of the file as a string.
- Yields:
Unpacked items from the bytes.
- async metrics()[source]
Get the runtime metrics of the Axon.
- Returns:
A dictionary of runtime data about the Axon.
- Return type:
dict
- async postfiles(fields, url, params=None, headers=None, method='POST', ssl=True, timeout=None, proxy=True, ssl_opts=None)[source]
Send files from the axon as fields in a multipart/form-data HTTP request.
- Parameters:
fields (list) – List of dicts containing the fields to add to the request as form-data.
url (str) – The URL to retrieve.
params (dict) – Additional parameters to add to the URL.
headers (dict) – Additional HTTP headers to add in the request.
method (str) – The HTTP method to use.
ssl (bool) – Perform SSL verification.
timeout (int) – The timeout of the request, in seconds.
proxy (str|bool) – The proxy value.
ssl_opts (dict) – Additional SSL/TLS options.
Notes
The dictionaries in the fields list may contain the following values:
{ 'name': <str> - Name of the field. 'sha256': <str> - SHA256 hash of the file to submit for this field. 'value': <str> - Value for the field. Ignored if a sha256 has been specified. 'filename': <str> - Optional filename for the field. 'content_type': <str> - Optional content type for the field. 'content_transfer_encoding': <str> - Optional content-transfer-encoding header for the field. }
The ssl_opts dictionary may contain the following values:
{ 'verify': <bool> - Perform SSL/TLS verification. Is overridden by the ssl argument. 'client_cert': <str> - PEM encoded full chain certificate for use in mTLS. 'client_key': <str> - PEM encoded key for use in mTLS. Alternatively, can be included in client_cert. }
The following proxy arguments are supported:
None: Deprecated - Use the proxy defined by the http:proxy configuration option if set. True: Use the proxy defined by the http:proxy configuration option if set. False: Do not use the proxy defined by the http:proxy configuration option if set. <str>: A proxy URL string.
The dictionary returned by this may contain the following values:
{ 'ok': <boolean> - False if there were exceptions retrieving the URL. 'err': <tuple> - Tuple of the error type and information if an exception occurred. 'url': <str> - The URL retrieved (which could have been redirected) 'code': <int> - The response code. 'body': <bytes> - The response body. 'reason': <str> - The reason phrase for the HTTP status code. 'headers': <dict> - The response headers as a dictionary. }
- Returns:
An information dictionary containing the results of the request.
- Return type:
dict
- async put(byts)[source]
Store bytes in the Axon.
- Parameters:
byts (bytes) – The bytes to store in the Axon.
Notes
This API should not be used for files greater than 128 MiB in size.
- Returns:
A tuple with the file size and sha256 hash of the bytes.
- Return type:
tuple(int, bytes)
- async puts(files)[source]
Store a set of bytes in the Axon.
- Parameters:
files (list) – A list of bytes to store in the Axon.
Notes
This API should not be used for storing more than 128 MiB of bytes at once.
- Returns:
A list containing tuples of file size and sha256 hash of the saved bytes.
- Return type:
list(tuple(int, bytes))
- async save(sha256, genr, size)[source]
Save a generator of bytes to the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
genr – The bytes generator function.
- Returns:
The size of the bytes saved.
- Return type:
int
- async size(sha256)[source]
Get the size of a file in the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
The size of the file, in bytes. If not present, None is returned.
- Return type:
int
- async upload()[source]
Get an Upload object.
Notes
The UpLoad object should be used to manage uploads greater than 128 MiB in size.
Examples
Use an UpLoad object to upload a file to the Axon:
async with await axon.upload() as upfd: # Assumes bytesGenerator yields bytes async for byts in bytsgenerator(): await upfd.write(byts) await upfd.save()
Use a single UpLoad object to save multiple files:
async with await axon.upload() as upfd: for fp in file_paths: # Assumes bytesGenerator yields bytes async for byts in bytsgenerator(fp): await upfd.write(byts) await upfd.save()
- Returns:
An Upload manager object.
- Return type:
- async wants(sha256s)[source]
Get a list of sha256 values the axon does not have from a input list.
- Parameters:
sha256s (list) – A list of sha256 values as bytes.
- Returns:
A list of bytes containing the sha256 hashes the Axon does not have.
- Return type:
list
- async wget(url, params=None, headers=None, json=None, body=None, method='GET', ssl=True, timeout=None, proxy=True, ssl_opts=None)[source]
Stream a file download directly into the Axon.
- Parameters:
url (str) – The URL to retrieve.
params (dict) – Additional parameters to add to the URL.
headers (dict) – Additional HTTP headers to add in the request.
json – A JSON body which is included with the request.
body – The body to be included in the request.
method (str) – The HTTP method to use.
ssl (bool) – Perform SSL verification.
timeout (int) – The timeout of the request, in seconds.
proxy (str|bool) – The proxy value.
ssl_opts (dict) – Additional SSL/TLS options.
Notes
The response body will be stored, regardless of the response code. The
ok
value in the response does not reflect that a status code, such as a 404, was encountered when retrieving the URL.The ssl_opts dictionary may contain the following values:
{ 'verify': <bool> - Perform SSL/TLS verification. Is overridden by the ssl argument. 'client_cert': <str> - PEM encoded full chain certificate for use in mTLS. 'client_key': <str> - PEM encoded key for use in mTLS. Alternatively, can be included in client_cert. }
The following proxy arguments are supported:
None: Deprecated - Use the proxy defined by the http:proxy configuration option if set. True: Use the proxy defined by the http:proxy configuration option if set. False: Do not use the proxy defined by the http:proxy configuration option if set. <str>: A proxy URL string.
The dictionary returned by this may contain the following values:
{ 'ok': <boolean> - False if there were exceptions retrieving the URL. 'url': <str> - The URL retrieved (which could have been redirected). This is a url-decoded string. 'code': <int> - The response code. 'reason': <str> - The reason phrase for the HTTP status code. 'mesg': <str> - An error message if there was an exception when retrieving the URL. 'err': <tuple> - An error tuple if there was an exception when retrieving the URL. 'headers': <dict> - The response headers as a dictionary. 'size': <int> - The size in bytes of the response body. 'hashes': { 'md5': <str> - The MD5 hash of the response body. 'sha1': <str> - The SHA1 hash of the response body. 'sha256': <str> - The SHA256 hash of the response body. 'sha512': <str> - The SHA512 hash of the response body. }, 'request': { 'url': The request URL. This is a url-decoded string. 'headers': The request headers. 'method': The request method. } 'history': A sequence of response bodies to track any redirects, not including hashes. }
- Returns:
An information dictionary containing the results of the request.
- Return type:
dict
- class synapse.axon.AxonApi[source]
-
- async csvrows(sha256, dialect='excel', errors='ignore', **fmtparams)[source]
Yield CSV rows from a CSV file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file.
dialect (str) – The CSV dialect to use.
errors (str) – Specify how encoding errors should handled.
**fmtparams – The CSV dialect format parameters.
Notes
The dialect and fmtparams expose the Python csv.reader() parameters.
Examples
Get the rows from a CSV file and process them:
async for row in axon.csvrows(sha256): await dostuff(row)
Get the rows from a tab separated file and process them:
async for row in axon.csvrows(sha256, delimiter=' '): await dostuff(row)
- Yields:
list – Decoded CSV rows.
- async del_(sha256)[source]
Remove the given bytes from the Axon by sha256.
- Parameters:
sha256 (bytes) – The sha256, in bytes, to remove from the Axon.
- Returns:
True if the file is removed; false if the file is not present.
- Return type:
boolean
- async dels(sha256s)[source]
Given a list of sha256 hashes, delete the files from the Axon.
- Parameters:
sha256s (list) – A list of sha256 hashes in bytes form.
- Returns:
A list of booleans, indicating if the file was deleted or not.
- Return type:
list
- async get(sha256, offs=None, size=None)[source]
Get bytes of a file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
offs (int) – The offset to start reading from.
size (int) – The total number of bytes to read.
Examples
Get the bytes from an Axon and process them:
buf = b'' async for bytz in axon.get(sha256): buf += bytz await dostuff(buf)
- Yields:
bytes – Chunks of the file bytes.
- Raises:
synapse.exc.NoSuchFile – If the file does not exist.
- async has(sha256)[source]
Check if the Axon has a file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
True if the Axon has the file; false otherwise.
- Return type:
boolean
- async hashes(offs, wait=False, timeout=None)[source]
Yield hash rows for files that exist in the Axon in added order starting at an offset.
- Parameters:
offs (int) – The index offset.
wait (boolean) – Wait for new results and yield them in realtime.
timeout (int) – Max time to wait for new results.
- Yields:
(int, (bytes, int)) – An index offset and the file SHA-256 and size.
- async hashset(sha256)[source]
Calculate additional hashes for a file in the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
A dictionary containing hashes of the file.
- Return type:
dict
- async history(tick, tock=None)[source]
Yield hash rows for files that existing in the Axon after a given point in time.
- Parameters:
tick (int) – The starting time (in epoch milliseconds).
tock (int) – The ending time to stop iterating at (in epoch milliseconds).
- Yields:
(int, (bytes, int)) – A tuple containing time of the hash was added and the file SHA-256 and size.
- async iterMpkFile(sha256)[source]
Yield items from a MsgPack (.mpk) file in the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Yields:
Unpacked items from the bytes.
- async jsonlines(sha256, errors='ignore')[source]
Yield JSON objects from JSONL (JSON lines) file.
- Parameters:
sha256 (bytes) – The sha256 hash of the file.
errors (str) – Specify how encoding errors should handled.
- Yields:
object – Decoded JSON objects.
- async metrics()[source]
Get the runtime metrics of the Axon.
- Returns:
A dictionary of runtime data about the Axon.
- Return type:
dict
- async postfiles(fields, url, params=None, headers=None, method='POST', ssl=True, timeout=None, proxy=True, ssl_opts=None)[source]
- async put(byts)[source]
Store bytes in the Axon.
- Parameters:
byts (bytes) – The bytes to store in the Axon.
Notes
This API should not be used for files greater than 128 MiB in size.
- Returns:
A tuple with the file size and sha256 hash of the bytes.
- Return type:
tuple(int, bytes)
- async puts(files)[source]
Store a set of bytes in the Axon.
- Parameters:
files (list) – A list of bytes to store in the Axon.
Notes
This API should not be used for storing more than 128 MiB of bytes at once.
- Returns:
A list containing tuples of file size and sha256 hash of the saved bytes.
- Return type:
list(tuple(int, bytes))
- async readlines(sha256, errors='ignore')[source]
Yield lines from a multi-line text file in the axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file.
errors (str) – Specify how encoding errors should handled.
- Yields:
str – Lines of text
- async size(sha256)[source]
Get the size of a file in the Axon.
- Parameters:
sha256 (bytes) – The sha256 hash of the file in bytes.
- Returns:
The size of the file, in bytes. If not present, None is returned.
- Return type:
int
- async upload()[source]
Get an Upload object.
Notes
The UpLoad object should be used to manage uploads greater than 128 MiB in size.
Examples
Use an UpLoad object to upload a file to the Axon:
async with axonProxy.upload() as upfd: # Assumes bytesGenerator yields bytes async for byts in bytsgenerator(): upfd.write(byts) upfd.save()
Use a single UpLoad object to save multiple files:
async with axonProxy.upload() as upfd: for fp in file_paths: # Assumes bytesGenerator yields bytes async for byts in bytsgenerator(fp): upfd.write(byts) upfd.save()
- Returns:
An Upload manager object.
- Return type:
- async wants(sha256s)[source]
Get a list of sha256 values the axon does not have from an input list.
- Parameters:
sha256s (list) – A list of sha256 values as bytes.
- Returns:
A list of bytes containing the sha256 hashes the Axon does not have.
- Return type:
list
- async wget(url, params=None, headers=None, json=None, body=None, method='GET', ssl=True, timeout=None, proxy=True, ssl_opts=None)[source]
Stream a file download directly into the Axon.
- Parameters:
url (str) – The URL to retrieve.
params (dict) – Additional parameters to add to the URL.
headers (dict) – Additional HTTP headers to add in the request.
json – A JSON body which is included with the request.
body – The body to be included in the request.
method (str) – The HTTP method to use.
ssl (bool) – Perform SSL verification.
timeout (int) – The timeout of the request, in seconds.
proxy (str|bool) – The proxy value.
ssl_opts (dict) – Additional SSL/TLS options.
Notes
The response body will be stored, regardless of the response code. The
ok
value in the response does not reflect that a status code, such as a 404, was encountered when retrieving the URL.The ssl_opts dictionary may contain the following values:
{ 'verify': <bool> - Perform SSL/TLS verification. Is overridden by the ssl argument. 'client_cert': <str> - PEM encoded full chain certificate for use in mTLS. 'client_key': <str> - PEM encoded key for use in mTLS. Alternatively, can be included in client_cert. }
The following proxy arguments are supported:
None: Deprecated - Use the proxy defined by the http:proxy configuration option if set. True: Use the proxy defined by the http:proxy configuration option if set. False: Do not use the proxy defined by the http:proxy configuration option if set. <str>: A proxy URL string.
The dictionary returned by this may contain the following values:
{ 'ok': <boolean> - False if there were exceptions retrieving the URL. 'url': <str> - The URL retrieved (which could have been redirected). This is a url-decoded string. 'code': <int> - The response code. 'reason': <str> - The reason phrase for the HTTP status code. 'mesg': <str> - An error message if there was an exception when retrieving the URL. 'err': <tuple> - An error tuple if there was an exception when retrieving the URL. 'headers': <dict> - The response headers as a dictionary. 'size': <int> - The size in bytes of the response body. 'hashes': { 'md5': <str> - The MD5 hash of the response body. 'sha1': <str> - The SHA1 hash of the response body. 'sha256': <str> - The SHA256 hash of the response body. 'sha512': <str> - The SHA512 hash of the response body. }, 'request': { 'url': The request URL. This is a url-decoded string. 'headers': The request headers. 'method': The request method. } 'history': A sequence of response bodies to track any redirects, not including hashes. }
- Returns:
An information dictionary containing the results of the request.
- Return type:
dict
- class synapse.axon.AxonFileHandler(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonHandlerMixin
,Handler
- class synapse.axon.AxonHttpBySha256InvalidV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonFileHandler
- class synapse.axon.AxonHttpBySha256V1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonFileHandler
- class synapse.axon.AxonHttpDelV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonHandlerMixin
,Handler
- class synapse.axon.AxonHttpHasV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonHandlerMixin
,Handler
- class synapse.axon.AxonHttpUploadV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
AxonHandlerMixin
,StreamHandler
- async data_received(chunk)[source]
Implement this method to handle streamed request data.
Requires the .stream_request_body decorator.
May be a coroutine for flow control.
- on_connection_close()[source]
Called in async handlers if the client closed the connection.
Override this to clean up resources associated with long-lived connections. Note that this method is called only if the connection was closed during asynchronous processing; if you need to do cleanup after every request override on_finish instead.
Proxies may keep a connection open for a time (perhaps indefinitely) after the client has gone away, so this method may not be called promptly after the end user closes their connection.
- on_finish()[source]
Called after the end of a request.
Override this method to perform cleanup, logging, etc. This method is a counterpart to prepare.
on_finish
may not produce any output, as it is called after the response has been sent to the client.
- async prepare()[source]
Called at the beginning of a request before get/post/etc.
Override this method to perform common initialization regardless of the request method.
Asynchronous support: Use
async def
or decorate this method with .gen.coroutine to make it asynchronous. If this method returns anAwaitable
execution will not proceed until theAwaitable
is done.Added in version 3.1: Asynchronous support.
- class synapse.axon.UpLoad[source]
Bases:
Base
An object used to manage uploads to the Axon.
synapse.cells module
synapse.common module
- synapse.common.buid(valu=None)[source]
A binary GUID like sequence of 32 bytes.
- Parameters:
valu (object) – Optional, if provided, the hash of the msgpack
to (encoded form of the object is returned. This can be used)
buids. (create stable)
Notes
By default, this returns a random 32 byte value.
- Returns:
A 32 byte value.
- Return type:
bytes
- synapse.common.chunks(item, size)[source]
Divide an iterable into chunks.
- Parameters:
item – Item to slice
size (int) – Maximum chunk size.
Notes
This supports Generator objects and objects which support calling the __getitem__() method with a slice object.
- Yields:
Slices of the item containing up to “size” number of items.
- synapse.common.config(conf, confdefs)[source]
Initialize a config dict using the given confdef tuples.
- synapse.common.ehex(byts)[source]
Encode a bytes variable to a string using binascii.hexlify.
- Parameters:
byts (bytes) – Bytes to encode.
- Returns:
A string representing the bytes.
- Return type:
str
- synapse.common.envbool(name, defval='false')[source]
Resolve an environment variable to a boolean value.
- Parameters:
name (str) – Environment variable to resolve.
defval (str) – Default string value to resolve as.
Notes
False values will be consider strings “0” or “false” after lower casing.
- Returns:
True if the envar is set, false if it is set to a false value.
- Return type:
boolean
- synapse.common.flatten(item)[source]
Normalize a primitive object for cryptographic signing.
- Parameters:
item – The python primitive object to normalize.
Notes
Only None, bool, int, bytes, strings, lists, tuples and dictionaries are acceptable input. List objects will be converted to tuples. Dictionary objects must have keys which can be sorted.
- Returns:
A new copy of the object.
- synapse.common.format(text, **kwargs)[source]
Similar to python str.format() but treats tokens as opaque.
- synapse.common.gendir(*paths, **opts)[source]
Return the absolute path of the joining of the arguments, creating a directory at the resulting path if one does not exist.
Performs home directory(~) and environment variable expansion.
- Parameters:
*paths ([str,...]) – A list of path elements
**opts – arguments as kwargs to os.makedirs
- synapse.common.genfile(*paths) BinaryIO [source]
Create or open (for read/write) a file path join.
- Parameters:
*paths – A list of paths to join together to make the file.
Notes
If the file already exists, the fd returned is opened in
r+b
mode. Otherwise, the fd is opened inw+b
mode.The file position is set to the start of the file. The user is responsible for truncating (
fd.truncate()
) if the existing file contents are not desired, or seeking to the end (fd.seek(0, 2)
) to append.- Returns:
A file-object which can be read/written too.
- synapse.common.genpath(*paths)[source]
Return an absolute path of the joining of the arguments as path elements
Performs home directory(
~
) and environment variable expansion on the joined path- Parameters:
*paths ([str,...]) – A list of path elements
Note
All paths used by Synapse operations (i.e. everything but the data) shall use this function or one of its callers before storing as object properties.
- synapse.common.getDirSize(*paths)[source]
Get the size of a directory.
- Parameters:
*paths (str) – A list of path elements.
Notes
This is equivalent to
du -B 1 -s
anddu -bs
.- Returns:
Tuple of total real and total apparent size of all normal files and directories underneath
*paths
plus*paths
itself.- Return type:
tuple
- synapse.common.getSslCtx(cadir, purpose=Purpose.SERVER_AUTH)[source]
Create as SSL Context and load certificates from a given directory.
- Parameters:
cadir (str) – Path to load certificates from.
purpose – SSLContext purposes flags.
- Returns:
A SSL Context object.
- Return type:
ssl.SSLContext
- synapse.common.getfile(*paths, **opts)[source]
Return a file at the path resulting from joining of the arguments, or None if the file does not exist.
- Parameters:
*paths ([str,...]) – A list of path elements
**opts – arguments as kwargs to io.open
- Returns:
A file-object which can be read/written too.
- Return type:
io.BufferedRandom
- synapse.common.guid(valu=None)[source]
Get a 16 byte guid value.
By default, this is a random guid value.
- Parameters:
valu – Object used to construct the guid valu from. This must be able to be msgpack’d.
- Returns:
32 character, lowercase ascii string.
- Return type:
str
- synapse.common.httpcodereason(code)[source]
Get the reason for an HTTP status code.
- Parameters:
code (int) – The code.
Note
If the status code is unknown, a string indicating it is unknown is returned.
- Returns:
A string describing the status code.
- Return type:
str
- synapse.common.hugeadd(x, y)[source]
Add two decimal.Decimal with proper precision to support synapse hugenums.
- synapse.common.hugediv(x, y)[source]
Divide two decimal.Decimal with proper precision to support synapse hugenums.
- synapse.common.hugemul(x, y)[source]
Multiply two decimal.Decimal with proper precision to support synapse hugenums.
- synapse.common.hugenum(valu)[source]
Return a decimal.Decimal with proper precision for use as a synapse hugenum.
- synapse.common.hugeround(x)[source]
Round a decimal.Decimal with proper precision for synapse hugenums.
- synapse.common.hugescaleb(x, y)[source]
Return the first operand with its exponent adjusted by the second operand.
- synapse.common.hugesub(x, y)[source]
Subtract two decimal.Decimal with proper precision to support synapse hugenums.
- synapse.common.intify(x)[source]
Ensure ( or coerce ) a value into being an integer or None.
- Parameters:
x (obj) – An object to intify
- Returns:
The int value ( or None )
- Return type:
(int)
- synapse.common.iterfd(fd, size=10000000)[source]
Generator which yields bytes from a file descriptor.
- Parameters:
fd (file) – A file-like object to read bytes from.
size (int) – Size, in bytes, of the number of bytes to read from the
time. (fd at a given)
Notes
If the first read call on the file descriptor is a empty bytestring, that zero length bytestring will be yielded and the generator will then be exhausted. This behavior is intended to allow the yielding of contents of a zero byte file.
- Yields:
bytes – Bytes from the file descriptor.
- synapse.common.listdir(*paths, glob=None)[source]
List the (optionally glob filtered) full paths from a dir.
- Parameters:
*paths ([str,...]) – A list of path elements
glob (str) – An optional fnmatch glob str
- async synapse.common.merggenr(genrs, cmprkey)[source]
Iterate multiple sorted async generators and yield their results in order.
- Parameters:
genrs (Sequence[AsyncGenerator[T]]) – a sequence of async generator that each yield sorted items
cmprkey (Callable[T, T, bool]) – a comparison function over the items yielded
Note
If the genrs yield increasing items, cmprkey should return True if the first parameter is less than the second parameter, e.g lambda x, y: x < y.
- async synapse.common.merggenr2(genrs, cmprkey=None, reverse=False)[source]
Optimized version of merggenr based on heapq.merge
- synapse.common.mononow()[source]
Get the current monotonic clock time in milliseconds.
This relies on time.monotonic_ns(), which is a relative time.
- Returns:
Monotonic clock time in milliseconds.
- Return type:
int
- synapse.common.normLogLevel(valu)[source]
Norm a log level value to a integer.
- Parameters:
valu – The value to norm ( a string or integer ).
- Returns:
A valid Logging log level.
- Return type:
int
- synapse.common.now()[source]
Get the current epoch time in milliseconds.
This relies on time.time_ns(), which is system-dependent in terms of resolution.
- Returns:
Epoch time in milliseconds.
- Return type:
int
- synapse.common.reqJsonSafeStrict(item)[source]
Require the item to be safe to serialize to JSON without type coercion issues.
- Parameters:
item – The python primitive to check.
- Returns:
None
- Raises:
s_exc.BadArg – If the item contains invalid data.
- synapse.common.reqdir(*paths)[source]
Return the absolute path of the joining of the arguments, raising an exception if a directory does not exist at the resulting path.
Performs home directory(~) and environment variable expansion.
- Parameters:
*paths ([str,...]) – A list of path elements
- synapse.common.reqfile(*paths, **opts)[source]
Return a file at the path resulting from joining of the arguments, raising an exception if the file does not exist.
- Parameters:
*paths ([str,...]) – A list of path elements
**opts – arguments as kwargs to io.open
- Returns:
A file-object which can be read/written too.
- Return type:
io.BufferedRandom
- synapse.common.reqjsonsafe(item)[source]
Returns None if item is json serializable, otherwise raises an exception. Uses default type coercion from built-in json.dumps.
- synapse.common.reqpath(*paths)[source]
Return the absolute path of the joining of the arguments, raising an exception if a file doesn’t exist at resulting path
- Parameters:
*paths ([str,...]) – A list of path elements
- synapse.common.setlogging(mlogger, defval=None, structlog=None, log_setup=True, datefmt=None)[source]
Configure synapse logging.
- Parameters:
mlogger (logging.Logger) – Reference to a logging.Logger()
defval (str) – Default log level. May be an integer.
structlog (bool) – Enabled structured (jsonl) logging output.
datefmt (str) – Optional strftime format string.
Notes
This calls logging.basicConfig and should only be called once per process.
- Returns:
None
- synapse.common.spin(genr)[source]
Crank through a generator but discard the yielded values.
- Parameters:
genr – Any generator or iterable valu.
Notes
This generator is exhausted via the
collections.dequeue()
constructor with amaxlen=0
, which will quickly exhaust an iterator staying in C code as much as possible.- Returns:
None
- synapse.common.switchext(*paths, ext)[source]
Return an absolute path of the joining of the arguments with the extension replaced.
If an extension does not exist, it will be added.
- Parameters:
*paths ([str,...]) – A list of path elements
ext (str) – A file extension (e.g. ‘.txt’). It should begin with a period.
- synapse.common.todo(_todoname, *args, **kwargs)[source]
Construct and return a todo tuple of (name, args, kwargs).
Note: the odd name for the first parameter is to avoid collision with keys in kwargs.
- synapse.common.trimText(text: str, n: int = 256, placeholder: str = '...') str [source]
Trim a text string larger than n characters and add a placeholder at the end.
- Parameters:
text – String to trim.
n – Number of characters to allow.
placeholder – Placeholder text.
- Returns:
The original string or the trimmed string.
- synapse.common.tuplify(obj)[source]
Convert a nested set of python primitives into tupleized forms via msgpack.
- synapse.common.uhex(text)[source]
Decode a hex string into bytes.
- Parameters:
text (str) – Text to decode.
- Returns:
The decoded bytes.
- Return type:
bytes
- synapse.common.vertup(vstr)[source]
Convert a version string to a tuple.
Example
ver = vertup(‘1.3.30’)
- synapse.common.yamldump(obj, stream: BinaryIO | None = None) bytes [source]
Dump a object to yaml.
- Parameters:
obj – The object to serialize.
stream – The optional stream to write the stream too.
- Returns:
The raw yaml bytes if stream is not provided.
- synapse.common.yamlmod(obj, *paths)[source]
Combines/creates a yaml file and combines with obj. obj and file must be maps/dict or empty.
synapse.cortex module
- class synapse.cortex.CoreApi[source]
Bases:
CellApi
The CoreApi is exposed when connecting to a Cortex over Telepath.
Many CoreApi methods operate on packed nodes consisting of primitive data structures which can be serialized with msgpack/json.
An example of a packaged Node:
( (<form>, <valu>), { "props": { <name>: <valu>, ... }, "tags": { "foo": <time>, "foo.bar": <time>, }, })
- async addForm(formname, basetype, typeopts, typeinfo)[source]
Add an extended form to the data model.
Extended forms must begin with _
- async addFormProp(form, prop, tdef, info)[source]
Add an extended property to the given form.
Extended properties must begin with _
- async addNodes(nodes)[source]
Add a list of packed nodes to the cortex.
- Parameters:
nodes (list) – [ ( (form, valu), {‘props’:{}, ‘tags’:{}}), … ]
- Yields:
(tuple) – Packed node tuples ((form,valu), {‘props’: {}, ‘tags’:{}})
Deprecated in 2.0.0
- async addUnivProp(name, tdef, info)[source]
Add an extended universal property.
Extended properties must begin with _
- async callStorm(text, opts=None)[source]
Return the value expressed in a return() statement within storm.
- async count(text, opts=None)[source]
Count the number of nodes which result from a storm query.
- Parameters:
text (str) – Storm query text.
opts (dict) – Storm query options.
- Returns:
The number of nodes resulting from the query.
- Return type:
(int)
- async exportStorm(text, opts=None)[source]
Execute a storm query and package nodes for export/import.
- NOTE: This API yields nodes after an initial complete lift
in order to limit exported edges.
- getCoreInfo()[source]
Return static generic information about the cortex including model definition
- async getCoreInfoV2()[source]
Return static generic information about the cortex including model definition
- async getFeedFuncs()[source]
Get a list of Cortex feed functions.
Notes
Each feed dictionary has the name of the feed function, the full docstring for the feed function, and the first line of the docstring broken out in their own keys for easy use.
- Returns:
A tuple of dictionaries.
- Return type:
tuple
- async getModelDict()[source]
Return a dictionary which describes the data model.
- Returns:
A model description dictionary.
- Return type:
(dict)
- async getPropNorm(prop, valu, typeopts=None)[source]
Get the normalized property value based on the Cortex data model.
- Parameters:
prop (str) – The property to normalize.
valu – The value to normalize.
typeopts – A Synapse type opts dictionary used to further normalize the value.
- Returns:
A two item tuple, containing the normed value and the info dictionary.
- Return type:
(tuple)
- Raises:
s_exc.NoSuchProp – If the prop does not exist.
s_exc.BadTypeValu – If the value fails to normalize.
- async getTypeNorm(name, valu, typeopts=None)[source]
Get the normalized type value based on the Cortex data model.
- Parameters:
name (str) – The type to normalize.
valu – The value to normalize.
typeopts – A Synapse type opts dictionary used to further normalize the value.
- Returns:
A two item tuple, containing the normed value and the info dictionary.
- Return type:
(tuple)
- Raises:
s_exc.NoSuchType – If the type does not exist.
s_exc.BadTypeValu – If the value fails to normalize.
- async iterFormRows(layriden, form, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes of a single form, optionally (re)starting at startvalue
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
form (str) – A form name
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterPropRows(layriden, form, prop, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes with a particular secondary property, optionally (re)starting at startvalue
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
form (str) – A form name.
prop (str) – A secondary property name.
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterTagPropRows(layriden, tag, prop, form=None, stortype=None, startvalu=None)[source]
Yields (buid, valu) that match a tag:prop, optionally (re)starting at startvalu.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
tag (str) – tag name
prop (str) – prop name
form (Optional[str]) – optional form name
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterTagRows(layriden, tag, form=None, starttupl=None)[source]
Yields (buid, (valu, form)) values that match a tag and optional form, optionally (re)starting at starttupl.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
tag (str) – the tag to match
form (Optional[str]) – if present, only yields buids of nodes that match the form.
starttupl (Optional[Tuple[buid, form]]) – if present, (re)starts the stream of values there.
- Returns:
AsyncIterator[Tuple(buid, (valu, form))]
Note
This yields (buid, (tagvalu, form)) instead of just buid, valu in order to allow resuming an interrupted call by feeding the last value retrieved into starttupl
- async iterUnivRows(layriden, prop, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes with a particular universal property, optionally (re)starting at startvalue
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
prop (str) – A universal property name.
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async reqValidStorm(text, opts=None)[source]
Parse a Storm query to validate it.
- Parameters:
text (str) – The text of the Storm query to parse.
opts (dict) – A Storm options dictionary.
- Returns:
If the query is valid.
- Return type:
True
- Raises:
BadSyntaxError – If the query is invalid.
- async storm(text, opts=None)[source]
Evaluate a storm query and yield result messages.
- Yields:
((str,dict)) – Storm messages.
- async syncLayerNodeEdits(offs, layriden=None, wait=True)[source]
Yield (indx, mesg) nodeedit sets for the given layer beginning at offset.
Once caught up, this API will begin yielding nodeedits in real-time. The generator will only terminate on network disconnect or if the consumer falls behind the max window size of 10,000 nodeedit messages.
- class synapse.cortex.Cortex[source]
Bases:
OAuthMixin
,Cell
A Cortex implements the synapse hypergraph.
The bulk of the Cortex API lives on the Snap() object which can be obtained by calling Cortex.snap() in a with block. This allows callers to manage transaction boundaries explicitly and dramatically increases performance.
- async addCronEdits(iden, edits)[source]
Take a dictionary of edits and apply them to the appointment (cron job)
- async addCronJob(cdef)[source]
Add a cron job to the cortex. Convenience wrapper around agenda.add
A cron job is a persistently-stored item that causes storm queries to be run in the future. The specification for the times that the queries run can be one-shot or recurring.
- Parameters:
query (str) – The storm query to execute in the future
reqs (Union[Dict[str, Union[int, List[int]]], List[Dict[...]]]) – Either a dict of the fixed time fields or a list of such dicts. The keys are in the set (‘year’, ‘month’, ‘dayofmonth’, ‘dayofweek’, ‘hour’, ‘minute’. The values must be positive integers, except for the key of ‘dayofmonth’ in which it may also be a negative integer which represents the number of days from the end of the month with -1 representing the last day of the month. All values may also be lists of valid values.
incunit (Optional[str]) – A member of the same set as above, with an additional member ‘day’. If is None (default), then the appointment is one-shot and will not recur.
incvals (Union[int, List[int]) – A integer or a list of integers of the number of units
- Returns (bytes):
An iden that can be used to later modify, query, and delete the job.
Notes
reqs must have fields present or incunit must not be None (or both) The incunit if not None it must be larger in unit size than all the keys in all reqs elements. Non-recurring jobs may also have a req of ‘now’ which will cause the job to also execute immediately.
- async addExtModel(model)[source]
Add an extended model definition to a Cortex from the output of getExtModel().
- Parameters:
model (dict) – An extended model dictionary.
- Returns:
True when the model was added.
- Return type:
- Raises:
s_exc.BadFormDef – If a form exists with a different definition than the provided definition.
s_exc.BadPropDef – If a property, tagprop, or universal property exists with a different definition than the provided definition.
s_exc.BadEdgeDef – If an edge exists with a different definition than the provided definition.
- async addFeedData(name, items, *, viewiden=None)[source]
Add data using a feed/parser function.
- Parameters:
name (str) – The name of the feed record format.
items (list) – A list of items to ingest.
viewiden (str) – The iden of a view to use. If a view is not specified, the default view is used.
- async addLayer(ldef=None, nexs=True)[source]
Add a Layer to the cortex.
- Parameters:
ldef (Optional[Dict]) – layer configuration
nexs (bool) – whether to record a nexus transaction (internal use only)
- async addNodeTag(user, iden, tag, valu=(None, None))[source]
Add a tag to a node specified by iden.
- Parameters:
iden (str) – A hex encoded node BUID.
tag (str) – A tag string.
valu (tuple) – A time interval tuple or (None, None).
- async addNodes(nodedefs, view=None)[source]
Quickly add/modify a list of nodes from node definition tuples. This API is the simplest/fastest way to add nodes, set node props, and add tags to nodes remotely.
- Parameters:
nodedefs (list) – A list of node definition tuples. See below.
A node definition tuple is defined as:
( (form, valu), {‘props’:{}, ‘tags’:{})
The “props” or “tags” keys may be omitted.
- addRuntLift(prop, func)[source]
Register a runt lift helper for a given prop.
- Parameters:
prop (str) – Full property name for the prop to register the helper for.
func
- Returns:
None.
- Return type:
None
- async addStormPkg(pkgdef, verify=False)[source]
Add the given storm package to the cortex.
This will store the package for future use.
- async addVault(vdef)[source]
Create a new vault.
- Parameters:
vdef (dict) – The vault to add.
- Raises:
synapse.exc.SchemaViolation – vdef does not conform to the vault schema.
Vault already exists for type/scope/owner. - Vault already exists with specified name.
Invalid vault definition provided. - Owner required for unscoped, user, and role vaults. - Vault secrets is not msgpack safe. - Vault configs is not msgpack safe.
Returns: iden of new vault
- async cloneLayer(iden, ldef=None)[source]
Make a copy of a Layer in the cortex.
- Parameters:
iden (str) – Layer iden to clone
ldef (Optional[Dict]) – Layer configuration overrides
Note
This should only be called with a reasonably static Cortex due to possible races.
- confbase = {'_log_conf': {'description': 'Opaque structure used for logging by spawned processes.', 'hideconf': True, 'type': 'object'}, 'aha:admin': {'description': 'An AHA client certificate CN to register as a local admin user.', 'type': 'string'}, 'aha:leader': {'description': 'The AHA service name to claim as the active instance of a storm service.', 'type': 'string'}, 'aha:name': {'description': 'The name of the cell service in the aha service registry.', 'type': 'string'}, 'aha:network': {'description': 'The AHA service network.', 'type': 'string'}, 'aha:provision': {'description': 'The telepath URL of the aha provisioning service.', 'items': {'type': 'string'}, 'type': ['string', 'array']}, 'aha:registry': {'description': 'The telepath URL of the aha service registry.', 'items': {'type': 'string'}, 'type': ['string', 'array']}, 'aha:svcinfo': {'description': 'An AHA svcinfo object. If set, this overrides self discovered Aha service information.', 'hidecmdl': True, 'hidedocs': True, 'properties': {'urlinfo': {'properties': {'host': {'type': 'string'}, 'port': {'type': 'integer'}, 'schema': {'type': 'string'}}, 'required': ('host', 'port', 'scheme'), 'type': 'object'}}, 'required': ('urlinfo',), 'type': 'object'}, 'aha:user': {'description': 'The username of this service when connecting to others.', 'type': 'string'}, 'auth:anon': {'description': 'Allow anonymous telepath access by mapping to the given user name.', 'type': 'string'}, 'auth:conf': {'description': 'Extended configuration to be used by an alternate auth constructor.', 'hideconf': True, 'type': 'object'}, 'auth:ctor': {'description': 'Allow the construction of the cell auth object to be hooked at runtime.', 'hideconf': True, 'type': 'string'}, 'auth:passwd': {'description': 'Set to <passwd> (local only) to bootstrap the root user password.', 'type': 'string'}, 'auth:passwd:policy': {'description': 'Specify password policy/complexity requirements.', 'type': 'object'}, 'backup:dir': {'description': 'A directory outside the service directory where backups will be saved. Defaults to ./backups in the service storage directory.', 'type': 'string'}, 'cell:ctor': {'description': 'An optional python path to the Cell class. Used by stemcell.', 'hideconf': True, 'type': 'string'}, 'cell:guid': {'description': 'An optional hard-coded GUID to store as the permanent GUID for the service.', 'hideconf': True, 'type': 'string'}, 'dmon:listen': {'description': 'A config-driven way to specify the telepath bind URL.', 'type': ['string', 'null']}, 'health:sysctl:checks': {'default': True, 'description': 'Enable sysctl parameter checks and warn if values are not optimal.', 'type': 'boolean'}, 'https:headers': {'description': 'Headers to add to all HTTPS server responses.', 'hidecmdl': True, 'type': 'object'}, 'https:parse:proxy:remoteip': {'default': False, 'description': 'Enable the HTTPS server to parse X-Forwarded-For and X-Real-IP headers to determine requester IP addresses.', 'type': 'boolean'}, 'https:port': {'description': 'A config-driven way to specify the HTTPS port.', 'type': ['integer', 'null']}, 'inaugural': {'description': 'Data used to drive configuration of the service upon first startup.', 'hidedocs': True, 'properties': {'roles': {'items': {'additionalProperties': False, 'properties': {'name': {'pattern': '^(?!all$).+$', 'type': 'string'}, 'rules': {'items': {'items': [{'type': 'boolean'}, {'items': {'type': 'string'}, 'type': 'array'}], 'maxItems': 2, 'minItems': 2, 'type': 'array'}, 'type': 'array'}}, 'required': ['name'], 'type': 'object'}, 'type': 'array'}, 'users': {'items': {'additionalProperties': False, 'properties': {'admin': {'default': False, 'type': 'boolean'}, 'email': {'type': 'string'}, 'name': {'pattern': '^(?!root$).+$', 'type': 'string'}, 'roles': {'items': {'type': 'string'}, 'type': 'array'}, 'rules': {'items': {'items': [{'type': 'boolean'}, {'items': {'type': 'string'}, 'type': 'array'}], 'maxItems': 2, 'minItems': 2, 'type': 'array'}, 'type': 'array'}}, 'required': ['name'], 'type': 'object'}, 'type': 'array'}}, 'type': 'object'}, 'limit:disk:free': {'default': 5, 'description': 'Minimum disk free space percentage before setting the cell read-only.', 'maximum': 100, 'minimum': 0, 'type': ['integer', 'null']}, 'max:users': {'default': 0, 'description': 'Maximum number of users allowed on system, not including root or locked/archived users (0 is no limit).', 'minimum': 0, 'type': 'integer'}, 'mirror': {'description': 'A telepath URL for our upstream mirror (we must be a backup!).', 'hidecmdl': False, 'hidedocs': False, 'type': ['string', 'null']}, 'nexslog:async': {'default': True, 'description': 'Deprecated. This option ignored.', 'hidecmdl': True, 'hidedocs': True, 'type': 'boolean'}, 'nexslog:en': {'default': True, 'description': 'Record all changes to a stream file on disk. Required for mirroring (on both sides).', 'type': 'boolean'}, 'onboot:optimize': {'default': False, 'description': 'Delay startup to optimize LMDB databases during boot to recover free space and increase performance. This may take a while.', 'type': 'boolean'}}
- confdefs = {'axon': {'description': 'A telepath URL for a remote axon.', 'type': 'string'}, 'cron:enable': {'default': True, 'description': 'Deprecated. This option no longer controls cron execution and will be removed in Synapse 3.0.', 'type': 'boolean'}, 'http:proxy': {'description': 'An aiohttp-socks compatible proxy URL to use storm HTTP API.', 'type': 'string'}, 'jsonstor': {'description': 'A telepath URL for a remote jsonstor.', 'type': 'string'}, 'layer:lmdb:map_async': {'default': True, 'description': 'Deprecated. This value is ignored.', 'hidecmdl': True, 'hideconf': True, 'type': 'boolean'}, 'layer:lmdb:max_replay_log': {'default': 10000, 'description': 'Deprecated. This value is ignored.', 'hidecmdl': True, 'hideconf': True, 'type': 'integer'}, 'layers:lockmemory': {'default': False, 'description': 'Should new layers lock memory for performance by default.', 'type': 'boolean'}, 'layers:logedits': {'default': True, 'description': 'Whether nodeedits are logged in each layer.', 'type': 'boolean'}, 'max:nodes': {'description': 'Maximum number of nodes which are allowed to be stored in a Cortex.', 'hidecmdl': True, 'minimum': 1, 'type': 'integer'}, 'modules': {'default': [], 'description': 'A list of module classes to load.', 'type': 'array'}, 'provenance:en': {'default': False, 'description': 'This no longer does anything.', 'hideconf': True, 'type': 'boolean'}, 'storm:interface:scrape': {'default': True, 'description': 'Enable Storm scrape interfaces when using $lib.scrape APIs.', 'type': 'boolean'}, 'storm:interface:search': {'default': True, 'description': 'Enable Storm search interfaces for lookup mode.', 'type': 'boolean'}, 'storm:log': {'default': False, 'description': 'Log storm queries via system logger.', 'type': 'boolean'}, 'storm:log:level': {'default': 'INFO', 'description': 'Logging log level to emit storm logs at.', 'type': ['integer', 'string']}, 'tls:ca:dir': {'description': 'An optional directory of CAs which are added to the TLS CA chain for Storm HTTP API calls.', 'type': 'string'}, 'trigger:enable': {'default': True, 'description': 'Deprecated. This option no longer controls trigger execution and will be removed in Synapse 3.0.', 'type': 'boolean'}}
- async delCronJob(iden)[source]
Delete a cron job
- Parameters:
iden (bytes) – The iden of the cron job to be deleted
- async delNodeTag(user, iden, tag)[source]
Delete a tag from the node specified by iden.
- Parameters:
iden (str) – A hex encoded node BUID.
tag (str) – A tag string.
- async delTagModel(tagname)[source]
Delete all the model specification properties for a tag.
- Parameters:
tagname (str) – The name of the tag.
- async delVault(iden)[source]
Delete a vault.
- Parameters:
iden (str) – Iden of the vault to delete.
Returns: None
- async delViewWithLayer(iden)[source]
Delete a Cortex View and its write Layer if not in use by other View stacks.
Note
Any children of the View will have their parent View updated to the deleted View’s parent (if present). The deleted View’s write Layer will also be removed from any child Views which contain it in their Layer stack. If the Layer is used in Views which are not children of the deleted View, the Layer will be preserved, otherwise it will be deleted as well.
- async disableCronJob(iden)[source]
Enable a cron job
- Parameters:
iden (bytes) – The iden of the cron job to be changed
- async enableCronJob(iden)[source]
Enable a cron job
- Parameters:
iden (bytes) – The iden of the cron job to be changed
- async getCellApi(link, user, path)[source]
Get an instance of the telepath Client object for a given user, link and path.
- Parameters:
link (s_link.Link) – The link object.
user (s_auth.User) – The heavy user object.
path (str) – The path requested.
Notes
This defaults to the self.cellapi class. Implementors may override the default class attribute for cellapi to share a different interface.
- Returns:
The shared object for this cell.
- Return type:
object
- async getExtModel()[source]
Get all extended model properties in the Cortex.
- Returns:
A dictionary containing forms, form properties, universal properties and tag properties.
- Return type:
dict
- getLayer(iden=None)[source]
Get a Layer object.
- Parameters:
iden (str) – The layer iden to retrieve.
- Returns:
A Layer object.
- Return type:
- async getPropNorm(prop, valu, typeopts=None)[source]
Get the normalized property value based on the Cortex data model.
- Parameters:
prop (str) – The property to normalize.
valu – The value to normalize.
typeopts – A Synapse type opts dictionary used to further normalize the value.
- Returns:
A two item tuple, containing the normed value and the info dictionary.
- Return type:
(tuple)
- Raises:
s_exc.NoSuchProp – If the prop does not exist.
s_exc.BadTypeValu – If the value fails to normalize.
- async getStormDocs()[source]
Get a struct containing the Storm Types documentation.
- Returns:
A Dictionary of storm documentation information.
- Return type:
dict
- async getTagModel(tagname)[source]
Retrieve the tag model specification for a tag.
- Returns:
The tag model specification or None.
- Return type:
(dict)
- async getTypeNorm(name, valu, typeopts=None)[source]
Get the normalized type value based on the Cortex data model.
- Parameters:
name (str) – The type to normalize.
valu – The value to normalize.
typeopts – A Synapse type opts dictionary used to further normalize the value.
- Returns:
A two item tuple, containing the normed value and the info dictionary.
- Return type:
(tuple)
- Raises:
s_exc.NoSuchType – If the type does not exist.
s_exc.BadTypeValu – If the value fails to normalize.
- getVault(iden)[source]
Get a vault.
- Parameters:
iden (str) – Iden of the vault to get.
Returns: vault or None
- getVaultByName(name)[source]
Get a vault by name.
- Parameters:
name (str) – Name of the vault to get.
Returns: vault or None
- getVaultByType(vtype, useriden, scope=None)[source]
Get a vault of type vtype and scope scope for user with iden.
This function allows the caller to retrieve a vault of the specified vtype by searching for the first available vault that matches the vtype and scope criteria. The search order for opening vaults is as follows:
If scope is specified, return the vault with vtype and scope. Return None if such a vault doesn’t exist.
Check ‘user’ scope for a vault of vtype. Continue if non-existent.
Check ‘role’ scope for a vault of vtype. Continue if non-existent.
Check ‘global’ scope for a vault of vtype. Continue if non-existent.
Return None
- Parameters:
vtype (str) – Type of the vault to open.
useriden (str) – Iden of user trying to open the vault.
scope (str|None) – The vault scope to open.
- Raises:
synapse.exc.BadArg – Invalid scope specified.
Returns: vault or None if matching vault could not be found.
- getView(iden=None, user=None)[source]
Get a View object.
- Parameters:
iden (str) – The View iden to retrieve.
- Returns:
A View object.
- Return type:
- isTagValid(tagname)[source]
Check if a tag name is valid according to tag model regular expressions.
- Returns:
True if the tag is valid.
- Return type:
(bool)
- async iterFormRows(layriden, form, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes of a single form, optionally (re)starting at startvalu.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
form (str) – A form name.
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterPropRows(layriden, form, prop, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes with a particular secondary property, optionally (re)starting at startvalu.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
form (str) – A form name.
prop (str) – A universal property name.
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterTagPropRows(layriden, tag, prop, form=None, stortype=None, startvalu=None)[source]
Yields (buid, valu) that match a tag:prop, optionally (re)starting at startvalu.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
tag (str) – tag name
prop (str) – prop name
form (Optional[str]) – optional form name
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async iterTagRows(layriden, tag, form=None, starttupl=None)[source]
Yields (buid, (valu, form)) values that match a tag and optional form, optionally (re)starting at starttupl.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
tag (str) – the tag to match
form (Optional[str]) – if present, only yields buids of nodes that match the form.
starttupl (Optional[Tuple[buid, form]]) – if present, (re)starts the stream of values there.
- Returns:
AsyncIterator[Tuple(buid, (valu, form))]
Note
This yields (buid, (tagvalu, form)) instead of just buid, valu in order to allow resuming an interrupted call by feeding the last value retrieved into starttupl
- async iterUnivRows(layriden, prop, stortype=None, startvalu=None)[source]
Yields buid, valu tuples of nodes with a particular universal property, optionally (re)starting at startvalu.
- Parameters:
layriden (str) – Iden of the layer to retrieve the nodes
prop (str) – A universal property name.
stortype (Optional[int]) – a STOR_TYPE_* integer representing the type of form:prop
startvalu (Any) – The value to start at. May only be not None if stortype is not None.
- Returns:
AsyncIterator[Tuple(buid, valu)]
- async classmethod layrctor(*args, **kwargs)
- async listCronJobs()[source]
Get information about all the cron jobs accessible to the current user
- async listTagModel()[source]
Retrieve a list of the tag model specifications.
- Returns:
A list of tag model specification tuples.
- Return type:
([(str, dict), …])
- listVaults()[source]
List all vaults.
Args: None
Raises: None
Yields: tuples of vault info: (<iden>, <name>, <type>, <scope>).
- async loadCoreModule(ctor, conf=None)[source]
Load a single cortex module with the given ctor and conf.
- Parameters:
ctor (str) – The python module class path
conf (dict) – Config dictionary for the module
- loadStormPkg(pkgdef)[source]
Load a storm package into the storm library for this cortex.
NOTE: This will not persist the package (allowing service dynamism).
- async popTagModel(tagname, name)[source]
Pop a property from the model specification of a tag.
- Parameters:
tagname (str) – The name of the tag.
name (str) – The name of the specification property.
- Returns:
The current value of the property.
- Return type:
(object)
- async renameVault(iden, name)[source]
Rename a vault.
- Parameters:
iden (str) – Iden of the vault to rename.
name (str) – New vault name.
- Raises:
synapse.exc.NoSuchIden – Vault with iden does not exist.
synapse.exc.DupName – Vault with name already exists.
Returns: Updated vault.
- async replaceVaultConfigs(iden, valu)[source]
Replace the entire vault config.
- Parameters:
iden (str) – The iden of the vault to edit.
valu (str) – New configs object to store on the vault.
- Raises:
synapse.exc.BadArg – valu is not a dictionary.
synapse.exc.NoSuchIden – Vault with iden does not exist.
synapse.exc.NotMsgpackSafe – valu is not msgpack safe.
Returns: New configs.
- async replaceVaultSecrets(iden, valu)[source]
Replace the entire vault config.
- Parameters:
iden (str) – The iden of the vault to edit.
valu (str) – New secrets object to store on the vault.
- Raises:
synapse.exc.BadArg – valu is not a dictionary.
synapse.exc.NoSuchIden – Vault with iden does not exist.
synapse.exc.NotMsgpackSafe – valu is not msgpack safe.
Returns: New secrets.
- async reqValidStorm(text, opts=None)[source]
Parse a storm query to validate it.
- Parameters:
text (str) – The text of the Storm query to parse.
opts (dict) – A Storm options dictionary.
- Returns:
If the query is valid.
- Return type:
True
- Raises:
BadSyntaxError – If the query is invalid.
- reqVault(iden)[source]
Get a vault by iden.
- Parameters:
iden (str) – Iden of the vault to get.
- Raises:
synapse.exc.NoSuchIden – Vault with iden not found.
Returns: vault
- reqVaultByName(name)[source]
Get a vault by name.
- Parameters:
name (str) – Name of the vault to get.
- Raises:
synapse.exc.NoSuchName – Vault with name not found.
Returns: vault
- reqVaultByType(vtype, iden, scope=None)[source]
Get a vault by type.
- Parameters:
vtype (str) – Type of the vault to get.
iden (str) – Iden of the user or role for the vault type.
scope (str|None) – Scope of the vault to get.
- Raises:
synapse.exc.NoSuchName – Vault with vtype/iden/scope not found.
Returns: vault
- async runRuntLift(full, valu=None, cmpr=None, view=None)[source]
Execute a runt lift function.
- Parameters:
full (str) – Property to lift by.
valu
cmpr
- Returns:
- Yields bytes, list tuples where the list contains a series of
key/value pairs which are used to construct a Node object.
- Return type:
bytes, list
- async setStormSvcEvents(iden, edef)[source]
Set the event callbacks for a storm service. Extends the sdef dict.
- Parameters:
iden (str) – The service iden.
edef (dict) – The events definition.
Notes
The edef is formatted like the following:
{ <name> : { 'storm': <storm> } }
where
name
is one of the following items:add
Run the given storm ‘before the service is first added (a la service.add), but not on a reconnect.
del
Run the given storm after the service is removed (a la service.del), but not on a disconnect.
- Returns:
An updated storm service definition dictionary.
- Return type:
dict
- async setTagModel(tagname, name, valu)[source]
Set a model specification property for a tag.
- Parameters:
tagname (str) – The name of the tag.
name (str) – The name of the property.
valu (object) – The value of the property.
- Tag Model Properties:
regex - A list of None or regular expression strings to match each tag level. prune - A number that determines how many levels of pruning are desired.
Examples
await core.setTagModel(“cno.cve”, “regex”, (None, None, “[0-9]{4}”, “[0-9]{5}”))
- async setVaultConfigs(iden, key, valu)[source]
Set vault config item.
This function sets the key:valu into the vault configs.
- Parameters:
iden (str) – The iden of the vault to edit.
key (str) – Vault secret key.
valu (str) – Vault secret value. s_common.novalu to delete a key.
- Raises:
synapse.exc.NoSuchIden – Vault with iden does not exist.
synapse.exc.NotMsgpackSafe – One of key or valu is not msgpack safe.
Returns: Updated vault.
- async setVaultPerm(viden, iden, level)[source]
Set vault permissions. :param viden: The iden of the vault to edit. :type viden: str :param iden: Iden of the user/role to add permissions for. :type iden: str :param level: Easy perms level. :type level: int
- Raises:
synapse.exc.NoSuchIden – Vault with iden does not exist.
Returns: Updated vault.
- async setVaultSecrets(iden, key, valu)[source]
Set vault secret item.
This function sets the key:valu into the vault secrets.
- Parameters:
iden (str) – The iden of the vault to edit.
key (str) – Vault secret key.
valu (str) – Vault secret value. s_common.novalu to delete a key.
- Raises:
synapse.exc.NoSuchIden – Vault with iden does not exist.
synapse.exc.NotMsgpackSafe – One of key or valu is not msgpack safe.
Returns: Updated vault.
- async setViewLayers(layers, iden=None)[source]
- Parameters:
layers ([str]) – A top-down list of of layer guids
iden (str) – The view iden (defaults to default view).
- async snap(user=None, view=None)[source]
Return a transaction object for the default view.
- Parameters:
user (str) – The user to get the snap for.
view (View) – View object to use when making the snap.
Notes
This must be used as an asynchronous context manager.
- Returns:
A Snap object for the view.
- Return type:
s_snap.Snap
- async swapLayer(oldiden, newiden)[source]
Atomically swap out a layer from all views that contain it.
- async syncIndexEvents(matchdef, offsdict=None, wait=True)[source]
Yield (offs, layriden, <STYPE>, <item>) tuples from the nodeedit logs of all layers starting from the given nexus/layer offset (they are synchronized). Only edits that match the filter in matchdef will be yielded, plus EDIT_PROGRESS (see layer.syncIndexEvents) messages.
The format of the 4th element of the tuple depends on STYPE. STYPE is one of the following constants:
SYNC_LAYR_ADD: item is an empty tuple () SYNC_LAYR_DEL: item is an empty tuple () SYNC_NODEEDIT: item is (buid, form, ETYPE, VALS, META)) or (None, None, s_layer.EDIT_PROGRESS, (), ())
For edits in the past, events are yielded in offset order across all layers. For current data (wait=True), events across different layers may be emitted slightly out of offset order.
Note
Will not yield any values from layers created with logedits disabled
- Parameters:
matchdef (Dict[str, Sequence[str]]) – a dict describing which events are yielded. See layer.syncIndexEvents for matchdef specification.
offsdict (Optional(Dict[str,int])) – starting nexus/editlog offset by layer iden. Defaults to 0 for unspecified layers or if offsdict is None.
wait (bool) – whether to pend and stream value until this layer is fini’d
- async syncLayerNodeEdits(iden, offs, wait=True)[source]
Yield (offs, mesg) tuples for nodeedits in a layer.
- async syncLayersEvents(offsdict=None, wait=True)[source]
Yield (offs, layriden, STYP, item, meta) tuples for nodeedits for all layers, interspersed with add/del layer messages.
- STYP is one of the following constants:
SYNC_NODEEDITS: item is a nodeedits (buid, form, edits) SYNC_LAYR_ADD: A layer was added (item and meta are empty) SYNC_LAYR_DEL: A layer was deleted (item and meta are empty)
- Parameters:
offsdict (Optional(Dict[str,int])) – starting nexus/editlog offset by layer iden. Defaults to 0 for unspecified layers or if offsdict is None.
wait (bool) – whether to pend and stream value until this layer is fini’d
- async updateCronJob(iden, query)[source]
Change an existing cron job’s query
- Parameters:
iden (bytes) – The iden of the cron job to be changed
- async classmethod viewctor(*args, **kwargs)
- class synapse.cortex.CortexAxonHttpBySha256InvalidV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
- class synapse.cortex.CortexAxonHttpBySha256V1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
CortexAxonMixin
,AxonHttpBySha256V1
- class synapse.cortex.CortexAxonHttpDelV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
CortexAxonMixin
,AxonHttpDelV1
- class synapse.cortex.CortexAxonHttpHasV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
CortexAxonMixin
,AxonHttpHasV1
- class synapse.cortex.CortexAxonHttpUploadV1(application: Application, request: HTTPServerRequest, **kwargs: Any)[source]
Bases:
CortexAxonMixin
,AxonHttpUploadV1
- synapse.cortex.getTempCortex(mods=None)[source]
Get a proxy to a cortex backed by a temporary directory.
- Parameters:
mods (list) – A list of modules which are loaded into the cortex.
Notes
The cortex and temporary directory are town down on exit. This should only be called from synchronous code.
- Returns:
Proxy to the cortex.
- synapse.cortex.stormlogger = <Logger synapse.storm (WARNING)>
A Cortex implements the synapse hypergraph object.
synapse.cryotank module
- class synapse.cryotank.CryoApi[source]
Bases:
CellApi
The CryoCell API as seen by a telepath proxy.
This is the API to reference for remote CryoCell use.
- class synapse.cryotank.CryoCell[source]
Bases:
Cell
- async getCellApi(link, user, path)[source]
Get an instance of the telepath Client object for a given user, link and path.
- Parameters:
link (s_link.Link) – The link object.
user (s_auth.User) – The heavy user object.
path (str) – The path requested.
Notes
This defaults to the self.cellapi class. Implementors may override the default class attribute for cellapi to share a different interface.
- Returns:
The shared object for this cell.
- Return type:
object
- async init(name, conf=None, user=None)[source]
Generate a new CryoTank with a given name or get a reference to an existing CryoTank.
- class synapse.cryotank.CryoTank[source]
Bases:
Base
A CryoTank implements a stream of structured data.
- async info()[source]
Returns information about the CryoTank instance.
- Returns:
A dict containing items and metrics indexes.
- Return type:
dict
- async metrics(offs, size=None)[source]
Yield metrics rows starting at offset.
- Parameters:
offs (int) – The index offset.
size (int) – The maximum number of records to yield.
- Yields:
((int, dict)) – An index offset, info tuple for metrics.
- async puts(items)[source]
Add the structured data from items to the CryoTank.
- Parameters:
items (list) – A list of objects to store in the CryoTank.
- Returns:
The ending offset of the items or seqn.
- Return type:
int
- async rows(offs, size=None)[source]
Yield a number of raw items from the CryoTank starting at a given offset.
- Parameters:
offs (int) – The index of the desired datum (starts at 0)
size (int) – The max number of items to yield.
- Yields:
((indx, bytes)) – Index and msgpacked bytes.
- async slice(offs, size=None, wait=False, timeout=None)[source]
Yield a number of items from the CryoTank starting at a given offset.
- Parameters:
offs (int) – The index of the desired datum (starts at 0)
size (int) – The max number of items to yield.
wait (bool) – Once caught up, yield new results in realtime
timeout (int) – Max time to wait for a new item.
- Yields:
((index, object)) – Index and item values.
synapse.daemon module
- class synapse.daemon.Daemon[source]
Bases:
Base
- async listen(url, **opts)[source]
Bind and listen on the given host/port with possible SSL.
- Parameters:
host (str) – A hostname or IP address.
port (int) – The TCP port to bind.
Share an object via the telepath protocol.
- Parameters:
name (str) – Name of the shared object
item (object) – The object to share over telepath.
synapse.datamodel module
An API to assist with the creation and enforcement of cortex data models.
- class synapse.datamodel.Form(modl, name, info)[source]
Bases:
object
The Form class implements data model logic for a node form.
- offAdd(func)[source]
Unregister a callback for tag addition.
- Parameters:
name (str) – The name of the tag.
func (function) – The callback func(node)
- onAdd(func)[source]
Add a callback for adding this type of node.
The callback is executed after node construction.
- Parameters:
func (function) – A callback func(node)
- def func(xact, node):
dostuff()
- class synapse.datamodel.Model(core=None)[source]
Bases:
object
The data model used by a Cortex hypergraph.
- addDataModels(mods)[source]
Add a list of (name, mdef) tuples.
A model definition (mdef) is structured as follows:
{ "ctors":( ('name', 'class.path.ctor', {}, {'doc': 'The foo thing.'}), ), "types":( ('name', ('basetype', {typeopts}), {info}), ), "forms":( (formname, (typename, typeopts), {info}, ( (propname, (typename, typeopts), {info}), )), ), "univs":( (propname, (typename, typeopts), {info}), ) "tagprops":( (tagpropname, (typename, typeopts), {info}), ) "interfaces":( (ifacename, { 'props': ((propname, (typename, typeopts), {info}),), 'doc': docstr, 'interfaces': (ifacename,) }), ) }
- Parameters:
mods (list) – The list of tuples.
- Returns:
None
- class synapse.datamodel.Prop(modl, form, name, typedef, info)[source]
Bases:
object
The Prop class represents a property defined within the data model.
- getAlts()[source]
Return a list of Prop instances that are considered alternative locations for our property value, including self.
- onDel(func)[source]
Add a callback for deleting this property.
The callback is executed after the property is deleted.
- Parameters:
func (function) – A prop del callback.
The callback is called within the current transaction, with the node, and the old property value (or None).
- def func(node, oldv):
dostuff()
- onSet(func)[source]
Add a callback for setting this property.
The callback is executed after the property is set.
- Parameters:
func (function) – A prop set callback.
The callback is called within the current transaction, with the node, and the old property value (or None).
- def func(node, oldv):
dostuff()
- async wasSet(node, oldv)[source]
Fire the onset() handlers for this property.
- Parameters:
node (synapse.lib.node.Node) – The node whose property was set.
oldv (obj) – The previous value of the property.
synapse.exc module
Exceptions used by synapse, all inheriting from SynErr
- exception synapse.exc.BackupAlreadyRunning(*args, **info)[source]
Bases:
SynErr
Only one backup may be running at a time
- exception synapse.exc.BadCertBytes(*args, **info)[source]
Bases:
SynErr
Raised by certdir when the certificate fails to load.
- exception synapse.exc.BadCertVerify(*args, **info)[source]
Bases:
SynErr
Raised by certdir when there is a failure to verify a certificate context.
- exception synapse.exc.BadCmprType(*args, **info)[source]
Bases:
SynErr
Attempt to compare two incomparable values
- exception synapse.exc.BadConfValu(*args, **info)[source]
Bases:
SynErr
The configuration value provided is not valid.
This should contain the config name, valu and mesg.
- exception synapse.exc.BadCoreStore(*args, **info)[source]
Bases:
SynErr
The storage layer has encountered an error
- exception synapse.exc.BadDataValu(*args, **info)[source]
Bases:
SynErr
Cannot process the data as intended.
- exception synapse.exc.BadEccExchange(*args, **info)[source]
Bases:
CryptoErr
Raised when there is an issue doing a ECC Key Exchange
- exception synapse.exc.BadOperArg(*args, **info)[source]
Bases:
SynErr
Improper storm function arguments
- exception synapse.exc.BadStorageVersion(*args, **info)[source]
Bases:
SynErr
Stored persistent data is incompatible with running software
- exception synapse.exc.BadVersion(*args, **info)[source]
Bases:
SynErr
Generic Bad Version exception.
- exception synapse.exc.CryptoErr(*args, **info)[source]
Bases:
SynErr
Raised when there is a synapse.lib.crypto error.
- exception synapse.exc.DataAlreadyExists(*args, **info)[source]
Bases:
SynErr
Cannot copy data to a location that already contains data
- exception synapse.exc.DmonSpawn(*args, **info)[source]
Bases:
SynErr
Raised by a dispatched telepath method that has answered the call using a spawned process. ( control flow that is compatible with aborting standard calls, generators, and async generators ).
- exception synapse.exc.FatalErr(*args, **info)[source]
Bases:
SynErr
Raised when a fatal error has occurred which an application cannot recover from.
- exception synapse.exc.InconsistentStorage(*args, **info)[source]
Bases:
SynErr
Stored persistent data is inconsistent
- exception synapse.exc.NoCertKey(*args, **info)[source]
Bases:
SynErr
Raised when a Cert object requires a RSA Private Key to perform an operation and the key is not present.
- exception synapse.exc.ParserExit(*args, **info)[source]
Bases:
SynErr
Raised by synapse.lib.cmd.Parser on Parser exit()
- exception synapse.exc.StepTimeout(*args, **info)[source]
Bases:
SynErr
Raised when a TestStep.wait() call times out.
- exception synapse.exc.StormRaise(*args, **info)[source]
Bases:
SynErr
This represents a user provided exception raised in the Storm runtime. It requires a errname key.
- exception synapse.exc.StormVarListError(*args, **info)[source]
Bases:
StormRuntimeError
synapse.glob module
- synapse.glob.sync(coro, timeout=None)[source]
Schedule a coroutine to run on the global loop and return it’s result.
- Parameters:
coro (coroutine) – The coroutine instance.
Notes
This API is thread safe and should only be called by non-loop threads.
- synapse.glob.synchelp(f)[source]
The synchelp decorator allows the transparent execution of a coroutine using the global loop from a thread other than the event loop. In both use cases, the actual work is done by the global event loop.
Examples
Use as a decorator:
@s_glob.synchelp async def stuff(x, y): await dostuff()
Calling the stuff function as regular async code using the standard await syntax:
valu = await stuff(x, y)
Calling the stuff function as regular sync code outside of the event loop thread:
valu = stuff(x, y)
synapse.mindmeld module
synapse.telepath module
An RMI framework for synapse.
- class synapse.telepath.Aware[source]
Bases:
object
The telepath.Aware mixin allows shared objects to handle individual links managed by the Daemon.
- async getTeleApi(link, mesg, path)[source]
Return a shared object for this link. :param link: A network link. :type link: synapse.lib.link.Link :param mesg: The tele:syn handshake message. :type mesg: (str,dict)
- class synapse.telepath.Client[source]
Bases:
Base
A Telepath client object which reconnects and allows waiting for link up.
Notes
The conf data allows changing parameters such as timeouts, retry period, and link pool size. The default conf data can be seen below:
conf = { 'timeout': 10, 'retrysleep': 0.2, 'link_poolsize': 4, }
- class synapse.telepath.ClientV2[source]
Bases:
Base
- A telepath client which:
connects to multiple services
distributes API calls across them
receives topology updates from AHA
- NOTE: This must co-exist with Client until we eliminate uses that
attempt to call telepath APIs directly from the Client rather than awaiting a proxy()
- class synapse.telepath.GenrIter(proxy, todo, share)[source]
Bases:
object
An object to help delay a telepath call until iteration.
- class synapse.telepath.Method(proxy, name, share=None)[source]
Bases:
object
The telepath Method is used to provide proxy method calls.
- class synapse.telepath.Proxy[source]
Bases:
Base
A telepath Proxy is used to call remote APIs on a shared object.
Example
import synapse.telepath as s_telepath
# open the “foo” object shared in a dmon on localhost:3344
async def doFooThing():
proxy = await s_telepath.openurl(’tcp://127.0.0.1:3344/foo’)
valu = await proxy.getFooValu(x, y)
The proxy (and openurl function) may also be used from sync code:
proxy = s_telepath.openurl(’tcp://127.0.0.1:3344/foo’)
valu = proxy.getFooValu(x, y)
- async call(methname, *args, **kwargs)[source]
Call a remote method by name.
- Parameters:
methname (str) – The name of the remote method.
*args – Arguments to the method call.
**kwargs – Keyword arguments to the method call.
Most use cases will likely use the proxy methods directly:
The following two are effectively the same:
valu = proxy.getFooBar(x, y) valu = proxy.call(‘getFooBar’, x, y)
- async getPipeline(genr, name=None)[source]
Construct a proxy API call pipeline in order to make multiple telepath API calls while minimizing round trips.
- Parameters:
genr (async generator) – An async generator that yields todo tuples.
name (str) – The name of the shared object on the daemon.
Example
- def genr():
yield s_common.todo(‘getFooByBar’, 10) yield s_common.todo(‘getFooByBar’, 20)
- for retn in proxy.getPipeline(genr()):
valu = s_common.result(retn)
Bases:
Base
The telepath client side of a dynamically shared object.
- class synapse.telepath.Task[source]
Bases:
object
A telepath Task is used to internally track calls/responses.
- async synapse.telepath.addAhaUrl(url)[source]
Add (incref) an aha registry URL.
NOTE: You may also add a list of redundant URLs.
- synapse.telepath.alias(name)[source]
Resolve a telepath alias via ~/.syn/aliases.yaml
- Parameters:
name (str) – Name of the alias to resolve.
Notes
An exact match against the aliases will always be returned first. If no exact match is found and the name contains a ‘/’ in it, the value before the slash is looked up and the remainder of the path is joined to any result. This is done to support dynamic Telepath share names.
- Returns:
The url string, if present in the alias. None will be returned if there are no matches.
- Return type:
str
- async synapse.telepath.delAhaUrl(url)[source]
Remove (decref) an aha registry URL.
NOTE: You may also remove a list of redundant URLs.
- async synapse.telepath.getAhaProxy(urlinfo)[source]
Return a telepath proxy by looking up a host from an AHA registry.
- async synapse.telepath.open(url, onlink=None)[source]
Open a new telepath ClientV2 object based on the given URL.
- Parameters:
url (str) – The URL to connect to.
onlink – An optional async callback function to run when connections are made.
Notes
The onlink callback function has the call signature
(proxy, urlinfo)
. The proxy is the Telepath Proxy object. The urlinfo is the parsed URL information used to create the proxy object. The urlinfo structure may change between versions of Synapse.- Returns:
A ClientV2 object.
- Return type: