This commit is contained in:
Richard Sanders 2024-04-16 09:07:56 +02:00 committed by GitHub
commit eba1621b00
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 69 additions and 2 deletions

17
.github/dependabot.yml vendored Normal file
View file

@ -0,0 +1,17 @@
# To get started with Dependabot version updates, you'll need to specify which
# package ecosystems to update and where the package manifests are located.
# Please see the documentation for all configuration options:
# https://docs.github.com/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file
version: 2
updates:
- package-ecosystem: "npm" # See documentation for possible values
directory: "/" # Location of package manifests
schedule:
interval: "weekly"
- package-ecosystem: "npm" # See documentation for possible values
directory: "/client" # Location of package manifests
schedule:
interval: "weekly"

View file

@ -4,23 +4,45 @@ const Logger = require('../../../utils/Logger');
const logger = new Logger();
const loadConfig = require('../../../utils/loadConfig');
const gatewayRoutes = [
{ type: 'httproutes', version: 'v1' },
{ type: 'httproutes', version: 'v1beta1' },
{ type: 'tcproutes', version: 'v1alpha2' },
{ type: 'grpcroutes', version: 'v1alpha2' },
{ type: 'tlsroutes', version: 'v1alpha2' },
{ type: 'udproutes', version: 'v1alpha2' }
];
const useKubernetes = async (apps) => {
const { useOrdering: orderType, unpinStoppedApps } = await loadConfig();
let ingresses = null;
let routeData = [];
try {
const kc = new k8s.KubeConfig();
kc.loadFromCluster();
const k8sNetworkingV1Api = kc.makeApiClient(k8s.NetworkingV1Api);
await k8sNetworkingV1Api.listIngressForAllNamespaces().then((res) => {
ingresses = res.body.items;
});
const customObjectsApi = kc.makeApiClient(k8s.CustomObjectsApi);
for (let route of gatewayRoutes) {
await customObjectsApi.listClusterCustomObject('gateway.networking.k8s.io', route.version, route.type).then((res) => {
res.body.items.forEach(item => routeData.push({ ...item, routeType: route.type }));
}).catch(error => {
logger.log(`Error fetching ${route.type}: ${error.message}`, 'ERROR');
});
}
} catch {
logger.log("Can't connect to the Kubernetes API", 'ERROR');
logger.log(error.message, 'ERROR');
}
if (ingresses) {
if (ingresses || routeData.length > 0) {
apps = await App.findAll({
order: [[orderType, 'ASC']],
});
@ -29,6 +51,12 @@ const useKubernetes = async (apps) => {
(e) => Object.keys(e.metadata.annotations).length !== 0
);
routeData = routeData.filter(
item => item.metadata &&
item.metadata.annotations &&
Object.keys(item.metadata.annotations).length !== 0
);
const kubernetesApps = [];
for (const ingress of ingresses) {
@ -47,13 +75,32 @@ const useKubernetes = async (apps) => {
}
}
for (const item of routeData) {
const annotations = item.metadata.annotations || {};
if (/^app/.test(annotations['flame.pawelmalak/type'])) {
if (item.spec && item.spec.hostnames) {
item.spec.hostnames.forEach(hostname => {
kubernetesApps.push({
name: annotations['flame.pawelmalak/name'] || item.metadata.name,
url: annotations['flame.pawelmalak/url'] || hostname,
icon: annotations['flame.pawelmalak/icon'] || 'kubernetes',
type: item.routeType.toUpperCase()
});
});
}
}
}
const uniqueApps = Array.from(new Set(kubernetesApps.map(app => JSON.stringify(app)))).map(item => JSON.parse(item));
if (unpinStoppedApps) {
for (const app of apps) {
await app.update({ isPinned: false });
}
}
for (const item of kubernetesApps) {
for (const item of uniqueApps) {
if (apps.some((app) => app.name === item.name)) {
const app = apps.find((a) => a.name === item.name);
await app.update({ ...item, isPinned: true });

View file

@ -12,6 +12,9 @@ rules:
- apiGroups: ["networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "list", "watch"]
- apiGroups: ["gateway.networking.k8s.io"]
resources: ["tcproutes","httproutes","grpcroutes","tlsroutes","udproutes"]
verbs: ["get", "list", "watch"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding