mirror of
https://github.com/Sheldan/OnePlusBot.git
synced 2026-01-22 07:38:11 +00:00
Compare commits
58 Commits
oneplusbot
...
oneplusbot
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6e25ac91cb | ||
|
|
44e3f8656c | ||
|
|
c8a6f67af5 | ||
|
|
a39942beef | ||
|
|
ca36645197 | ||
|
|
e177b5f559 | ||
|
|
9f11ec5ffa | ||
|
|
5378a4038b | ||
|
|
d448dfbf9b | ||
|
|
f0b548a97e | ||
|
|
b0c2c24dce | ||
|
|
658683c013 | ||
|
|
8c8cadefdd | ||
|
|
8e9a7004a2 | ||
|
|
29fb53fb7a | ||
|
|
6d23fffc77 | ||
|
|
d816a8a48c | ||
|
|
386011d2e9 | ||
|
|
015609f9d2 | ||
|
|
35a6f0aeeb | ||
|
|
743195b137 | ||
|
|
9f35781f2d | ||
|
|
dbf131abfe | ||
|
|
05dbb1fc2f | ||
|
|
47284686d6 | ||
|
|
46ef5435c7 | ||
|
|
bcfaf1c928 | ||
|
|
124d45ba5b | ||
|
|
4cdaf87412 | ||
|
|
13cf06e1dc | ||
|
|
e8ae0f430d | ||
|
|
cda9d1a2b8 | ||
|
|
653246f3ee | ||
|
|
0879c7cc93 | ||
|
|
4ea878dd42 | ||
|
|
562f5ae9e1 | ||
|
|
92925d176f | ||
|
|
6a5f45c416 | ||
|
|
c7e8fd315f | ||
|
|
95ad8fdd3a | ||
|
|
51775b454e | ||
|
|
aa4de8f571 | ||
|
|
eae07fd07c | ||
|
|
c492640cd7 | ||
|
|
2c49cf2918 | ||
|
|
60ac314ecc | ||
|
|
c82ef9ac18 | ||
|
|
6369ae7c01 | ||
|
|
f9b2174f84 | ||
|
|
d5c8509ab0 | ||
|
|
eaddea63b3 | ||
|
|
7dc141a8a4 | ||
|
|
6652c90edb | ||
|
|
d7f5fc21d6 | ||
|
|
bf98d5db3a | ||
|
|
57fb34920d | ||
|
|
3f959f3bbb | ||
|
|
0380720ec8 |
42
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
42
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
name: Bug Report
|
||||||
|
description: Found a bug that needs fixing?
|
||||||
|
body:
|
||||||
|
- type: checkboxes
|
||||||
|
attributes:
|
||||||
|
label: General Troubleshooting
|
||||||
|
description: You confirm to have made the following checks first.
|
||||||
|
options:
|
||||||
|
- label: I have checked for similar issues on the Issue-tracker.
|
||||||
|
required: true
|
||||||
|
- label: I have updated to the latest version
|
||||||
|
required: true
|
||||||
|
- label: I have checked the branches or the maintainers' PRs for upcoming bug fixes.
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Description"
|
||||||
|
description: "General information about the bug"
|
||||||
|
placeholder: "..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Steps to reproduce"
|
||||||
|
description: "What happened when the bug occurred?"
|
||||||
|
placeholder: "1. ..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Expected behaviour"
|
||||||
|
description: "What should happen?"
|
||||||
|
placeholder: "It should..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Actual behaviour"
|
||||||
|
description: "What did happen instead?"
|
||||||
|
placeholder: "It actually ..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
36
.github/ISSUE_TEMPLATE/feature.yml
vendored
Normal file
36
.github/ISSUE_TEMPLATE/feature.yml
vendored
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
name: Feature request
|
||||||
|
description: Want some functionality added?
|
||||||
|
body:
|
||||||
|
- type: checkboxes
|
||||||
|
attributes:
|
||||||
|
label: General Information
|
||||||
|
description: You confirm to have made the following checks first.
|
||||||
|
options:
|
||||||
|
- label: I have checked for similar issues on the Issue-tracker.
|
||||||
|
required: true
|
||||||
|
- label: I have updated to the latest version
|
||||||
|
required: true
|
||||||
|
- label: I have checked the branches or the maintainers' PRs for upcoming features fixes.
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Description"
|
||||||
|
description: "General description of the feature"
|
||||||
|
placeholder: "..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Feature worth and general use"
|
||||||
|
description: "Why should this exist?"
|
||||||
|
placeholder: "..."
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: "Suggestions for implementation"
|
||||||
|
description: "Any ideas about what the feature should behave/look like? Commands?"
|
||||||
|
placeholder: "It should..."
|
||||||
|
validations:
|
||||||
|
required: false
|
||||||
|
|
||||||
11
.github/workflows/build.yml
vendored
11
.github/workflows/build.yml
vendored
@@ -17,11 +17,14 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
- name: Set up JDK 1.8
|
|
||||||
uses: actions/setup-java@v1
|
|
||||||
with:
|
with:
|
||||||
java-version: 1.8
|
persist-credentials: false
|
||||||
|
- name: Set up JDK 17
|
||||||
|
uses: actions/setup-java@v3
|
||||||
|
with:
|
||||||
|
distribution: 'corretto'
|
||||||
|
java-version: 17
|
||||||
- name: Build with Maven
|
- name: Build with Maven
|
||||||
run: mvn -s settings.xml -B install --file pom.xml
|
run: mvn -s settings.xml -B install --file pom.xml
|
||||||
env:
|
env:
|
||||||
|
|||||||
36
.github/workflows/release.yml
vendored
36
.github/workflows/release.yml
vendored
@@ -6,13 +6,14 @@ jobs:
|
|||||||
publish:
|
publish:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
persist-credentials: false
|
persist-credentials: false
|
||||||
- name: Set up Java for publishing to GitHub Packages
|
- name: Set up Java for publishing to GitHub Packages
|
||||||
uses: actions/setup-java@v1
|
uses: actions/setup-java@v3
|
||||||
with:
|
with:
|
||||||
java-version: 1.8
|
distribution: 'corretto'
|
||||||
|
java-version: 17
|
||||||
- name: Load current version
|
- name: Load current version
|
||||||
id: version
|
id: version
|
||||||
run: echo "version=$(mvn -s settings.xml --file pom.xml -q -Dexec.executable="echo" -Dexec.args='${project.version}' --non-recursive exec:exec)" >> $GITHUB_ENV
|
run: echo "version=$(mvn -s settings.xml --file pom.xml -q -Dexec.executable="echo" -Dexec.args='${project.version}' --non-recursive exec:exec)" >> $GITHUB_ENV
|
||||||
@@ -22,17 +23,26 @@ jobs:
|
|||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
user: Sheldan
|
user: Sheldan
|
||||||
token: ${{ secrets.ABSTRACTO_PAT }}
|
token: ${{ secrets.ABSTRACTO_PAT }}
|
||||||
- name: Login to GitHub Packages Docker Registry
|
- name: Login to Harbor
|
||||||
uses: docker/login-action@v1
|
uses: docker/login-action@v2
|
||||||
with:
|
with:
|
||||||
registry: docker.pkg.github.com
|
registry: harbor.sheldan.dev
|
||||||
username: ${{ github.repository_owner }}
|
username: ${{ secrets.HARBOR_USERNAME }}
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
password: ${{ secrets.HARBOR_TOKEN }}
|
||||||
- name: Push deployment container
|
- name: Load env files
|
||||||
|
id: dotenv
|
||||||
|
uses: falti/dotenv-action@v1.0.4
|
||||||
|
with:
|
||||||
|
path: ./deployment/image-packaging/src/main/docker/.env
|
||||||
|
- name: Push container
|
||||||
working-directory: ./deployment/image-packaging/src/main/docker
|
working-directory: ./deployment/image-packaging/src/main/docker
|
||||||
run: docker-compose build && docker-compose push
|
run: docker-compose build && docker-compose push
|
||||||
env:
|
env:
|
||||||
REGISTRY_PREFIX: docker.pkg.github.com/sheldan/oneplusbot/
|
REGISTRY_PREFIX: ${{ steps.dotenv.outputs.registry_prefix }}
|
||||||
VERSION: ${{ env.version }}
|
VERSION: ${{ steps.dotenv.outputs.version }}
|
||||||
ABSTRACTO_VERSION: 1.3.6
|
- name: Helm push
|
||||||
ABSTRACTO_REGISTRY_PREFIX: docker.pkg.github.com/sheldan/abstracto/
|
working-directory: ./deployment/helm/
|
||||||
|
run: |-
|
||||||
|
helm registry login -u '${{ secrets.HARBOR_USERNAME }}' -p '${{ secrets.HARBOR_TOKEN }}' harbor.sheldan.dev
|
||||||
|
helm package oneplus-bot
|
||||||
|
helm push oneplus-bot*.tgz oci://harbor.sheldan.dev/oneplus-bot
|
||||||
|
|||||||
2
LICENSE
2
LICENSE
@@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2021 Sheldan
|
Copyright (c) 2022 Sheldan
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# r/oneplus Discord bot privacy policy
|
# r/oneplus Discord bot privacy policy
|
||||||
|
|
||||||
Last updated: 04.07.2021
|
Last updated: 06.09.2021
|
||||||
|
|
||||||
## Description
|
## Description
|
||||||
|
|
||||||
@@ -75,6 +75,7 @@ The detailed list of what information is stored and processed is the following:
|
|||||||
* this was used for the message used to update the status of a suggestion, but this is currently disabled
|
* this was used for the message used to update the status of a suggestion, but this is currently disabled
|
||||||
* the author of the suggestion and the message which has been posted in the suggestions channel
|
* the author of the suggestion and the message which has been posted in the suggestions channel
|
||||||
* every suggestion will be deleted completely from the database a few days after it has reached a final state (rejected, denied, accepted)
|
* every suggestion will be deleted completely from the database a few days after it has reached a final state (rejected, denied, accepted)
|
||||||
|
* whether you voted for a suggestion and which decision you took
|
||||||
|
|
||||||
### Leveling system
|
### Leveling system
|
||||||
* the amount of messages which were considered for the leveling system
|
* the amount of messages which were considered for the leveling system
|
||||||
|
|||||||
14
README.md
14
README.md
@@ -1,11 +1,21 @@
|
|||||||
# r/oneplus Discord server bot
|
# r/oneplus Discord server bot
|
||||||
|
|
||||||
This repository contains the rewrite of the [Bot](https://github.com/Rithari/OnePlusBot), which is still in use. The features will be gradually be ported
|
This repository contains the rewrite of the [Bot](https://github.com/Rithari/OnePlusBot). It is developed by customizing [abstracto](https://github.com/Sheldan/abstracto), because some features are r/oneplus specific.
|
||||||
and most of them will be in [abstracto](https://github.com/Sheldan/abstracto), but some of the features need to be customized, as they are r/oneplus specific.
|
|
||||||
|
|
||||||
The migration of the existing data from the database is handled via one time migration, and can be found [here](https://github.com/Sheldan/OnePlusBot-migration).
|
The migration of the existing data from the database is handled via one time migration, and can be found [here](https://github.com/Sheldan/OnePlusBot-migration).
|
||||||
|
|
||||||
|
The FAQ configuration can be found [here](https://github.com/Sheldan/OnePlusBot-faq/).
|
||||||
|
|
||||||
Custom features which were ported
|
Custom features which were ported
|
||||||
- [x] FAQ
|
- [x] FAQ
|
||||||
- [x] Setup channel handling
|
- [x] Setup channel handling
|
||||||
- [x] Referral link handling
|
- [x] Referral link handling
|
||||||
|
|
||||||
|
# Technologies used in addition to the ones provided in abstracto
|
||||||
|
- [grafana](https://github.com/grafana/grafana) for visualization of the bot status and metrics
|
||||||
|
- [Loki](https://github.com/grafana/loki) to visualize and query log files
|
||||||
|
- [pgAdmin](https://github.com/postgres/pgadmin4) to view the database
|
||||||
|
- [prometheus](https://github.com/prometheus/prometheus) for metric collection
|
||||||
|
- [postgres](https://github.com/postgres/postgres) as a database
|
||||||
|
- [loki](https://github.com/grafana/loki) for log aggregation
|
||||||
|
|
||||||
40
Tiltfile
Normal file
40
Tiltfile
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
allow_k8s_contexts('k8s-cluster')
|
||||||
|
|
||||||
|
load('ext://restart_process', 'docker_build_with_restart')
|
||||||
|
registry = 'harbor.sheldan.dev/oneplus-bot/'
|
||||||
|
|
||||||
|
local_resource(
|
||||||
|
'oneplus-bot-java-compile',
|
||||||
|
'mvn install && ' +
|
||||||
|
'rm -rf application/executable/target/jar-staging && ' +
|
||||||
|
'unzip -o application/executable/target/oneplus-bot-exec.jar -d application/executable/target/jar-staging && ' +
|
||||||
|
'rsync --delete --inplace --checksum -r application/executable/target/jar-staging/ application/executable/target/jar && ' +
|
||||||
|
'mkdir application/executable/target/jar/snapshots && ' +
|
||||||
|
'rsync --delete --inplace --checksum -r application/executable/target/jar/BOOT-INF/lib/*-SNAPSHOT.jar application/executable/target/jar/snapshots && ' +
|
||||||
|
'rm -f application/executable/target/jar/BOOT-INF/lib/*-SNAPSHOT.jar ',
|
||||||
|
deps=['pom.xml'])
|
||||||
|
|
||||||
|
docker_build_with_restart(
|
||||||
|
registry + 'oneplus-bot',
|
||||||
|
'./application/executable/target/jar',
|
||||||
|
entrypoint=['java', '-noverify', '-cp', '.:./lib/*', 'dev.sheldan.oneplus.bot.executable.Application'],
|
||||||
|
dockerfile='./application/executable/Dockerfile',
|
||||||
|
live_update=[
|
||||||
|
sync('./application/executable/target/jar/BOOT-INF/lib', '/app/lib'),
|
||||||
|
sync('./application/executable/target/jar/META-INF', '/app/META-INF'),
|
||||||
|
sync('./application/executable/target/jar/BOOT-INF/classes', '/app'),
|
||||||
|
sync('./application/executable/target/jar/snapshots', '/app/lib')
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
docker_build(registry + 'oneplus-bot-db-data', 'deployment/image-packaging/src/main/docker/db-data/')
|
||||||
|
docker_build(registry + 'oneplus-bot-template-data', 'deployment/image-packaging/src/main/docker/template-data/')
|
||||||
|
|
||||||
|
|
||||||
|
k8s_yaml(helm('deployment/helm/oneplus-bot', values=
|
||||||
|
['./../OnePlusBot-environments/argocd/apps/oneplus-bot/values/local/values.yaml',
|
||||||
|
'secrets://./../OnePlusBot-environments/argocd/apps/oneplus-bot/values/local/values.secrets.yaml']
|
||||||
|
))
|
||||||
|
|
||||||
|
local_resource('fetch-packages', 'mvn install -f deployment/image-packaging/pom.xml', auto_init=False, trigger_mode = TRIGGER_MODE_MANUAL)
|
||||||
|
k8s_resource('chart-oneplus-bot', port_forwards='5005:5005')
|
||||||
10
application/executable/Dockerfile
Normal file
10
application/executable/Dockerfile
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
FROM amazoncorretto:17.0.8-alpine3.18
|
||||||
|
RUN apk add entr
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
ADD BOOT-INF/lib/ /app/lib
|
||||||
|
ADD snapshots/ /app/lib
|
||||||
|
ADD META-INF /app/META-INF
|
||||||
|
ADD BOOT-INF/classes /app
|
||||||
|
|
||||||
|
ENTRYPOINT java -cp .:./lib/* dev.sheldan.oneplus.bot.executable.Application
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
||||||
<artifactId>application</artifactId>
|
<artifactId>application</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>executable</artifactId>
|
<artifactId>executable</artifactId>
|
||||||
@@ -14,6 +14,7 @@
|
|||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
<finalName>oneplus-bot</finalName>
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
@@ -191,6 +192,12 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
|
<artifactId>seasonal</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.executable;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||||
|
import org.springframework.security.web.SecurityFilterChain;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
public class SecurityConfig {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
|
||||||
|
http.authorizeHttpRequests((authorize) -> authorize
|
||||||
|
.anyRequest().permitAll());
|
||||||
|
return http.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -1,21 +0,0 @@
|
|||||||
spring.datasource.url=jdbc:postgresql://localhost:5432/abstracto
|
|
||||||
spring.datasource.username= abstracto
|
|
||||||
spring.datasource.password= abstracto
|
|
||||||
spring.jpa.properties.hibernate.default_schema=abstracto
|
|
||||||
spring.quartz.jdbc.initialize-schema=never
|
|
||||||
|
|
||||||
spring.jpa.hibernate.ddl-auto = none
|
|
||||||
|
|
||||||
spring.jpa.show-sql = false
|
|
||||||
|
|
||||||
spring.jpa.properties.hibernate.format_sql = true
|
|
||||||
log4j.logger.org.hibernate.SQL=trace
|
|
||||||
log4j.logger.org.hibernate.type.descriptor.sql=trace
|
|
||||||
log4j.logger.org.hibernate.type=trace
|
|
||||||
|
|
||||||
management.metrics.tags.application=oneplus-bot
|
|
||||||
spring.security.user.name=abstracto
|
|
||||||
spring.security.user.password=password
|
|
||||||
spring.security.user.roles=USER
|
|
||||||
|
|
||||||
spring.application.name=OnePlusBot
|
|
||||||
@@ -1,11 +1,13 @@
|
|||||||
spring.datasource.url=jdbc:postgresql://${DB_HOST}:${DB_PORT}/${DB_NAME}
|
spring.datasource.url=jdbc:postgresql://${DB_HOST}:${DB_PORT}/${DB_NAME}
|
||||||
spring.datasource.username= ${DB_USER}
|
spring.datasource.username= ${DB_USER}
|
||||||
spring.datasource.password= ${DB_PASS}
|
spring.datasource.password= ${DB_PASS}
|
||||||
spring.jpa.hibernate.default_schema=${DB_NAME}
|
spring.jpa.hibernate.default_schema=abstracto
|
||||||
|
spring.jpa.properties.hibernate.default_schema=abstracto
|
||||||
spring.quartz.jdbc.initialize-schema=never
|
spring.quartz.jdbc.initialize-schema=never
|
||||||
management.metrics.tags.application=oneplus-bot
|
management.metrics.tags.application=OnePlusBot
|
||||||
spring.security.user.name= ${REST_USER_NAME}
|
management.endpoint.health.probes.enabled=true
|
||||||
spring.security.user.password= ${REST_PASSWORD}
|
management.health.livenessState.enabled=true
|
||||||
spring.security.user.roles=USER
|
management.health.readinessState.enabled=true
|
||||||
|
spring.application.name=OnePlusBot
|
||||||
|
|
||||||
spring.application.name=OnePlusBot
|
spring.main.allow-circular-references=true
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
||||||
<artifactId>oneplus-bot-customizations</artifactId>
|
<artifactId>oneplus-bot-customizations</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<artifactId>oneplus-bot-customizations</artifactId>
|
<artifactId>oneplus-bot-customizations</artifactId>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package dev.sheldan.oneplus.bot.custom.moderation.config;
|
|||||||
|
|
||||||
import dev.sheldan.abstracto.core.config.FeatureConfig;
|
import dev.sheldan.abstracto.core.config.FeatureConfig;
|
||||||
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.abstracto.core.config.PostTargetEnum;
|
||||||
import dev.sheldan.abstracto.moderation.config.feature.ModerationFeatureConfig;
|
import dev.sheldan.abstracto.moderation.config.feature.ModerationFeatureConfig;
|
||||||
import dev.sheldan.oneplus.bot.custom.moderation.service.ModModeServiceBean;
|
import dev.sheldan.oneplus.bot.custom.moderation.service.ModModeServiceBean;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
@@ -14,6 +15,8 @@ import java.util.List;
|
|||||||
@Component
|
@Component
|
||||||
public class ModerationCustomFeature implements FeatureConfig {
|
public class ModerationCustomFeature implements FeatureConfig {
|
||||||
|
|
||||||
|
public static final String WARN_NOTIFICATION_THRESHOLD = "warnNotificationThreshold";
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ModerationFeatureConfig moderationFeatureConfig;
|
private ModerationFeatureConfig moderationFeatureConfig;
|
||||||
|
|
||||||
@@ -27,9 +30,14 @@ public class ModerationCustomFeature implements FeatureConfig {
|
|||||||
return Arrays.asList(moderationFeatureConfig);
|
return Arrays.asList(moderationFeatureConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<PostTargetEnum> getRequiredPostTargets() {
|
||||||
|
return Arrays.asList(ModerationCustomPostTarget.WARN_THRESHOLD_NOTIFICATION);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<String> getRequiredSystemConfigKeys() {
|
public List<String> getRequiredSystemConfigKeys() {
|
||||||
return Arrays.asList(ModModeServiceBean.MODMODE_ROLE_CONFIG_KEY,
|
return Arrays.asList(ModModeServiceBean.MODMODE_ROLE_CONFIG_KEY,
|
||||||
ModModeServiceBean.MODMODE_CHANGED_ROLE_COLOR_CONFIG_KEY);
|
ModModeServiceBean.MODMODE_CHANGED_ROLE_COLOR_CONFIG_KEY, WARN_NOTIFICATION_THRESHOLD);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.custom.moderation.config;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.config.PostTargetEnum;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public enum ModerationCustomPostTarget implements PostTargetEnum {
|
||||||
|
WARN_THRESHOLD_NOTIFICATION("warnThresholdNotification");
|
||||||
|
|
||||||
|
private String key;
|
||||||
|
|
||||||
|
ModerationCustomPostTarget(String key) {
|
||||||
|
this.key = key;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,98 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.custom.moderation.listener;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.abstracto.core.listener.DefaultListenerResult;
|
||||||
|
import dev.sheldan.abstracto.core.models.ServerUser;
|
||||||
|
import dev.sheldan.abstracto.core.models.database.AUserInAServer;
|
||||||
|
import dev.sheldan.abstracto.core.models.template.display.ChannelDisplay;
|
||||||
|
import dev.sheldan.abstracto.core.models.template.display.MemberDisplay;
|
||||||
|
import dev.sheldan.abstracto.core.service.*;
|
||||||
|
import dev.sheldan.abstracto.core.service.management.UserInServerManagementService;
|
||||||
|
import dev.sheldan.abstracto.core.templating.model.MessageToSend;
|
||||||
|
import dev.sheldan.abstracto.core.templating.service.TemplateService;
|
||||||
|
import dev.sheldan.abstracto.core.utils.FutureUtils;
|
||||||
|
import dev.sheldan.abstracto.moderation.listener.WarningCreatedListener;
|
||||||
|
import dev.sheldan.abstracto.moderation.model.listener.WarningCreatedEventModel;
|
||||||
|
import dev.sheldan.abstracto.moderation.service.management.WarnManagementService;
|
||||||
|
import dev.sheldan.oneplus.bot.custom.moderation.config.ModerationCustomFeature;
|
||||||
|
import dev.sheldan.oneplus.bot.custom.moderation.config.ModerationCustomFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.custom.moderation.config.ModerationCustomPostTarget;
|
||||||
|
import dev.sheldan.oneplus.bot.custom.moderation.model.template.WarningThresholdNotificationModel;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import net.dv8tion.jda.api.entities.channel.middleman.GuildMessageChannel;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
@Slf4j
|
||||||
|
public class WarningAddedListener implements WarningCreatedListener {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ConfigService configService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private WarnManagementService warnManagementService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private UserInServerManagementService userInServerManagementService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ChannelService channelService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private PostTargetService postTargetService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private TemplateService templateService;
|
||||||
|
|
||||||
|
public static final String WARN_THRESHOLD_NOTIFICATION_TEMPLATE_KEY = "warning_threshold_notification";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DefaultListenerResult execute(WarningCreatedEventModel model) {
|
||||||
|
Long warnNotificationAmount = configService.getLongValueOrConfigDefault(ModerationCustomFeature.WARN_NOTIFICATION_THRESHOLD, model.getServerId());
|
||||||
|
ServerUser warnedUser = ServerUser
|
||||||
|
.builder()
|
||||||
|
.userId(model.getWarnedUserId())
|
||||||
|
.serverId(model.getServerId())
|
||||||
|
.build();
|
||||||
|
AUserInAServer warnedUserInAServer = userInServerManagementService.loadOrCreateUser(warnedUser);
|
||||||
|
List<Long> activeWarnsForUser = warnManagementService.getActiveWarnsForUser(warnedUserInAServer)
|
||||||
|
.stream().map(warning -> warning.getWarnId().getId()).collect(Collectors.toList());
|
||||||
|
Set<Long> warnIds = new HashSet<>(activeWarnsForUser);
|
||||||
|
// we cant be sure we receive the newly persisted warning yet, sadly
|
||||||
|
warnIds.add(model.getWarningId());
|
||||||
|
if(warnIds.size() == warnNotificationAmount) {
|
||||||
|
Long serverId = model.getServerId();
|
||||||
|
|
||||||
|
Long channelId = model.getWarningChannelId();
|
||||||
|
Long warnedUserId = model.getWarnedUserId();
|
||||||
|
GuildMessageChannel channel = channelService.getMessageChannelFromServer(serverId, channelId);
|
||||||
|
WarningThresholdNotificationModel notificationModel = WarningThresholdNotificationModel
|
||||||
|
.builder()
|
||||||
|
.channelDisplay(ChannelDisplay.fromChannel(channel))
|
||||||
|
.memberDisplay(MemberDisplay.fromAUserInAServer(warnedUserInAServer))
|
||||||
|
.messageId(model.getWarningMessageId())
|
||||||
|
.warnCount(warnIds.size())
|
||||||
|
.build();
|
||||||
|
|
||||||
|
MessageToSend messageToSend = templateService.renderEmbedTemplate(WARN_THRESHOLD_NOTIFICATION_TEMPLATE_KEY, notificationModel, serverId);
|
||||||
|
FutureUtils.toSingleFutureGeneric(postTargetService.sendEmbedInPostTarget(messageToSend, ModerationCustomPostTarget.WARN_THRESHOLD_NOTIFICATION, serverId))
|
||||||
|
.thenAccept(unused -> log.info("Warn threshold notification sent for user {} in server {}.", warnedUserId, serverId))
|
||||||
|
.exceptionally(throwable -> {
|
||||||
|
log.error("Failed to sent warn threshold notification for user {} in server {}.", warnedUserId, serverId, throwable);
|
||||||
|
return null;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return DefaultListenerResult.PROCESSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FeatureDefinition getFeature() {
|
||||||
|
return ModerationCustomFeatureDefinition.MODERATION_CUSTOM;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.custom.moderation.model.template;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.models.template.display.ChannelDisplay;
|
||||||
|
import dev.sheldan.abstracto.core.models.template.display.MemberDisplay;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
@Builder
|
||||||
|
@Getter
|
||||||
|
public class WarningThresholdNotificationModel {
|
||||||
|
private MemberDisplay memberDisplay;
|
||||||
|
private Integer warnCount;
|
||||||
|
private ChannelDisplay channelDisplay;
|
||||||
|
private Long messageId;
|
||||||
|
}
|
||||||
@@ -5,4 +5,9 @@ abstracto.systemConfigs.modModeRoleId.name=modModeRoleId
|
|||||||
abstracto.systemConfigs.modModeRoleId.longValue=0
|
abstracto.systemConfigs.modModeRoleId.longValue=0
|
||||||
|
|
||||||
abstracto.systemConfigs.modModeNewRoleColor.name=modModeNewRoleColor
|
abstracto.systemConfigs.modModeNewRoleColor.name=modModeNewRoleColor
|
||||||
abstracto.systemConfigs.modModeNewRoleColor.stringValue=0,0,0
|
abstracto.systemConfigs.modModeNewRoleColor.stringValue=0,0,0
|
||||||
|
|
||||||
|
abstracto.systemConfigs.warnNotificationThreshold.name=warnNotificationThreshold
|
||||||
|
abstracto.systemConfigs.warnNotificationThreshold.longValue=3
|
||||||
|
|
||||||
|
abstracto.postTargets.warnThresholdNotification.name=warnThresholdNotification
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
||||||
<artifactId>application</artifactId>
|
<artifactId>application</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.custom</groupId>
|
||||||
<artifactId>oneplus-bot-customizations</artifactId>
|
<artifactId>oneplus-bot-customizations</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<artifactId>oneplus-bot-modules</artifactId>
|
<artifactId>oneplus-bot-modules</artifactId>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ import dev.sheldan.oneplus.bot.modules.faq.config.FAQFeatureDefinition;
|
|||||||
import dev.sheldan.oneplus.bot.modules.faq.config.FAQModuleDefinition;
|
import dev.sheldan.oneplus.bot.modules.faq.config.FAQModuleDefinition;
|
||||||
import dev.sheldan.oneplus.bot.modules.faq.models.command.faq.FAQResponseModel;
|
import dev.sheldan.oneplus.bot.modules.faq.models.command.faq.FAQResponseModel;
|
||||||
import dev.sheldan.oneplus.bot.modules.faq.service.FAQResponseServiceBean;
|
import dev.sheldan.oneplus.bot.modules.faq.service.FAQResponseServiceBean;
|
||||||
import net.dv8tion.jda.api.entities.TextChannel;
|
import net.dv8tion.jda.api.entities.channel.concrete.TextChannel;
|
||||||
|
import net.dv8tion.jda.api.entities.channel.middleman.GuildMessageChannel;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
@@ -50,7 +51,7 @@ public class FAQ extends AbstractConditionableCommand {
|
|||||||
String commandName;
|
String commandName;
|
||||||
if(!parameters.isEmpty()) {
|
if(!parameters.isEmpty()) {
|
||||||
commandName = (String) parameters.get(0);
|
commandName = (String) parameters.get(0);
|
||||||
TextChannel channel;
|
GuildMessageChannel channel;
|
||||||
if (parameters.size() == 2) {
|
if (parameters.size() == 2) {
|
||||||
channel = (TextChannel) parameters.get(1);
|
channel = (TextChannel) parameters.get(1);
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -66,6 +66,7 @@ public class ImportFAQ extends AbstractConditionableCommand {
|
|||||||
AServer server = serverManagementService.loadServer(commandContext.getGuild());
|
AServer server = serverManagementService.loadServer(commandContext.getGuild());
|
||||||
List<FaqCommandConfig> commands = faqServiceBean.loadFAQCommandsFromJson(jsonContent);
|
List<FaqCommandConfig> commands = faqServiceBean.loadFAQCommandsFromJson(jsonContent);
|
||||||
faqServiceBean.createOrUpdateFAQCommands(commands, server);
|
faqServiceBean.createOrUpdateFAQCommands(commands, server);
|
||||||
|
return CompletableFuture.completedFuture(CommandResult.fromSuccess());
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
List<String> errors = jsonValidationService.getDetailedException(result.getExceptions())
|
List<String> errors = jsonValidationService.getDetailedException(result.getExceptions())
|
||||||
@@ -73,8 +74,8 @@ public class ImportFAQ extends AbstractConditionableCommand {
|
|||||||
.map(ValidationException::getMessage)
|
.map(ValidationException::getMessage)
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
channelService.sendTextToChannel(String.join("\n", errors), commandContext.getChannel());
|
channelService.sendTextToChannel(String.join("\n", errors), commandContext.getChannel());
|
||||||
|
return CompletableFuture.completedFuture(CommandResult.fromError("Incorrect faq config."));
|
||||||
}
|
}
|
||||||
return CompletableFuture.completedFuture(CommandResult.fromSuccess());
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log.error("IO Exception when loading input file.", e);
|
log.error("IO Exception when loading input file.", e);
|
||||||
throw new AbstractoTemplatedException("Failed to load json config.", "failed_to_set_template_exception", e);
|
throw new AbstractoTemplatedException("Failed to load json config.", "failed_to_set_template_exception", e);
|
||||||
|
|||||||
@@ -65,7 +65,8 @@ public class FAQCommandConfigConverter {
|
|||||||
|
|
||||||
private FaqCommandResponseMessageConfig convertCommandResponse(FAQCommandResponse response, Long botUserId) {
|
private FaqCommandResponseMessageConfig convertCommandResponse(FAQCommandResponse response, Long botUserId) {
|
||||||
FaqCommandResponseEmbedConfig embedConfig = null;
|
FaqCommandResponseEmbedConfig embedConfig = null;
|
||||||
if(response.getDescription() != null) {
|
// one of those must not be null, for it to be considered a proper embed
|
||||||
|
if(response.getDescription() != null || response.getImageURL() != null) {
|
||||||
boolean useBot = response.getAuthorUserId().equals(botUserId);
|
boolean useBot = response.getAuthorUserId().equals(botUserId);
|
||||||
FaqCommandResponseEmbedColorConfig colorConfig = FaqCommandResponseEmbedColorConfig
|
FaqCommandResponseEmbedColorConfig colorConfig = FaqCommandResponseEmbedColorConfig
|
||||||
.builder()
|
.builder()
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database;
|
|||||||
import dev.sheldan.abstracto.core.models.database.AChannelGroup;
|
import dev.sheldan.abstracto.core.models.database.AChannelGroup;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
|
||||||
@Builder
|
@Builder
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database;
|
|||||||
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.ChannelGroupCommandId;
|
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.ChannelGroupCommandId;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database;
|
|||||||
import dev.sheldan.abstracto.core.models.database.AServer;
|
import dev.sheldan.abstracto.core.models.database.AServer;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database;
|
|||||||
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.FAQCommandAliasId;
|
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.FAQCommandAliasId;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database;
|
|||||||
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.CommandResponseId;
|
import dev.sheldan.oneplus.bot.modules.faq.models.database.embed.CommandResponseId;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
|
||||||
@Builder
|
@Builder
|
||||||
|
|||||||
@@ -2,8 +2,8 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database.embed;
|
|||||||
|
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.Column;
|
import jakarta.persistence.Column;
|
||||||
import javax.persistence.Embeddable;
|
import jakarta.persistence.Embeddable;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
@Embeddable
|
@Embeddable
|
||||||
|
|||||||
@@ -2,8 +2,8 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database.embed;
|
|||||||
|
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.Column;
|
import jakarta.persistence.Column;
|
||||||
import javax.persistence.Embeddable;
|
import jakarta.persistence.Embeddable;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
@Embeddable
|
@Embeddable
|
||||||
|
|||||||
@@ -2,8 +2,8 @@ package dev.sheldan.oneplus.bot.modules.faq.models.database.embed;
|
|||||||
|
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.Column;
|
import jakarta.persistence.Column;
|
||||||
import javax.persistence.Embeddable;
|
import jakarta.persistence.Embeddable;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
@Embeddable
|
@Embeddable
|
||||||
|
|||||||
@@ -22,10 +22,8 @@ import dev.sheldan.oneplus.bot.modules.faq.service.management.FAQChannelGroupCom
|
|||||||
import dev.sheldan.oneplus.bot.modules.faq.service.management.FAQCommandAliasManagementService;
|
import dev.sheldan.oneplus.bot.modules.faq.service.management.FAQCommandAliasManagementService;
|
||||||
import dev.sheldan.oneplus.bot.modules.faq.service.management.FAQCommandManagementServiceBean;
|
import dev.sheldan.oneplus.bot.modules.faq.service.management.FAQCommandManagementServiceBean;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import net.dv8tion.jda.api.entities.ISnowflake;
|
import net.dv8tion.jda.api.entities.*;
|
||||||
import net.dv8tion.jda.api.entities.SelfUser;
|
import net.dv8tion.jda.api.entities.channel.middleman.GuildMessageChannel;
|
||||||
import net.dv8tion.jda.api.entities.TextChannel;
|
|
||||||
import net.dv8tion.jda.api.entities.User;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
@@ -67,7 +65,7 @@ public class FAQResponseServiceBean {
|
|||||||
@Autowired
|
@Autowired
|
||||||
private FAQResponseServiceBean self;
|
private FAQResponseServiceBean self;
|
||||||
|
|
||||||
public CompletableFuture<FAQResponseModel> loadFAQResponse(String commandName, TextChannel textChannel) {
|
public CompletableFuture<FAQResponseModel> loadFAQResponse(String commandName, GuildMessageChannel textChannel) {
|
||||||
AServer server = serverManagementService.loadServer(textChannel.getGuild().getIdLong());
|
AServer server = serverManagementService.loadServer(textChannel.getGuild().getIdLong());
|
||||||
Optional<FAQCommand> faqCommandOptional = faqCommandManagementServiceBean.findByNameAndServer(commandName, server);
|
Optional<FAQCommand> faqCommandOptional = faqCommandManagementServiceBean.findByNameAndServer(commandName, server);
|
||||||
if(!faqCommandOptional.isPresent()) {
|
if(!faqCommandOptional.isPresent()) {
|
||||||
|
|||||||
@@ -3,143 +3,124 @@
|
|||||||
"type": "array",
|
"type": "array",
|
||||||
"minItems": 1,
|
"minItems": 1,
|
||||||
"maxItems": 30,
|
"maxItems": 30,
|
||||||
"items": [
|
"items": {
|
||||||
{
|
"type": "object",
|
||||||
"type": "object",
|
"properties": {
|
||||||
"properties": {
|
"faqCommandName": {
|
||||||
"faqCommandName": {
|
"type": "string",
|
||||||
|
"minLength": 1,
|
||||||
|
"maxLength": 30,
|
||||||
|
"pattern": "\\w*"
|
||||||
|
},
|
||||||
|
"global": {
|
||||||
|
"default": false,
|
||||||
|
"type": "boolean"
|
||||||
|
},
|
||||||
|
"aliases": {
|
||||||
|
"type": "array",
|
||||||
|
"minItems": 0,
|
||||||
|
"maxItems": 20,
|
||||||
|
"items": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"minLength": 1,
|
"minLength": 1,
|
||||||
"maxLength": 30,
|
"maxLength": 30,
|
||||||
"pattern": "\\w*"
|
"pattern": "\\w*"
|
||||||
},
|
}
|
||||||
"global": {
|
},
|
||||||
"default": false,
|
"responses": {
|
||||||
"type": "boolean"
|
"type": "array",
|
||||||
},
|
"minItems": 1,
|
||||||
"aliases": {
|
"maxItems": 255,
|
||||||
"type": "array",
|
"items": {
|
||||||
"minItems": 1,
|
"type": "object",
|
||||||
"maxItems": 20,
|
"properties": {
|
||||||
"items": {
|
"channelGroupName": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"minLength": 1,
|
"minLength": 1,
|
||||||
"maxLength": 30,
|
"maxLength": 20,
|
||||||
"pattern": "\\w*"
|
"pattern": "\\w*"
|
||||||
}
|
},
|
||||||
},
|
"messages": {
|
||||||
"responses": {
|
"type": "array",
|
||||||
"type": "array",
|
"minItems": 1,
|
||||||
"minItems": 1,
|
"maxItems": 3,
|
||||||
"maxItems": 255,
|
"items": {
|
||||||
"items": {
|
"type": "object",
|
||||||
"type": "object",
|
"properties": {
|
||||||
"properties": {
|
"position": {
|
||||||
"channelGroupName": {
|
"type": "number",
|
||||||
"type": "string",
|
"minimum": 0,
|
||||||
"minLength": 1,
|
"maximum": 2
|
||||||
"maxLength": 20,
|
},
|
||||||
"pattern": "\\w*"
|
"additionalMessage": {
|
||||||
},
|
"type": "string",
|
||||||
"messages": {
|
"minLength": 1,
|
||||||
"type": "array",
|
"maxLength": 2000
|
||||||
"minItems": 1,
|
},
|
||||||
"maxItems": 3,
|
"embed": {
|
||||||
"items": [
|
|
||||||
{
|
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"position": {
|
"description": {
|
||||||
"type": "number",
|
|
||||||
"minimum": 0,
|
|
||||||
"maximum": 2
|
|
||||||
},
|
|
||||||
"additionalMessage": {
|
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"minLength": 1,
|
"minLength": 1,
|
||||||
"maxLength": 2000
|
"maxLength": 2000
|
||||||
},
|
},
|
||||||
"embed": {
|
"imageUrl": {
|
||||||
|
"type": "string",
|
||||||
|
"minLength": 1,
|
||||||
|
"maxLength": 2000,
|
||||||
|
"pattern": "\\s*https?:\/\/\\S+"
|
||||||
|
},
|
||||||
|
"color": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
"description": {
|
"red": {
|
||||||
"type": "string",
|
"type": "integer",
|
||||||
"minLength": 1,
|
"minimum": 0,
|
||||||
"maxLength": 2000
|
"default": 0,
|
||||||
|
"maximum": 255
|
||||||
},
|
},
|
||||||
"imageUrl": {
|
"green": {
|
||||||
"type": "string",
|
"type": "integer",
|
||||||
"minLength": 1,
|
"minimum": 0,
|
||||||
"maxLength": 2000,
|
"default": 0,
|
||||||
"pattern": "\\s*https?:\/\/\\S+"
|
"maximum": 255
|
||||||
},
|
},
|
||||||
"color": {
|
"blue": {
|
||||||
"type": "object",
|
"type": "integer",
|
||||||
"properties": {
|
"minimum": 0,
|
||||||
"red": {
|
"default": 0,
|
||||||
"type": "integer",
|
"maximum": 255
|
||||||
"minimum": 0,
|
}
|
||||||
"default": 0,
|
},
|
||||||
"maximum": 255
|
"required": [
|
||||||
},
|
"red",
|
||||||
"green": {
|
"green",
|
||||||
"type": "integer",
|
"blue"
|
||||||
"minimum": 0,
|
]
|
||||||
"default": 0,
|
},
|
||||||
"maximum": 255
|
"author": {
|
||||||
},
|
"type": "object",
|
||||||
"blue": {
|
"properties": {
|
||||||
"type": "integer",
|
"userId": {
|
||||||
"minimum": 0,
|
"minimum": 1,
|
||||||
"default": 0,
|
"maximum": 18446744073709551615,
|
||||||
"maximum": 255
|
"type": "integer"
|
||||||
}
|
|
||||||
},
|
|
||||||
"required": [
|
|
||||||
"red",
|
|
||||||
"green",
|
|
||||||
"blue"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"author": {
|
"useBot": {
|
||||||
"type": "object",
|
"type": "boolean"
|
||||||
"properties": {
|
|
||||||
"userId": {
|
|
||||||
"minimum": 1,
|
|
||||||
"maximum": 18446744073709551615,
|
|
||||||
"type": "integer"
|
|
||||||
},
|
|
||||||
"useBot": {
|
|
||||||
"type": "boolean"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"additionalProperties": false,
|
|
||||||
"anyOf": [
|
|
||||||
{
|
|
||||||
"required": [
|
|
||||||
"userId"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"required": [
|
|
||||||
"useBot"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"required": [
|
"required": [
|
||||||
"description",
|
"userId"
|
||||||
"author"
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"required": [
|
"required": [
|
||||||
"imageUrl",
|
"useBot"
|
||||||
"author"
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@@ -149,41 +130,56 @@
|
|||||||
"anyOf": [
|
"anyOf": [
|
||||||
{
|
{
|
||||||
"required": [
|
"required": [
|
||||||
"additionalMessage",
|
"description",
|
||||||
"position"
|
"author"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"required": [
|
"required": [
|
||||||
"embed",
|
"imageUrl",
|
||||||
"position"
|
"author"
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"required": [
|
|
||||||
"additionalMessage",
|
|
||||||
"embed",
|
|
||||||
"position"
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false,
|
||||||
|
"anyOf": [
|
||||||
|
{
|
||||||
|
"required": [
|
||||||
|
"additionalMessage",
|
||||||
|
"position"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"required": [
|
||||||
|
"embed",
|
||||||
|
"position"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"required": [
|
||||||
|
"additionalMessage",
|
||||||
|
"embed",
|
||||||
|
"position"
|
||||||
|
]
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
}
|
||||||
"additionalProperties": false,
|
},
|
||||||
"required": [
|
"additionalProperties": false,
|
||||||
"channelGroupName",
|
"required": [
|
||||||
"messages"
|
"channelGroupName",
|
||||||
]
|
"messages"
|
||||||
}
|
]
|
||||||
}
|
}
|
||||||
},
|
}
|
||||||
"additionalProperties": false,
|
},
|
||||||
"required": [
|
"additionalProperties": false,
|
||||||
"faqCommandName",
|
"required": [
|
||||||
"responses"
|
"faqCommandName",
|
||||||
]
|
"responses"
|
||||||
}
|
]
|
||||||
]
|
}
|
||||||
}
|
}
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<artifactId>oneplus-bot-modules</artifactId>
|
<artifactId>oneplus-bot-modules</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
@@ -14,6 +14,13 @@
|
|||||||
<maven.compiler.target>8</maven.compiler.target>
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>dev.sheldan.abstracto.scheduling</groupId>
|
||||||
|
<artifactId>scheduling-int</artifactId>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import dev.sheldan.abstracto.core.models.database.AServer;
|
|||||||
import dev.sheldan.abstracto.core.models.database.AUserInAServer;
|
import dev.sheldan.abstracto.core.models.database.AUserInAServer;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
|
||||||
@Builder
|
@Builder
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ import dev.sheldan.oneplus.bot.modules.news.model.database.NewsPost;
|
|||||||
import dev.sheldan.oneplus.bot.modules.news.service.management.NewsPostManagementServiceBean;
|
import dev.sheldan.oneplus.bot.modules.news.service.management.NewsPostManagementServiceBean;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import net.dv8tion.jda.api.entities.Message;
|
import net.dv8tion.jda.api.entities.Message;
|
||||||
import net.dv8tion.jda.api.entities.TextChannel;
|
import net.dv8tion.jda.api.entities.channel.middleman.GuildMessageChannel;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
@@ -113,7 +113,7 @@ public class NewsServiceBean {
|
|||||||
log.info("Updating news post {} with new content based on message from user {} in server {}.",
|
log.info("Updating news post {} with new content based on message from user {} in server {}.",
|
||||||
newsPost.getSourceMessageId(), updatedMessage.getIdLong(), updatedMessage.getGuild().getId());
|
newsPost.getSourceMessageId(), updatedMessage.getIdLong(), updatedMessage.getGuild().getId());
|
||||||
MessageToSend messageToSend = templateService.renderEmbedTemplate(MESSAGE_TEMPLATE_KEY, model, serverId);
|
MessageToSend messageToSend = templateService.renderEmbedTemplate(MESSAGE_TEMPLATE_KEY, model, serverId);
|
||||||
TextChannel newsChannel = channelService.getTextChannelFromServer(serverId, newsPost.getNewsChannel().getId());
|
GuildMessageChannel newsChannel = channelService.getMessageChannelFromServer(serverId, newsPost.getNewsChannel().getId());
|
||||||
return channelService.editMessageInAChannelFuture(messageToSend, newsChannel, newsPost.getNewsMessageId())
|
return channelService.editMessageInAChannelFuture(messageToSend, newsChannel, newsPost.getNewsMessageId())
|
||||||
.thenApply(message -> null);
|
.thenApply(message -> null);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,12 +6,12 @@ import dev.sheldan.abstracto.core.service.management.UserInServerManagementServi
|
|||||||
import dev.sheldan.oneplus.bot.modules.news.exception.NewsPostNotFoundException;
|
import dev.sheldan.oneplus.bot.modules.news.exception.NewsPostNotFoundException;
|
||||||
import dev.sheldan.oneplus.bot.modules.news.model.database.NewsPost;
|
import dev.sheldan.oneplus.bot.modules.news.model.database.NewsPost;
|
||||||
import dev.sheldan.oneplus.bot.modules.news.repository.NewsPostRepository;
|
import dev.sheldan.oneplus.bot.modules.news.repository.NewsPostRepository;
|
||||||
|
import jakarta.persistence.*;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import net.dv8tion.jda.api.entities.Message;
|
import net.dv8tion.jda.api.entities.Message;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
||||||
<artifactId>application</artifactId>
|
<artifactId>application</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
@@ -15,6 +15,7 @@
|
|||||||
<module>setup</module>
|
<module>setup</module>
|
||||||
<module>referral</module>
|
<module>referral</module>
|
||||||
<module>faq</module>
|
<module>faq</module>
|
||||||
|
<module>seasonal</module>
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<artifactId>oneplus-bot-modules</artifactId>
|
<artifactId>oneplus-bot-modules</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import dev.sheldan.abstracto.core.models.database.AServer;
|
|||||||
import dev.sheldan.abstracto.core.models.database.AUserInAServer;
|
import dev.sheldan.abstracto.core.models.database.AUserInAServer;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
import javax.persistence.*;
|
import jakarta.persistence.*;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
|
||||||
@Builder
|
@Builder
|
||||||
|
|||||||
@@ -1,13 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<artifactId>application</artifactId>
|
<artifactId>oneplus-bot-modules</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
<artifactId>database</artifactId>
|
<artifactId>seasonal</artifactId>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<maven.compiler.source>8</maven.compiler.source>
|
||||||
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
|
</properties>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
@@ -0,0 +1,24 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.config;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.command.config.ModuleDefinition;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.ModuleInfo;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class SeasonalEntertainmentFeatureDefinition implements ModuleDefinition {
|
||||||
|
public static final String ENTERTAINMENT = "entertainment";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ModuleInfo getInfo() {
|
||||||
|
return ModuleInfo
|
||||||
|
.builder()
|
||||||
|
.name(ENTERTAINMENT)
|
||||||
|
.templated(true)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getParentModule() {
|
||||||
|
return "default";
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.config;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public enum SeasonalFeatureDefinition implements FeatureDefinition {
|
||||||
|
LIGHTS("lights");
|
||||||
|
|
||||||
|
private String key;
|
||||||
|
|
||||||
|
SeasonalFeatureDefinition(String key) {
|
||||||
|
this.key = key;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,10 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.config;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.context.annotation.PropertySource;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@PropertySource("classpath:seasonal.properties")
|
||||||
|
public class SeasonalProperties {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,58 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.command;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.command.condition.AbstractConditionableCommand;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.CommandConfiguration;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.HelpInfo;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.Parameter;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandContext;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandResult;
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.abstracto.core.exception.EntityGuildMismatchException;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalEntertainmentFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.service.LightsRoleServiceBean;
|
||||||
|
import net.dv8tion.jda.api.entities.Role;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class AddRoleToLights extends AbstractConditionableCommand {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsRoleServiceBean lightsMemberServiceBean;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandResult execute(CommandContext commandContext) {
|
||||||
|
List<Object> parameters = commandContext.getParameters().getParameters();
|
||||||
|
Role role = (Role) parameters.get(0);
|
||||||
|
if(!role.getGuild().equals(commandContext.getGuild())) {
|
||||||
|
throw new EntityGuildMismatchException();
|
||||||
|
}
|
||||||
|
lightsMemberServiceBean.addMemberToSeasonalLights(role);
|
||||||
|
return CommandResult.fromSuccess();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandConfiguration getConfiguration() {
|
||||||
|
List<Parameter> parameters = new ArrayList<>();
|
||||||
|
parameters.add(Parameter.builder().name("role").templated(true).type(Role.class).build());
|
||||||
|
HelpInfo helpInfo = HelpInfo.builder().templated(true).build();
|
||||||
|
return CommandConfiguration.builder()
|
||||||
|
.name("addRoleToLights")
|
||||||
|
.module(SeasonalEntertainmentFeatureDefinition.ENTERTAINMENT)
|
||||||
|
.templated(true)
|
||||||
|
.supportsEmbedException(true)
|
||||||
|
.causesReaction(true)
|
||||||
|
.parameters(parameters)
|
||||||
|
.help(helpInfo)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FeatureDefinition getFeature() {
|
||||||
|
return SeasonalFeatureDefinition.LIGHTS;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,58 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.command;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.command.condition.AbstractConditionableCommand;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.CommandConfiguration;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.HelpInfo;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.Parameter;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandContext;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandResult;
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.abstracto.core.exception.EntityGuildMismatchException;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalEntertainmentFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.service.LightsRoleServiceBean;
|
||||||
|
import net.dv8tion.jda.api.entities.Role;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class RemoveRoleFromLights extends AbstractConditionableCommand {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsRoleServiceBean lightsMemberServiceBean;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandResult execute(CommandContext commandContext) {
|
||||||
|
List<Object> parameters = commandContext.getParameters().getParameters();
|
||||||
|
Role role = (Role) parameters.get(0);
|
||||||
|
if(!role.getGuild().equals(commandContext.getGuild())) {
|
||||||
|
throw new EntityGuildMismatchException();
|
||||||
|
}
|
||||||
|
lightsMemberServiceBean.removeMemberFromSeasonalLights(role);
|
||||||
|
return CommandResult.fromSuccess();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandConfiguration getConfiguration() {
|
||||||
|
List<Parameter> parameters = new ArrayList<>();
|
||||||
|
parameters.add(Parameter.builder().name("role").templated(true).type(Role.class).build());
|
||||||
|
HelpInfo helpInfo = HelpInfo.builder().templated(true).build();
|
||||||
|
return CommandConfiguration.builder()
|
||||||
|
.name("removeRoleFromLights")
|
||||||
|
.module(SeasonalEntertainmentFeatureDefinition.ENTERTAINMENT)
|
||||||
|
.templated(true)
|
||||||
|
.supportsEmbedException(true)
|
||||||
|
.causesReaction(true)
|
||||||
|
.parameters(parameters)
|
||||||
|
.help(helpInfo)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FeatureDefinition getFeature() {
|
||||||
|
return SeasonalFeatureDefinition.LIGHTS;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,55 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.command;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.command.condition.AbstractConditionableCommand;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.CommandConfiguration;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.HelpInfo;
|
||||||
|
import dev.sheldan.abstracto.core.command.config.Parameter;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandContext;
|
||||||
|
import dev.sheldan.abstracto.core.command.execution.CommandResult;
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalEntertainmentFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalFeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.service.LightsRoleServiceBean;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class SwitchLights extends AbstractConditionableCommand {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsRoleServiceBean lightsMemberServiceBean;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CompletableFuture<CommandResult> executeAsync(CommandContext commandContext) {
|
||||||
|
return lightsMemberServiceBean.switchLights(commandContext.getGuild())
|
||||||
|
.thenApply(unused -> CommandResult.fromSuccess());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandConfiguration getConfiguration() {
|
||||||
|
List<Parameter> parameters = new ArrayList<>();
|
||||||
|
HelpInfo helpInfo = HelpInfo
|
||||||
|
.builder()
|
||||||
|
.templated(true)
|
||||||
|
.build();
|
||||||
|
return CommandConfiguration.builder()
|
||||||
|
.name("switchLights")
|
||||||
|
.module(SeasonalEntertainmentFeatureDefinition.ENTERTAINMENT)
|
||||||
|
.templated(true)
|
||||||
|
.async(true)
|
||||||
|
.causesReaction(true)
|
||||||
|
.supportsEmbedException(true)
|
||||||
|
.parameters(parameters)
|
||||||
|
.help(helpInfo)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FeatureDefinition getFeature() {
|
||||||
|
return SeasonalFeatureDefinition.LIGHTS;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.config;
|
||||||
|
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.models.LightsRoleColor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import org.springframework.boot.context.properties.ConfigurationProperties;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@Configuration
|
||||||
|
@ConfigurationProperties(prefix = "abstracto.feature.lights")
|
||||||
|
public class LightsColorConfig {
|
||||||
|
private List<LightsRoleColor> colors;
|
||||||
|
}
|
||||||
@@ -0,0 +1,16 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.config;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureConfig;
|
||||||
|
import dev.sheldan.abstracto.core.config.FeatureDefinition;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.config.SeasonalFeatureDefinition;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class LightsFeatureConfig implements FeatureConfig {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FeatureDefinition getFeature() {
|
||||||
|
return SeasonalFeatureDefinition.LIGHTS;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.models;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
import java.awt.*;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class LightsRoleColor {
|
||||||
|
private Integer r;
|
||||||
|
private Integer g;
|
||||||
|
private Integer b;
|
||||||
|
|
||||||
|
public Color toColor() {
|
||||||
|
return new Color(r, g, b);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,31 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.models.database;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.models.database.ARole;
|
||||||
|
import dev.sheldan.abstracto.core.models.database.AServer;
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
|
import jakarta.persistence.*;
|
||||||
|
|
||||||
|
@Builder
|
||||||
|
@Entity
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@Table(name = "lights_role")
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@EqualsAndHashCode
|
||||||
|
public class LightsRole {
|
||||||
|
@Id
|
||||||
|
@Column(name = "id")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@ManyToOne(fetch = FetchType.LAZY)
|
||||||
|
@JoinColumn(name = "server_id", nullable = false)
|
||||||
|
private AServer server;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@ManyToOne(fetch = FetchType.LAZY)
|
||||||
|
@PrimaryKeyJoinColumn
|
||||||
|
private ARole role;
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.repository;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.models.database.AServer;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.models.database.LightsRole;
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface LightsRoleRepository extends JpaRepository<LightsRole, Long> {
|
||||||
|
List<LightsRole> findByServer(AServer server);
|
||||||
|
}
|
||||||
@@ -0,0 +1,81 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.service;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.models.database.ARole;
|
||||||
|
import dev.sheldan.abstracto.core.models.database.AServer;
|
||||||
|
import dev.sheldan.abstracto.core.service.RoleService;
|
||||||
|
import dev.sheldan.abstracto.core.service.management.RoleManagementService;
|
||||||
|
import dev.sheldan.abstracto.core.service.management.ServerManagementService;
|
||||||
|
import dev.sheldan.abstracto.core.utils.FutureUtils;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.config.LightsColorConfig;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.models.database.LightsRole;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.service.management.LightsRoleServiceManagementBean;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import net.dv8tion.jda.api.entities.Guild;
|
||||||
|
import net.dv8tion.jda.api.entities.Role;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.awt.*;
|
||||||
|
import java.security.SecureRandom;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
@Slf4j
|
||||||
|
public class LightsRoleServiceBean {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ServerManagementService serverManagementService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsRoleServiceManagementBean serviceManagementBean;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private RoleManagementService roleManagementService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private RoleService roleService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private SecureRandom secureRandom;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsColorConfig lightsColorConfig;
|
||||||
|
|
||||||
|
public void addMemberToSeasonalLights(Role role) {
|
||||||
|
ARole aRole = roleManagementService.findRole(role.getIdLong());
|
||||||
|
log.info("Adding {} to lights for guild {}.", role.getId(), role.getGuild().getId());
|
||||||
|
serviceManagementBean.addMemberToLights(aRole);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeMemberFromSeasonalLights(Role role) {
|
||||||
|
ARole aRole = roleManagementService.findRole(role.getIdLong());
|
||||||
|
log.info("Removing {} from lights for guild {}.", role.getId(), role.getGuild().getId());
|
||||||
|
serviceManagementBean.removeMemberFromLights(aRole);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CompletableFuture<Void> switchLights(Guild guild) {
|
||||||
|
log.info("Switching lights in guild {}", guild.getIdLong());
|
||||||
|
AServer server = serverManagementService.loadServer(guild.getIdLong());
|
||||||
|
List<LightsRole> lightUsers = serviceManagementBean.getLightsUserInServer(server);
|
||||||
|
List<Long> roleIds = lightUsers
|
||||||
|
.stream()
|
||||||
|
.map(lightsMember -> lightsMember.getRole().getId())
|
||||||
|
.distinct()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
List<CompletableFuture<Void>> futures = new ArrayList<>();
|
||||||
|
roleIds.forEach(roleId -> {
|
||||||
|
Role foundRole = guild.getRoleById(roleId);
|
||||||
|
if(foundRole != null) {
|
||||||
|
futures.add(roleService.setRoleColorTo(foundRole, getRandomColor()));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return FutureUtils.toSingleFutureGeneric(futures);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Color getRandomColor() {
|
||||||
|
return lightsColorConfig.getColors().get(secureRandom.nextInt(lightsColorConfig.getColors().size())).toColor();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,37 @@
|
|||||||
|
package dev.sheldan.oneplus.bot.modules.seasonal.lights.service.management;
|
||||||
|
|
||||||
|
import dev.sheldan.abstracto.core.models.database.ARole;
|
||||||
|
import dev.sheldan.abstracto.core.models.database.AServer;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.models.database.LightsRole;
|
||||||
|
import dev.sheldan.oneplus.bot.modules.seasonal.lights.repository.LightsRoleRepository;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class LightsRoleServiceManagementBean {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LightsRoleRepository lightMemberRepository;
|
||||||
|
|
||||||
|
public void addMemberToLights(ARole aRole) {
|
||||||
|
if(!lightMemberRepository.existsById(aRole.getId())) {
|
||||||
|
LightsRole member = LightsRole
|
||||||
|
.builder()
|
||||||
|
.id(aRole.getId())
|
||||||
|
.server(aRole.getServer())
|
||||||
|
.role(aRole)
|
||||||
|
.build();
|
||||||
|
lightMemberRepository.save(member);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeMemberFromLights(ARole aRole) {
|
||||||
|
lightMemberRepository.deleteById(aRole.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<LightsRole> getLightsUserInServer(AServer server) {
|
||||||
|
return lightMemberRepository.findByServer(server);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -6,5 +6,6 @@
|
|||||||
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
<include file="structure/structure.xml" relativeToChangelogFile="true"/>
|
<include file="tables/tables.xml" relativeToChangelogFile="true"/>
|
||||||
|
<include file="seedData/data.xml" relativeToChangelogFile="true"/>
|
||||||
</databaseChangeLog>
|
</databaseChangeLog>
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
<?xml version="1.1" encoding="UTF-8" standalone="no"?>
|
||||||
|
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
|
||||||
|
xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext"
|
||||||
|
xmlns:pro="http://www.liquibase.org/xml/ns/pro"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
|
<property name="lightsFeature" value="(SELECT id FROM feature WHERE key = 'lights')"/>
|
||||||
|
<property name="entertainmentModule" value="(SELECT id FROM module WHERE name = 'entertainment')"/>
|
||||||
|
<changeSet author="Sheldan" id="lights-commands" >
|
||||||
|
<insert tableName="command">
|
||||||
|
<column name="name" value="addRoleToLights"/>
|
||||||
|
<column name="module_id" valueComputed="${entertainmentModule}"/>
|
||||||
|
<column name="feature_id" valueComputed="${lightsFeature}"/>
|
||||||
|
</insert>
|
||||||
|
<insert tableName="command">
|
||||||
|
<column name="name" value="removeRoleFromLights"/>
|
||||||
|
<column name="module_id" valueComputed="${entertainmentModule}"/>
|
||||||
|
<column name="feature_id" valueComputed="${lightsFeature}"/>
|
||||||
|
</insert>
|
||||||
|
<insert tableName="command">
|
||||||
|
<column name="name" value="switchLights"/>
|
||||||
|
<column name="module_id" valueComputed="${entertainmentModule}"/>
|
||||||
|
<column name="feature_id" valueComputed="${lightsFeature}"/>
|
||||||
|
</insert>
|
||||||
|
</changeSet>
|
||||||
|
</databaseChangeLog>
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.1" encoding="UTF-8" standalone="no"?>
|
||||||
|
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
|
||||||
|
xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext"
|
||||||
|
xmlns:pro="http://www.liquibase.org/xml/ns/pro"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
|
<include file="feature.xml" relativeToChangelogFile="true"/>
|
||||||
|
<include file="command.xml" relativeToChangelogFile="true"/>
|
||||||
|
</databaseChangeLog>
|
||||||
@@ -6,14 +6,9 @@
|
|||||||
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
<changeSet author="Sheldan" id="create_grafana_user">
|
<changeSet author="Sheldan" id="seasonal_lights_feature-insertion">
|
||||||
<sql>
|
<insert tableName="feature">
|
||||||
CREATE USER ${abstractografanadbuser} WITH PASSWORD '${abstractografanadbpass}';
|
<column name="key" value="lights"/>
|
||||||
GRANT CONNECT ON DATABASE abstracto TO ${abstractografanadbuser};
|
</insert>
|
||||||
GRANT USAGE ON SCHEMA abstracto TO ${abstractografanadbuser};
|
|
||||||
GRANT SELECT ON ALL TABLES IN SCHEMA abstracto TO ${abstractografanadbuser};
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA abstracto
|
|
||||||
GRANT SELECT ON TABLES TO ${abstractografanadbuser};
|
|
||||||
</sql>
|
|
||||||
</changeSet>
|
</changeSet>
|
||||||
</databaseChangeLog>
|
</databaseChangeLog>
|
||||||
@@ -0,0 +1,44 @@
|
|||||||
|
<?xml version="1.1" encoding="UTF-8" standalone="no"?>
|
||||||
|
<databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog"
|
||||||
|
xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext"
|
||||||
|
xmlns:pro="http://www.liquibase.org/xml/ns/pro"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
|
|
||||||
|
<changeSet author="Sheldan" id="lights_role-table">
|
||||||
|
<createTable tableName="lights_role">
|
||||||
|
<column name="id" type="BIGINT">
|
||||||
|
<constraints nullable="true" primaryKey="true" primaryKeyName="pk_lights_role"/>
|
||||||
|
</column>
|
||||||
|
<column name="server_id" type="BIGINT">
|
||||||
|
<constraints nullable="false"/>
|
||||||
|
</column>
|
||||||
|
<column name="role_id" type="BIGINT">
|
||||||
|
<constraints nullable="false"/>
|
||||||
|
</column>
|
||||||
|
<column name="created" type="TIMESTAMP WITHOUT TIME ZONE">
|
||||||
|
<constraints nullable="true"/>
|
||||||
|
</column>
|
||||||
|
<column name="updated" type="TIMESTAMP WITHOUT TIME ZONE"/>
|
||||||
|
</createTable>
|
||||||
|
<addForeignKeyConstraint baseColumnNames="server_id" baseTableName="lights_role" constraintName="fk_lights_role_server"
|
||||||
|
deferrable="false" initiallyDeferred="false" onDelete="NO ACTION" onUpdate="NO ACTION"
|
||||||
|
referencedColumnNames="id" referencedTableName="server" validate="true"/>
|
||||||
|
<addForeignKeyConstraint baseColumnNames="id" baseTableName="lights_role" constraintName="fk_lights_role_role"
|
||||||
|
deferrable="false" initiallyDeferred="false" onDelete="NO ACTION" onUpdate="NO ACTION"
|
||||||
|
referencedColumnNames="id" referencedTableName="role" validate="true"/>
|
||||||
|
|
||||||
|
|
||||||
|
<sql>
|
||||||
|
DROP TRIGGER IF EXISTS lights_role_update_trigger ON lights_role;
|
||||||
|
CREATE TRIGGER lights_role_update_trigger BEFORE UPDATE ON lights_role FOR EACH ROW EXECUTE PROCEDURE update_trigger_procedure();
|
||||||
|
</sql>
|
||||||
|
<sql>
|
||||||
|
DROP TRIGGER IF EXISTS lights_role_insert_trigger ON lights_role;
|
||||||
|
CREATE TRIGGER lights_role_insert_trigger BEFORE INSERT ON lights_role FOR EACH ROW EXECUTE PROCEDURE insert_trigger_procedure();
|
||||||
|
</sql>
|
||||||
|
</changeSet>
|
||||||
|
|
||||||
|
</databaseChangeLog>
|
||||||
@@ -6,5 +6,5 @@
|
|||||||
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
<include file="grafana_user.xml" relativeToChangelogFile="true"/>
|
<include file="lights_role.xml" relativeToChangelogFile="true"/>
|
||||||
</databaseChangeLog>
|
</databaseChangeLog>
|
||||||
@@ -6,5 +6,5 @@
|
|||||||
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
http://www.liquibase.org/xml/ns/dbchangelog-ext dbchangelog.xsd
|
||||||
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
http://www.liquibase.org/xml/ns/pro dbchangelog.xsd" >
|
||||||
<include file="1.5.4/collection.xml" relativeToChangelogFile="true"/>
|
<include file="1.5.9/collection.xml" relativeToChangelogFile="true"/>
|
||||||
</databaseChangeLog>
|
</databaseChangeLog>
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
abstracto.featureFlags.lights.featureName=lights
|
||||||
|
abstracto.featureFlags.lights.enabled=false
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[0].r=12
|
||||||
|
abstracto.feature.lights.colors[0].g=169
|
||||||
|
abstracto.feature.lights.colors[0].b=12
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[1].r=206
|
||||||
|
abstracto.feature.lights.colors[1].g=13
|
||||||
|
abstracto.feature.lights.colors[1].b=13
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[2].r=255
|
||||||
|
abstracto.feature.lights.colors[2].g=255
|
||||||
|
abstracto.feature.lights.colors[2].b=255
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[3].r=148
|
||||||
|
abstracto.feature.lights.colors[3].g=125
|
||||||
|
abstracto.feature.lights.colors[3].b=0
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[4].r=77
|
||||||
|
abstracto.feature.lights.colors[4].g=106
|
||||||
|
abstracto.feature.lights.colors[4].b=255
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[5].r=166
|
||||||
|
abstracto.feature.lights.colors[5].g=51
|
||||||
|
abstracto.feature.lights.colors[5].b=222
|
||||||
|
|
||||||
|
abstracto.feature.lights.colors[6].r=246
|
||||||
|
abstracto.feature.lights.colors[6].g=232
|
||||||
|
abstracto.feature.lights.colors[6].b=63
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<artifactId>oneplus-bot-modules</artifactId>
|
<artifactId>oneplus-bot-modules</artifactId>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
|||||||
@@ -5,18 +5,17 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot</groupId>
|
<groupId>dev.sheldan.oneplus.bot</groupId>
|
||||||
<artifactId>oneplusbot</artifactId>
|
<artifactId>oneplusbot</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
||||||
<artifactId>application</artifactId>
|
<artifactId>application</artifactId>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
<modules>
|
<modules>
|
||||||
<module>executable</module>
|
<module>executable</module>
|
||||||
<module>oneplus-bot-customizations</module>
|
<module>oneplus-bot-customizations</module>
|
||||||
<module>oneplus-bot-modules</module>
|
<module>oneplus-bot-modules</module>
|
||||||
<module>database</module>
|
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
<dependencyManagement>
|
<dependencyManagement>
|
||||||
@@ -38,15 +37,7 @@
|
|||||||
<artifactId>core-int</artifactId>
|
<artifactId>core-int</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>dev.sheldan.abstracto.modules</groupId>
|
|
||||||
<artifactId>utility-int</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>dev.sheldan.abstracto.scheduling</groupId>
|
|
||||||
<artifactId>scheduling-int</artifactId>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<parent>
|
|
||||||
<groupId>dev.sheldan.oneplus.bot.deployment</groupId>
|
|
||||||
<artifactId>deployment</artifactId>
|
|
||||||
<version>1.5.5</version>
|
|
||||||
</parent>
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
|
|
||||||
<packaging>pom</packaging>
|
|
||||||
<artifactId>docker-compose</artifactId>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<artifactId>maven-assembly-plugin</artifactId>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<id>assembly-docker-compose-configuration</id>
|
|
||||||
<phase>package</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>single</goal>
|
|
||||||
</goals>
|
|
||||||
<configuration>
|
|
||||||
<descriptors>
|
|
||||||
<descriptor>src/main/assembly/docker-compose.xml</descriptor>
|
|
||||||
</descriptors>
|
|
||||||
</configuration>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</project>
|
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0"
|
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd">
|
|
||||||
<id>docker-compose</id>
|
|
||||||
<formats>
|
|
||||||
<format>zip</format>
|
|
||||||
</formats>
|
|
||||||
<includeBaseDirectory>false</includeBaseDirectory>
|
|
||||||
<fileSets>
|
|
||||||
<fileSet>
|
|
||||||
<outputDirectory>./docker-compose</outputDirectory>
|
|
||||||
<directory>${project.basedir}/src/main/resources/</directory>
|
|
||||||
<includes>
|
|
||||||
<include>**/*</include>
|
|
||||||
</includes>
|
|
||||||
<filtered>true</filtered>
|
|
||||||
</fileSet>
|
|
||||||
</fileSets>
|
|
||||||
</assembly>
|
|
||||||
@@ -1,31 +0,0 @@
|
|||||||
# database configuration
|
|
||||||
DATABASE_HOST=database
|
|
||||||
DATABASE_PORT=5432
|
|
||||||
DATABASE_USER=abstracto
|
|
||||||
DATABASE_NAME=abstracto
|
|
||||||
DATABASE_PASSWORD=abstracto
|
|
||||||
GRAFANA_DATABASE_PASSWORD=grafana
|
|
||||||
GRAFANA_DATABASE_USER=grafana
|
|
||||||
# deployment configuration, whether or not the container should execute the parts on startup
|
|
||||||
EXECUTE_DEPLOYMENT=true
|
|
||||||
EXECUTE_LIQUIBASE=true
|
|
||||||
EXECUTE_TEMPLATES=true
|
|
||||||
# whether or not remote debug should be enabled on the application
|
|
||||||
REMOTE_DEBUG=false
|
|
||||||
DEBUG_PORT=5005
|
|
||||||
TOMCAT_PORT=8080
|
|
||||||
# authentication for actuator endpoints
|
|
||||||
REST_USER_NAME=abstracto
|
|
||||||
REST_PASSWORD=password
|
|
||||||
# port grafana will be reachable
|
|
||||||
GRAFANA_PORT=3000
|
|
||||||
# port prometheus will be reachable
|
|
||||||
PROMETHEUS_PORT=9090
|
|
||||||
# port pg admin will be reachable
|
|
||||||
PGADMIN_PORT=5050
|
|
||||||
# default authentication for pg admin
|
|
||||||
PGADMIN_DEFAULT_EMAIL=sheldan@sheldan.dev
|
|
||||||
PGADMIN_DEFAULT_PASSWORD=admin
|
|
||||||
TOKEN=<INSERT TOKEN>
|
|
||||||
YOUTUBE_API_KEY=<INSERT KEY>
|
|
||||||
ONEPLUS_BOT_VERSION=1.5.5
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
# Setup for local docker-compose deployment
|
|
||||||
|
|
||||||
* Install docker [here](https://docs.docker.com/get-docker/)
|
|
||||||
* Install docker-compose [here](https://docs.docker.com/compose/install/).
|
|
||||||
* Execute `docker-compose build` in `image-packaging`.
|
|
||||||
* Fill out values in `.env` for token and database password. There are some default values, but token is required to be changed.
|
|
||||||
* Execute `fill-prometheus-file-sh` in order to populate the prometheus config with the correct password (https://github.com/prometheus/prometheus/issues/2357)
|
|
||||||
* Execute `docker-compose up` in this directory and wait for completion.
|
|
||||||
* Per default pgAdmin is available on `localhost:5050` with the configured user and password. It will contain a configuration in the servers list.
|
|
||||||
|
|
||||||
@@ -1,122 +0,0 @@
|
|||||||
version: '3.7'
|
|
||||||
|
|
||||||
services:
|
|
||||||
db:
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_database:${ONEPLUS_BOT_VERSION}
|
|
||||||
container_name: database
|
|
||||||
restart: always
|
|
||||||
environment:
|
|
||||||
POSTGRES_PASSWORD: ${DATABASE_PASSWORD}
|
|
||||||
POSTGRES_USER: ${DATABASE_USER}
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:${DATABASE_PORT}:5432"
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
volumes:
|
|
||||||
- db-data:/var/lib/postgresql/data
|
|
||||||
deployment_container:
|
|
||||||
container_name: deployment
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_deployment:${ONEPLUS_BOT_VERSION}
|
|
||||||
depends_on:
|
|
||||||
- db
|
|
||||||
environment:
|
|
||||||
DB_PASS: ${DATABASE_PASSWORD}
|
|
||||||
DB_HOST: ${DATABASE_HOST}
|
|
||||||
DB_PORT: ${DATABASE_PORT}
|
|
||||||
DB_USER: ${DATABASE_USER}
|
|
||||||
DB_NAME: ${DATABASE_NAME}
|
|
||||||
ABSTRACTO_GRAFANA_DB_PASS: ${GRAFANA_DATABASE_PASSWORD}
|
|
||||||
ABSTRACTO_GRAFANA_DB_USER: ${GRAFANA_DATABASE_USER}
|
|
||||||
EXECUTE_DEPLOYMENT: ${EXECUTE_DEPLOYMENT}
|
|
||||||
EXECUTE_LIQUIBASE: ${EXECUTE_LIQUIBASE}
|
|
||||||
EXECUTE_TEMPLATES: ${EXECUTE_TEMPLATES}
|
|
||||||
LIQUIBASE_PATH: ${LIQUIBASE_PATH:-/liquibase}
|
|
||||||
POSTGRES_DRIVER_PATH: ${EXECUTE_DEPLOYMENT:-/postgres/driver.jar}
|
|
||||||
WAIT_HOSTS: database:5432
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
bot:
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot:${ONEPLUS_BOT_VERSION}
|
|
||||||
depends_on:
|
|
||||||
- db
|
|
||||||
- deployment_container
|
|
||||||
restart: on-failure
|
|
||||||
container_name: oneplusbot
|
|
||||||
environment:
|
|
||||||
TOKEN: ${TOKEN}
|
|
||||||
REMOTE_DEBUG: ${REMOTE_DEBUG}
|
|
||||||
DB_PASS: ${DATABASE_PASSWORD}
|
|
||||||
DB_HOST: ${DATABASE_HOST}
|
|
||||||
DB_PORT: ${DATABASE_PORT}
|
|
||||||
DB_USER: ${DATABASE_USER}
|
|
||||||
DB_NAME: ${DATABASE_NAME}
|
|
||||||
REST_USER_NAME: ${REST_USER_NAME}
|
|
||||||
REST_PASSWORD: ${REST_PASSWORD}
|
|
||||||
YOUTUBE_API_KEY: ${YOUTUBE_API_KEY}
|
|
||||||
command: sh -c "while ping -c1 deployment_container &>/dev/null; do sleep 1; done; echo 'Liquibase finished!' && ./start.sh"
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:${DEBUG_PORT}:5005"
|
|
||||||
- "127.0.0.1:${TOMCAT_PORT}:8080"
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
volumes:
|
|
||||||
- bot-logs:/logs
|
|
||||||
- ./config:/config
|
|
||||||
pgadmin:
|
|
||||||
container_name: pgadmin
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_pg_admin:${ONEPLUS_BOT_VERSION}
|
|
||||||
depends_on:
|
|
||||||
- db
|
|
||||||
environment:
|
|
||||||
PGADMIN_DEFAULT_EMAIL: ${PGADMIN_DEFAULT_EMAIL}
|
|
||||||
PGADMIN_DEFAULT_PASSWORD: ${PGADMIN_DEFAULT_PASSWORD}
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:${PGADMIN_PORT}:80"
|
|
||||||
restart: unless-stopped
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
prometheus:
|
|
||||||
container_name: prometheus
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_prometheus:${ONEPLUS_BOT_VERSION}
|
|
||||||
depends_on:
|
|
||||||
- bot
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:${PROMETHEUS_PORT}:9090"
|
|
||||||
restart: unless-stopped
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
volumes:
|
|
||||||
- ./res/prometheus-scrapper-password-filled:/etc/prometheus/micrometer_password
|
|
||||||
- prometheus-data:/prometheus
|
|
||||||
grafana:
|
|
||||||
container_name: grafana
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_grafana:${ONEPLUS_BOT_VERSION}
|
|
||||||
depends_on:
|
|
||||||
- prometheus
|
|
||||||
- bot
|
|
||||||
ports:
|
|
||||||
- "127.0.0.1:${GRAFANA_PORT}:3000"
|
|
||||||
restart: unless-stopped
|
|
||||||
environment:
|
|
||||||
DB_PASS: ${GRAFANA_DATABASE_PASSWORD}
|
|
||||||
DB_HOST: ${DATABASE_HOST}
|
|
||||||
DB_PORT: ${DATABASE_PORT}
|
|
||||||
DB_USER: ${GRAFANA_DATABASE_USER}
|
|
||||||
DB_NAME: ${DATABASE_NAME}
|
|
||||||
PROMETHEUS_HOST: 'prometheus'
|
|
||||||
PROMETHEUS_PORT: 9090
|
|
||||||
volumes:
|
|
||||||
- grafana-user-data:/var/lib/grafana
|
|
||||||
networks:
|
|
||||||
- oneplusbot
|
|
||||||
|
|
||||||
networks:
|
|
||||||
oneplusbot:
|
|
||||||
driver: bridge
|
|
||||||
name: oneplusbot-network
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
db-data:
|
|
||||||
grafana-user-data:
|
|
||||||
prometheus-data:
|
|
||||||
bot-logs:
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -o allexport
|
|
||||||
source .env
|
|
||||||
set +o allexport
|
|
||||||
envsubst < res/prometheus-scrapper-password > res/prometheus-scrapper-password-filled
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
${REST_PASSWORD}
|
|
||||||
23
deployment/helm/oneplus-bot/.helmignore
Normal file
23
deployment/helm/oneplus-bot/.helmignore
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*.orig
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
||||||
|
.vscode/
|
||||||
24
deployment/helm/oneplus-bot/Chart.yaml
Normal file
24
deployment/helm/oneplus-bot/Chart.yaml
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
apiVersion: v2
|
||||||
|
name: oneplus-bot
|
||||||
|
description: A Helm chart for Kubernetes
|
||||||
|
|
||||||
|
# A chart can be either an 'application' or a 'library' chart.
|
||||||
|
#
|
||||||
|
# Application charts are a collection of templates that can be packaged into versioned archives
|
||||||
|
# to be deployed.
|
||||||
|
#
|
||||||
|
# Library charts provide useful utilities or functions for the chart developer. They're included as
|
||||||
|
# a dependency of application charts to inject those utilities and functions into the rendering
|
||||||
|
# pipeline. Library charts do not define any templates and therefore cannot be deployed.
|
||||||
|
type: application
|
||||||
|
|
||||||
|
# This is the chart version. This version number should be incremented each time you make changes
|
||||||
|
# to the chart and its templates, including the app version.
|
||||||
|
# Versions are expected to follow Semantic Versioning (https://semver.org/)
|
||||||
|
version: 1.6.8
|
||||||
|
|
||||||
|
# This is the version number of the application being deployed. This version number should be
|
||||||
|
# incremented each time you make changes to the application. Versions are not expected to
|
||||||
|
# follow Semantic Versioning. They should reflect the version the application is using.
|
||||||
|
# It is recommended to use it with quotes.
|
||||||
|
appVersion: "1.6.8"
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
base_url: {{ $.Values.grafanaDeployment.grafana.host }}
|
||||||
|
username: {{ $.Values.grafanaDeployment.grafana.basicAuth.username }}
|
||||||
|
password: {{ $.Values.grafanaDeployment.grafana.basicAuth.password }}
|
||||||
|
folder_name: OnePlusBot
|
||||||
@@ -0,0 +1,939 @@
|
|||||||
|
{
|
||||||
|
"dashboard": {
|
||||||
|
"annotations": {
|
||||||
|
"list": [
|
||||||
|
{
|
||||||
|
"builtIn": 1,
|
||||||
|
"datasource": {
|
||||||
|
"type": "grafana",
|
||||||
|
"uid": "-- Grafana --"
|
||||||
|
},
|
||||||
|
"enable": true,
|
||||||
|
"hide": true,
|
||||||
|
"iconColor": "rgba(0, 211, 255, 1)",
|
||||||
|
"name": "Annotations & Alerts",
|
||||||
|
"type": "dashboard"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"editable": true,
|
||||||
|
"fiscalYearStartMonth": 0,
|
||||||
|
"graphTooltip": 0,
|
||||||
|
"links": [],
|
||||||
|
"liveNow": false,
|
||||||
|
"panels": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 0,
|
||||||
|
"y": 0
|
||||||
|
},
|
||||||
|
"id": 1,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(discord_api_interactions_total{namespace=\"oneplus-bot\"}[1m]) /2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }} action {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Discord API Interaction",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 12,
|
||||||
|
"y": 0
|
||||||
|
},
|
||||||
|
"id": 2,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(command_processed_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }}type{{ "}}" }}-{{ "{{" }}status{{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Commands processed",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 0,
|
||||||
|
"y": 8
|
||||||
|
},
|
||||||
|
"id": 3,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(message_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }} action {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Message events",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 12,
|
||||||
|
"y": 8
|
||||||
|
},
|
||||||
|
"id": 4,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(okhttp_request_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }} http_code {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "HTTP Reponse codes",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 0,
|
||||||
|
"y": 16
|
||||||
|
},
|
||||||
|
"id": 5,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(cache_evictions_total{application=\"$application\", cache=\"messages\", namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Cache evictions",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(cache_gets_total{application=\"$application\", cache=\"messages\", namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"hide": false,
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Cache gets {{ "{{" }} result {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "B"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(cache_puts_total{application=\"$application\", cache=\"messages\", namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"hide": false,
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Cache puts",
|
||||||
|
"range": true,
|
||||||
|
"refId": "C"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(cache_removals{application=\"$application\", cache=\"messages\", namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"hide": false,
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Cache removals",
|
||||||
|
"range": true,
|
||||||
|
"refId": "D"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Message cache statistic",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 12,
|
||||||
|
"y": 16
|
||||||
|
},
|
||||||
|
"id": 6,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "discord_gateway_ping{namespace=\"oneplus-bot\"}",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Gateway ping",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Gateway ping",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 0,
|
||||||
|
"y": 24
|
||||||
|
},
|
||||||
|
"id": 7,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(starboard_stars_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }} action {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Starboard reactions",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 12,
|
||||||
|
"y": 24
|
||||||
|
},
|
||||||
|
"id": 8,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(emote_usages_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "Used emotes",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Used tracked emotes",
|
||||||
|
"type": "timeseries"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 16,
|
||||||
|
"w": 24,
|
||||||
|
"x": 0,
|
||||||
|
"y": 32
|
||||||
|
},
|
||||||
|
"id": 9,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "prometheus",
|
||||||
|
"uid": "prometheus"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "increase(jda_event_total{namespace=\"oneplus-bot\"}[1m]) / 2",
|
||||||
|
"instant": false,
|
||||||
|
"legendFormat": "{{ "{{" }} event_class {{ "}}" }}",
|
||||||
|
"range": true,
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "JDA Events",
|
||||||
|
"type": "timeseries"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"refresh": "",
|
||||||
|
"schemaVersion": 38,
|
||||||
|
"style": "dark",
|
||||||
|
"tags": [],
|
||||||
|
"templating": {
|
||||||
|
"list": [
|
||||||
|
{
|
||||||
|
"hide": 2,
|
||||||
|
"label": "",
|
||||||
|
"name": "application",
|
||||||
|
"query": "OnePlusBot",
|
||||||
|
"skipUrlSync": false,
|
||||||
|
"type": "constant"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"time": {
|
||||||
|
"from": "now-30m",
|
||||||
|
"to": "now"
|
||||||
|
},
|
||||||
|
"timepicker": {},
|
||||||
|
"timezone": "",
|
||||||
|
"title": "OnePlusBot Discord status",
|
||||||
|
"uid": "a7b3297d-972e-4dbd-9223-88d589817d34",
|
||||||
|
"version": 2,
|
||||||
|
"weekStart": ""
|
||||||
|
},
|
||||||
|
"overwrite": true
|
||||||
|
}
|
||||||
@@ -0,0 +1,238 @@
|
|||||||
|
{
|
||||||
|
"dashboard": {
|
||||||
|
"annotations": {
|
||||||
|
"list": [
|
||||||
|
{
|
||||||
|
"builtIn": 1,
|
||||||
|
"datasource": {
|
||||||
|
"type": "grafana",
|
||||||
|
"uid": "-- Grafana --"
|
||||||
|
},
|
||||||
|
"enable": true,
|
||||||
|
"hide": true,
|
||||||
|
"iconColor": "rgba(0, 211, 255, 1)",
|
||||||
|
"name": "Annotations & Alerts",
|
||||||
|
"type": "dashboard"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"description": "Overview over logging outputs of OnePlusBot",
|
||||||
|
"editable": true,
|
||||||
|
"fiscalYearStartMonth": 0,
|
||||||
|
"graphTooltip": 0,
|
||||||
|
"links": [],
|
||||||
|
"liveNow": false,
|
||||||
|
"panels": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"description": "Display logs and search for logs",
|
||||||
|
"gridPos": {
|
||||||
|
"h": 13,
|
||||||
|
"w": 24,
|
||||||
|
"x": 0,
|
||||||
|
"y": 0
|
||||||
|
},
|
||||||
|
"id": 4,
|
||||||
|
"options": {
|
||||||
|
"dedupStrategy": "none",
|
||||||
|
"enableLogDetails": true,
|
||||||
|
"prettifyLogMessage": false,
|
||||||
|
"showCommonLabels": false,
|
||||||
|
"showLabels": false,
|
||||||
|
"showTime": false,
|
||||||
|
"sortOrder": "Ascending",
|
||||||
|
"wrapLogMessage": true
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"editorMode": "builder",
|
||||||
|
"expr": "{app=\"OnePlusBot\", namespace=\"oneplus-bot\"} |= `$logFilter`",
|
||||||
|
"maxLines": 5000,
|
||||||
|
"queryType": "range",
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "OnePlusBot Logs",
|
||||||
|
"type": "logs"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"description": "Any line on level ERROR",
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 0,
|
||||||
|
"y": 13
|
||||||
|
},
|
||||||
|
"id": 2,
|
||||||
|
"options": {
|
||||||
|
"dedupStrategy": "none",
|
||||||
|
"enableLogDetails": true,
|
||||||
|
"prettifyLogMessage": false,
|
||||||
|
"showCommonLabels": false,
|
||||||
|
"showLabels": false,
|
||||||
|
"showTime": false,
|
||||||
|
"sortOrder": "Ascending",
|
||||||
|
"wrapLogMessage": true
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "{app=\"OnePlusBot\", namespace=\"oneplus-bot\"} |= \"ERROR\"",
|
||||||
|
"maxLines": 5000,
|
||||||
|
"queryType": "range",
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "OnePlusBot Error Logs",
|
||||||
|
"type": "logs"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"description": "Number of log events",
|
||||||
|
"fieldConfig": {
|
||||||
|
"defaults": {
|
||||||
|
"color": {
|
||||||
|
"mode": "palette-classic"
|
||||||
|
},
|
||||||
|
"custom": {
|
||||||
|
"axisCenteredZero": false,
|
||||||
|
"axisColorMode": "text",
|
||||||
|
"axisLabel": "",
|
||||||
|
"axisPlacement": "auto",
|
||||||
|
"barAlignment": 0,
|
||||||
|
"drawStyle": "line",
|
||||||
|
"fillOpacity": 0,
|
||||||
|
"gradientMode": "none",
|
||||||
|
"hideFrom": {
|
||||||
|
"legend": false,
|
||||||
|
"tooltip": false,
|
||||||
|
"viz": false
|
||||||
|
},
|
||||||
|
"insertNulls": false,
|
||||||
|
"lineInterpolation": "linear",
|
||||||
|
"lineWidth": 1,
|
||||||
|
"pointSize": 5,
|
||||||
|
"scaleDistribution": {
|
||||||
|
"type": "linear"
|
||||||
|
},
|
||||||
|
"showPoints": "auto",
|
||||||
|
"spanNulls": false,
|
||||||
|
"stacking": {
|
||||||
|
"group": "A",
|
||||||
|
"mode": "none"
|
||||||
|
},
|
||||||
|
"thresholdsStyle": {
|
||||||
|
"mode": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mappings": [],
|
||||||
|
"thresholds": {
|
||||||
|
"mode": "absolute",
|
||||||
|
"steps": [
|
||||||
|
{
|
||||||
|
"color": "green",
|
||||||
|
"value": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"color": "red",
|
||||||
|
"value": 80
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
},
|
||||||
|
"gridPos": {
|
||||||
|
"h": 8,
|
||||||
|
"w": 12,
|
||||||
|
"x": 12,
|
||||||
|
"y": 13
|
||||||
|
},
|
||||||
|
"id": 3,
|
||||||
|
"options": {
|
||||||
|
"legend": {
|
||||||
|
"calcs": [],
|
||||||
|
"displayMode": "list",
|
||||||
|
"placement": "bottom",
|
||||||
|
"showLegend": true
|
||||||
|
},
|
||||||
|
"tooltip": {
|
||||||
|
"mode": "single",
|
||||||
|
"sort": "none"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"targets": [
|
||||||
|
{
|
||||||
|
"datasource": {
|
||||||
|
"type": "loki",
|
||||||
|
"uid": "loki"
|
||||||
|
},
|
||||||
|
"editorMode": "code",
|
||||||
|
"expr": "rate({app=\"OnePlusBot\", namespace=\"oneplus-bot\"}[$__interval])",
|
||||||
|
"queryType": "range",
|
||||||
|
"refId": "A"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"title": "Log Rate",
|
||||||
|
"type": "timeseries"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"refresh": "",
|
||||||
|
"schemaVersion": 38,
|
||||||
|
"style": "dark",
|
||||||
|
"tags": [],
|
||||||
|
"templating": {
|
||||||
|
"list": [
|
||||||
|
{
|
||||||
|
"current": {
|
||||||
|
"selected": false,
|
||||||
|
"text": "",
|
||||||
|
"value": ""
|
||||||
|
},
|
||||||
|
"description": "What to search in the logs",
|
||||||
|
"hide": 0,
|
||||||
|
"name": "logFilter",
|
||||||
|
"options": [
|
||||||
|
{
|
||||||
|
"selected": true,
|
||||||
|
"text": "",
|
||||||
|
"value": ""
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"query": "",
|
||||||
|
"skipUrlSync": false,
|
||||||
|
"type": "textbox"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"time": {
|
||||||
|
"from": "now-30m",
|
||||||
|
"to": "now"
|
||||||
|
},
|
||||||
|
"timepicker": {},
|
||||||
|
"timezone": "",
|
||||||
|
"title": "OnePlus Bot Logs",
|
||||||
|
"uid": "a5b429af-860c-4438-a575-24bed6dcba09",
|
||||||
|
"version": 2,
|
||||||
|
"weekStart": ""
|
||||||
|
},
|
||||||
|
"overwrite": true
|
||||||
|
}
|
||||||
62
deployment/helm/oneplus-bot/templates/_helpers.tpl
Normal file
62
deployment/helm/oneplus-bot/templates/_helpers.tpl
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
{{/*
|
||||||
|
Expand the name of the chart.
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create a default fully qualified app name.
|
||||||
|
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
|
||||||
|
If release name contains chart name it will be used as a full name.
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.fullname" -}}
|
||||||
|
{{- if .Values.fullnameOverride }}
|
||||||
|
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }}
|
||||||
|
{{- else }}
|
||||||
|
{{- $name := default .Chart.Name .Values.nameOverride }}
|
||||||
|
{{- if contains $name .Release.Name }}
|
||||||
|
{{- .Release.Name | trunc 63 | trimSuffix "-" }}
|
||||||
|
{{- else }}
|
||||||
|
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create chart name and version as used by the chart label.
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.chart" -}}
|
||||||
|
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Common labels
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.labels" -}}
|
||||||
|
helm.sh/chart: {{ include "oneplusBot.chart" . }}
|
||||||
|
{{ include "oneplusBot.selectorLabels" . }}
|
||||||
|
{{- if .Chart.AppVersion }}
|
||||||
|
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
|
||||||
|
{{- end }}
|
||||||
|
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Selector labels
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.selectorLabels" -}}
|
||||||
|
app.kubernetes.io/name: {{ include "oneplusBot.name" . }}
|
||||||
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
Create the name of the service account to use
|
||||||
|
*/}}
|
||||||
|
{{- define "oneplusBot.serviceAccountName" -}}
|
||||||
|
{{- if .Values.serviceAccount.create }}
|
||||||
|
{{- default (include "oneplusBot.fullname" .) .Values.serviceAccount.name }}
|
||||||
|
{{- else }}
|
||||||
|
{{- default "default" .Values.serviceAccount.name }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
7
deployment/helm/oneplus-bot/templates/api-keys.yaml
Normal file
7
deployment/helm/oneplus-bot/templates/api-keys.yaml
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: api-keys
|
||||||
|
data:
|
||||||
|
discordToken: {{ $.Values.apiKeys.discord.token | b64enc }} # b64enc is needed, because a stringData secret field cannot hold numeric values
|
||||||
|
youtubeApiKey: {{ $.Values.apiKeys.youtube.apiKey | b64enc }}
|
||||||
@@ -0,0 +1,69 @@
|
|||||||
|
{{- if .Values.dbConfigDeployment.enabled -}}
|
||||||
|
apiVersion: batch/v1
|
||||||
|
kind: Job
|
||||||
|
metadata:
|
||||||
|
{{- $deploymentJobName := print ((include "oneplusBot.fullname" .) | trunc 39) "-db-config-deployment-job" }}
|
||||||
|
name: {{ $deploymentJobName | trunc 63 }}
|
||||||
|
annotations:
|
||||||
|
"helm.sh/hook": pre-upgrade,pre-install
|
||||||
|
"helm.sh/hook-weight": "-5"
|
||||||
|
"helm.sh/hook-delete-policy": hook-succeeded
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
{{- with .Values.imagePullSecrets }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
- name: db-config-deployment-job
|
||||||
|
image: "{{ $.Values.dbConfigDeployment.repository }}/{{ $.Values.dbConfigDeployment.image }}:{{ $.Values.dbConfigDeployment.tag | default .Chart.AppVersion}}"
|
||||||
|
imagePullPolicy: {{ $.Values.dbConfigDeployment.pullPolicy }}
|
||||||
|
args:
|
||||||
|
- "/var/db-config/"
|
||||||
|
env:
|
||||||
|
- name: DB_PASS
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPassword
|
||||||
|
- name: DB_HOST
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbHost
|
||||||
|
- name: DB_PORT
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPort
|
||||||
|
- name: DB_USER
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbUser
|
||||||
|
- name: DB_NAME
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbName
|
||||||
|
- name: DB_SCHEME
|
||||||
|
value: "abstracto"
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/var/db-config/"
|
||||||
|
name: database-config-mount
|
||||||
|
restartPolicy: Never
|
||||||
|
initContainers:
|
||||||
|
- name: database-config-data
|
||||||
|
image: "{{ $.Values.dbConfigDeploymentData.repository }}/{{ $.Values.dbConfigDeploymentData.image }}:{{ $.Values.dbConfigDeploymentData.tag | default .Chart.AppVersion}}"
|
||||||
|
imagePullPolicy: {{ $.Values.dbConfigDeploymentData.pullPolicy }}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/var/run-config"
|
||||||
|
name: database-config-mount
|
||||||
|
volumes:
|
||||||
|
- name: database-config-mount
|
||||||
|
emptyDir: {}
|
||||||
|
backoffLimit: 4
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
|
||||||
13
deployment/helm/oneplus-bot/templates/db-credentials.yaml
Normal file
13
deployment/helm/oneplus-bot/templates/db-credentials.yaml
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: db-credentials
|
||||||
|
annotations:
|
||||||
|
"helm.sh/hook": pre-upgrade,pre-install
|
||||||
|
"helm.sh/hook-weight": "-6"
|
||||||
|
data:
|
||||||
|
dbPassword: {{ $.Values.dbCredentials.password | b64enc }} # b64enc is needed, because a stringData secret field cannot hold numeric values
|
||||||
|
dbUser: {{ $.Values.dbCredentials.userName | b64enc }}
|
||||||
|
dbHost: {{ $.Values.dbCredentials.host | b64enc }}
|
||||||
|
dbPort: {{ $.Values.dbCredentials.port | b64enc }}
|
||||||
|
dbName: {{ $.Values.dbCredentials.name | b64enc }}
|
||||||
106
deployment/helm/oneplus-bot/templates/deployment.yaml
Normal file
106
deployment/helm/oneplus-bot/templates/deployment.yaml
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ include "oneplusBot.fullname" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "oneplusBot.labels" . | nindent 4 }}
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
{{- include "oneplusBot.selectorLabels" . | nindent 6 }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
{{- with .Values.podAnnotations }}
|
||||||
|
annotations:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
labels:
|
||||||
|
{{- include "oneplusBot.selectorLabels" . | nindent 8 }}
|
||||||
|
spec:
|
||||||
|
{{- with .Values.imagePullSecrets }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
serviceAccountName: {{ include "oneplusBot.serviceAccountName" . }}
|
||||||
|
securityContext:
|
||||||
|
{{- toYaml .Values.podSecurityContext | nindent 8 }}
|
||||||
|
containers:
|
||||||
|
- name: {{ .Chart.Name }}
|
||||||
|
securityContext:
|
||||||
|
{{- toYaml .Values.securityContext | nindent 12 }}
|
||||||
|
image: "{{ .Values.bot.repository }}/{{ .Values.bot.image }}:{{ .Values.bot.tag | default .Chart.AppVersion }}"
|
||||||
|
imagePullPolicy: {{ .Values.bot.pullPolicy }}
|
||||||
|
env:
|
||||||
|
- name: DB_PASS
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPassword
|
||||||
|
- name: DB_HOST
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbHost
|
||||||
|
- name: DB_PORT
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPort
|
||||||
|
- name: DB_USER
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbUser
|
||||||
|
- name: DB_NAME
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbName
|
||||||
|
- name: TOKEN
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: api-keys
|
||||||
|
key: discordToken
|
||||||
|
- name: OPEN_WEATHER_MAP_API_KEY
|
||||||
|
value: "placeholder" # a value is required, if the webservices module is loaded, but weather not used
|
||||||
|
- name: YOUTUBE_API_KEY
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: api-keys
|
||||||
|
key: youtubeApiKey
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: {{ .Values.service.port }}
|
||||||
|
protocol: TCP
|
||||||
|
- name: debug
|
||||||
|
containerPort: 5005
|
||||||
|
protocol: TCP
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /actuator/health/liveness
|
||||||
|
port: 8080
|
||||||
|
initialDelaySeconds: {{ $.Values.bot.livenessProbe.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ $.Values.bot.livenessProbe.periodSeconds }}
|
||||||
|
failureThreshold: {{ $.Values.bot.livenessProbe.failureThreshold }}
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /actuator/health/readiness
|
||||||
|
port: 8080
|
||||||
|
initialDelaySeconds: {{ $.Values.bot.readinessProbe.initialDelaySeconds }}
|
||||||
|
periodSeconds: {{ $.Values.bot.readinessProbe.periodSeconds }}
|
||||||
|
failureThreshold: {{ $.Values.bot.readinessProbe.failureThreshold }}
|
||||||
|
resources:
|
||||||
|
{{- toYaml .Values.resources | nindent 12 }}
|
||||||
|
{{- with .Values.nodeSelector }}
|
||||||
|
nodeSelector:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.affinity }}
|
||||||
|
affinity:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.tolerations }}
|
||||||
|
tolerations:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
@@ -0,0 +1,42 @@
|
|||||||
|
{{- if $.Values.grafanaDeployment.enabled }}
|
||||||
|
apiVersion: batch/v1
|
||||||
|
kind: Job
|
||||||
|
metadata:
|
||||||
|
name: grafana-dashboard-deployment-job
|
||||||
|
annotations:
|
||||||
|
"helm.sh/hook": post-install
|
||||||
|
"helm.sh/hook-weight": "-4"
|
||||||
|
"helm.sh/hook-delete-policy": hook-succeeded
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
{{- with .Values.imagePullSecrets }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
- name: template-deployment-job
|
||||||
|
image: "{{ $.Values.grafanaDeployment.repository }}/{{ $.Values.grafanaDeployment.image }}:{{ $.Values.grafanaDeployment.tag }}"
|
||||||
|
imagePullPolicy: {{ $.Values.grafanaDeployment.pullPolicy }}
|
||||||
|
args:
|
||||||
|
- "/var/userconfig"
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/var/userconfig"
|
||||||
|
name: grafana-dashboard-config
|
||||||
|
readOnly: true
|
||||||
|
volumes:
|
||||||
|
- name: grafana-dashboard-config
|
||||||
|
secret:
|
||||||
|
secretName: grafana-dashboard-config
|
||||||
|
restartPolicy: Never
|
||||||
|
backoffLimit: 4
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: grafana-dashboard-config
|
||||||
|
data:
|
||||||
|
config.yaml: {{ (tpl (.Files.Get "configuration/grafana/config.yaml") . ) | b64enc }}
|
||||||
|
log-dashboard.json: {{ (tpl (.Files.Get "configuration/grafana/oneplus-bot-log-dashboard.json") . ) | b64enc }}
|
||||||
|
discord-dashboard.json: {{ (tpl (.Files.Get "configuration/grafana/oneplus-bot-discord-dashboard.json") . ) | b64enc }}
|
||||||
|
{{- end }}
|
||||||
19
deployment/helm/oneplus-bot/templates/service.yaml
Normal file
19
deployment/helm/oneplus-bot/templates/service.yaml
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: {{ include "oneplusBot.fullname" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "oneplusBot.labels" . | nindent 4 }}
|
||||||
|
{{- with .Values.service.annotations }}
|
||||||
|
annotations:
|
||||||
|
{{- toYaml . | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
type: {{ .Values.service.type }}
|
||||||
|
ports:
|
||||||
|
- port: {{ .Values.service.port }}
|
||||||
|
targetPort: http
|
||||||
|
protocol: TCP
|
||||||
|
name: http
|
||||||
|
selector:
|
||||||
|
{{- include "oneplusBot.selectorLabels" . | nindent 4 }}
|
||||||
12
deployment/helm/oneplus-bot/templates/serviceaccount.yaml
Normal file
12
deployment/helm/oneplus-bot/templates/serviceaccount.yaml
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
{{- if .Values.serviceAccount.create -}}
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: {{ include "oneplusBot.serviceAccountName" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "oneplusBot.labels" . | nindent 4 }}
|
||||||
|
{{- with .Values.serviceAccount.annotations }}
|
||||||
|
annotations:
|
||||||
|
{{- toYaml . | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
@@ -0,0 +1,69 @@
|
|||||||
|
{{- if .Values.dbConfigDeployment.enabled -}}
|
||||||
|
apiVersion: batch/v1
|
||||||
|
kind: Job
|
||||||
|
metadata:
|
||||||
|
{{- $deploymentJobName := print ((include "oneplusBot.fullname" .) | trunc 39) "-template-deployment-job" }}
|
||||||
|
name: {{ $deploymentJobName | trunc 63 }}
|
||||||
|
annotations:
|
||||||
|
"helm.sh/hook": pre-upgrade,pre-install
|
||||||
|
"helm.sh/hook-weight": "-4"
|
||||||
|
"helm.sh/hook-delete-policy": hook-succeeded
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
{{- with .Values.imagePullSecrets }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
- name: template-deployment-job
|
||||||
|
image: "{{ $.Values.templateDeployment.repository }}/{{ $.Values.templateDeployment.image }}:{{ $.Values.templateDeployment.tag | default .Chart.AppVersion }}"
|
||||||
|
imagePullPolicy: {{ $.Values.templateDeployment.pullPolicy }}
|
||||||
|
args:
|
||||||
|
- "/var/template-config/"
|
||||||
|
env:
|
||||||
|
- name: DB_PASS
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPassword
|
||||||
|
- name: DB_HOST
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbHost
|
||||||
|
- name: DB_PORT
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbPort
|
||||||
|
- name: DB_USER
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbUser
|
||||||
|
- name: DB_NAME
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: db-credentials
|
||||||
|
key: dbName
|
||||||
|
- name: DB_SCHEME
|
||||||
|
value: "abstracto."
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/var/template-config/"
|
||||||
|
name: template-config-mount
|
||||||
|
initContainers:
|
||||||
|
- name: database-config-data
|
||||||
|
image: "{{ $.Values.templateDeploymentData.repository }}/{{ $.Values.templateDeploymentData.image }}:{{ $.Values.templateDeploymentData.tag | default .Chart.AppVersion}}"
|
||||||
|
imagePullPolicy: {{ $.Values.templateDeploymentData.pullPolicy }}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/var/run-config"
|
||||||
|
name: template-config-mount
|
||||||
|
volumes:
|
||||||
|
- name: template-config-mount
|
||||||
|
emptyDir: {}
|
||||||
|
restartPolicy: Never
|
||||||
|
backoffLimit: 4
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
|
||||||
125
deployment/helm/oneplus-bot/values.yaml
Normal file
125
deployment/helm/oneplus-bot/values.yaml
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
# Default values for oneplus-bot.
|
||||||
|
# This is a YAML-formatted file.
|
||||||
|
# Declare variables to be passed into your templates.
|
||||||
|
|
||||||
|
replicaCount: 1
|
||||||
|
|
||||||
|
bot:
|
||||||
|
repository: harbor.sheldan.dev/oneplus-bot
|
||||||
|
pullPolicy: IfNotPresent
|
||||||
|
image: oneplus-bot-image
|
||||||
|
tag: 1.6.8
|
||||||
|
livenessProbe:
|
||||||
|
initialDelaySeconds: 60
|
||||||
|
periodSeconds: 5
|
||||||
|
failureThreshold: 3
|
||||||
|
readinessProbe:
|
||||||
|
initialDelaySeconds: 60
|
||||||
|
periodSeconds: 5
|
||||||
|
failureThreshold: 3
|
||||||
|
|
||||||
|
templateDeployment:
|
||||||
|
enabled: true
|
||||||
|
repository: harbor.sheldan.dev/abstracto
|
||||||
|
pullPolicy: Always
|
||||||
|
image: abstracto-template-deployment
|
||||||
|
tag: 1.5.9
|
||||||
|
|
||||||
|
templateDeploymentData:
|
||||||
|
repository: harbor.sheldan.dev/oneplus-bot
|
||||||
|
pullPolicy: Always
|
||||||
|
image: oneplus-bot-template-data
|
||||||
|
tag: 1.6.8
|
||||||
|
|
||||||
|
dbConfigDeployment:
|
||||||
|
enabled: true
|
||||||
|
repository: harbor.sheldan.dev/abstracto
|
||||||
|
pullPolicy: Always
|
||||||
|
image: abstracto-db-deployment
|
||||||
|
tag: 1.5.9
|
||||||
|
|
||||||
|
dbConfigDeploymentData:
|
||||||
|
repository: harbor.sheldan.dev/oneplus-bot
|
||||||
|
pullPolicy: Always
|
||||||
|
image: oneplus-bot-db-data
|
||||||
|
tag: 1.6.8
|
||||||
|
|
||||||
|
dbCredentials:
|
||||||
|
host:
|
||||||
|
port:
|
||||||
|
userName:
|
||||||
|
password:
|
||||||
|
name:
|
||||||
|
|
||||||
|
grafanaDeployment:
|
||||||
|
repository: harbor.sheldan.dev/grafana-tools
|
||||||
|
pullPolicy: Always
|
||||||
|
image: grafana-dashboard-deployment
|
||||||
|
tag: 0.0.2
|
||||||
|
enabled: true
|
||||||
|
grafana:
|
||||||
|
host:
|
||||||
|
basicAuth:
|
||||||
|
username:
|
||||||
|
password:
|
||||||
|
|
||||||
|
apiKeys:
|
||||||
|
discord:
|
||||||
|
token:
|
||||||
|
youtube:
|
||||||
|
apiKey:
|
||||||
|
openWeatherMap:
|
||||||
|
apiKey:
|
||||||
|
twitch:
|
||||||
|
secret:
|
||||||
|
clientId:
|
||||||
|
|
||||||
|
|
||||||
|
imagePullSecrets:
|
||||||
|
nameOverride: ""
|
||||||
|
fullnameOverride: ""
|
||||||
|
|
||||||
|
serviceAccount:
|
||||||
|
# Specifies whether a service account should be created
|
||||||
|
create: true
|
||||||
|
# Annotations to add to the service account
|
||||||
|
annotations: {}
|
||||||
|
# The name of the service account to use.
|
||||||
|
# If not set and create is true, a name is generated using the fullname template
|
||||||
|
name: ""
|
||||||
|
|
||||||
|
podAnnotations: {}
|
||||||
|
|
||||||
|
podSecurityContext: {}
|
||||||
|
# fsGroup: 2000
|
||||||
|
|
||||||
|
securityContext: {}
|
||||||
|
# capabilities:
|
||||||
|
# drop:
|
||||||
|
# - ALL
|
||||||
|
# readOnlyRootFilesystem: true
|
||||||
|
# runAsNonRoot: true
|
||||||
|
# runAsUser: 1000
|
||||||
|
|
||||||
|
service:
|
||||||
|
type: ClusterIP
|
||||||
|
port: 8080
|
||||||
|
annotations:
|
||||||
|
prometheus.io/scrape: "true"
|
||||||
|
prometheus.io/path: "/actuator/prometheus"
|
||||||
|
prometheus.io/port: "8080"
|
||||||
|
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpu:
|
||||||
|
memory:
|
||||||
|
requests:
|
||||||
|
cpu:
|
||||||
|
memory:
|
||||||
|
|
||||||
|
|
||||||
|
nodeSelector: {}
|
||||||
|
|
||||||
|
tolerations: []
|
||||||
|
|
||||||
|
affinity: {}
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>dev.sheldan.oneplus.bot.deployment</groupId>
|
<groupId>dev.sheldan.oneplus.bot.deployment</groupId>
|
||||||
<artifactId>deployment</artifactId>
|
<artifactId>deployment</artifactId>
|
||||||
<version>1.5.5</version>
|
<version>1.6.8</version>
|
||||||
</parent>
|
</parent>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
@@ -49,7 +49,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>core.zip</destFileName>
|
<destFileName>core.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -59,7 +59,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>experience-tracking.zip</destFileName>
|
<destFileName>experience-tracking.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>assignable-roles.zip</destFileName>
|
<destFileName>assignable-roles.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -79,7 +79,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>anti-raid.zip</destFileName>
|
<destFileName>anti-raid.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -89,7 +89,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>voice-channel-context.zip</destFileName>
|
<destFileName>voice-channel-context.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -99,7 +99,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>modmail.zip</destFileName>
|
<destFileName>modmail.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -109,7 +109,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>moderation.zip</destFileName>
|
<destFileName>moderation.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -119,7 +119,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>entertainment.zip</destFileName>
|
<destFileName>entertainment.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
@@ -128,7 +128,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>link-embed.zip</destFileName>
|
<destFileName>link-embed.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
@@ -137,7 +137,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard.zip</destFileName>
|
<destFileName>starboard.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
@@ -146,7 +146,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>utility.zip</destFileName>
|
<destFileName>utility.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -156,7 +156,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>webservices.zip</destFileName>
|
<destFileName>webservices.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -166,7 +166,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>remind.zip</destFileName>
|
<destFileName>remind.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -176,7 +176,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>suggestion.zip</destFileName>
|
<destFileName>suggestion.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -186,7 +186,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>invite-filter.zip</destFileName>
|
<destFileName>invite-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -196,7 +196,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>statistic.zip</destFileName>
|
<destFileName>statistic.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -206,7 +206,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>logging.zip</destFileName>
|
<destFileName>logging.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -216,17 +216,17 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>profanity-filter.zip</destFileName>
|
<destFileName>profanity-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.modules</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.customizations</groupId>
|
||||||
<artifactId>starboard-custom-templates</artifactId>
|
<artifactId>starboard-customization-templates</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard-custom.zip</destFileName>
|
<destFileName>starboard-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -236,7 +236,7 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>news.zip</destFileName>
|
<destFileName>news.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -246,7 +246,7 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>referral.zip</destFileName>
|
<destFileName>referral.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -256,7 +256,7 @@
|
|||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>faq.zip</destFileName>
|
<destFileName>faq.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -268,7 +268,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>core.zip</destFileName>
|
<destFileName>core.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -278,7 +278,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>modmail.zip</destFileName>
|
<destFileName>modmail.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -288,7 +288,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>assignable-roles.zip</destFileName>
|
<destFileName>assignable-roles.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -298,7 +298,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>anti-raid.zip</destFileName>
|
<destFileName>anti-raid.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -308,7 +308,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>voice-channel-context.zip</destFileName>
|
<destFileName>voice-channel-context.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -318,7 +318,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>utility.zip</destFileName>
|
<destFileName>utility.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -328,7 +328,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>experience-tracking.zip</destFileName>
|
<destFileName>experience-tracking.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -338,7 +338,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>entertainment.zip</destFileName>
|
<destFileName>entertainment.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -348,7 +348,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>moderation.zip</destFileName>
|
<destFileName>moderation.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -358,7 +358,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>link-embed.zip</destFileName>
|
<destFileName>link-embed.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -368,27 +368,17 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard.zip</destFileName>
|
<destFileName>starboard.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
|
||||||
<groupId>dev.sheldan.abstracto-templates.translations</groupId>
|
|
||||||
<artifactId>utility</artifactId>
|
|
||||||
<version>${abstracto.templates.version}</version>
|
|
||||||
<type>zip</type>
|
|
||||||
<overWrite>true</overWrite>
|
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
|
||||||
<destFileName>utility.zip</destFileName>
|
|
||||||
</artifactItem>
|
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.abstracto-templates.translations</groupId>
|
<groupId>dev.sheldan.abstracto-templates.translations</groupId>
|
||||||
<artifactId>webservices</artifactId>
|
<artifactId>webservices</artifactId>
|
||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>webservices.zip</destFileName>
|
<destFileName>webservices.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -398,7 +388,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>remind.zip</destFileName>
|
<destFileName>remind.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -408,7 +398,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>suggestion.zip</destFileName>
|
<destFileName>suggestion.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -418,7 +408,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>invite-filter.zip</destFileName>
|
<destFileName>invite-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -428,7 +418,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>statistic.zip</destFileName>
|
<destFileName>statistic.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -438,7 +428,7 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>profanity-filter.zip</destFileName>
|
<destFileName>profanity-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -448,78 +438,88 @@
|
|||||||
<version>${abstracto.templates.version}</version>
|
<version>${abstracto.templates.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>logging.zip</destFileName>
|
<destFileName>logging.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.customizations</groupId>
|
||||||
<artifactId>starboard-custom-translations</artifactId>
|
<artifactId>starboard-customization-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard-custom.zip</destFileName>
|
<destFileName>starboard-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.customizations</groupId>
|
||||||
<artifactId>moderation-custom</artifactId>
|
<artifactId>moderation-customization-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>moderation-custom.zip</destFileName>
|
<destFileName>moderation-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.customizations</groupId>
|
||||||
<artifactId>dynamic-activity-custom-translations</artifactId>
|
<artifactId>dynamic-activity-custom-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>dynamic-activity-custom-translations.zip</destFileName>
|
<destFileName>dynamic-activity-custom-translations.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<!-- custom -->
|
<!-- custom -->
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.modules</groupId>
|
||||||
<artifactId>news-translations</artifactId>
|
<artifactId>news-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>news.zip</destFileName>
|
<destFileName>news.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.modules</groupId>
|
||||||
<artifactId>setup-translations</artifactId>
|
<artifactId>setup-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>setup.zip</destFileName>
|
<destFileName>setup.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.modules</groupId>
|
||||||
<artifactId>referral-translations</artifactId>
|
<artifactId>referral-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>referral.zip</destFileName>
|
<destFileName>referral.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.modules</groupId>
|
||||||
|
<artifactId>seasonal-translations</artifactId>
|
||||||
|
<version>${project.version}</version>
|
||||||
|
<type>zip</type>
|
||||||
|
<overWrite>true</overWrite>
|
||||||
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
|
<destFileName>seasonal.zip</destFileName>
|
||||||
|
</artifactItem>
|
||||||
|
|
||||||
|
<artifactItem>
|
||||||
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.modules</groupId>
|
||||||
<artifactId>faq-translations</artifactId>
|
<artifactId>faq-translations</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>faq.zip</destFileName>
|
<destFileName>faq.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -531,7 +531,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>scheduling.zip</destFileName>
|
<destFileName>scheduling.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -542,7 +542,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>core.zip</destFileName>
|
<destFileName>core.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -553,7 +553,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>assignable-roles.zip</destFileName>
|
<destFileName>assignable-roles.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -564,7 +564,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>anti-raid.zip</destFileName>
|
<destFileName>anti-raid.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -575,7 +575,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>voice-channel-context.zip</destFileName>
|
<destFileName>voice-channel-context.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -586,21 +586,10 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>dynamic-activity.zip</destFileName>
|
<destFileName>dynamic-activity.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
|
||||||
<groupId>dev.sheldan.abstracto.modules</groupId>
|
|
||||||
<artifactId>utility-impl</artifactId>
|
|
||||||
<version>${abstracto.version}</version>
|
|
||||||
<classifier>liquibase</classifier>
|
|
||||||
<type>zip</type>
|
|
||||||
<overWrite>true</overWrite>
|
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
|
||||||
<destFileName>utility.zip</destFileName>
|
|
||||||
</artifactItem>
|
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.abstracto.modules</groupId>
|
<groupId>dev.sheldan.abstracto.modules</groupId>
|
||||||
<artifactId>modmail-impl</artifactId>
|
<artifactId>modmail-impl</artifactId>
|
||||||
@@ -608,7 +597,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>modmail.zip</destFileName>
|
<destFileName>modmail.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -619,7 +608,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>moderation.zip</destFileName>
|
<destFileName>moderation.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -630,7 +619,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>experience-tracking.zip</destFileName>
|
<destFileName>experience-tracking.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -641,7 +630,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>entertainment.zip</destFileName>
|
<destFileName>entertainment.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -652,7 +641,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>link-embed.zip</destFileName>
|
<destFileName>link-embed.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -663,7 +652,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard.zip</destFileName>
|
<destFileName>starboard.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -675,7 +664,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>utility.zip</destFileName>
|
<destFileName>utility.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -686,7 +675,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>webservices.zip</destFileName>
|
<destFileName>webservices.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -697,7 +686,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>remind.zip</destFileName>
|
<destFileName>remind.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -708,7 +697,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>suggestion.zip</destFileName>
|
<destFileName>suggestion.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -719,7 +708,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>invite-filter.zip</destFileName>
|
<destFileName>invite-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -730,7 +719,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>statistic.zip</destFileName>
|
<destFileName>statistic.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -741,7 +730,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>profanity-filter.zip</destFileName>
|
<destFileName>profanity-filter.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -752,7 +741,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>logging.zip</destFileName>
|
<destFileName>logging.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -764,7 +753,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>starboard-custom.zip</destFileName>
|
<destFileName>starboard-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -775,7 +764,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>moderation-custom.zip</destFileName>
|
<destFileName>moderation-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -786,7 +775,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>dynamic-activity-custom.zip</destFileName>
|
<destFileName>dynamic-activity-custom.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -797,7 +786,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>news.zip</destFileName>
|
<destFileName>news.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -808,7 +797,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>setup.zip</destFileName>
|
<destFileName>setup.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -819,7 +808,7 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>referral.zip</destFileName>
|
<destFileName>referral.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
@@ -830,92 +819,92 @@
|
|||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>faq.zip</destFileName>
|
<destFileName>faq.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.application</groupId>
|
<groupId>dev.sheldan.oneplus.bot.application.modules</groupId>
|
||||||
<artifactId>database</artifactId>
|
<artifactId>seasonal</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<classifier>liquibase</classifier>
|
<classifier>liquibase</classifier>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/liquibase-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/db-data/liquibase-artifacts/</outputDirectory>
|
||||||
<destFileName>database.zip</destFileName>
|
<destFileName>seasonal.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<!-- overrides -->
|
<!-- overrides -->
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>core</artifactId>
|
<artifactId>core-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-core.zip</destFileName>
|
<destFileName>overrides-templates-core.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>webservices</artifactId>
|
<artifactId>webservices-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-webservices.zip</destFileName>
|
<destFileName>overrides-templates-webservices.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>logging</artifactId>
|
<artifactId>logging-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-logging.zip</destFileName>
|
<destFileName>overrides-templates-logging.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>statistic</artifactId>
|
<artifactId>statistic-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-statistic.zip</destFileName>
|
<destFileName>overrides-templates-statistic.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>modmail</artifactId>
|
<artifactId>modmail-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-modmail.zip</destFileName>
|
<destFileName>overrides-templates-modmail.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.templates</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.overrides</groupId>
|
||||||
<artifactId>moderation</artifactId>
|
<artifactId>moderation-template-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/template-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/template-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-templates-moderation.zip</destFileName>
|
<destFileName>overrides-templates-moderation.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
<!-- overrides translations -->
|
<!-- overrides translations -->
|
||||||
<artifactItem>
|
<artifactItem>
|
||||||
<groupId>dev.sheldan.oneplus.bot.templates.overrides.translations</groupId>
|
<groupId>dev.sheldan.oneplus.bot.templates.translations.overrides</groupId>
|
||||||
<artifactId>moderation</artifactId>
|
<artifactId>moderation-translation-overrides</artifactId>
|
||||||
<version>${project.version}</version>
|
<version>${project.version}</version>
|
||||||
<type>zip</type>
|
<type>zip</type>
|
||||||
<overWrite>true</overWrite>
|
<overWrite>true</overWrite>
|
||||||
<outputDirectory>${file.basedir}/deployment/translation-artifacts/</outputDirectory>
|
<outputDirectory>${file.basedir}/template-data/translation-artifacts/</outputDirectory>
|
||||||
<destFileName>overrides-translation-moderation.zip</destFileName>
|
<destFileName>overrides-translation-moderation.zip</destFileName>
|
||||||
</artifactItem>
|
</artifactItem>
|
||||||
|
|
||||||
|
|||||||
2
deployment/image-packaging/src/main/docker/.env
Normal file
2
deployment/image-packaging/src/main/docker/.env
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
REGISTRY_PREFIX=harbor.sheldan.dev/oneplus-bot/
|
||||||
|
VERSION=1.6.8
|
||||||
@@ -1,4 +0,0 @@
|
|||||||
FROM postgres
|
|
||||||
MAINTAINER Sheldan
|
|
||||||
VOLUME /tmp
|
|
||||||
ADD sql/init.sql /docker-entrypoint-initdb.d/init.sql
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
CREATE SCHEMA abstracto
|
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
FROM alpine:3.18.0
|
||||||
|
MAINTAINER Sheldan
|
||||||
|
ADD config/ /var/db-config/
|
||||||
|
ADD liquibase-artifacts /var/db-config/liquibase-zips
|
||||||
|
|
||||||
|
CMD ["/bin/sh", "/var/db-config/move.sh"]
|
||||||
@@ -1,17 +1,4 @@
|
|||||||
{
|
{
|
||||||
"template_artifacts": ["utility", "core", "entertainment", "starboard", "link-embed", "webservices", "remind", "logging",
|
|
||||||
"suggestion", "invite-filter", "profanity-filter", "statistic", "experience-tracking", "moderation", "modmail", "assignable-roles",
|
|
||||||
"voice-channel-context", "anti-raid",
|
|
||||||
"starboard-custom",
|
|
||||||
"overrides-templates-webservices", "overrides-templates-core", "overrides-templates-logging", "overrides-templates-statistic",
|
|
||||||
"overrides-templates-modmail", "overrides-templates-moderation",
|
|
||||||
"news", "referral", "faq"],
|
|
||||||
"translation_artifacts": ["utility", "core", "entertainment", "starboard", "link-embed", "webservices", "suggestion",
|
|
||||||
"remind", "logging", "invite-filter", "profanity-filter", "statistic", "experience-tracking", "moderation", "modmail", "assignable-roles",
|
|
||||||
"voice-channel-context", "anti-raid",
|
|
||||||
"starboard-custom", "dynamic-activity-custom-translations", "moderation-custom",
|
|
||||||
"overrides-translation-moderation",
|
|
||||||
"news", "setup", "referral", "faq"],
|
|
||||||
"liquibase_artifacts": [
|
"liquibase_artifacts": [
|
||||||
{ "zip": "scheduling", "file": "scheduling-changeLog.xml" },
|
{ "zip": "scheduling", "file": "scheduling-changeLog.xml" },
|
||||||
{ "zip": "core", "file": "core-changeLog.xml" },
|
{ "zip": "core", "file": "core-changeLog.xml" },
|
||||||
@@ -34,13 +21,13 @@
|
|||||||
{ "zip": "anti-raid", "file": "antiRaid-changeLog.xml"},
|
{ "zip": "anti-raid", "file": "antiRaid-changeLog.xml"},
|
||||||
{ "zip": "dynamic-activity", "file": "dynamicActivity-changeLog.xml"},
|
{ "zip": "dynamic-activity", "file": "dynamicActivity-changeLog.xml"},
|
||||||
{ "zip": "setup", "file": "setup-changeLog.xml"},
|
{ "zip": "setup", "file": "setup-changeLog.xml"},
|
||||||
{ "zip": "database", "file": "changeLog.xml"},
|
|
||||||
{ "zip": "referral", "file": "referral-changeLog.xml"},
|
{ "zip": "referral", "file": "referral-changeLog.xml"},
|
||||||
{ "zip": "starboard-custom", "file": "starboard-custom-changeLog.xml"},
|
{ "zip": "starboard-custom", "file": "starboard-custom-changeLog.xml"},
|
||||||
{ "zip": "moderation-custom", "file": "moderation-custom-changeLog.xml"},
|
{ "zip": "moderation-custom", "file": "moderation-custom-changeLog.xml"},
|
||||||
{ "zip": "dynamic-activity-custom", "file": "dynamicActivity-custom-changeLog.xml"},
|
{ "zip": "dynamic-activity-custom", "file": "dynamicActivity-custom-changeLog.xml"},
|
||||||
{ "zip": "news", "file": "news-changeLog.xml"},
|
{ "zip": "news", "file": "news-changeLog.xml"},
|
||||||
{ "zip": "faq", "file": "faq-changeLog.xml"}
|
{ "zip": "faq", "file": "faq-changeLog.xml"},
|
||||||
|
{ "zip": "seasonal", "file": "seasonal-changeLog.xml"}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
mv /var/db-config/* /var/run-config/
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
ARG ABSTRACTO_REGISTRY_PREFIX
|
|
||||||
ARG ABSTRACTO_VERSION=latest
|
|
||||||
FROM ${ABSTRACTO_REGISTRY_PREFIX}abstracto_deployment:${ABSTRACTO_VERSION:-latest}
|
|
||||||
MAINTAINER Sheldan
|
|
||||||
ADD template-artifacts /templates
|
|
||||||
ADD translation-artifacts /translations
|
|
||||||
ADD liquibase-artifacts /liquibase-zips
|
|
||||||
ADD config /
|
|
||||||
@@ -2,24 +2,14 @@ version: "3.7"
|
|||||||
|
|
||||||
services:
|
services:
|
||||||
bot:
|
bot:
|
||||||
build: oneplusbot
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot:${VERSION:-latest}
|
|
||||||
database:
|
|
||||||
build: database
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_database:${VERSION:-latest}
|
|
||||||
pg_admin:
|
|
||||||
build: pgAdmin
|
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_pg_admin:${VERSION:-latest}
|
|
||||||
deployment_container:
|
|
||||||
build:
|
build:
|
||||||
context: deployment
|
context: oneplusbot
|
||||||
args:
|
image: ${REGISTRY_PREFIX}oneplus-bot-image:${VERSION:-latest}
|
||||||
ABSTRACTO_REGISTRY_PREFIX: ${ABSTRACTO_REGISTRY_PREFIX}
|
db-data:
|
||||||
ABSTRACTO_VERSION: ${ABSTRACTO_VERSION}
|
build:
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_deployment:${VERSION:-latest}
|
context: db-data
|
||||||
prometheus:
|
image: ${REGISTRY_PREFIX}oneplus-bot-db-data:${VERSION:-latest}
|
||||||
build: prometheus
|
template-data:
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_prometheus:${VERSION:-latest}
|
build:
|
||||||
grafana:
|
context: template-data
|
||||||
build: grafana
|
image: ${REGISTRY_PREFIX}oneplus-bot-template-data:${VERSION:-latest}
|
||||||
image: ${REGISTRY_PREFIX}oneplus_bot_grafana:${VERSION:-latest}
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user