{"id":34191410,"url":"https://github.com/ctdk/goas","last_synced_at":"2026-03-12T17:14:08.892Z","repository":{"id":18116186,"uuid":"21190547","full_name":"ctdk/goas","owner":"ctdk","description":"Tideland Go Application Support","archived":false,"fork":false,"pushed_at":"2014-06-25T05:16:01.000Z","size":139,"stargazers_count":0,"open_issues_count":0,"forks_count":3,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-12-18T16:03:49.146Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Go","has_issues":false,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-3-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ctdk.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2014-06-25T04:43:53.000Z","updated_at":"2015-09-09T07:54:38.000Z","dependencies_parsed_at":"2022-09-07T15:12:12.185Z","dependency_job_id":null,"html_url":"https://github.com/ctdk/goas","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/ctdk/goas","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ctdk%2Fgoas","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ctdk%2Fgoas/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ctdk%2Fgoas/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ctdk%2Fgoas/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ctdk","download_url":"https://codeload.github.com/ctdk/goas/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ctdk%2Fgoas/sbom","scorecard":{"id":311653,"data":{"date":"2025-08-11","repo":{"name":"github.com/ctdk/goas","commit":"18b5c55fb847882d6593b6487219572054f66a56"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/15 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: BSD 3-Clause \"New\" or \"Revised\" License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}}]},"last_synced_at":"2025-08-17T23:16:22.832Z","repository_id":18116186,"created_at":"2025-08-17T23:16:22.832Z","updated_at":"2025-08-17T23:16:22.832Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30434369,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-12T14:34:45.044Z","status":"ssl_error","status_checked_at":"2026-03-12T14:09:33.793Z","response_time":114,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-12-15T16:02:17.754Z","updated_at":"2026-03-12T17:14:08.860Z","avatar_url":"https://github.com/ctdk.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"Tideland Go Application Support\n===============================\n\nDescription\n-----------\n\nThe *Tideland Go Application Support* (GOAS) is a collection of smaller \nhelpful packages for multiple purposes. They are those little helpers we\nalways need. See their descriptions below.\n\nInstallation\n------------\n\n    go get github.com/tideland/goas/v3/errors\n    go get github.com/tideland/goas/v2/identifier\n    go get github.com/tideland/goas/v2/logger\n    go get github.com/tideland/goas/v2/loop\n    go get github.com/tideland/goas/v2/monitoring\n    go get github.com/tideland/goas/v1/scroller\n    go get github.com/tideland/goas/v2/times\n\nUsage\n-----\n\n**Errors**\n\nTypical errors in Go are often created using `errors.New()` or `fmt.Errorf()`. Those\nerrors only contain a string as information. When trying to differentiate between\nerrors or to carry helpful payload own types are needed.\n\nThe errors package allows to easily create formatted errors with `errors.New()` or \n`errors.Annotate()` like with the `fmt.Errorf()` function, but also with an error code. \nThis easily can be tested with `errors.IsError(err, code)`. \n\n**Identifier**\n\nThe identifier packge provides different ways to produce identifiers like UUIDs. The\nUUID generation follows version 4 (based on random numbers), other identifier types are\nbased on passed data or types. Here the individual parts are harmonized and concatenated\nby the passed seperators. It is the users responsibility to check if the identifier is\nunique in its context.\n\n**Logger**\n\nThis package helps to log with different levels and on different backends like on an\nio.Writer or the Go logging. Own backends can be defined based on a simple interface.\nSetting the level controls what will be logged. Debug and critical logging also print\nfilename, function name and line number.\n\n**Loop**\n\nA typical Go idiom for concurrent applications is running a loop in the background doing\na select on one or more channels. Stopping those loops or getting aware of internal errors\nrequires extra efforts. The loop package helps to manage this kind of goroutines.\n\nThe loop function, or method, looks like\n\n    func (f *Foo) backendLoop(l loop.Loop) error {\n            select {\n            case \u003c-l.ShallStop():\n                    return nil\n            case bar := \u003c-f.barChan:\n                    ...\n                    if err != nil {\n                            return err\n                    }\n            case baz := \u003c-f.bazChan:\n                    ...\n                    if err != nil {\n                            return err\n                    }\n            }\n    }\n\nThe loop is started with `l := loop.Go(f.backendLoop)`. Now the loop can be stopped with\n`l.Stop()` which will return `nil` in case of no error or the error that has been returned\nby the loop during message processing. The loop also can be killed with `l.Kill(err)` or\nthe status retrieved with `status, err := l.Error()`. The status is one of\n\n- `loop.Running`,\n- `loop.Stopping`, or \n- `loop.Stopped`.\n\nAnother variant is `loop.GoRecoverable(f.backendLoop, f.recoverFunc)`. Here a loop error\nor the value of a recovering after a panic are passed to the recover function. It then\ncan decide if the loop shall be restarted or really terminated.\n\n**Monitoring**\n\nThe monitoring package supports three kinds of system monitoring. They are helpful to\nunderstand what's happening inside a system during runtime. So execution times can be\nmeasured and analyzed, stay-set indicators integrated and dynamic control value retrieval\nprovided.\n\n    etm := monitoring.BeginMeasuring(\"foo\")\n    defer etm.EndMeasuring()\n\n    monitoring.SetVariable(\"bar\", 4711)\n    monitoring.IncrVariable(\"bar\")\n    monitoring.DecrVariable(\"bar\")\n\n    monitoring.Register(\"baz\", func() (string, error) { ... })\n\n**Scroller**\n\nA scroller allows a filtered streaming of lines from a `Reader` into a `Writer`. If the\nend of the data out of the reader is reached the scroller waits until new data is\ndelivered.\n\n**Timex**\n\nThe timex package supports the work with dates and times. Additionally it provides a\nsimple crontab.\n\nAnd now have fun. ;)\n\nDocumentation\n-------------\n\n- http://godoc.org/github.com/tideland/goas/v3/errors\n- http://godoc.org/github.com/tideland/goas/v2/identifier\n- http://godoc.org/github.com/tideland/goas/v2/logger\n- http://godoc.org/github.com/tideland/goas/v2/loop\n- http://godoc.org/github.com/tideland/goas/v2/monitoring\n- http://godoc.org/github.com/tideland/goas/v1/scroller\n- http://godoc.org/github.com/tideland/goas/v2/timex\n\nAuthors\n------\n\n- Frank Mueller - \u003cmue@tideland.biz\u003e\n\nLicense\n-------\n\n*Tideland Go Application Support* is distributed under the terms of the BSD 3-Clause license.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fctdk%2Fgoas","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fctdk%2Fgoas","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fctdk%2Fgoas/lists"}