theoretically works, BUT:
All checks were successful
gitea.arg.rip/deployment/pipeline/head This commit looks good
All checks were successful
gitea.arg.rip/deployment/pipeline/head This commit looks good
how do I add a room *to a space*? how do I give control of a room to someone else?
This commit is contained in:
parent
ca3d31de38
commit
159a0027ff
@ -5,93 +5,109 @@ pipeline {
|
|||||||
string(name: 'videodesc', description: "video description")
|
string(name: 'videodesc', description: "video description")
|
||||||
}
|
}
|
||||||
environment {
|
environment {
|
||||||
GITEATOKEN = credentials('d0e86441-2157-405f-8539-a9a9010c6ecf')
|
JENKINSONGITEA=credentials('d0e86441-2157-405f-8539-a9a9010c6ecf')
|
||||||
JENKINSMATRIX=credentials('040b63d1-2f14-4692-badb-114bddd7c5a5')
|
JENKINSONMATRIXTOKEN=credentials('17d18fd7-29eb-4957-9532-ce42aaa9b4ec')
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
stage("environment setup") {
|
stage("environment setup") {
|
||||||
steps{
|
steps{
|
||||||
script{
|
script{
|
||||||
if (videoname.isEmpty()) {
|
if (videoname.isEmpty()) {
|
||||||
error("videoname mandatory")
|
error("videoname mandatory")
|
||||||
}
|
}
|
||||||
if (videoname.contains(' ')) {
|
if (videoname.contains(' ')) {
|
||||||
error("videoname cannot have spaces. try dashes.")
|
error("videoname cannot have spaces. try dashes.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("create gitea project"){
|
stage("create gitea project"){
|
||||||
steps{
|
steps{
|
||||||
sh """
|
script{
|
||||||
curl -X 'POST' \
|
env.giteaCreateEvent=sh(returnStdout: true, script: """
|
||||||
'https://gitea.arg.rip/api/v1/repos/beefhavers/_videotemplate/generate' \
|
curl -X 'POST' \
|
||||||
-H 'accept: application/json' \
|
'https://gitea.arg.rip/api/v1/repos/beefhavers/_videotemplate/generate' \
|
||||||
-H 'Authorization: token ${env.GITEATOKEN}' \
|
-H 'accept: application/json' \
|
||||||
-H 'Content-Type: application/json' \
|
-H 'Authorization: token ${env.JENKINSONGITEA}' \
|
||||||
-d '{
|
-H 'Content-Type: application/json' \
|
||||||
"description": "${videodesc}",
|
-d '{
|
||||||
"git_content": true,
|
"description": "${videodesc}",
|
||||||
"git_hooks": true,
|
"git_content": true,
|
||||||
"labels": true,
|
"git_hooks": true,
|
||||||
"name": "${videoname}",
|
"labels": true,
|
||||||
"owner": "beefhavers",
|
"name": "${videoname}",
|
||||||
"private": false,
|
"owner": "beefhavers",
|
||||||
"protected_branch": true,
|
"private": false,
|
||||||
"topics": true,
|
"protected_branch": true,
|
||||||
"webhooks": true
|
"topics": true,
|
||||||
}'
|
"webhooks": true
|
||||||
"""
|
}'
|
||||||
|
""").trim()
|
||||||
|
if (!env.giteaCreateEvent?.trim()) {
|
||||||
|
error "couldn't make gitea repo, apparently"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("create matrix room"){
|
stage("create matrix room"){
|
||||||
steps{
|
steps{
|
||||||
env.roomId=sh(returnStdout: true, script: """
|
script{
|
||||||
curl -X 'POST' \
|
env.roomcreationevent=sh(returnStdout: true, script: """
|
||||||
'https://greyn.club:8448/_matrix/client/v3/createRoom' \
|
curl -X 'POST' \
|
||||||
-H 'accept: application/json' \
|
'https://greyn.club:8448/_matrix/client/v3/createRoom' \
|
||||||
-H 'Authorization: Bearer ${JENKINSMATRIX}}' \
|
-H 'accept: application/json' \
|
||||||
-H 'Content-Type: application/json' \
|
-H 'Authorization: Bearer ${JENKINSONMATRIXTOKEN}' \
|
||||||
-d '{
|
-H 'Content-Type: application/json' \
|
||||||
"creation_content": {
|
-d '{
|
||||||
"m.federate": false
|
"creation_content": {
|
||||||
},
|
"m.federate": false
|
||||||
"name": "${videoname}",
|
},
|
||||||
"preset": "public_chat",
|
"name": "${videoname}",
|
||||||
"invite": ["@adam:greyn.club", "@gitea:greyn.club"],
|
"preset": "public_chat",
|
||||||
"topic": "[link to gitea project]"
|
"invite": ["@adam:greyn.club", "@gitea:greyn.club"],
|
||||||
}' | jq .room_id
|
"topic": "[link to gitea project]"
|
||||||
"""
|
}'
|
||||||
).trim()
|
"""
|
||||||
}
|
).trim()
|
||||||
|
if (!env.roomcreationevent?.trim()) {
|
||||||
|
error "couldn't make matrix room, apparently"
|
||||||
|
}
|
||||||
|
echo "roomcreationevent:"
|
||||||
|
echo env.roomcreationevent
|
||||||
|
env.room_id = sh(returnStdout: true, script: "${env.roomcreationevent} | jq .room_id").trim()
|
||||||
|
if(!env.room_id?.trim()){
|
||||||
|
error "couldn't make matrix room, apparently"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
stage("link gitea webhook"){
|
stage("link gitea webhook"){
|
||||||
steps{
|
steps{
|
||||||
sh """
|
sh """
|
||||||
curl -X 'GET' 'https://gitea.arg.rip/api/v1/repos/beefhavers/${videoname}/hooks' \
|
curl -X 'GET' 'https://gitea.arg.rip/api/v1/repos/beefhavers/${videoname}/hooks' \
|
||||||
-H 'accept: application/json' \
|
-H 'accept: application/json' \
|
||||||
-H 'authorization: token ${env.GITEATOKEN}' \
|
-H 'authorization: token ${env.JENKINSONGITEA}' \
|
||||||
>reporesponse.json
|
>reporesponse.json
|
||||||
"""
|
"""
|
||||||
|
|
||||||
sh """
|
sh """
|
||||||
curl -X 'PATCH' 'https://gitea.arg.rip/api/v1/repos/beefhavers/${videoname}/hooks' \
|
curl -X 'PATCH' 'https://gitea.arg.rip/api/v1/repos/beefhavers/${videoname}/hooks' \
|
||||||
-H 'accept: application/json' \
|
-H 'accept: application/json' \
|
||||||
-H 'authorization: token ${env.GITEATOKEN}' \
|
-H 'authorization: token ${env.JENKINSONGITEA}' \
|
||||||
-H 'Content-Type: application/json' \
|
-H 'Content-Type: application/json' \
|
||||||
-d '{
|
-d '{
|
||||||
"active": true,
|
"active": true,
|
||||||
"authorization_header": \$(cat reporesponse.json | jq .[0].authorization_header),
|
"authorization_header": \$(cat reporesponse.json | jq .[0].authorization_header),
|
||||||
"branch_filter": "*",
|
"branch_filter": "*",
|
||||||
"config": {
|
"config": {
|
||||||
"content_type": "json",
|
"content_type": "json",
|
||||||
"url": "https://greyn.club:8448/_matrix/client/r0/rooms/\$(echo ${env.roomId} | sed 's/!/%21/')/send/m.room.message"
|
"url": "https://greyn.club:8448/_matrix/client/r0/rooms/\$(echo ${env.room_id} | sed 's/!/%21/')/send/m.room.message"
|
||||||
},
|
},
|
||||||
"events": \$(cat reporesponse.json | jq .[0].events)
|
"events": \$(cat reporesponse.json | jq .[0].events)
|
||||||
}'
|
}'
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user