|
|
@ -811,112 +811,6 @@ data:
|
|
|
|
labels:
|
|
|
|
labels:
|
|
|
|
namespace: default
|
|
|
|
namespace: default
|
|
|
|
|
|
|
|
|
|
|
|
mongo-init.sh: |
|
|
|
|
|
|
|
|
echo "before running mongosh..."
|
|
|
|
|
|
|
|
mongosh <<EOF
|
|
|
|
|
|
|
|
var maxRetries = 300;
|
|
|
|
|
|
|
|
var connected = false;
|
|
|
|
|
|
|
|
var rootUsername = '$MONGO_INITDB_ROOT_USERNAME';
|
|
|
|
|
|
|
|
var rootPassword = '$MONGO_INITDB_ROOT_PASSWORD';
|
|
|
|
|
|
|
|
var dbName = '$MONGO_INITDB_DATABASE';
|
|
|
|
|
|
|
|
var openimUsername = '$MONGO_OPENIM_USERNAME';
|
|
|
|
|
|
|
|
var openimPassword = '$MONGO_OPENIM_PASSWORD';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print('Starting MongoDB connection script...');
|
|
|
|
|
|
|
|
print('Root username: ' + rootUsername);
|
|
|
|
|
|
|
|
print('Target database: ' + dbName);
|
|
|
|
|
|
|
|
print('OpenIM user to create: ' + openimUsername);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while (!connected && maxRetries > 0) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
print('Attempting to connect to MongoDB. Remaining retries: ' + maxRetries);
|
|
|
|
|
|
|
|
db = connect('mongodb://127.0.0.1:27017/admin');
|
|
|
|
|
|
|
|
var authResult = db.auth(rootUsername, rootPassword);
|
|
|
|
|
|
|
|
if (authResult) {
|
|
|
|
|
|
|
|
print('Authentication successful for root user: ' + rootUsername);
|
|
|
|
|
|
|
|
connected = true;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
print('Authentication failed for root user: ' + rootUsername + ' with password: ' + rootPassword);
|
|
|
|
|
|
|
|
quit(1);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
|
|
maxRetries--;
|
|
|
|
|
|
|
|
print('Connection failed due to error: ' + e);
|
|
|
|
|
|
|
|
print('Retrying... Remaining attempts: ' + maxRetries);
|
|
|
|
|
|
|
|
sleep(1000); // Sleep for 1 second
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (connected) {
|
|
|
|
|
|
|
|
print('Connected to MongoDB successfully. Proceeding to create user...');
|
|
|
|
|
|
|
|
db = db.getSiblingDB(dbName);
|
|
|
|
|
|
|
|
var createUserResult = db.createUser({
|
|
|
|
|
|
|
|
user: openimUsername,
|
|
|
|
|
|
|
|
pwd: openimPassword,
|
|
|
|
|
|
|
|
roles: [{
|
|
|
|
|
|
|
|
role: 'readWrite',
|
|
|
|
|
|
|
|
db: dbName
|
|
|
|
|
|
|
|
}]
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (createUserResult.ok == 1) {
|
|
|
|
|
|
|
|
print('User creation successful. User: ' + openimUsername + ', Database: ' + dbName);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
print('User creation failed for user: ' + openimUsername + ' in database: ' + dbName);
|
|
|
|
|
|
|
|
quit(1);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
print('Failed to connect to MongoDB after 300 retries.');
|
|
|
|
|
|
|
|
quit(1);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print('Script execution completed.');
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
echo "mongosh completed..."
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
create-topic.sh: |
|
|
|
|
|
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
# Wait for Kafka to be ready
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
KAFKA_SERVER=kafka-service:9092
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
MAX_ATTEMPTS=300
|
|
|
|
|
|
|
|
attempt_num=1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
echo "Waiting for Kafka to be ready..."
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
until /opt/bitnami/kafka/bin/kafka-topics.sh --list --bootstrap-server $KAFKA_SERVER; do
|
|
|
|
|
|
|
|
echo "Attempt $attempt_num of $MAX_ATTEMPTS: Kafka not ready yet..."
|
|
|
|
|
|
|
|
if [ $attempt_num -eq $MAX_ATTEMPTS ]; then
|
|
|
|
|
|
|
|
echo "Kafka not ready after $MAX_ATTEMPTS attempts, exiting"
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
attempt_num=$((attempt_num+1))
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
echo "Kafka is ready. Creating topics..."
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
topics=("toRedis" "toMongo" "toPush" "toOfflinePush")
|
|
|
|
|
|
|
|
partitions=8
|
|
|
|
|
|
|
|
replicationFactor=1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for topic in "${topics[@]}"; do
|
|
|
|
|
|
|
|
if /opt/bitnami/kafka/bin/kafka-topics.sh --create \
|
|
|
|
|
|
|
|
--bootstrap-server $KAFKA_SERVER \
|
|
|
|
|
|
|
|
--replication-factor $replicationFactor \
|
|
|
|
|
|
|
|
--partitions $partitions \
|
|
|
|
|
|
|
|
--topic $topic
|
|
|
|
|
|
|
|
then
|
|
|
|
|
|
|
|
echo "Topic $topic created."
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
echo "Failed to create topic $topic."
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
echo "All topics created."
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
webhooks.yml: |
|
|
|
|
webhooks.yml: |
|
|
|
|
url: http://127.0.0.1:10006/callbackExample
|
|
|
|
url: http://127.0.0.1:10006/callbackExample
|
|
|
|
beforeSendSingleMsg:
|
|
|
|
beforeSendSingleMsg:
|
|
|
|