summaryrefslogtreecommitdiff
path: root/net/kafka/Makefile
blob: d037b6b7228c5ea63a3ebd82f4afcee8c025d9d9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
PORTNAME=	kafka
DISTVERSION=	3.9.1
CATEGORIES=	net java
MASTER_SITES=	APACHE/${PORTNAME}/${DISTVERSION}/
DISTNAME=	${PORTNAME}_2.13-${DISTVERSION}

MAINTAINER=	timp87@gmail.com
COMMENT=	Distributed streaming platform
WWW=		https://kafka.apache.org/

LICENSE=	APACHE20
LICENSE_FILE=	${WRKSRC}/LICENSE

RUN_DEPENDS=	bash:shells/bash

USES=		cpe java shebangfix tar:tgz
CPE_VENDOR=	apache
JAVA_VERSION=	17+

USE_RC_SUBR=	kafka kafka_connect

SHEBANG_FILES=	bin/*.sh

KAFKA_USER?=		kafka
KAFKA_GROUP?=		kafka
KAFKA_DBDIR?=		/var/db/${PORTNAME}
KAFKA_DBDIR_KRAFT?=	${KAFKA_DBDIR}-kraft
KAFKA_LOGDIR?=		/var/log/${PORTNAME}

DATADIR=	${JAVASHAREDIR}/${PORTNAME}

NO_ARCH=	yes
NO_BUILD=	yes

SUB_FILES=	pkg-message
SUB_LIST=	JAVA=${JAVA} \
		KAFKA_DBDIR=${KAFKA_DBDIR} \
		KAFKA_DBDIR_KRAFT=${KAFKA_DBDIR_KRAFT} \
		KAFKA_GROUP=${KAFKA_GROUP} \
		KAFKA_LOGDIR=${KAFKA_LOGDIR} \
		KAFKA_USER=${KAFKA_USER}
USERS=		${KAFKA_USER}
GROUPS=		${KAFKA_GROUP}

KAFKA_BINS=		connect-distributed.sh connect-mirror-maker.sh \
			connect-plugin-path.sh connect-standalone.sh \
			kafka-acls.sh kafka-broker-api-versions.sh \
			kafka-client-metrics.sh kafka-cluster.sh \
			kafka-configs.sh kafka-console-consumer.sh \
			kafka-console-producer.sh kafka-consumer-groups.sh \
			kafka-consumer-perf-test.sh kafka-delegation-tokens.sh \
			kafka-delete-records.sh kafka-dump-log.sh \
			kafka-e2e-latency.sh kafka-features.sh \
			kafka-get-offsets.sh kafka-jmx.sh \
			kafka-leader-election.sh kafka-log-dirs.sh \
			kafka-metadata-quorum.sh kafka-metadata-shell.sh \
			kafka-mirror-maker.sh kafka-producer-perf-test.sh \
			kafka-reassign-partitions.sh \
			kafka-replica-verification.sh kafka-run-class.sh \
			kafka-server-start.sh kafka-server-stop.sh \
			kafka-storage.sh kafka-streams-application-reset.sh \
			kafka-topics.sh kafka-transactions.sh \
			kafka-verifiable-consumer.sh \
			kafka-verifiable-producer.sh trogdor.sh \
			zookeeper-security-migration.sh \
			zookeeper-shell.sh
KAFKA_CONFIGS=		connect-console-sink.properties \
			connect-console-source.properties \
			connect-distributed.properties \
			connect-file-sink.properties \
			connect-file-source.properties connect-log4j.properties \
			connect-mirror-maker.properties \
			connect-standalone.properties consumer.properties \
			log4j.properties producer.properties server.properties \
			tools-log4j.properties trogdor.conf
KAFKA_CONFIGS_KRAFT=	broker.properties controller.properties \
			server.properties

PLIST_SUB=	KAFKA_DBDIR=${KAFKA_DBDIR} \
		KAFKA_DBDIR_KRAFT=${KAFKA_DBDIR_KRAFT} \
		KAFKA_GROUP=${KAFKA_GROUP} \
		KAFKA_LOGDIR=${KAFKA_LOGDIR} \
		KAFKA_USER=${KAFKA_USER} \
		PORTVERSION=${DISTVERSION}

OPTIONS_DEFINE=	DOCS

post-patch:
	@${REINPLACE_CMD} "s|JAVA=\"java\"|JAVA=\"${JAVA}\"|" ${WRKSRC}/bin/kafka-run-class.sh
	@${REINPLACE_CMD} "/LOG_DIR=/s|\$$base_dir/logs|${KAFKA_LOGDIR}|" ${WRKSRC}/bin/kafka-run-class.sh
	@${REINPLACE_CMD} "s|\$$base_dir.*/config|${ETCDIR}|" ${WRKSRC}/bin/*.sh
	@${REINPLACE_CMD} "s|ps ax|ps axww|" ${WRKSRC}/bin/kafka-server-stop.sh
	@${REINPLACE_CMD} "/log.dirs/s|=.*|=${KAFKA_DBDIR}|" ${WRKSRC}/config/server.properties
.for f in ${KAFKA_CONFIGS_KRAFT}
	@${REINPLACE_CMD} "/log.dirs/s|=.*|=${KAFKA_DBDIR_KRAFT}|" ${WRKSRC}/config/kraft/${f}
.endfor

do-install:
	${MKDIR} ${STAGEDIR}${ETCDIR}
	${MKDIR} ${STAGEDIR}${ETCDIR}/kraft
	${MKDIR} ${STAGEDIR}${KAFKA_DBDIR}
	${MKDIR} ${STAGEDIR}${KAFKA_DBDIR_KRAFT}
	${MKDIR} ${STAGEDIR}${KAFKA_LOGDIR}
	${MKDIR} ${STAGEDIR}${DATADIR}/bin
.for f in ${KAFKA_BINS}
	${INSTALL_SCRIPT} ${WRKSRC}/bin/${f} ${STAGEDIR}${DATADIR}/bin/
.endfor
	@(cd ${WRKSRC} && ${COPYTREE_SHARE} libs ${STAGEDIR}${DATADIR} "-not ( \
		-name kafka_*-javadoc\.jar -or -name kafka_*-scaladoc\.jar -or \
		-name kafka_*-sources\.jar -or -name kafka_*-test\.jar -or \
		-name *\.asc )" \
	)
.for f in ${KAFKA_CONFIGS}
	${INSTALL_DATA} ${WRKSRC}/config/${f} ${STAGEDIR}${ETCDIR}/${f}.sample
.endfor
.for f in ${KAFKA_CONFIGS_KRAFT}
	${INSTALL_DATA} ${WRKSRC}/config/kraft/${f} ${STAGEDIR}${ETCDIR}/kraft/${f}.sample
.endfor

do-install-DOCS-on:
	${MKDIR} ${STAGEDIR}${DOCSDIR}
	${EXTRACT_CMD} -xf ${WRKSRC}/site-docs/${PORTNAME}_2.13-${DISTVERSION}-site-docs.tgz -C ${STAGEDIR}${DOCSDIR}

.include <bsd.port.mk>