diff options
author | Valery Piashchynski <[email protected]> | 2020-09-17 13:35:48 +0300 |
---|---|---|
committer | Valery Piashchynski <[email protected]> | 2020-09-17 13:35:48 +0300 |
commit | 08d6b6b7f773f83b286cd48c1a0fbec9a62fb42b (patch) | |
tree | afd077d7a3a22ed0999773f861d4c48d68e26b68 /_old/entry.go | |
parent | 0af502835616774a8b306596e4d1a8c5843b6bc8 (diff) |
Move old container to the _old folder
Diffstat (limited to '_old/entry.go')
-rw-r--r-- | _old/entry.go | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/_old/entry.go b/_old/entry.go new file mode 100644 index 00000000..0b2ad33e --- /dev/null +++ b/_old/entry.go @@ -0,0 +1,59 @@ +package _old + +import ( + "sync" +) + +const ( + // StatusUndefined when service bus can not find the service. + StatusUndefined = iota + + // StatusInactive when service has been registered in container. + StatusInactive + + // StatusOK when service has been properly configured. + StatusOK + + // StatusServing when service is currently done. + StatusServing + + // StatusStopping when service is currently stopping. + StatusStopping + + // StatusStopped when service being stopped. + StatusStopped +) + +// entry creates association between service instance and given name. +type entry struct { + name string + svc interface{} + mu sync.Mutex + status int +} + +// status returns service status +func (e *entry) getStatus() int { + e.mu.Lock() + defer e.mu.Unlock() + + return e.status +} + +// setStarted indicates that service hasStatus status. +func (e *entry) setStatus(status int) { + e.mu.Lock() + defer e.mu.Unlock() + e.status = status +} + +// hasStatus checks if entry in specific status +func (e *entry) hasStatus(status int) bool { + return e.getStatus() == status +} + +// canServe returns true is service can serve. +func (e *entry) canServe() bool { + _, ok := e.svc.(Service) + return ok +} |