{"id":3501789,"name":"github.com/gchaincl/sqlhooks","ecosystem":"go","description":"This example shows how to instrument sql queries in order to display the time that they consume package main import ( \"context\" \"database/sql\" \"fmt\" \"time\" \"github.com/gchaincl/sqlhooks\" \"github.com/mattn/go-sqlite3\" ) // Hooks satisfies the sqlhook.Hooks interface type Hooks struct {} // Before hook will print the query with it's args and return the context with the timestamp func (h *Hooks) Before(ctx context.Context, query string, args ...interface{}) (context.Context, error) { fmt.Printf(\"\u003e %s %q\", query, args) return context.WithValue(ctx, \"begin\", time.Now()), nil } // After hook will get the timestamp registered on the Before hook and print the elapsed time func (h *Hooks) After(ctx context.Context, query string, args ...interface{}) (context.Context, error) { begin := ctx.Value(\"begin\").(time.Time) fmt.Printf(\".","homepage":"https://github.com/gchaincl/sqlhooks","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/gchaincl/sqlhooks","keywords_array":[],"namespace":"github.com/gchaincl","versions_count":4,"first_release_published_at":"2017-05-08T08:47:50.000Z","latest_release_published_at":"2019-11-25T14:26:02.000Z","latest_release_number":"v1.3.0","last_synced_at":"2026-06-02T10:55:07.802Z","created_at":"2022-04-10T20:14:39.471Z","updated_at":"2026-06-02T10:55:07.802Z","registry_url":"https://pkg.go.dev/github.com/gchaincl/sqlhooks","install_command":"go get github.com/gchaincl/sqlhooks","documentation_url":"https://pkg.go.dev/github.com/gchaincl/sqlhooks#section-documentation","metadata":{},"repo_metadata":{"uuid":"56711473","full_name":"qustavo/sqlhooks","owner":"qustavo","description":"Attach hooks to any database/sql driver","archived":false,"fork":false,"pushed_at":"2022-08-29T16:19:57.000Z","size":110,"stargazers_count":602,"open_issues_count":8,"forks_count":42,"subscribers_count":9,"default_branch":"master","last_synced_at":"2023-03-13T16:01:54.025Z","etag":null,"topics":["database","driver","golang","instrumentation","opentracing","sql","sql-driver","tracing"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"logo_url":null,"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":"2016-04-20T18:37:14.000Z","updated_at":"2023-03-11T19:59:36.000Z","dependencies_parsed_at":"2022-07-21T04:49:40.663Z","dependency_job_id":null,"html_url":"https://github.com/qustavo/sqlhooks","commit_stats":null,"repository_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/qustavo%2Fsqlhooks","tags_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/qustavo%2Fsqlhooks/tags","manifests_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/qustavo%2Fsqlhooks/manifests","owner_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/qustavo","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":108921946,"host_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names"},"owner_record":{"login":"qustavo","name":"Gustavo Chaín","uuid":"1288313","kind":"user","description":"Technical Dealer","email":"","website":null,"location":"Siurana","twitter":null,"company":null,"avatar_url":"https://avatars.githubusercontent.com/u/1288313?u=39b374fe114a4c719f7c54b228f0f37ffaca8e6f\u0026v=4","repositories_count":41,"last_synced_at":"2023-02-16T03:15:21.570Z","metadata":{"has_sponsors_listing":false},"owner_url":"http://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/qustavo"},"tags":[{"name":"v2.1.0","sha":"a8e358e9521f1d55b7815d274eea8c5c9b0060b7","kind":"tag","published_at":"2021-08-08T08:42:42.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v2.1.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v2.1.0"},{"name":"v2.0.1","sha":"1b9e7183e69f37a50efe0ec7eccea5990ff9dab4","kind":"tag","published_at":"2021-01-27T10:10:55.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v2.0.1","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v2.0.1"},{"name":"v2.0.0","sha":"9db12c77f3a7c25e1e8282f7dd9015d2eb13eb25","kind":"commit","published_at":"2021-01-21T13:05:20.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v2.0.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v2.0.0"},{"name":"v1.3.0","sha":"e01e589194fe30567fdff020d15a2d26f16c5135","kind":"tag","published_at":"2019-11-25T14:50:25.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v1.3.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v1.3.0"},{"name":"v1.2.0","sha":"a494b89347123b3eecbd063569a25eb723595566","kind":"commit","published_at":"2019-11-05T17:12:36.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v1.2.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v1.2.0"},{"name":"v1.1.0","sha":"928fba38878d453967fcf9b4a0b7952b90c94d34","kind":"commit","published_at":"2018-01-30T21:27:56.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v1.1.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v1.1.0"},{"name":"v1.0.0","sha":"5805f20baa8b7dade6beb34b521b564b7a3533f7","kind":"commit","published_at":"2017-05-08T08:47:50.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v1.0.0","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v1.0.0"},{"name":"v0.4","sha":"51cae7f79563905f7a587f91c72f381be75f1d2b","kind":"commit","published_at":"2017-03-23T09:11:59.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v0.4","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v0.4"},{"name":"v0.3","sha":"3868017fad5de920ac9e3c38835e07888ec52639","kind":"commit","published_at":"2016-06-02T12:30:54.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v0.3","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v0.3"},{"name":"v0.2","sha":"eb2171e3dd4a467e077f291547ef9c21f059382f","kind":"commit","published_at":"2016-05-01T19:17:00.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v0.2","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v0.2"},{"name":"v0.1","sha":"c1a9c38bfc7ca62ea508da2a05b68241f977fe12","kind":"commit","published_at":"2016-04-25T02:47:33.000Z","download_url":"https://codeload.github.com/qustavo/sqlhooks/tar.gz/v0.1","html_url":"https://github.com/qustavo/sqlhooks/releases/tag/v0.1"}]},"repo_metadata_updated_at":"2026-05-23T18:33:05.398Z","dependent_packages_count":46,"downloads":null,"downloads_period":null,"dependent_repos_count":283,"rankings":{"downloads":null,"dependent_repos_count":0.3940592457706036,"dependent_packages_count":0.7373055887971031,"stargazers_count":2.415168377367726,"forks_count":3.6630765944296844,"docker_downloads_count":0.05547939381244024,"average":1.4530178400355114},"purl":"pkg:golang/github.com/gchaincl/sqlhooks","advisories":[],"docker_usage_url":"https://docker.ecosyste.ms/usage/go/github.com/gchaincl/sqlhooks","docker_dependents_count":301,"docker_downloads_count":4952912952,"usage_url":"https://repos.ecosyste.ms/usage/go/github.com/gchaincl/sqlhooks","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/go/github.com/gchaincl/sqlhooks/dependencies","status":null,"funding_links":[],"critical":null,"issue_metadata":{"last_synced_at":"2023-05-18T19:23:49.113Z","issues_count":22,"pull_requests_count":31,"avg_time_to_close_issue":23938121.17647059,"avg_time_to_close_pull_request":4074993.535714286,"issues_closed_count":17,"pull_requests_closed_count":28,"pull_request_authors_count":12,"issue_authors_count":16,"avg_comments_per_issue":3.5,"avg_comments_per_pull_request":3.774193548387097,"merged_pull_requests_count":21,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":2,"past_year_pull_requests_count":1,"past_year_avg_time_to_close_issue":null,"past_year_avg_time_to_close_pull_request":null,"past_year_issues_closed_count":0,"past_year_pull_requests_closed_count":0,"past_year_pull_request_authors_count":1,"past_year_issue_authors_count":2,"past_year_avg_comments_per_issue":2.5,"past_year_avg_comments_per_pull_request":1.0,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/version_numbers","latest_version_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/latest_version","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/related_packages","codemeta_url":"https://packages.ecosyste.ms/api/v1/registries/proxy.golang.org/packages/github.com%2Fgchaincl%2Fsqlhooks/codemeta","maintainers":[]}