cephalo-db
v1.0.0
Published
CephaloDB is an intelligent, real-time document-based database system designed to build and manage complex relationships dynamically. Inspired by the adaptability of an octopus, CephaloDB leverages fuzzy logic and automation to establish and update connec
Downloads
30
Maintainers
Keywords
Readme
CephaloDB Documentation
Introduction
CephaloDB is an intelligent, real-time, document-based database system inspired by the adaptability and intelligence of the octopus (cephalopod). It dynamically manages and builds complex relationships using fuzzy logic, automation, and role-based access control (RBAC). Designed with enterprise-level security, CephaloDB leverages AES-256 encryption to offer military-grade protection for data without compromising performance.
Built using Node.js, Socket.IO, and Docker, CephaloDB is highly flexible, adaptive, and scalable, making it the perfect choice for modern applications that require interconnected, secure, and real-time data management.
Table of Contents
- Features
- Getting Started
- Installation
- Core Concepts
- API Reference
- Comprehensive Usage Examples
- Contributing
- License
Features
CephaloDB provides a range of features designed for real-time, adaptive, and secure data management:
- Document-based Storage: Store and manage documents using a flexible schema. Documents are the core data units, enabling easy storage, retrieval, sorting, and filtering.
- Dynamic Node Relationships: Automatically establish and manage relationships between nodes using fuzzy logic, enhancing data interconnectivity.
- Global State Management: Maintain a synchronized global state, dynamically updated based on node changes, user actions, and events.
- Military-grade Encryption: Protect sensitive data with AES-256 encryption for all stored documents and nodes.
- Role-based Access Control (RBAC): Manage access permissions through robust role-based control, ensuring that only authorized users can access or modify resources.
- Real-time Synchronization: Propagate changes in documents, nodes, or states across connected clients instantly using WebSocket technology (Socket.IO).
- Modular & Extensible: Built with Node.js and Docker, CephaloDB can be deployed locally or in containerized environments, offering flexibility for development and production.
Getting Started
To get started with CephaloDB, follow the installation instructions below. CephaloDB can run locally or within a Docker container, allowing for flexibility depending on your development setup.
I understand now that CephaloDB is set up to run directly using the provided server and app configuration. Here's the updated installation and running process to align with the actual setup.
Installation
CephaloDB can be installed and run locally or using Docker. You can also download it directly using npm and git. Follow the steps below based on your preferred method.
Prerequisites:
- Node.js (v14 or higher)
- npm (v6 or higher)
- Docker and Docker Compose (if using the Docker setup)
Installation Options
Option 1: Install via npm (Standalone Project)
Install CephaloDB Globally:
npm install -g cephalo-db
Set Up Environment Variables:
Create a
.env
file in your project root and add the necessary environment variables:NODE_ENV=development JWT_SECRET=your-secret-key DATABASE_URL=http://localhost:3000 IS_DOCKER=false
Run the Application Directly:
CephaloDB can be run directly using its built-in server setup. Execute the command below:
cephalodb
This command will start the application using the default configuration. The application will be accessible at
http://localhost:3000
.
Option 2: Clone the Repository (Git Method)
Clone the Repository:
git clone https://github.com/VSPaone/CephaloDB.git cd cephalodb
Install Dependencies:
npm install
Set Up Environment Variables:
Create a
.env
file in your project root:NODE_ENV=development JWT_SECRET=your-secret-key DATABASE_URL=http://localhost:3000 IS_DOCKER=false
Run the Application Locally:
npm run dev
This will start the application using Nodemon for hot reloading in development mode.
Run the Application in Production Mode:
npm start
This will run the application directly using Node.js.
Run the Application with Docker:
docker-compose up --build
This command will build and run CephaloDB using Docker containers. The application will be accessible at
http://localhost:3000
.
Option 3: Download Directly Using Git
Download CephaloDB via Git:
git clone https://github.com/VSPaone/CephaloDB.git
Navigate to the Directory:
cd cephalodb
Install Dependencies:
npm install
Set Up Environment Variables:
Create a
.env
file in your project root:NODE_ENV=development JWT_SECRET=your-secret-key DATABASE_URL=http://localhost:3000 IS_DOCKER=false
Run the Application:
Locally (Development Mode):
npm run dev
This will start the application with Nodemon for development.
Production Mode:
npm start
This will run the application using the default Node.js setup.
With Docker:
docker-compose up --build
The application will be accessible at
http://localhost:3000
.
Notes:
Ensure that the environment variables (
JWT_SECRET
,DATABASE_URL
, etc.) are correctly set up in your.env
file. These are essential for the security and configuration of CephaloDB.If you encounter any issues, check the logs using:
docker-compose logs
or when running locally:
npm run dev
Core Concepts
Document Storage
CephaloDB uses a document-based architecture, where each document can have a flexible schema and multiple nodes:
- Documents: The core units for storing data, similar to collections in MongoDB.
- Nodes: Elements within documents that can have relationships with nodes in the same or other documents.
Example: Creating, Retrieving, Updating, Deleting, Sorting, and Filtering Documents
const axios = require('axios');
// Create a new document
const newDocument = {
title: "Employee Data",
description: "Contains information about employees",
nodes: [
{ name: "John Doe", role: "Developer" },
{ name: "Jane Smith", role: "Manager" }
]
};
axios.post('http://localhost:3000/api/documents', newDocument, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Document Created:', response.data))
.catch(error => console.error('Error:', error));
// Retrieve all documents
axios.get('http://localhost:3000/api/documents', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Documents:', response.data))
.catch(error => console.error('Error:', error));
// Update a document
const updatedDocument = {
title: "Updated Employee Data",
nodes: [{ name: "John Doe", role: "Senior Developer" }]
};
axios.put('http://localhost:3000/api/documents/1', updatedDocument, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Document Updated:', response.data))
.catch(error => console.error('Error:', error));
// Delete a document
axios.delete('http://localhost:3000/api/documents/1', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Document Deleted:', response.data))
.catch(error => console.error('Error:', error));
// Sorting documents by title
axios.get('http://localhost:3000/api/documents?sort=title', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Sorted Documents:', response.data))
.catch(error => console.error('Error:', error));
// Filtering documents by role
axios.get('http://localhost:3000/api/documents?filter=role:Developer', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Filtered Documents:', response.data))
.catch(error => console.error('Error:', error));
Node Relationships
Nodes within CephaloDB can form complex relationships. CephaloDB uses fuzzy logic to establish these connections dynamically, adapting based on data changes.
Example: Establishing and Managing Node Relationships
// Create a relationship between nodes
const relationship = {
sourceNodeId: 'node1_id',
targetNodeId: 'node2_id',
relationshipType: 'reportsTo'
};
axios.post('http://localhost:3000/api/relations', relationship, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Relationship Created:', response.data))
.catch(error => console.error('Error:', error));
// Remove a relationship
axios.delete('http://localhost:3000/api/relations/relation_id', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Relationship Removed:', response.data))
.catch(error => console.error('Error:', error));
Global State Management
CephaloDB manages a synchronized global state, ensuring data consistency and synchronization across all clients and nodes.
Example: Retrieving and Updating Global State
// Fetch the global state
axios.get('http://localhost:3000/api/state', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Global State:', response.data))
.catch(error => console.error('Error:', error));
// Update the global state
const updatedState = {
maintenanceMode: true,
updatedBy: "admin_user"
};
axios.put('http://localhost:3000/api/state', updatedState, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Global State Updated:', response.data))
.catch(error => console.error('Error:', error));
Security & Encryption
CephaloDB offers AES-256 encryption for all data stored within the system, ensuring data privacy and security.
Example: Encrypting and Accessing Data
// Middleware usage for encrypting documents
app.post('/api/documents', encryptionMiddleware.encryptFile('path/to/encryptedFile'), (req, res) => {
// Document creation logic
});
Role-Based Access Control (RBAC)
RBAC enables you to define access permissions based on roles, ensuring that only authorized users have access to specific resources.
Example: Applying RBAC Middleware
app.put('/api/documents/:id', authMiddleware.authenticateToken, rbacMiddleware(['admin', 'editor']), documentController.updateDocument);
Real-time Synchronization
CephaloDB supports real-time updates and synchronization, ensuring that all connected clients have access to the latest data.
Example: Using WebSocket for Real-time Updates
const io = require('socket.io-client');
const socket = io('http://localhost:3000');
socket.on('connect', () => {
console.log('Connected to CephaloDB');
});
socket.on('documentUpdate', (data) => {
console.log('Document Updated:', data);
});
Fuzzy Logic Engine
CephaloDB uses a fuzzy logic engine to establish dynamic relationships between nodes based on patterns, similarity, and predefined rules. The fuzzy logic engine analyzes documents and nodes to automatically detect and create connections that reflect real-world relationships, even when the data may not be explicitly defined.
This allows CephaloDB to adapt and evolve its data structures, enabling powerful automation and pattern recognition capabilities.
Example: Using the Fuzzy Logic Engine to Establish Relationships
Suppose you have a set of employee records, and you want CephaloDB to automatically identify relationships between employees based on their roles, projects, or departments. The fuzzy logic engine can identify these patterns and establish connections dynamically.
const document = {
title: "Project Team",
description: "Details about team members and their roles",
nodes: [
{ id: "node1", name: "Alice", role: "Developer", project: "Alpha" },
{ id: "node2", name: "Bob", role: "Manager", project: "Alpha" },
{ id: "node3", name: "Charlie", role: "Developer", project: "Beta" }
]
};
// Post the document to create nodes
axios.post('http://localhost:3000/api/documents', document, { headers: { Authorization: 'Bearer <token>' } })
.then(response => {
console.log('Document Created:', response.data);
// Trigger fuzzy logic processing
axios.post('http://localhost:3000/api/relations/fuzzy', { documentId: response.data.id }, { headers: { Authorization: 'Bearer <token>' } })
.then(relResponse => console.log('Fuzzy Logic Relationships Established:', relResponse.data))
.catch(err => console.error('Fuzzy Logic Error:', err));
})
.catch(error => console.error('Error:', error));
In this example:
- A document containing nodes for team members is created.
- The fuzzy logic engine is then triggered to process the document, automatically identifying relationships like:
- Developers working on the same project might be linked as colleagues.
- Managers and developers on the same project might be linked as supervisors.
Advanced Example: Custom Fuzzy Logic Rules
CephaloDB allows you to define custom fuzzy logic rules to enhance its automation capabilities. These rules can be used to fine-tune how relationships are established based on specific conditions.
const customFuzzyRules = {
conditions: [
{ field: "role", operator: "equals", value: "Manager" },
{ field: "project", operator: "equals", value: "Alpha" }
],
actions: [
{ type: "link", relationshipType: "manages", targetField: "project" }
]
};
// Post custom rules to the fuzzy logic engine
axios.post('http://localhost:3000/api/relations/fuzzy/rules', customFuzzyRules, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Custom Fuzzy Rules Applied:', response.data))
.catch(error => console.error('Error Applying Fuzzy Rules:', error));
In this example:
- The conditions specify that if a node's role is "Manager" and they are assigned to the "Alpha" project, the fuzzy logic engine will create a manages relationship with all nodes sharing the same project.
- You can customize the rules based on any field and define complex conditions (e.g., matching multiple fields with various operators like equals, contains, greater than, etc.).
Monitoring Fuzzy Logic Events
The fuzzy logic engine logs events and can notify clients in real-time when new relationships are established or modified.
const io = require('socket.io-client');
const socket = io('http://localhost:3000');
socket.on('fuzzyLogicUpdate', (data) => {
console.log('Fuzzy Logic Update:', data);
});
This example sets up a WebSocket listener for fuzzy logic updates, allowing you to monitor when the system automatically modifies relationships based on new data or changes.
API Reference
Document APIs
- GET /api/documents: Retrieve all documents, with optional query parameters for filtering and sorting.
- POST /api/documents: Create a new document with a set of nodes.
- PUT /api/documents/:id: Update an existing document.
- DELETE /api/documents/:id: Delete a document by its ID.
Relationship APIs
- POST /api/relations: Manually create a relationship between two nodes.
- POST /api/relations/fuzzy: Trigger the fuzzy logic engine to analyze a document and establish relationships.
- POST /api/relations/fuzzy/rules: Define custom fuzzy logic rules.
- DELETE /api/relations/:id: Remove a relationship.
State APIs
- GET /api/state: Retrieve the current global state of the application.
- PUT /api/state: Update the global state.
Comprehensive Usage Examples
1. Managing Documents
CephaloDB provides robust capabilities for document management, including sorting, filtering, and complex queries.
Example: Sorting and Filtering
// Retrieve documents sorted by title in ascending order
axios.get('http://localhost:3000/api/documents?sort=title:asc', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Sorted Documents:', response.data))
.catch(error => console.error('Error:', error));
// Filter documents where role contains "Developer"
axios.get('http://localhost:3000/api/documents?filter=role:Developer', { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Filtered Documents:', response.data))
.catch(error => console.error('Error:', error));
2. Establishing Complex Relationships Using Fuzzy Logic
The fuzzy logic engine enables automatic relationship creation based on predefined rules.
Example: Auto-Relate Based on Multiple Fields
const ruleSet = {
conditions: [
{ field: "department", operator: "equals", value: "Engineering" },
{ field: "experience", operator: "greaterThan", value: 5 }
],
actions: [
{ type: "link", relationshipType: "mentor", targetField: "department" }
]
};
// Apply fuzzy logic rules for mentorship relationships
axios.post('http://localhost:3000/api/relations/fuzzy/rules', ruleSet, { headers: { Authorization: 'Bearer <token>' } })
.then(response => console.log('Custom Fuzzy Logic Rules Applied:', response.data))
.catch(error => console.error('Error:', error));
This setup defines a rule where if an employee in the Engineering department has more than 5 years of experience, they are automatically linked as a mentor to other employees in the same department.
3. Real-time Updates and Event Monitoring
CephaloDB’s WebSocket integration allows real-time data synchronization across connected clients.
Example: Listening for Real-time Changes
const socket = io('http://localhost:3000');
// Listen for document updates
socket.on('documentUpdate', (data) => {
console.log('Document Updated:', data);
});
// Listen for fuzzy logic changes
socket.on('fuzzyLogicUpdate', (data) => {
console.log('Fuzzy Logic Update:', data);
});
// Listen for global state changes
socket.on('stateChange', (data) => {
console.log('Global State Change:', data);
});
This example sets up listeners for different events, allowing clients to stay in sync with changes in the database, relationships, and global state.
More examples
Contributing
We welcome contributions to CephaloDB. To contribute:
- Fork the repository.
- Create a new branch for your feature or bug fix.
- Submit a pull request with a clear description of the changes.
Development Setup
- Run
npm install
to install dependencies. - Use
npm run dev
for local development. - Run tests (coming soon) using
npm test
.
License
CephaloDB is licensed under the CephaloDB Non-Commercial License. You are permitted to use, copy, modify, and distribute this software for non-commercial purposes only. For commercial usage, please contact [email protected] for licensing options.
See the LICENSE file for more details.