Commit c0e9c969 authored by Rosanny Sihombing's avatar Rosanny Sihombing
Browse files

pulling gitlab pages without accessing runners

parent e21da7e2
var env = process.env.NODE_ENV || 'testing'
const config = require('../config/config')[env]
const axios = require('axios') const axios = require('axios')
var gitlab = { var gitlab = {
getRepos: async function(perPage, idAfter) { getProjects: async function(perPage, idAfter) {
try { try {
let projects = await axios({ let projects = await axios({
method: 'get', method: 'get',
...@@ -11,43 +9,20 @@ var gitlab = { ...@@ -11,43 +9,20 @@ var gitlab = {
}) })
let data = projects.data let data = projects.data
let reposArr = [] let reposArr = []
for(let i = 0; i < data.length; i++){
// skip template project
if (data[i].name == 'template_gitlab_page') {
continue
} else if(!data[i].tag_list.includes('website')) {
reposArr.push(data[i])
}
}
return {
error: false,
data: reposArr}
}
catch (err) {
return {
error: true,
data: err}
}
},
getPages: async function(perPage, idAfter) {
try {
let projects = await axios({
method: 'get',
url: 'https://transfer.hft-stuttgart.de/gitlab/api/v4/projects?visibility=public&pagination=keyset&per_page='+perPage+'&order_by=id&sort=asc&id_after='+idAfter
})
let data = projects.data
let pagesArr = [] let pagesArr = []
for(let i = 0; i < data.length; i++){ for(let i = 0; i < data.length; i++){
// skip template project // skip template project
if (data[i].name == 'template_gitlab_page') { if (data[i].name == 'page_basic' || data[i].name == 'generic' || data[i].name == 'simple_raw' || data[i].name == 'simple_thesis') {
continue continue
} else if(data[i].tag_list.includes('website')) { } else if(data[i].tag_list.includes('website')) {
pagesArr.push(data[i]) pagesArr.push(data[i])
} else {
reposArr.push(data[i])
} }
} }
return { return {
error: false, error: false,
data: pagesArr} data: [reposArr, pagesArr]}
} }
catch (err) { catch (err) {
return { return {
...@@ -55,26 +30,13 @@ var gitlab = { ...@@ -55,26 +30,13 @@ var gitlab = {
data: err} data: err}
} }
}, },
getProjectsFromRunners: async function() { getLatestPipelineStatus: async function(projectId) {
try { return axios({
let runner = await axios({
method: 'get', method: 'get',
url: 'https://transfer.hft-stuttgart.de/gitlab/api/v4/runners/7', url: 'https://transfer.hft-stuttgart.de/gitlab/api/v4/projects/'+projectId+'/pipelines'
headers: {
'Authorization': 'Bearer '+config.gitlab.token_readWriteProjects
}
}) })
let runnerProjects = runner.data.projects .then(res => res.data[0].status)
return { .catch(err => console.error(err))
error: false,
data: runnerProjects
}
}
catch (err) {
return {
error: true,
data: err}
}
} }
} }
......
...@@ -257,8 +257,8 @@ module.exports = function (app) { ...@@ -257,8 +257,8 @@ module.exports = function (app) {
let firstId = 0 let firstId = 0
while (isProject == true) { while (isProject == true) {
let projects = await gitlab.getRepos(100, firstId) let projects = await gitlab.getProjects(100, firstId)
let projectData = projects.data let projectData = projects.data[0]
if (projectData.length == 0) { if (projectData.length == 0) {
isProject = false isProject = false
...@@ -298,27 +298,16 @@ module.exports = function (app) { ...@@ -298,27 +298,16 @@ module.exports = function (app) {
let isProject = true let isProject = true
let firstId = 0 let firstId = 0
let runnerProjects = await gitlab.getProjectsFromRunners()
if(runnerProjects.error) {
// error response: to be updated
res.status(500).render(lang+'/500', { error: err })
} else {
let runnerProjectsData = runnerProjects.data
let runnerProjectsIds = []
for(let i = 0; i < runnerProjectsData.length; i++){
runnerProjectsIds.push(runnerProjectsData[i].id)
}
while (isProject == true) { while (isProject == true) {
let pages = await gitlab.getPages(100, firstId) let projects = await gitlab.getProjects(100, firstId)
let pagesData = pages.data let pagesData = projects.data[1]
if (pagesData.length == 0) { if (pagesData.length == 0) {
isProject = false isProject = false
} else { } else {
for(let i = 0; i < pagesData.length; i++){ for(let i = 0; i < pagesData.length; i++){
// ONLY IF THE PROJECT IS AVAILABLE IN THE RUNNER let status = await gitlab.getLatestPipelineStatus(pagesData[i].id)
if(runnerProjectsIds.indexOf(pagesData[i].id) > -1) { if (status) {
// M4_LAB logo for all projects that do not have logo // M4_LAB logo for all projects that do not have logo
if (pagesData[i].avatar_url == null) { if (pagesData[i].avatar_url == null) {
pagesData[i].avatar_url = "https://m4lab.hft-stuttgart.de/img/footer/M4_LAB_LOGO_Graustufen.png" pagesData[i].avatar_url = "https://m4lab.hft-stuttgart.de/img/footer/M4_LAB_LOGO_Graustufen.png"
...@@ -327,17 +316,21 @@ module.exports = function (app) { ...@@ -327,17 +316,21 @@ module.exports = function (app) {
if (pagesData[i].description == "") { if (pagesData[i].description == "") {
pagesData[i].description = "- no description -" pagesData[i].description = "- no description -"
} }
// customize website name // customized website name
if (pagesData[i].name == "Visualization") { if (pagesData[i].name == "Visualization") {
//todo: update URL - user? group?
pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/visualization" pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/visualization"
} }
else if (pagesData[i].name == "IN-Source") { else if (pagesData[i].name == "IN-Source") {
//todo: update URL
pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/INsource" pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/INsource"
} }
else if (pagesData[i].name == "3DS_Visualization_Cesium") { else if (pagesData[i].name == "3DS_Visualization_Cesium") {
//todo: update URL
pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/3ds_visualization_cesium" pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/3ds_visualization_cesium"
} }
else { else {
//todo: update URL
pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/"+pagesData[i].name pagesData[i].web_url = "https://transfer.hft-stuttgart.de/pages/"+pagesData[i].name
} }
// remove 'website' from tag list // remove 'website' from tag list
...@@ -360,7 +353,6 @@ module.exports = function (app) { ...@@ -360,7 +353,6 @@ module.exports = function (app) {
firstId = pagesData[pagesData.length-1].id firstId = pagesData[pagesData.length-1].id
} }
} }
}
res.render(lang+'/project/pagesList', { res.render(lang+'/project/pagesList', {
pages: pagesArr pages: pagesArr
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment