h$/'      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                                                                                                                                                                                      None #$r keterbundleketerprefix for folder name  None  keter0Represents a folder used for totating log files. Since 0.2.1 keterA  RotatingLog which performs no logging. Since 0.2.1keter Create a new  RotatingLog. Since 0.2.1keterfolder to contain logsketermaximum log file size, in bytes    None  3 HketerAbstract type containing information on a process which will be restarted.keter;Represents the child process which handles process cleanup. Since 0.2.1keter#Fork off the child cleanup process.?This will ideally only be run once for your entire application. Since 0.2.1keter6Run the given command, restarting if the process dies.keter:Terminate the process and prevent it from being restarted.keterlogketersetuidketer executableketerworking directoryketercommand line parameterketer environmentketershould we restart?None> RketerA replacement for the standard FromJSON/ typeclass which can handle relative filepaths.keter7The directory from which we're reading the config file.keterParse a config file, using the  typeclass.keterA replacement for the .: operator which will both parse a file path and apply the relative file logic.keterA replacement for the .:? operator which will both parse a file path and apply the relative file logic. Safe-Inferred _#keterA data structure for storing a hierarchical set of domain labels from TLD down, supporting wildcards.*Data structure is mutually recursive with , and each level of the tree supports a static assignment for a hostname such as:  example.com0Or a wildcard assignment for a hostname such as:  *.example.com=Or a wildcard assignment with a set of teptions, for example: ! *.example.com admin.example.comAnd lastly, empty labels are supported so that, of course, an assignment for example.com does not necessarily have any subdomains available. As an example suppose we have the following assigned domains:  example.com foo.example.com *.bar.example.com *.qux.example.com baz.qux.example.comThis will resolve to the following value, with some loose pseudocode notation.  Static (map) 'com' -> Unassigned Static (map) 'example' -> Assigned a (map) 'foo' -> Assigned a EmptyLabelMap 'bar' -> Unassigned (Wildcard (Assigned a EmptyLabelMap) 'qux' -> Unassigned (WildcardExcept (Assigned a (map))) 'baz' -> Assigned a EmptyLabelMapNote that the hostname "bar.example.com" is unassigned, only the wildcard was set.#$%&'(#$%&'(None 3Xketer-A virtual host we want to serve content from.Yketer*A port for an individual app to listen on.ZketerUsed for versioning data types.aketerName of the application. Should just be the basename of the application file.?-0./1324=<;:98756>?VUTSRQPONMLKJIHGFEDCB@AWXYZ[\[]^_`abc>-0./1324=<;:98756>?VUTSRQPONMLKJIHGFEDCB@AWXYZ[\]^_`abcNone 8dxketerRealm [(username,password)]yketerStatus Message qxvuwytsrz{| qxvuwytsrz{|None #$ None mketerControls execution of the nginx thread. Follows the settings type pattern. See:  +http://www.yesodweb.com/book/settings-types.keterWhich ports to assign to apps. Defaults to unassigned ranges from IANAketer4Maximum request time in milliseconds per connection.keter.Default connection time bound in milliseconds.&& None  #$>?s keterprimary host, used for approotketer)all hosts, not including the approot hostketer)how long are connections supposed to lastketerhow long in microseconds the app gets before we expect it to bind to a port (default 90 seconds)keter3An action to be performed for a requested hostname.This datatype is very similar to Stanza, but is necessarily separate since: Webapps will be assigned ports.0Not all stanzas have an associated proxy action.keter1Whether we should force redirect to HTTPS routes.keter,External HTTP port when generating APPROOTs.keter-External HTTPS port when generating APPROOTs.keter/Environment variables to be passed to all apps.keter4Maximum request time in milliseconds per connection.ketersettings used for pluginsNone-0./1324=<;:98756>?VUTSRQPONMLKJIHGFEDCB@AWXYZ[\[]^_`abc-0./1324=<;:98756>?VUTSRQPONMLKJIHGFEDCB@AWXYZ[\]^_`abc None#$9keterGets an unassigned port number.keterReturn a port to the recycled collection of the pool. Note that recycling puts the new ports at the end of the queue (FIFO), so that if an application holds onto the port longer than expected, there should be no issues. None #$ keter9How to create the given user/database. Default: uses the psql command line tool and sudo -u postgres.keterLoad a set of existing connections from a config file. If the file does not exist, it will be created. Any newly created databases will automatically be saved to this file. None &$ keterReserve the given hosts so that no other application may use them. Does not yet enable any action. The semantics are: If a requested host is currently actively used or by an app of the same name, it is considered reserved.If a requested host is currently reserved by an app of the same name, it is considered an error in calling this API. Only one app reservation can happen at a time.If any requested host is currently used or reserved by an app with a different name, then those values are returned as Left.9Otherwise, the hosts which were reserved are returned as Right. This does not! include previously active hosts.keter$Forget previously made reservations.keter"Activate a new app. Note that you must- first reserve the hostnames you'll be using.  None  #$%$keterGet the modification time of the bundle file this app was launched from, if relevant.None #$&.keterReset which apps are running.Any app not listed here that is currently running will be terminated.?Any app listed here that is currently running will be reloaded.Any app listed here that is not currently running will be started.  None #$&keter-Mapping from virtual hostname to port number.None  #$'keterroot directory or config file !"#$%&'()*+,-./01234456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyzz{|}~                                                                                                                                                                                                      keter-1.5-inplaceKeter.Types.CommonCodec.Archive.TempTarballData.Conduit.LogFileData.Conduit.Process.UnixData.Yaml.FilePathKeter.LabelMapKeter.Types.Middleware!Network.HTTP.ReverseProxy.RewriteKeter.Types.V04Keter.Types.V10Keter.PortPoolKeter.Plugin.PostgresKeter.HostManager Keter.AppKeter.AppManager Keter.Proxy Keter.Main Keter.Typesbytestring-0.10.12.0Data.ByteString.Internal ByteString text-1.2.4.1Data.Text.InternalTextcontainers-0.6.2.1Data.Map.InternalMapbaseGHC.IOFilePathGHC.Exception.Type Exception SomeExceptionData.Set.InternalSet TempFoldersetup unpackTempTar RotatingLogdummyaddChunkcloseopenRotatingLogdefaultMaxTotalMonitoredProcessProcessTrackerinitProcessTrackermonitorProcessterminateMonitoredProcess"$fExceptionProcessTrackerException$fShowProcessTrackerExceptionNonEmptyVector ParseYamlFile parseYamlFileBaseDirdecodeFileRelative lookupBaselookupBaseMaybe$fParseYamlFileVector$fParseYamlFileSet$fParseYamlFile[]$fParseYamlFileNonEmptyVectorLabelMapinsertdeletelookup labelAssignedempty$fShowLabelEntry$fEqLabelEntry$fShowLabelMap $fEqLabelMap SSLConfigSSLFalseSSLTrueSSLAppId AIBuiltinAINamedKeterExceptionCannotParsePostgresExitCodeFailureNoPortsAvailableInvalidConfigFileInvalidKeterConfigFileCannotReserveHostsFileNotExecutableExecutableNotFound!EnsureAliveShouldBeBiggerThenZeroketerExceptionGot LogMessageProcessCreated InvalidBundleProcessDidNotStartExceptionThrown RemovingPortUnpackingBundleTerminatingAppFinishedReloadingTerminatingOldProcessRemovingOldFolderReceivedInotifyEventProcessWaiting OtherMessageErrorStartingBundleSanityChecksPassedReservingHostsForgetingReservations ActivatingAppDeactivatingAppReactivatingApp WatchedFile ReloadFrom TerminatingHostBSHostPort ToCurrentPrevious toCurrentPluginsPlugin pluginGetEnvAppname getAppnamelogEx$fToCurrentMaybe $fShowAppId$fExceptionKeterException$fShowLogMessage$fFromJSONSSLConfig$fToJSONSSLConfig$fParseYamlFileSSLConfig$fShowSSLConfig $fEqSSLConfig$fOrdSSLConfig$fShowKeterException $fEqAppId $fOrdAppIdMiddlewareConfigAcceptOverrideAutoheadJsonpMethodOverrideMethodOverridePost AddHeaders BasicAuthLocalprocessMiddleware toMiddlewarecomposeMiddleware$fToJSONMiddlewareConfig$fFromJSONMiddlewareConfig$fShowMiddlewareConfig$fGenericMiddlewareConfig RewriteRule ruleHeader ruleRegexruleReplacementReverseProxyConfig reversedHost reversedPortreversedUseSSL reversingHostreversingUseSSLreverseTimeoutrewriteResponseRulesrewriteRequestRulesRPEntryconfig httpManagersimpleReverseProxy$fToJSONRewriteRule$fFromJSONRewriteRule$fDefaultReverseProxyConfig$fToJSONReverseProxyConfig$fFromJSONReverseProxyConfig $fShowRPEntry$fEqReverseProxyConfig$fOrdReverseProxyConfig$fShowReverseProxyConfig$fEqRewriteRule$fOrdRewriteRule$fShowRewriteRule PortSettings portRange TLSConfig KeterConfig kconfigDirkconfigPortMan kconfigHost kconfigPort kconfigSsl kconfigSetuidkconfigReverseProxykconfigIpFromHeaderkconfigConnectionTimeBoundRedirectredFromredTo StaticHostshHostshRoot BundleConfig bconfigAppbconfigStaticHostsbconfigRedirects AppConfig configExec configArgs configHost configSslconfigExtraHosts configRaw fiveMinutes$fParseYamlFileAppConfig$fParseYamlFileStaticHost$fFromJSONRedirect$fParseYamlFileBundleConfig$fParseYamlFileTLSConfig$fFromJSONPortSettings$fDefaultPortSettings$fParseYamlFileKeterConfig$fDefaultKeterConfig $fEqRedirect $fOrdRedirect$fEqStaticHost$fOrdStaticHost RestartCountUnlimitedRestartsLimitedRestartsBackgroundConfig bgconfigExec bgconfigArgsbgconfigEnvironmentbgconfigRestartCountbgconfigRestartDelaySecondsbgconfigForwardEnvAppInputAIBundleAIData WebAppConfig waconfigExec waconfigArgswaconfigEnvironmentwaconfigApprootHost waconfigHosts waconfigSsl waconfigPortwaconfigForwardEnvwaconfigTimeoutwaconfigEnsureAliveTimeoutIsSecure RedirectDestRDUrlRDPrefix SourcePathSPAny SPSpecificRedirectActionRedirectConfigredirconfigHostsredirconfigStatusredirconfigActionsredirconfigSslStaticFilesConfig sfconfigRoot sfconfigHostssfconfigListingssfconfigMiddlewaresfconfigTimeout sfconfigSsl ProxyActionProxyActionRawPAPortPAStatic PARedirectPAReverseProxy StanzaRawStanzaStaticFilesStanzaRedirect StanzaWebAppStanzaReverseProxyStanzaBackgroundStanzaRequiresSecurekconfigPortPoolkconfigListenerskconfigBuiltinStanzaskconfigExternalHttpPortkconfigExternalHttpsPortkconfigEnvironment ListeningPortLPSecure LPInsecurebconfigStanzasbconfigPluginsaddRequiresSecure addStanzaType$fParseYamlFileListeningPort$fToJSONStaticFilesConfig $fParseYamlFileStaticFilesConfig$fToCurrentStaticFilesConfig$fToJSONRedirectDest$fFromJSONRedirectDest$fToJSONRedirectAction$fFromJSONRedirectAction$fToJSONRedirectConfig$fParseYamlFileRedirectConfig$fToCurrentRedirectConfig$fToJSONWebAppConfig$fParseYamlFileWebAppConfig$fToCurrentWebAppConfig$fFromJSONRestartCount$fToJSONBackgroundConfig$fParseYamlFileBackgroundConfig$fToJSONStanzaRaw$fToJSONStanza$fParseYamlFileStanza$fToCurrentKeterConfig$fToJSONBundleConfig$fToCurrentBundleConfig$fShowAppInput$fShowBundleConfig $fShowStanza$fShowStanzaRaw$fShowBackgroundConfig$fShowRestartCount$fShowWebAppConfig$fShowProxyActionRaw$fShowRedirectConfig$fShowRedirectAction$fShowRedirectDest$fShowSourcePath$fShowStaticFilesConfigPortPoolgetPort releasePortstartSettings setupDBInfoload$fDefaultDBServerInfo$fFromJSONDBServerInfo$fFromJSONDBInfo$fToJSONDBInfo$fDefaultSettings $fShowDBInfo$fShowDBServerInfo Reservations HostManager reserveHostsforgetReservations activateApp deactivateApp reactivateApp lookupActionAppStartConfig ascTempFolder ascSetuidascProcessTrackerascHostManager ascPortPool ascPluginsascLogascKeterConfigAppreload terminate getTimestamp $fShowAppActionReload Terminate AppManager initialize reloadAppListperformaddApp terminateApp HostLookup reverseProxyketer LabelEntry