321 Zeilen
11 KiB
SQL
321 Zeilen
11 KiB
SQL
-- Test-Daten für Resource Pool System
|
|
-- Generiert für AccountForger v2-Docker
|
|
-- Stand: 2025-06-09
|
|
|
|
-- ====================================
|
|
-- Test-Domains (500 Stück)
|
|
-- ====================================
|
|
|
|
-- Verfügbare Domains
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, notes) VALUES
|
|
('domain', 'example-shop-001.com', 'available', 'Premium Domain'),
|
|
('domain', 'best-deals-online.net', 'available', 'E-Commerce Domain'),
|
|
('domain', 'super-store-24.com', 'available', 'Shop Domain'),
|
|
('domain', 'mega-market-place.org', 'available', 'Marketplace Domain'),
|
|
('domain', 'discount-heaven.net', 'available', 'Discount Domain'),
|
|
('domain', 'fashion-outlet-now.com', 'available', 'Fashion Domain'),
|
|
('domain', 'tech-gadgets-pro.net', 'available', 'Tech Domain'),
|
|
('domain', 'home-decor-style.com', 'available', 'Home Domain'),
|
|
('domain', 'sports-gear-central.net', 'available', 'Sports Domain'),
|
|
('domain', 'beauty-products-24.com', 'available', 'Beauty Domain');
|
|
|
|
-- Weitere Domains mit verschiedenen Patterns
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 11..400 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status)
|
|
VALUES ('domain',
|
|
CASE
|
|
WHEN i % 5 = 0 THEN 'shop-' || i || '-online.com'
|
|
WHEN i % 5 = 1 THEN 'store-' || i || '-pro.net'
|
|
WHEN i % 5 = 2 THEN 'market-' || i || '-24.org'
|
|
WHEN i % 5 = 3 THEN 'outlet-' || i || '-deals.com'
|
|
ELSE 'commerce-' || i || '-now.net'
|
|
END,
|
|
'available');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Einige zugeteilte Domains (50 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 401..450 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, allocated_to_license, status_changed_at, status_changed_by)
|
|
VALUES ('domain',
|
|
'allocated-domain-' || i || '.com',
|
|
'allocated',
|
|
(i % 10) + 1, -- Zuweisung zu Lizenzen 1-10
|
|
NOW() - INTERVAL '30 days' * RANDOM(),
|
|
'admin');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Domains in Quarantäne (50 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 451..500 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, quarantine_reason, quarantine_until, notes)
|
|
VALUES ('domain',
|
|
'quarantine-domain-' || i || '.com',
|
|
'quarantine',
|
|
CASE i % 5
|
|
WHEN 0 THEN 'abuse'
|
|
WHEN 1 THEN 'defect'
|
|
WHEN 2 THEN 'blacklisted'
|
|
WHEN 3 THEN 'expired'
|
|
ELSE 'review'
|
|
END,
|
|
NOW() + INTERVAL '7 days' + INTERVAL '1 day' * (i % 14),
|
|
'Automatisch in Quarantäne versetzt');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- ====================================
|
|
-- Test IPv4-Adressen (200 Stück)
|
|
-- ====================================
|
|
|
|
-- Verfügbare IPv4-Adressen
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 1..150 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, notes)
|
|
VALUES ('ipv4',
|
|
'192.168.' || (i / 256 + 1)::INT || '.' || (i % 256),
|
|
'available',
|
|
CASE
|
|
WHEN i % 10 = 0 THEN 'Premium IP'
|
|
WHEN i % 20 = 0 THEN 'Dedicated Server IP'
|
|
ELSE 'Standard IP'
|
|
END);
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Zugeteilte IPv4-Adressen (30 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 151..180 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, allocated_to_license, status_changed_at, status_changed_by)
|
|
VALUES ('ipv4',
|
|
'10.0.' || ((i-150) / 256)::INT || '.' || ((i-150) % 256),
|
|
'allocated',
|
|
((i-150) % 15) + 1,
|
|
NOW() - INTERVAL '60 days' * RANDOM(),
|
|
'system');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- IPv4 in Quarantäne (20 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 181..200 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, quarantine_reason, quarantine_until, notes)
|
|
VALUES ('ipv4',
|
|
'172.16.' || ((i-180) / 256)::INT || '.' || ((i-180) % 256),
|
|
'quarantine',
|
|
CASE (i-180) % 4
|
|
WHEN 0 THEN 'blacklisted'
|
|
WHEN 1 THEN 'abuse'
|
|
WHEN 2 THEN 'maintenance'
|
|
ELSE 'defect'
|
|
END,
|
|
NOW() + INTERVAL '3 days' + INTERVAL '1 day' * ((i-180) % 7),
|
|
'IP wurde gemeldet oder ist in Wartung');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- ====================================
|
|
-- Test Telefonnummern (100 Stück)
|
|
-- ====================================
|
|
|
|
-- Verfügbare Telefonnummern
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 1..70 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, notes)
|
|
VALUES ('phone',
|
|
'+49' || (1500000000 + i),
|
|
'available',
|
|
CASE
|
|
WHEN i % 5 = 0 THEN 'Premium Nummer'
|
|
WHEN i % 10 = 0 THEN 'Vanity Nummer'
|
|
ELSE 'Standard Nummer'
|
|
END);
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Zugeteilte Telefonnummern (20 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 71..90 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, allocated_to_license, status_changed_at, status_changed_by)
|
|
VALUES ('phone',
|
|
'+49' || (1600000000 + i),
|
|
'allocated',
|
|
((i-70) % 10) + 1,
|
|
NOW() - INTERVAL '45 days' * RANDOM(),
|
|
'admin');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Telefonnummern in Quarantäne (10 Stück)
|
|
DO $$
|
|
BEGIN
|
|
FOR i IN 91..100 LOOP
|
|
INSERT INTO resource_pools (resource_type, resource_value, status, quarantine_reason, quarantine_until, notes)
|
|
VALUES ('phone',
|
|
'+49' || (1700000000 + i),
|
|
'quarantine',
|
|
CASE (i-90) % 3
|
|
WHEN 0 THEN 'expired'
|
|
WHEN 1 THEN 'defect'
|
|
ELSE 'review'
|
|
END,
|
|
NOW() + INTERVAL '5 days' + INTERVAL '1 day' * ((i-90) % 5),
|
|
'Nummer wurde zurückgegeben oder ist defekt');
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- ====================================
|
|
-- Resource History für einige Ressourcen
|
|
-- ====================================
|
|
|
|
-- Historie für einige Domains
|
|
INSERT INTO resource_history (resource_id, license_id, action, action_by, details, ip_address)
|
|
SELECT
|
|
id,
|
|
allocated_to_license,
|
|
'allocated',
|
|
'system',
|
|
'{"reason": "Neue Lizenz erstellt", "customer": "Test Customer"}'::jsonb,
|
|
'192.168.1.100'
|
|
FROM resource_pools
|
|
WHERE status = 'allocated'
|
|
AND resource_type = 'domain'
|
|
LIMIT 10;
|
|
|
|
-- Historie für Quarantäne
|
|
INSERT INTO resource_history (resource_id, action, action_by, details, ip_address)
|
|
SELECT
|
|
id,
|
|
'quarantined',
|
|
'admin',
|
|
jsonb_build_object('reason', quarantine_reason, 'duration', '7 days'),
|
|
'192.168.1.101'
|
|
FROM resource_pools
|
|
WHERE status = 'quarantine'
|
|
LIMIT 20;
|
|
|
|
-- ====================================
|
|
-- Resource Metrics für Performance-Tracking
|
|
-- ====================================
|
|
|
|
-- Metriken für die letzten 30 Tage
|
|
DO $$
|
|
DECLARE
|
|
resource_rec RECORD;
|
|
days_back INT;
|
|
BEGIN
|
|
-- Für jede Ressource, die allocated ist
|
|
FOR resource_rec IN
|
|
SELECT id FROM resource_pools WHERE status = 'allocated' LIMIT 50
|
|
LOOP
|
|
-- Generiere Metriken für die letzten 30 Tage
|
|
FOR days_back IN 0..29 LOOP
|
|
INSERT INTO resource_metrics (
|
|
resource_id,
|
|
metric_date,
|
|
usage_count,
|
|
performance_score,
|
|
cost,
|
|
revenue,
|
|
issues_count,
|
|
availability_percent
|
|
) VALUES (
|
|
resource_rec.id,
|
|
CURRENT_DATE - INTERVAL '1 day' * days_back,
|
|
FLOOR(RANDOM() * 100 + 50), -- 50-150 Nutzungen
|
|
ROUND((RANDOM() * 40 + 60)::numeric, 2), -- 60-100 Score
|
|
ROUND((RANDOM() * 5 + 2)::numeric, 2), -- 2-7 EUR Kosten
|
|
ROUND((RANDOM() * 20 + 10)::numeric, 2), -- 10-30 EUR Umsatz
|
|
FLOOR(RANDOM() * 3), -- 0-2 Issues
|
|
ROUND((RANDOM() * 5 + 95)::numeric, 2) -- 95-100% Verfügbarkeit
|
|
) ON CONFLICT (resource_id, metric_date) DO NOTHING;
|
|
END LOOP;
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- ====================================
|
|
-- License Resources Zuordnungen
|
|
-- ====================================
|
|
|
|
-- Verbinde einige bestehende Lizenzen mit Ressourcen
|
|
DO $$
|
|
DECLARE
|
|
license_rec RECORD;
|
|
domain_id INT;
|
|
ipv4_id INT;
|
|
phone_id INT;
|
|
BEGIN
|
|
-- Für die ersten 10 aktiven Lizenzen
|
|
FOR license_rec IN
|
|
SELECT id FROM licenses WHERE is_active = TRUE LIMIT 10
|
|
LOOP
|
|
-- Hole eine verfügbare Domain
|
|
SELECT id INTO domain_id FROM resource_pools
|
|
WHERE resource_type = 'domain' AND status = 'available'
|
|
ORDER BY RANDOM() LIMIT 1;
|
|
|
|
IF domain_id IS NOT NULL THEN
|
|
-- Weise die Domain zu
|
|
UPDATE resource_pools
|
|
SET status = 'allocated',
|
|
allocated_to_license = license_rec.id,
|
|
status_changed_at = NOW(),
|
|
status_changed_by = 'migration'
|
|
WHERE id = domain_id;
|
|
|
|
-- Erstelle Zuordnung
|
|
INSERT INTO license_resources (license_id, resource_id, assigned_by)
|
|
VALUES (license_rec.id, domain_id, 'migration');
|
|
END IF;
|
|
|
|
-- Wiederhole für IPv4
|
|
SELECT id INTO ipv4_id FROM resource_pools
|
|
WHERE resource_type = 'ipv4' AND status = 'available'
|
|
ORDER BY RANDOM() LIMIT 1;
|
|
|
|
IF ipv4_id IS NOT NULL THEN
|
|
UPDATE resource_pools
|
|
SET status = 'allocated',
|
|
allocated_to_license = license_rec.id,
|
|
status_changed_at = NOW(),
|
|
status_changed_by = 'migration'
|
|
WHERE id = ipv4_id;
|
|
|
|
INSERT INTO license_resources (license_id, resource_id, assigned_by)
|
|
VALUES (license_rec.id, ipv4_id, 'migration');
|
|
END IF;
|
|
END LOOP;
|
|
END $$;
|
|
|
|
-- Zusammenfassung ausgeben
|
|
DO $$
|
|
DECLARE
|
|
domain_count INT;
|
|
ipv4_count INT;
|
|
phone_count INT;
|
|
BEGIN
|
|
SELECT COUNT(*) INTO domain_count FROM resource_pools WHERE resource_type = 'domain';
|
|
SELECT COUNT(*) INTO ipv4_count FROM resource_pools WHERE resource_type = 'ipv4';
|
|
SELECT COUNT(*) INTO phone_count FROM resource_pools WHERE resource_type = 'phone';
|
|
|
|
RAISE NOTICE 'Test-Daten erfolgreich eingefügt:';
|
|
RAISE NOTICE '- Domains: %', domain_count;
|
|
RAISE NOTICE '- IPv4-Adressen: %', ipv4_count;
|
|
RAISE NOTICE '- Telefonnummern: %', phone_count;
|
|
RAISE NOTICE '';
|
|
RAISE NOTICE 'Status-Verteilung:';
|
|
RAISE NOTICE '- Verfügbar: % Ressourcen', (SELECT COUNT(*) FROM resource_pools WHERE status = 'available');
|
|
RAISE NOTICE '- Zugeteilt: % Ressourcen', (SELECT COUNT(*) FROM resource_pools WHERE status = 'allocated');
|
|
RAISE NOTICE '- Quarantäne: % Ressourcen', (SELECT COUNT(*) FROM resource_pools WHERE status = 'quarantine');
|
|
END $$; |