Date: Tue, 27 Dec 2022 20:36:39 GMT From: Xin LI <delphij@FreeBSD.org> To: ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-main@FreeBSD.org Subject: git: 59878ba8f59c - main - www/remark42: A privacy-focused lightweight commenting engine Message-ID: <202212272036.2BRKadeZ083399@gitrepo.freebsd.org>
next in thread | raw e-mail | index | archive | help
The branch main has been updated by delphij: URL: https://cgit.FreeBSD.org/ports/commit/?id=59878ba8f59cd479b091f542078b550ce0ced79e commit 59878ba8f59cd479b091f542078b550ce0ced79e Author: Xin LI <delphij@FreeBSD.org> AuthorDate: 2022-12-27 20:36:30 +0000 Commit: Xin LI <delphij@FreeBSD.org> CommitDate: 2022-12-27 20:36:31 +0000 www/remark42: A privacy-focused lightweight commenting engine Remark42 allows you to have a self-hosted, lightweight, and simple (yet functional) comment engine, which doesn't spy on users. It can be embedded into blogs, articles or any other place where readers add comments. --- www/Makefile | 1 + www/remark42/Makefile | 138 +++++++++++++++++++++ www/remark42/distinfo | 143 +++++++++++++++++++++ www/remark42/files/remark.in | 288 +++++++++++++++++++++++++++++++++++++++++++ www/remark42/pkg-descr | 3 + 5 files changed, 573 insertions(+) diff --git a/www/Makefile b/www/Makefile index 6059870b367b..84edeb519062 100644 --- a/www/Makefile +++ b/www/Makefile @@ -1819,6 +1819,7 @@ SUBDIR += rearx SUBDIR += redmine42 SUBDIR += redmine50 + SUBDIR += remark42 SUBDIR += rejik SUBDIR += reportmagic SUBDIR += repos-style diff --git a/www/remark42/Makefile b/www/remark42/Makefile new file mode 100644 index 000000000000..5b161d67b380 --- /dev/null +++ b/www/remark42/Makefile @@ -0,0 +1,138 @@ +PORTNAME= remark42 +DISTVERSIONPREFIX= v +DISTVERSION= 1.11.2 +CATEGORIES= www +MASTER_SITES= LOCAL/delphij:npmcache +DISTFILES= ${PORTNAME}-npm-cache-${DISTVERSION}${EXTRACT_SUFX}:npmcache + +MAINTAINER= delphij@FreeBSD.org +COMMENT= Privacy-focused lightweight commenting engine +WWW= https://remark42.com/ + +LICENSE= MIT +LICENSE_FILE= ${WRKSRC}/LICENSE + +BUILD_DEPENDS+= npm-node16>0:www/npm-node16 + +USES= cpe go:modules tar:xz + +GO_BUILDFLAGS= -ldflags "-s -w -X main.revision=${DISTVERSION}" +GO_TARGET= app:${PREFIX}/libexec/${PORTNAME} +GO_PKGNAME= github.com/${GH_ACCOUNT}/${PORTNAME}/backend +LD_FLAG_X_PREFIX= -X ${GO_PKGNAME}/version + +MAKE_ENV+= npm_config_offline=true + +USE_RC_SUBR= ${PORTNAME} + +USE_GITHUB= yes +GH_ACCOUNT= umputun + +PLIST_FILES= libexec/${PORTNAME} + +GH_TUPLE= \ + Depado:bfchroma:v2.0.0:depado_bfchroma_v2/vendor/github.com/Depado/bfchroma/v2 \ + PuerkitoBio:goquery:v1.8.0:puerkitobio_goquery/vendor/github.com/PuerkitoBio/goquery \ + ajg:form:v1.5.1:ajg_form/vendor/github.com/ajg/form \ + alecthomas:chroma:v2.3.0:alecthomas_chroma_v2/vendor/github.com/alecthomas/chroma/v2 \ + andybalholm:cascadia:v1.3.1:andybalholm_cascadia/vendor/github.com/andybalholm/cascadia \ + aymerick:douceur:v0.2.0:aymerick_douceur/vendor/github.com/aymerick/douceur \ + cespare:xxhash:v2.1.2:cespare_xxhash_v2/vendor/github.com/cespare/xxhash/v2 \ + davecgh:go-spew:v1.1.1:davecgh_go_spew/vendor/github.com/davecgh/go-spew \ + dghubble:oauth1:v0.7.1:dghubble_oauth1/vendor/github.com/dghubble/oauth1 \ + dgryski:go-rendezvous:9f7001d12a5f:dgryski_go_rendezvous/vendor/github.com/dgryski/go-rendezvous \ + didip:tollbooth:v7.0.1:didip_tollbooth_v7/vendor/github.com/didip/tollbooth/v7 \ + didip:tollbooth_chi:d662a7f6928f:didip_tollbooth_chi/vendor/github.com/didip/tollbooth_chi \ + dlclark:regexp2:v1.4.0:dlclark_regexp2/vendor/github.com/dlclark/regexp2 \ + etcd-io:bbolt:v1.3.6:etcd_io_bbolt/vendor/go.etcd.io/bbolt \ + go-chi:chi:v5.0.7:go_chi_chi_v5/vendor/github.com/go-chi/chi/v5 \ + go-chi:cors:v1.2.1:go_chi_cors/vendor/github.com/go-chi/cors \ + go-chi:render:v1.0.2:go_chi_render/vendor/github.com/go-chi/render \ + go-oauth2:oauth2:v4.5.1:go_oauth2_oauth2_v4/vendor/github.com/go-oauth2/oauth2/v4 \ + go-pkgz:auth:v1.20.0:go_pkgz_auth/vendor/github.com/go-pkgz/auth \ + go-pkgz:email:v0.4.0:go_pkgz_email/vendor/github.com/go-pkgz/email \ + go-pkgz:expirable-cache:v0.1.0:go_pkgz_expirable_cache/vendor/github.com/go-pkgz/expirable-cache \ + go-pkgz:jrpc:v0.3.0:go_pkgz_jrpc/vendor/github.com/go-pkgz/jrpc \ + go-pkgz:lcw:v1.0.1:go_pkgz_lcw/vendor/github.com/go-pkgz/lcw \ + go-pkgz:lgr:v0.10.4:go_pkgz_lgr/vendor/github.com/go-pkgz/lgr \ + go-pkgz:notify:v0.2.0:go_pkgz_notify/vendor/github.com/go-pkgz/notify \ + go-pkgz:repeater:v1.1.3:go_pkgz_repeater/vendor/github.com/go-pkgz/repeater \ + go-pkgz:rest:v1.16.0:go_pkgz_rest/vendor/github.com/go-pkgz/rest \ + go-pkgz:syncs:v1.2.0:go_pkgz_syncs/vendor/github.com/go-pkgz/syncs \ + go-redis:redis:v8.11.5:go_redis_redis_v8/vendor/github.com/go-redis/redis/v8 \ + go-yaml:yaml:v3.0.1:go_yaml_yaml/vendor/gopkg.in/yaml.v3 \ + golang-jwt:jwt:v3.2.2:golang_jwt_jwt/vendor/github.com/golang-jwt/jwt \ + golang:appengine:v1.6.7:golang_appengine/vendor/google.golang.org/appengine \ + golang:crypto:05595931fe9d:golang_crypto/vendor/golang.org/x/crypto \ + golang:image:41969df76e82:golang_image/vendor/golang.org/x/image \ + golang:net:83b083e8dc8b:golang_net/vendor/golang.org/x/net \ + golang:oauth2:9780585627b5:golang_oauth2/vendor/golang.org/x/oauth2 \ + golang:protobuf:v1.5.2:golang_protobuf/vendor/github.com/golang/protobuf \ + golang:snappy:v0.0.4:golang_snappy/vendor/github.com/golang/snappy \ + golang:sync:036812b2e83c:golang_sync/vendor/golang.org/x/sync \ + golang:sys:3c1f35247d10:golang_sys/vendor/golang.org/x/sys \ + golang:text:v0.3.7:golang_text/vendor/golang.org/x/text \ + google:uuid:v1.3.0:google_uuid/vendor/github.com/google/uuid \ + googleapis:google-cloud-go:compute/v1.6.1:googleapis_google_cloud_go_compute/vendor/cloud.google.com/go \ + gorilla:css:v1.0.0:gorilla_css/vendor/github.com/gorilla/css \ + gorilla:feeds:v1.1.1:gorilla_feeds/vendor/github.com/gorilla/feeds \ + gorilla:websocket:v1.5.0:gorilla_websocket/vendor/github.com/gorilla/websocket \ + hashicorp:errwrap:v1.1.0:hashicorp_errwrap/vendor/github.com/hashicorp/errwrap \ + hashicorp:go-multierror:v1.1.1:hashicorp_go_multierror/vendor/github.com/hashicorp/go-multierror \ + hashicorp:golang-lru:v0.5.4:hashicorp_golang_lru/vendor/github.com/hashicorp/golang-lru \ + jessevdk:go-flags:v1.5.0:jessevdk_go_flags/vendor/github.com/jessevdk/go-flags \ + klauspost:compress:v1.15.2:klauspost_compress/vendor/github.com/klauspost/compress \ + kyokomi:emoji:v2.2.10:kyokomi_emoji_v2/vendor/github.com/kyokomi/emoji/v2 \ + microcosm-cc:bluemonday:v1.0.20:microcosm_cc_bluemonday/vendor/github.com/microcosm-cc/bluemonday \ + mongodb:mongo-go-driver:v1.10.2:mongodb_mongo_go_driver/vendor/go.mongodb.org/mongo-driver \ + montanaflynn:stats:1bf9dbcd8cbe:montanaflynn_stats/vendor/github.com/montanaflynn/stats \ + nullrocks:identicon:7875f45b0022:nullrocks_identicon/vendor/github.com/nullrocks/identicon \ + pkg:errors:v0.9.1:pkg_errors/vendor/github.com/pkg/errors \ + pmezard:go-difflib:v1.0.0:pmezard_go_difflib/vendor/github.com/pmezard/go-difflib \ + protocolbuffers:protobuf-go:v1.28.0:protocolbuffers_protobuf_go/vendor/google.golang.org/protobuf \ + rs:xid:v1.4.0:rs_xid/vendor/github.com/rs/xid \ + russross:blackfriday:v2.1.0:russross_blackfriday_v2/vendor/github.com/russross/blackfriday/v2 \ + skip2:go-qrcode:da1b6568686e:skip2_go_qrcode/vendor/github.com/skip2/go-qrcode \ + slack-go:slack:v0.11.3:slack_go_slack/vendor/github.com/slack-go/slack \ + stretchr:testify:v1.8.0:stretchr_testify/vendor/github.com/stretchr/testify \ + uber-go:goleak:v1.2.0:uber_go_goleak/vendor/go.uber.org/goleak \ + xdg-go:pbkdf2:v1.0.0:xdg_go_pbkdf2/vendor/github.com/xdg-go/pbkdf2 \ + xdg-go:scram:v1.1.1:xdg_go_scram/vendor/github.com/xdg-go/scram \ + xdg-go:stringprep:v1.0.3:xdg_go_stringprep/vendor/github.com/xdg-go/stringprep \ + youmark:pkcs8:1326539a0a0a:youmark_pkcs8/vendor/github.com/youmark/pkcs8 + +REMARK_PIDDIR= /var/run/${PORTNAME}/ +REMARK_USER?= www +REMARK_DATADIR?=/var/db/${PORTNAME} + +REMARK_URL?= http://127.0.0.1:8080 + +USE_RC_SUBR= remark + +SUB_LIST+= REMARK_PIDDIR=${REMARK_PIDDIR} \ + REMARK_USER=${REMARK_USER} \ + REMARK_DATADIR=${REMARK_DATADIR} + +# (for maintainer) helper target to generate node_modules tarball +make-npm-cache: extract + @cd ${WRKDIR} && ${RM} -r .npm + @cd ${WRKSRC}/frontend/apps/${PORTNAME} \ + && ${SETENV} HOME=${WRKDIR} npm install + @cd ${WRKDIR} \ + && ${TAR} -cJf ${PORTNAME}-npm-cache-${DISTVERSION}${EXTRACT_SUFX} .npm \ + ${PORTNAME}-${DISTVERSION}/frontend/apps/remark42/package-lock.json \ + && ${ECHO} "Please upload the file ${WRKDIR}/${PORTNAME}-npm-cache-${DISTVERSION}${EXTRACT_SUFX}" + +pre-build: + cd ${WRKSRC}/frontend/apps/${PORTNAME} && ${SETENV} HOME=${WRKDIR} npm install + cd ${WRKSRC}/frontend/apps/${PORTNAME} && ${SETENV} HOME=${WRKDIR} npm run build + ${RM} -r ${WRKSRC}/backend/app/cmd/web/ + ${MV} ${WRKSRC}/frontend/apps/remark42/public ${WRKSRC}/backend/app/cmd/web + ${FIND} ${WRKSRC}/backend/app/cmd/web -type f \( -name '*.html' -or -name '*.js' -or -name '*.mjs' \) \ + -print -exec ${REINPLACE_CMD} -e "s|{% REMARK_URL %}|${REMARK_URL}|g" {} + + +do-build: + cd ${WRKSRC}/backend && ${SETENV} ${MAKE_ENV} ${GO_ENV} GOPROXY=off ${GO_CMD} build ${GO_BUILDFLAGS} \ + -o ${GO_WRKDIR_BIN}/${PORTNAME} ./app + +.include <bsd.port.mk> diff --git a/www/remark42/distinfo b/www/remark42/distinfo new file mode 100644 index 000000000000..ab9dce036dcd --- /dev/null +++ b/www/remark42/distinfo @@ -0,0 +1,143 @@ +TIMESTAMP = 1671646617 +SHA256 (remark42-npm-cache-1.11.2.tar.xz) = fa998c535034402555e6922c0ff139568be9708cea793ee7aacc3694e349f793 +SIZE (remark42-npm-cache-1.11.2.tar.xz) = 106273124 +SHA256 (umputun-remark42-v1.11.2_GH0.tar.gz) = f05b5ef33e7642ad06ae28636a08080d0fb319e75ab118b1282ff8512752ccf9 +SIZE (umputun-remark42-v1.11.2_GH0.tar.gz) = 5742684 +SHA256 (Depado-bfchroma-v2.0.0_GH0.tar.gz) = d999d4cf56554c15fe8d1651e4b5e87dbd5b399a0d4c7af7bc7b682e93da4f18 +SIZE (Depado-bfchroma-v2.0.0_GH0.tar.gz) = 7451 +SHA256 (PuerkitoBio-goquery-v1.8.0_GH0.tar.gz) = 3b7c6f02d8ecea5f615d6b55a925403e51ae26b13dec93ccdbd7d99d79aff231 +SIZE (PuerkitoBio-goquery-v1.8.0_GH0.tar.gz) = 105200 +SHA256 (ajg-form-v1.5.1_GH0.tar.gz) = 085e8e98cf63d39241c6ba815b9a71d38808c3fadb6b522feb7fab6d123c44c7 +SIZE (ajg-form-v1.5.1_GH0.tar.gz) = 14946 +SHA256 (alecthomas-chroma-v2.3.0_GH0.tar.gz) = 1dc319a4b5f584858165900c94aa4cdef03f0f8e7a95fe3a3d0ab04bc0403c8c +SIZE (alecthomas-chroma-v2.3.0_GH0.tar.gz) = 875885 +SHA256 (andybalholm-cascadia-v1.3.1_GH0.tar.gz) = ced0bf6f8daadb38619be1e70675c6920c994649b83cd0a20e9e096c3785eb72 +SIZE (andybalholm-cascadia-v1.3.1_GH0.tar.gz) = 33071 +SHA256 (aymerick-douceur-v0.2.0_GH0.tar.gz) = ceed015cddc99b600ccbbd6aa0ebe39063554049f70153887d3df7c21fefedbb +SIZE (aymerick-douceur-v0.2.0_GH0.tar.gz) = 20914 +SHA256 (cespare-xxhash-v2.1.2_GH0.tar.gz) = 471399cfcf0b1bd188add8d34435b91e7011cedbfe76e29687803a9d74320352 +SIZE (cespare-xxhash-v2.1.2_GH0.tar.gz) = 11244 +SHA256 (davecgh-go-spew-v1.1.1_GH0.tar.gz) = 7d82b9bb7291adbe7498fe946920ab3e7fc9e6cbfc3b2294693fad00bf0dd17e +SIZE (davecgh-go-spew-v1.1.1_GH0.tar.gz) = 42152 +SHA256 (dghubble-oauth1-v0.7.1_GH0.tar.gz) = 6f31adddfcaff9f52106a2cfefc274daf6eeec5d4439e8ab032ec1495e6c050e +SIZE (dghubble-oauth1-v0.7.1_GH0.tar.gz) = 22523 +SHA256 (dgryski-go-rendezvous-9f7001d12a5f_GH0.tar.gz) = 29584550745fd4b8fce2e2f3def7b9d9ffe2b86cf9b6596b53a660c9bbfe27b6 +SIZE (dgryski-go-rendezvous-9f7001d12a5f_GH0.tar.gz) = 1699 +SHA256 (didip-tollbooth-v7.0.1_GH0.tar.gz) = fc8258f324a0232ee6fbbc327b3d5ead417349ef4c179fd04a9281fa9363fb99 +SIZE (didip-tollbooth-v7.0.1_GH0.tar.gz) = 26431 +SHA256 (didip-tollbooth_chi-d662a7f6928f_GH0.tar.gz) = a64242f72a7c7274ce3ba6416fe3028c9c9c13edbfd633a0c2748f8641cbf60a +SIZE (didip-tollbooth_chi-d662a7f6928f_GH0.tar.gz) = 1830 +SHA256 (dlclark-regexp2-v1.4.0_GH0.tar.gz) = 774718cb87c5cc7b954e4f17056f6a189c8d542ecbf989330296bc7e3885851b +SIZE (dlclark-regexp2-v1.4.0_GH0.tar.gz) = 205882 +SHA256 (etcd-io-bbolt-v1.3.6_GH0.tar.gz) = a2e524f7f32c44fa0765de192ac0789c585010cadd2c2ddcf9518e858a96ec1f +SIZE (etcd-io-bbolt-v1.3.6_GH0.tar.gz) = 98025 +SHA256 (go-chi-chi-v5.0.7_GH0.tar.gz) = 23873c5982e0c9929d46f4432ff9c89dcfbce29ca2db54f2058e67e5361a2b1f +SIZE (go-chi-chi-v5.0.7_GH0.tar.gz) = 82798 +SHA256 (go-chi-cors-v1.2.1_GH0.tar.gz) = d3fa42948b4b365db19c9a6639090c6869b968fa8c5ecb9635dce1a9bf4cf8d8 +SIZE (go-chi-cors-v1.2.1_GH0.tar.gz) = 8827 +SHA256 (go-chi-render-v1.0.2_GH0.tar.gz) = f81077eeae4fc649891ee4a8d6259f25dbeb01f179c0b89242f2f8c439e69e0a +SIZE (go-chi-render-v1.0.2_GH0.tar.gz) = 6240 +SHA256 (go-oauth2-oauth2-v4.5.1_GH0.tar.gz) = 5939a767fb5a62ba88675dbf0eec297826c25126b6010b783df0cc0d49ffdd42 +SIZE (go-oauth2-oauth2-v4.5.1_GH0.tar.gz) = 579131 +SHA256 (go-pkgz-auth-v1.20.0_GH0.tar.gz) = 16a64d7ba01609ac29f0bba1c6a602377e1d2fedaaa39ddafa63687e7fafad3a +SIZE (go-pkgz-auth-v1.20.0_GH0.tar.gz) = 183489 +SHA256 (go-pkgz-email-v0.4.0_GH0.tar.gz) = 5d7a3939143f0650569d34035239211cf78f07a1011c4eec967bc77ae3241971 +SIZE (go-pkgz-email-v0.4.0_GH0.tar.gz) = 100651 +SHA256 (go-pkgz-expirable-cache-v0.1.0_GH0.tar.gz) = 910bff8add2ce863a6bb1dc95ddf08e07322605f4dbd4b793ed53ba279e7f0a4 +SIZE (go-pkgz-expirable-cache-v0.1.0_GH0.tar.gz) = 7161 +SHA256 (go-pkgz-jrpc-v0.3.0_GH0.tar.gz) = 158ec6a2c711cee4608f5c55ecc0692c3e38b0c6c4f2af01aea008a64822d988 +SIZE (go-pkgz-jrpc-v0.3.0_GH0.tar.gz) = 15188 +SHA256 (go-pkgz-lcw-v1.0.1_GH0.tar.gz) = bcc39f9b32d71635640c322c9d88ed0ddc86a1cb63b4a19224570f0bcbbfc223 +SIZE (go-pkgz-lcw-v1.0.1_GH0.tar.gz) = 29082 +SHA256 (go-pkgz-lgr-v0.10.4_GH0.tar.gz) = c55109e8c62706e210bc960e5f18ffa020af362c6b17ac39cfefc4a88b387351 +SIZE (go-pkgz-lgr-v0.10.4_GH0.tar.gz) = 14722 +SHA256 (go-pkgz-notify-v0.2.0_GH0.tar.gz) = 558eecf2a17c45b1c66fbf88f7647c17f06450867e92f3dffeb55c59700f7077 +SIZE (go-pkgz-notify-v0.2.0_GH0.tar.gz) = 18854 +SHA256 (go-pkgz-repeater-v1.1.3_GH0.tar.gz) = d3c6bdece4cd305e33efc64369aaab9ebf0452dffb7bd841b9e5a8e861607f43 +SIZE (go-pkgz-repeater-v1.1.3_GH0.tar.gz) = 6059 +SHA256 (go-pkgz-rest-v1.16.0_GH0.tar.gz) = d093822737d543b36865a6afc943cdf857d25686ac87082e4fac62ef4a1e3390 +SIZE (go-pkgz-rest-v1.16.0_GH0.tar.gz) = 30179 +SHA256 (go-pkgz-syncs-v1.2.0_GH0.tar.gz) = 5b5dfca765afa5b80af4a8f721cf2c7143ae9962a52db72fa0a4246ad1d97bc8 +SIZE (go-pkgz-syncs-v1.2.0_GH0.tar.gz) = 6931 +SHA256 (go-redis-redis-v8.11.5_GH0.tar.gz) = 49f307ad85960c25d98bea3b2d155c893e43f41831c1bb4891e1eb867ead1245 +SIZE (go-redis-redis-v8.11.5_GH0.tar.gz) = 168188 +SHA256 (go-yaml-yaml-v3.0.1_GH0.tar.gz) = cf05411540d3e6ef8f1fd88434b34f94cedaceb540329031d80e23b74540c4e5 +SIZE (go-yaml-yaml-v3.0.1_GH0.tar.gz) = 91173 +SHA256 (golang-jwt-jwt-v3.2.2_GH0.tar.gz) = 4cd18a4bb5d949244f137fed0884f93695ff268cb9efaba71ddcf4c50b17efe0 +SIZE (golang-jwt-jwt-v3.2.2_GH0.tar.gz) = 39887 +SHA256 (golang-appengine-v1.6.7_GH0.tar.gz) = c623d81235f7c9699e299b328191d813337dd57dcc800d7afdb5130e8c321a8f +SIZE (golang-appengine-v1.6.7_GH0.tar.gz) = 333007 +SHA256 (golang-crypto-05595931fe9d_GH0.tar.gz) = ce17e1237290dc1666351238e0ab42d2821b0a0bd48490402a1779be82d67910 +SIZE (golang-crypto-05595931fe9d_GH0.tar.gz) = 1631418 +SHA256 (golang-image-41969df76e82_GH0.tar.gz) = 2692f7c8621ea6ece3dabef5de26bf4b4b945ff11be6b4117bdb8e091e8098e7 +SIZE (golang-image-41969df76e82_GH0.tar.gz) = 5038491 +SHA256 (golang-net-83b083e8dc8b_GH0.tar.gz) = 39e58948d9d65c8f6be2b9fc0f5c2993179f740aad764fa8d7387ddf293d0121 +SIZE (golang-net-83b083e8dc8b_GH0.tar.gz) = 1226340 +SHA256 (golang-oauth2-9780585627b5_GH0.tar.gz) = 1c811dfb03781324c5a8bcd9124e437ed15253139fecbfe9f4106363bbe3b5c5 +SIZE (golang-oauth2-9780585627b5_GH0.tar.gz) = 88428 +SHA256 (golang-protobuf-v1.5.2_GH0.tar.gz) = 088cc0f3ba18fb8f9d00319568ff0af5a06d8925a6e6cb983bb837b4efb703b3 +SIZE (golang-protobuf-v1.5.2_GH0.tar.gz) = 171702 +SHA256 (golang-snappy-v0.0.4_GH0.tar.gz) = 77df678795596f9dfecb5744deb984633d780460a7e9a59e0c7ecfe2052b644f +SIZE (golang-snappy-v0.0.4_GH0.tar.gz) = 66129 +SHA256 (golang-sync-036812b2e83c_GH0.tar.gz) = 75ac8fc16bdceb2496c4a9cc98584b70c29032d91a9e57a624acb073e3232fda +SIZE (golang-sync-036812b2e83c_GH0.tar.gz) = 18752 +SHA256 (golang-sys-3c1f35247d10_GH0.tar.gz) = 27fdc75cc74da979f59142f1f5a1f08505c55918a0d5019ed4ebb04901834842 +SIZE (golang-sys-3c1f35247d10_GH0.tar.gz) = 1336787 +SHA256 (golang-text-v0.3.7_GH0.tar.gz) = 7cab2f6c3133ac1d422edd952b0dd2082fa55a73c2663fb2defd9bf83d649b26 +SIZE (golang-text-v0.3.7_GH0.tar.gz) = 8354718 +SHA256 (google-uuid-v1.3.0_GH0.tar.gz) = 7f7f37c47980e0afcc178a9ffc390bec29ed2371919b4c07658eb01791a7f921 +SIZE (google-uuid-v1.3.0_GH0.tar.gz) = 16210 +SHA256 (googleapis-google-cloud-go-compute-v1.6.1_GH0.tar.gz) = b93ea68f6191465d4ebb5885303eedc661eac1e3729f60d0af9335653897cfd0 +SIZE (googleapis-google-cloud-go-compute-v1.6.1_GH0.tar.gz) = 7801792 +SHA256 (gorilla-css-v1.0.0_GH0.tar.gz) = 9decf83063b85bcd5392f645fac322e986b5fc596b3e44c3be02ee5939106f4c +SIZE (gorilla-css-v1.0.0_GH0.tar.gz) = 6443 +SHA256 (gorilla-feeds-v1.1.1_GH0.tar.gz) = 361482738014da53e03d0be5b22d39f3a4d9a8f258cf7e09faf3694ee63e091f +SIZE (gorilla-feeds-v1.1.1_GH0.tar.gz) = 14733 +SHA256 (gorilla-websocket-v1.5.0_GH0.tar.gz) = 5d86f9e1c76ff7ceca0747f78b79864fbaec9d440f4fdb03197466e5102a86b0 +SIZE (gorilla-websocket-v1.5.0_GH0.tar.gz) = 54155 +SHA256 (hashicorp-errwrap-v1.1.0_GH0.tar.gz) = 0d73891a7a179e50a142ac8832db97b17c792d29ae205b0e6aeedde4c43d51a4 +SIZE (hashicorp-errwrap-v1.1.0_GH0.tar.gz) = 8581 +SHA256 (hashicorp-go-multierror-v1.1.1_GH0.tar.gz) = 8d1bb3377310e8ffe4c7b5672c5de1eaed153402aebd15d6e5b9673c356a065f +SIZE (hashicorp-go-multierror-v1.1.1_GH0.tar.gz) = 13803 +SHA256 (hashicorp-golang-lru-v0.5.4_GH0.tar.gz) = d50c188af0cc8b22e7e4b79e9071694fa06428a9964b22d68dc997fa787a177a +SIZE (hashicorp-golang-lru-v0.5.4_GH0.tar.gz) = 13428 +SHA256 (jessevdk-go-flags-v1.5.0_GH0.tar.gz) = d4bf30f729cbc16d2aa0095ac10ca4fadc8f092b9a28990c0cfca2345c3e7ffd +SIZE (jessevdk-go-flags-v1.5.0_GH0.tar.gz) = 59316 +SHA256 (klauspost-compress-v1.15.2_GH0.tar.gz) = 025b574782b167ec1b25d5ab2ac38abf589feabe7e7236dbff4b8a007a2a9423 +SIZE (klauspost-compress-v1.15.2_GH0.tar.gz) = 16074509 +SHA256 (kyokomi-emoji-v2.2.10_GH0.tar.gz) = 1efa7937b408c979d18799290402bb7edfa9b5043801a250e4d7b4a9fafe8788 +SIZE (kyokomi-emoji-v2.2.10_GH0.tar.gz) = 103029 +SHA256 (microcosm-cc-bluemonday-v1.0.20_GH0.tar.gz) = 3664d074b28ec7929e248b39aeea9fdf93a5f96e8fb75c3346c4875810cd5c7e +SIZE (microcosm-cc-bluemonday-v1.0.20_GH0.tar.gz) = 171139 +SHA256 (mongodb-mongo-go-driver-v1.10.2_GH0.tar.gz) = 5c2068ae9fd9fd7f59794396edc0c06a215743bb5cf5fe04d924358b19855630 +SIZE (mongodb-mongo-go-driver-v1.10.2_GH0.tar.gz) = 4620702 +SHA256 (montanaflynn-stats-1bf9dbcd8cbe_GH0.tar.gz) = f850d83c5404eb5c5995e95a54e7bde802d967f72b4e4ee82673865d5077a867 +SIZE (montanaflynn-stats-1bf9dbcd8cbe_GH0.tar.gz) = 19343 +SHA256 (nullrocks-identicon-7875f45b0022_GH0.tar.gz) = d1e5a569e2314748c2523ec8aa6603a9db09d128c408148add8630b7b0b44580 +SIZE (nullrocks-identicon-7875f45b0022_GH0.tar.gz) = 24819 +SHA256 (pkg-errors-v0.9.1_GH0.tar.gz) = 56bfd893023daa498508bfe161de1be83299fcf15376035e7df79cbd7d6fa608 +SIZE (pkg-errors-v0.9.1_GH0.tar.gz) = 13415 +SHA256 (pmezard-go-difflib-v1.0.0_GH0.tar.gz) = 28f3dc1b5c0efd61203ab07233f774740d3bf08da4d8153fb5310db6cea0ebda +SIZE (pmezard-go-difflib-v1.0.0_GH0.tar.gz) = 11398 +SHA256 (protocolbuffers-protobuf-go-v1.28.0_GH0.tar.gz) = e59ae9ace31c3a84bddf1bc3f04a04c498adb9ea7f9fcde60db91bba33d55171 +SIZE (protocolbuffers-protobuf-go-v1.28.0_GH0.tar.gz) = 1279757 +SHA256 (rs-xid-v1.4.0_GH0.tar.gz) = e3fd89f7cbbc8bf8268235b353e9aa026c2aed741bb3a6d38ec34abd60883f01 +SIZE (rs-xid-v1.4.0_GH0.tar.gz) = 10994 +SHA256 (russross-blackfriday-v2.1.0_GH0.tar.gz) = a13af0fc5305713f5154693feaf654d024689efea76390091a5e8c757335b4f4 +SIZE (russross-blackfriday-v2.1.0_GH0.tar.gz) = 92896 +SHA256 (skip2-go-qrcode-da1b6568686e_GH0.tar.gz) = af179c37da861a43242fb4383186724b34866d7b5bd3e54ca44031a2b9f92046 +SIZE (skip2-go-qrcode-da1b6568686e_GH0.tar.gz) = 36693 +SHA256 (slack-go-slack-v0.11.3_GH0.tar.gz) = ab4f67822333c2897af33f62be49d637c0e7d9bb4370ac94ac595226ebbbe687 +SIZE (slack-go-slack-v0.11.3_GH0.tar.gz) = 366052 +SHA256 (stretchr-testify-v1.8.0_GH0.tar.gz) = c31f0bc88114cc11a3d1f2e837d2c0aa7b4cd28c7b81e1946d47c158ba3e6841 +SIZE (stretchr-testify-v1.8.0_GH0.tar.gz) = 97595 +SHA256 (uber-go-goleak-v1.2.0_GH0.tar.gz) = 360d6a48d28e003eac42e6b01f0550d9f870dcca074e7bd87216a3fa49b822c9 +SIZE (uber-go-goleak-v1.2.0_GH0.tar.gz) = 13351 +SHA256 (xdg-go-pbkdf2-v1.0.0_GH0.tar.gz) = 2eec55146447215eb58190e04c546c93cad7f369ac9b5aacd9dc11330d756757 +SIZE (xdg-go-pbkdf2-v1.0.0_GH0.tar.gz) = 7758 +SHA256 (xdg-go-scram-v1.1.1_GH0.tar.gz) = ead1bc7c262e7258c9e4c8fb05507e90f17a3bccfc289f6b2f81696329a22142 +SIZE (xdg-go-scram-v1.1.1_GH0.tar.gz) = 17555 +SHA256 (xdg-go-stringprep-v1.0.3_GH0.tar.gz) = 274337fc163cc1d2c30a85de51bd874c0caadd954a3e40f0de65eff883f3629d +SIZE (xdg-go-stringprep-v1.0.3_GH0.tar.gz) = 30127 +SHA256 (youmark-pkcs8-1326539a0a0a_GH0.tar.gz) = fa6a73620cb59309acec57b0c8743cf19322c09da3aaa66e9dd55b5bbf57c309 +SIZE (youmark-pkcs8-1326539a0a0a_GH0.tar.gz) = 14322 diff --git a/www/remark42/files/remark.in b/www/remark42/files/remark.in new file mode 100644 index 000000000000..ed7f7a2d754c --- /dev/null +++ b/www/remark42/files/remark.in @@ -0,0 +1,288 @@ +#!/bin/sh + +# PROVIDE: remark +# REQUIRE: LOGIN +# KEYWORD: shutdown + +# Add the following lines to /etc/rc.conf to enable remark +# remark_enable="YES" +# +# Required settings: +# remark_enable (bool): Set to YES to enable remark +# Default: NO +# remark_url (str): URL to Remark42 server, required +# +# Options: +# remark_secret (str): 256-bit shared key used to sign JWT. +# Default: random string +# remark_site (str): site name(s), multi +# Default: remark +# remark_store_type (str): type of storage, bolt or rpc +# Default: bolt +# remark_store_bolt_path (str): parent directory for the bolt files +# Default: %%REMARK42_DATADIR%% +# remark_backup_path (str): backups location +# Default: %%REMARK_DATADIR%%/backup +# remark_avatar_fs_path (str): avatars location for fs store +# Default: %%REMARK_DATADIR%%/avatars +# remark_avatar_bolt_file (str): +# avatars bolt file location +# Default: %%REMARK_DATADIR%%/avatars.db +# remark_avatar_uri (str): avatars store URI +# Default: %%REMARK_DATADIR%%/avatars +# remark_image_fs_path (str): permanent location of images +# Default: %%REMARK_DATADIR%%/pictures +# remark_image_fs_staging (str): +# staging location of images +# Default: %%REMARK_DATADIR%%/pictures.staging +# remark_image_bolt_file (str): images bolt file location +# Default: %%REMARK_DATADIR%%/pictures.db +# +# Additional configuration variables available at https://remark42.com/docs/configuration/parameters/ +# are exposed with similar naming convention. + +. /etc/rc.subr + +name=remark +rcvar=remark_enable +load_rc_config ${name} + +: ${remark_enable:="NO"} +: ${remark_secret:="$(head -c32 /dev/urandom| uuencode -r -m -)"} +: ${remark_url:=""} +: ${remark_site:="remark"} +: ${remark_store_type:="bolt"} +: ${remark_store_bolt_path:="%%REMARK_DATADIR%%"} +: ${remark_store_bolt_timeout:="30s"} +: ${remark_store_rpc_api:=""} +: ${remark_store_rpc_timeout:=""} +: ${remark_store_rpc_auth_user:=""} +: ${remark_store_rpc_auth_passwd:=""} +: ${remark_admin_type:="shared"} +: ${remark_admin_rpc_api:=""} +: ${remark_admin_rpc_timeout:="5s"} +: ${remark_admin_shared_id:=""} +: ${remark_admin_shared_email:=""} +: ${remark_backup_path:="%%REMARK_DATADIR%%/backup"} +: ${remark_backup_max:="10"} +: ${remark_cache_type:="mem"} +: ${remark_avatar_type:="fs"} +: ${remark_avatar_fs_path:="%%REMARK_DATADIR%%/avatars"} +: ${remark_avatar_bolt_file:="%%REMARK_DATADIR%%/avatars.db"} +: ${remark_avatar_uri:=""} +: ${remark_avatar_resize_limit:="0"} +: ${remark_image_type:="fs"} +: ${remark_image_fs_path:="%%REMARK_DATADIR%%/pictures"} +: ${remark_image_fs_staging:="%%REMARK_DATADIR%%/pictures.staging"} +: ${remark_image_fs_partitions:="100"} +: ${remark_image_bolt_file:="%%REMARK_DATADIR%%/pictures.db"} +: ${remark_image_rpc_api:=""} +: ${remark_image_rpc_timeout:="5s"} +: ${remark_image_rpc_auth_user:=""} +: ${remark_image_rpc_auth_passwd:=""} +: ${remark_image_max_size:="5000000"} +: ${remark_image_resize_width:="2400"} +: ${remark_image_resize_height:="900"} +: ${remark_auth_same_site:="default"} +: ${remark_auth_google_cid:=""} +: ${remark_auth_google_csec:=""} +: ${remark_auth_facebook_cid:=""} +: ${remark_auth_facebook_csec:=""} +: ${remark_auth_microsoft_cid:=""} +: ${remark_auth_microsoft_csec:=""} +: ${remark_auth_github_cid:=""} +: ${remark_auth_github_csec:=""} +: ${remark_auth_twitter_cid:=""} +: ${remark_auth_twitter_csec:=""} +: ${remark_auth_patreon_cid:=""} +: ${remark_auth_patreon_csec:=""} +: ${remark_auth_yandex_cid:=""} +: ${remark_auth_yandex_csec:=""} +: ${remark_auth_telegram:=""} +: ${remark_user:="%%REMARK_USER%%"} +: ${remark_auth_anon:="false"} +: ${remark_auth_enable:="false"} +: ${remark_auth_email_from:=""} +: ${remark_auth_email_subject:="remark42 confirmation"} +: ${remark_auth_email_content_type:="text/html"} +: ${remark_notify_users:=""} +: ${remark_notify_admins:=""} +: ${remark_notify_queue:=""} +: ${remark_notify_telegram_chan:=""} +: ${remark_notify_slack_token:=""} +: ${remark_notify_slack_chan:=""} +: ${remark_notify_webhook_url:=""} +: ${remark_notify_webhook_template:=""} +: ${remark_notify_webhook_headers:=""} +: ${remark_notify_webhook_timeout:=""} +: ${remark_notify_email_from:=""} +: ${remark_notify_email_verification_subj:=""} +: ${remark_telegram_token:=""} +: ${remark_telegram_timeout:=""} +: ${remark_smtp_host:=""} +: ${remark_smtp_port:=""} +: ${remark_smtp_username:=""} +: ${remark_smtp_password:=""} +: ${remark_smtp_login_auth:=""} +: ${remark_smtp_tls:=""} +: ${remark_smtp_starttls:=""} +: ${remark_smtp_timeout:=""} +: ${remark_ssl_type:=""} +: ${remark_ssl_port:=""} +: ${remark_ssl_cert:=""} +: ${remark_ssl_key:=""} +: ${remark_ssl_acme_location:=""} +: ${remark_ssl_acme_email:=""} +: ${remark_max_comment_size:=""} +: ${remark_max_votes:=""} +: ${remark_votes_ip:=""} +: ${remark_anon_vote:=""} +: ${remark_votes_ip_time:=""} +: ${remark_low_score:=""} +: ${remark_critical_score:=""} +: ${remark_positive_score:=""} +: ${remark_restricted_words:=""} +: ${remark_restricted_names:=""} +: ${remark_edit_time:=""} +: ${remark_admin_edit:=""} +: ${remark_readonly_age:=""} +: ${remark_image_proxy_http2https:=""} +: ${remark_image_proxy_cache_external:=""} +: ${remark_emoji:=""} +: ${remark_simple_view:=""} +: ${remark_proxy_cors:=""} +: ${remark_allowed_hosts:=""} +: ${remark_remark_address:=""} +: ${remark_remark_port:=""} +: ${remark_remark_web_root:=""} +: ${remark_update_limit:=""} +: ${remark_subscribers_only:=""} +: ${remark_disable_signature:=""} +: ${remark_admin_passwd:=""} +: ${remark_debug:=""} + +export_variable() +{ + _var="remark_$(echo $1 | tr A-Z a-z)" + eval _val="\$${_var}" + [ -z "${_val}" ] || export "${1}"="${_val}" +} + +export_variables() +{ + for _v in $@; do + export_variable "${_v}" + done +} + +remark_precmd() +{ + install -d -o ${remark_user} %%REMARK_PIDDIR%% + install -o ${remark_user} /dev/null ${pidfile} + install -d -o ${remark_user} ${remark_store_bolt_path} + + if [ -z "${remark_url}" ]; then + err 1 "remark_url must be set" + fi + export REMARK_URL="${remark_url}" + export REMARK_SITE="${remark_site}" + export_variables SECRET SITE STORE_TYPE + case "${STORE_TYPE}" in + bolt) + export_variables STORE_BOLT_PATH STORE_BOLT_TIMEOUT + ;; + rpc) + export_variables STORE_RPC_API STORE_RPC_TIMEOUT STORE_RPC_AUTH_USER STORE_RPC_AUTH_PASSWD + ;; + *) + err 1 "remark_store_type has to be either 'bolt' or 'rpc'" + ;; + esac + export_variable ADMIN_TYPE + case "${ADMIN_TYPE}" in + shared) + ;; + rpc) + export_variables ADMIN_RPC_API ADMIN_RPC_TIMEOUT ADMIN_RPC_AUTH_USER ADMIN_RPC_AUTH_PASSWD + ;; + *) + err 1 "remark_admin_type has to be either 'shared' or 'rpc'" + ;; + esac + export_variables ADMIN_SHARED_ID ADMIN_SHARED_EMAIL BACKUP_PATH + export MAX_BACKUP_FILES="${remark_backup_max}" + export_variables CACHE_TYPE AVATAR_TYPE + case "${AVATAR_TYPE}" in + fs) + export_variable AVATAR_FS_PATH + ;; + bolt) + export_variable AVATAR_BOLT_FILE + ;; + uri) + export_variable AVATAR_URI + ;; + *) + err 1 "remark_avatar_path has to be 'fs', 'bolt' or 'uri'" + ;; + esac + export AVATAR_RESIZE="${remark_avatar_resize_limit}" + export_variable IMAGE_TYPE + case "${remark_image_type}" in + fs) + export_variables IMAGE_FS_PATH IMAGE_FS_STAGING IMAGE_FS_PARTITIONS + ;; + bolt) + export_variable IMAGE_BOLT_FILE + ;; + rpc) + export_variables IMAGE_RPC_API IMAGE_RPC_TIMEOUT IMAGE_RPC_AUTH_USER IMAGE_RPC_AUTH_PASSWD + ;; + *) + err 1 "remark_image_type has to be 'fs', 'bolt' or 'rpc'" + ;; + esac + export_variables IMAGE_MAX_SIZE IMAGE_RESIZE_WIDTH IMAGE_RESIZE_HEIGHT AUTH_SAME_SITE AUTH_TELEGRAM + for _provider in google facebook microsoft github twitter patreon yandex; do + _provider_upper="$(echo ${_provider} | tr a-z A-Z)" + export_variables "AUTH_${_provider_upper}_CID" "AUTH_${_provider_upper}_CSEC" + done + export_variables AUTH_ANON AUTH_EMAIL_ENABLE AUTH_EMAIL_FROM AUTH_EMAIL_SUBJ AUTH_EMAIL_CONTENT_TYPE + export_variables NOTIFY_USERS NOTIFY_ADMINS NOTIFY_QUEUE NOTIFY_TELEGRAM_CHAN NOTIFY_SLACK_TOKEN NOTIFY_SLACK_CHAN + export_variables NOTIFY_WEBHOOK_URL NOTIFY_WEBHOOK_TEMPLATE NOTIFY_WEBHOOK_HEADERS NOTIFY_WEBHOOK_TIMEOUT + export_variables NOTIFY_EMAIL_FROM NOTIFY_EMAIL_VERIFICATION_SUBJ TELEGRAM_TOKEN TELEGRAM_TIMEOUT + export_variables SMTP_HOST SMTP_PORT SMTP_USERNAME SMTP_PASSWORD SMTP_LOGIN_AUTH SMTP_TLS + export_variables SMTP_STARTTLS SMTP_TIMEOUT SSL_TYPE SSL_PORT SSL_CERT SSL_KEY SSL_ACME_LOCATION + export_variables SSL_ACME_EMAIL MAX_COMMENT_SIZE MAX_VOTES VOTES_IP ANON_VOTE VOTES_IP_TIME + export_variables LOW_SCORE CRITICAL_SCORE POSITIVE_SCORE RESTRICTED_WORDS RESTRICTED_NAMES + export_variables EDIT_TIME ADMIN_EDIT READONLY_AGE IMAGE_PROXY_HTTP2HTTPS IMAGE_PROXY_CACHE_EXTERNAL + export_variables EMOJI SIMPLE_VIEW PROXY_CORS ALLOWED_HOSTS REMARK_ADDRESS REMARK_PORT REMARK_WEB_ROOT + export_variables UPDATE_LIMIT SUBSCRIBERS_ONLY DISABLE_SIGNATURE ADMIN_PASSWD DEBUG +} + +pidfile="%%REMARK_PIDDIR%%${name}.pid" +procname="%%PREFIX%%/libexec/remark42" +command=/usr/sbin/daemon +command_args="-c -p ${pidfile} -T ${name} ${procname} server ${remark_options}" +start_precmd="remark_precmd" +extra_commands="backup restore cleanup" +cleanup_cmd="cleanup" +cleanup_precmd="remark_precmd" +backup_cmd="backup" +backup_precmd="remark_precmd" +restore_cmd="restore" +restore_precmd="remark_precmd" + +cleanup() { + su -m ${remark_user} -c "${procname} cleanup $@" +} + +backup() { + su -m ${remark_user} -c "${procname} backup $@" +} + +restore() { + su -m ${remark_user} -c "${procname} restore $@" +} + +run_rc_command $@ diff --git a/www/remark42/pkg-descr b/www/remark42/pkg-descr new file mode 100644 index 000000000000..15e079d727a5 --- /dev/null +++ b/www/remark42/pkg-descr @@ -0,0 +1,3 @@ +Remark42 allows you to have a self-hosted, lightweight, and simple (yet +functional) comment engine, which doesn't spy on users. It can be embedded +into blogs, articles or any other place where readers add comments.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202212272036.2BRKadeZ083399>