Compare commits
13 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
aea88c632e | ||
|
|
dd60c9067b | ||
|
|
03818d6102 | ||
|
|
4e1ca8a700 | ||
|
|
be0ed2a40d | ||
|
|
af07976c78 | ||
|
|
fb4f43c234 | ||
|
|
34a6c0cdd3 | ||
|
|
a6cde5c69c | ||
|
|
a2420f19c9 | ||
|
|
2019dc4643 | ||
|
|
9bb35bb30a | ||
|
|
3cad5680b0 |
48
.github/workflows/main.yml
vendored
48
.github/workflows/main.yml
vendored
@ -20,33 +20,45 @@ jobs:
|
|||||||
- name: Get Version
|
- name: Get Version
|
||||||
id: get_version
|
id: get_version
|
||||||
uses: battila7/get-version-action@v2.0.0
|
uses: battila7/get-version-action@v2.0.0
|
||||||
|
|
||||||
- name: Build container image
|
- name: install buildx
|
||||||
env:
|
id: buildx
|
||||||
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
|
uses: crazy-max/ghaction-docker-buildx@v1
|
||||||
run: docker build -t registry.digitalocean.com/djpianalto/goff:$IMAGE_TAG .
|
|
||||||
|
|
||||||
- name: Install doctl
|
|
||||||
uses: digitalocean/action-doctl@v2
|
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }}
|
version: latest
|
||||||
|
|
||||||
- name: Login to DigitalOcean Container Registry with short-lived credentials
|
- name: Docker Login
|
||||||
run: doctl registry login --expiry-seconds 600
|
# You may pin to the exact commit or the version.
|
||||||
|
# uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9
|
||||||
|
uses: docker/login-action@v1.10.0
|
||||||
|
with:
|
||||||
|
registry: ${{ secrets.DR_URL }}
|
||||||
|
# Username used to log against the Docker registry
|
||||||
|
username: ${{ secrets.DH_USERNAME }}
|
||||||
|
# Password or personal access token used to log against the Docker registry
|
||||||
|
password: ${{ secrets.DH_PASSWORD }}
|
||||||
|
# Log out from the Docker registry at the end of a job
|
||||||
|
logout: true
|
||||||
|
|
||||||
- name: Push image to DigitalOcean Container Registry
|
- name: Docker Build & Push
|
||||||
env:
|
env:
|
||||||
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
|
IMAGE_TAG: ${{ steps.get_version.outputs.version-without-v }}
|
||||||
run: docker push registry.digitalocean.com/djpianalto/goff:$IMAGE_TAG
|
run: |
|
||||||
|
docker buildx build --push \
|
||||||
|
--tag ${{ secrets.DR_URL }}/goff:$IMAGE_TAG \
|
||||||
|
--platform linux/amd64,linux/arm/v7,linux/arm64 .
|
||||||
|
|
||||||
- name: Update deployment file
|
- name: Update deployment file
|
||||||
run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|registry.digitalocean.com/djpianalto/goff:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
|
run: TAG=${{ steps.get_version.outputs.version-without-v }} && sed -i 's|<IMAGE>|${{ secrets.DR_URL }}/goff:'${TAG}'|' $GITHUB_WORKSPACE/deployment.yml
|
||||||
|
|
||||||
- name: Save DigitalOcean kubeconfig with short-lived credentials
|
- uses: azure/k8s-set-context@v1
|
||||||
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 discord-bots
|
with:
|
||||||
|
method: kubeconfig
|
||||||
|
kubeconfig: ${{ secrets.KUBE_CONFIG }}
|
||||||
|
id: setcontext
|
||||||
|
|
||||||
- name: Deploy to DigitalOcean Kubernetes
|
- name: Deploy to Kubernetes
|
||||||
run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml
|
run: kubectl apply -f $GITHUB_WORKSPACE/deployment.yml
|
||||||
|
|
||||||
- name: Verify deployment
|
- name: Verify deployment
|
||||||
run: kubectl rollout status deployment/goff
|
run: kubectl rollout status deployment/goff -n discord-bots
|
||||||
|
|||||||
@ -86,6 +86,7 @@ func main() {
|
|||||||
dg.AddHandler(user_management.OnGuildMemberAdd)
|
dg.AddHandler(user_management.OnGuildMemberAdd)
|
||||||
dg.AddHandler(user_management.OnGuildMemberRemoveLogging)
|
dg.AddHandler(user_management.OnGuildMemberRemoveLogging)
|
||||||
dg.AddHandler(user_management.OnGuildMemberRemove)
|
dg.AddHandler(user_management.OnGuildMemberRemove)
|
||||||
|
dg.AddHandler(user_management.OnGuildMemberUpdate)
|
||||||
|
|
||||||
err = dg.Open()
|
err = dg.Open()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@ -2,7 +2,7 @@ apiVersion: apps/v1
|
|||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
name: goff
|
name: goff
|
||||||
namespace: default
|
namespace: discord-bots
|
||||||
labels:
|
labels:
|
||||||
app: goff
|
app: goff
|
||||||
spec:
|
spec:
|
||||||
@ -21,8 +21,42 @@ spec:
|
|||||||
app: goff
|
app: goff
|
||||||
spec:
|
spec:
|
||||||
containers:
|
containers:
|
||||||
|
- name: pgbouncer
|
||||||
|
image: timoha/pgbouncer:1.15.0
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: "256Mi"
|
||||||
|
cpu: "0.5"
|
||||||
|
limits:
|
||||||
|
memory: "512Mi"
|
||||||
|
cpu: "1"
|
||||||
|
env:
|
||||||
|
- name: DATABASE_URL
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: goff
|
||||||
|
key: pgbouncer_url
|
||||||
|
- name: SERVER_TLS_SSLMODE
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: goff
|
||||||
|
key: pgbouncer_ssl
|
||||||
|
- name: AUTH_TYPE
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: goff
|
||||||
|
key: pgbouncer_auth
|
||||||
|
ports:
|
||||||
|
- containerPort: 5432
|
||||||
- name: goff
|
- name: goff
|
||||||
image: <IMAGE>
|
image: <IMAGE>
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: "512Mi"
|
||||||
|
cpu: "1"
|
||||||
|
limits:
|
||||||
|
memory: "1Gi"
|
||||||
|
cpu: "2"
|
||||||
env:
|
env:
|
||||||
- name: DATABASE_URL
|
- name: DATABASE_URL
|
||||||
valueFrom:
|
valueFrom:
|
||||||
@ -44,3 +78,5 @@ spec:
|
|||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: goff
|
name: goff
|
||||||
key: email_password
|
key: email_password
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: registry-1
|
||||||
|
|||||||
@ -103,13 +103,7 @@ func OnGuildMemberUpdate(s *discordgo.Session, member *discordgo.GuildMemberUpda
|
|||||||
log.Println("Error getting Auto Join Roles: ", err)
|
log.Println("Error getting Auto Join Roles: ", err)
|
||||||
}
|
}
|
||||||
log.Println(roles)
|
log.Println(roles)
|
||||||
RoleLoop:
|
|
||||||
for _, r := range roles {
|
for _, r := range roles {
|
||||||
for _, rl := range member.Roles {
|
|
||||||
if rl == r.ID {
|
|
||||||
continue RoleLoop
|
|
||||||
}
|
|
||||||
}
|
|
||||||
role, err := s.State.Role(member.GuildID, r.ID)
|
role, err := s.State.Role(member.GuildID, r.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Error getting role: ", err)
|
log.Println("Error getting role: ", err)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user