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.
- Features
- Getting Started
- Installation
- Core Concepts
- API Reference
- Comprehensive Usage Examples
- Contributing
- License
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.
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.
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)
-
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
.
-
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
.
-
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
.
-
-
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
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.
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));
Nodes within CephaloDB can form complex relationships. CephaloDB uses fuzzy logic to establish these connections dynamically, adapting based on data changes.
// 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));
CephaloDB manages a synchronized global state, ensuring data consistency and synchronization across all clients and nodes.
// 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));
CephaloDB offers AES-256 encryption for all data stored within the system, ensuring data privacy and security.
// Middleware usage for encrypting documents
app.post('/api/documents', encryptionMiddleware.encryptFile('path/to/encryptedFile'), (req, res) => {
// Document creation logic
});
RBAC enables you to define access permissions based on roles, ensuring that only authorized users have access to specific resources.
app.put('/api/documents/:id', authMiddleware.authenticateToken, rbacMiddleware(['admin', 'editor']), documentController.updateDocument);
CephaloDB supports real-time updates and synchronization, ensuring that all connected clients have access to the latest data.
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);
});
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.
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.
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.).
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.
- 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.
- 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.
- GET /api/state: Retrieve the current global state of the application.
- PUT /api/state: Update the global state.
CephaloDB provides robust capabilities for document management, including sorting, filtering, and complex queries.
// 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));
The fuzzy logic engine enables automatic relationship creation based on predefined rules.
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.
CephaloDB’s WebSocket integration allows real-time data synchronization across connected clients.
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.
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.
- Run
npm install
to install dependencies. - Use
npm run dev
for local development. - Run tests (coming soon) using
npm test
.
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.