- Add full Telegram bot functionality with Z.AI API integration
- Implement 4 tools: Bash, FileEdit, WebSearch, Git
- Add 3 agents: Code Reviewer, Architect, DevOps Engineer
- Add 6 skills for common coding tasks
- Add systemd service file for 24/7 operation
- Add nginx configuration for HTTPS webhook
- Add comprehensive documentation
- Implement WebSocket server for real-time updates
- Add logging system with Winston
- Add environment validation
🤖 zCode CLI X - Agentic coder with Z.AI + Telegram integration
97 lines
4.8 KiB
JavaScript
97 lines
4.8 KiB
JavaScript
/*
|
|
* Copyright The OpenTelemetry Authors
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
import { isDescriptorCompatibleWith } from '../InstrumentDescriptor';
|
|
import * as api from '@opentelemetry/api';
|
|
import { getConflictResolutionRecipe, getIncompatibilityDetails, } from '../view/RegistrationConflicts';
|
|
/**
|
|
* Internal class for storing {@link MetricStorage}
|
|
*/
|
|
export class MetricStorageRegistry {
|
|
_sharedRegistry = new Map();
|
|
_perCollectorRegistry = new Map();
|
|
static create() {
|
|
return new MetricStorageRegistry();
|
|
}
|
|
getStorages(collector) {
|
|
let storages = [];
|
|
for (const metricStorages of this._sharedRegistry.values()) {
|
|
storages = storages.concat(metricStorages);
|
|
}
|
|
const perCollectorStorages = this._perCollectorRegistry.get(collector);
|
|
if (perCollectorStorages != null) {
|
|
for (const metricStorages of perCollectorStorages.values()) {
|
|
storages = storages.concat(metricStorages);
|
|
}
|
|
}
|
|
return storages;
|
|
}
|
|
register(storage) {
|
|
this._registerStorage(storage, this._sharedRegistry);
|
|
}
|
|
registerForCollector(collector, storage) {
|
|
let storageMap = this._perCollectorRegistry.get(collector);
|
|
if (storageMap == null) {
|
|
storageMap = new Map();
|
|
this._perCollectorRegistry.set(collector, storageMap);
|
|
}
|
|
this._registerStorage(storage, storageMap);
|
|
}
|
|
findOrUpdateCompatibleStorage(expectedDescriptor) {
|
|
const storages = this._sharedRegistry.get(expectedDescriptor.name);
|
|
if (storages === undefined) {
|
|
return null;
|
|
}
|
|
// If the descriptor is compatible, the type of their metric storage
|
|
// (either SyncMetricStorage or AsyncMetricStorage) must be compatible.
|
|
return this._findOrUpdateCompatibleStorage(expectedDescriptor, storages);
|
|
}
|
|
findOrUpdateCompatibleCollectorStorage(collector, expectedDescriptor) {
|
|
const storageMap = this._perCollectorRegistry.get(collector);
|
|
if (storageMap === undefined) {
|
|
return null;
|
|
}
|
|
const storages = storageMap.get(expectedDescriptor.name);
|
|
if (storages === undefined) {
|
|
return null;
|
|
}
|
|
// If the descriptor is compatible, the type of their metric storage
|
|
// (either SyncMetricStorage or AsyncMetricStorage) must be compatible.
|
|
return this._findOrUpdateCompatibleStorage(expectedDescriptor, storages);
|
|
}
|
|
_registerStorage(storage, storageMap) {
|
|
const descriptor = storage.getInstrumentDescriptor();
|
|
const storages = storageMap.get(descriptor.name);
|
|
if (storages === undefined) {
|
|
storageMap.set(descriptor.name, [storage]);
|
|
return;
|
|
}
|
|
storages.push(storage);
|
|
}
|
|
_findOrUpdateCompatibleStorage(expectedDescriptor, existingStorages) {
|
|
let compatibleStorage = null;
|
|
for (const existingStorage of existingStorages) {
|
|
const existingDescriptor = existingStorage.getInstrumentDescriptor();
|
|
if (isDescriptorCompatibleWith(existingDescriptor, expectedDescriptor)) {
|
|
// Use the longer description if it does not match.
|
|
if (existingDescriptor.description !== expectedDescriptor.description) {
|
|
if (expectedDescriptor.description.length >
|
|
existingDescriptor.description.length) {
|
|
existingStorage.updateDescription(expectedDescriptor.description);
|
|
}
|
|
api.diag.warn('A view or instrument with the name ', expectedDescriptor.name, ' has already been registered, but has a different description and is incompatible with another registered view.\n', 'Details:\n', getIncompatibilityDetails(existingDescriptor, expectedDescriptor), 'The longer description will be used.\nTo resolve the conflict:', getConflictResolutionRecipe(existingDescriptor, expectedDescriptor));
|
|
}
|
|
// Storage is fully compatible. There will never be more than one pre-existing fully compatible storage.
|
|
compatibleStorage = existingStorage;
|
|
}
|
|
else {
|
|
// The implementation SHOULD warn about duplicate instrument registration
|
|
// conflicts after applying View configuration.
|
|
api.diag.warn('A view or instrument with the name ', expectedDescriptor.name, ' has already been registered and is incompatible with another registered view.\n', 'Details:\n', getIncompatibilityDetails(existingDescriptor, expectedDescriptor), 'To resolve the conflict:\n', getConflictResolutionRecipe(existingDescriptor, expectedDescriptor));
|
|
}
|
|
}
|
|
return compatibleStorage;
|
|
}
|
|
}
|
|
//# sourceMappingURL=MetricStorageRegistry.js.map
|