interfaces/readme.md

162 lines
5.2 KiB
Markdown
Raw Normal View History

# @social.io/interfaces
An interface package for social.io.
2020-09-14 09:43:39 +00:00
## Install
To install the `@social.io/interfaces` package, you can use npm. Make sure you have Node.js installed, then run the following command in your terminal:
2020-09-14 09:43:39 +00:00
```bash
npm install @social.io/interfaces
```
2020-09-14 09:43:39 +00:00
This will fetch the latest package from the npm registry and add it to your project's dependencies.
2020-09-14 09:43:39 +00:00
## Usage
The `@social.io/interfaces` package provides a set of interfaces to be used with the social.io application, designed to standardize the communication and data exchange within the application. To effectively use this package, it's recommended to employ TypeScript, which provides advanced features like intellisense and type safety, promoting a better development experience.
2020-09-14 09:43:39 +00:00
### Setting Up Your Project
2020-09-14 09:43:39 +00:00
Firstly, ensure that you set up your project to work with ES Modules and optionally TypeScript. If you are working with JavaScript, ensure your `package.json` file contains the line `"type": "module"`. For TypeScript, you might want to add configuration in `tsconfig.json` as follows:
```json
{
"compilerOptions": {
"module": "ESNext",
"target": "ESNext",
"moduleResolution": "Node",
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"strict": true
}
}
```
### Importing Interfaces
The package exports various interfaces for managing social.io data and operations. You can import them using:
```typescript
import {
ISioConversation,
ISioSession,
IRequest_GetSocialSession,
IRequest_AttachProfileId,
IRequest_GetConversations
} from '@social.io/interfaces';
```
### Managing Sessions
The package provides an interface `IRequest_GetSocialSession` which models a request to get a social session. This can be useful when you need to manage user sessions:
```typescript
const getSessionRequest: IRequest_GetSocialSession = {
method: 'getSocialSession',
request: {
existingSessionId: 'currentSessionId123'
},
response: {
newSessionId: 'newSessionId456'
}
};
// Utilize getSessionRequest in your session management logic
```
This follows a pattern of detailing a request/response structure, allowing you to handle sessions more seamlessly.
### Attaching Profile IDs
The interaction with user profiles is essential in most social applications. Use `IRequest_AttachProfileId` to attach a profile to a session:
```typescript
const attachProfileRequest: IRequest_AttachProfileId = {
method: 'attachProfileId',
request: {
sessionId: 'newSessionId456',
profileId: 'userProfileId789'
},
response: {
newSessionId: 'updatedSessionId012'
}
};
// Implement logic to leverage attachProfileRequest for profile operations
```
These types ensure strict adherence to your backend contract, reducing runtime errors and improving code quality.
### Handling Conversations
Conversations are a critical part of any social platform. The package defines various interfaces to accommodate complex conversation structures:
```typescript
const conversation: ISioConversation = {
subject: 'Chat about TypeScript best practices',
parties: [
{ id: 'user1', name: 'Alice', description: 'TypeScript enthusiast' },
{ id: 'user2', name: 'Bob', description: 'Node.js guru' }
],
conversationBlocks: [
{ partyId: 'user1', text: 'I love using TypeScript with Node.js!' },
{ partyId: 'user2', text: 'Same here! It makes development so much safer and robust.' }
]
};
// These conversations can be leveraged in your business logic to create engaging user experiences
```
This interface allows for a detailed conversational structure including multiple participants and conversation blocks.
### Extending Sessions and Conversations
For further extensions, the `ISioSession` interface is key, providing session-level information like tenant IDs, activity status, and user profiles:
```typescript
const session: ISioSession = {
tenantId: 'socialTenant123',
active: true,
abandoned: false,
markedForDeletion: false,
profileInfo: {
profileId: 'profileId1234',
name: 'Alice Johnson',
email: 'alice@example.com',
mobilePhone: '+1234567890'
},
conversations: [conversation]
};
// Handle session operations and data management through this detailed session structure
```
This level of detail in interfaces encourages robust software design by promoting thorough type usage and better communication through shared types.
### Requests Pattern
The package uses a consistent pattern by inheriting from a base typed request interface, promoting consistency and reusability:
```typescript
import * as plugins from '@social.io/interfaces';
export interface IRequest_GetArrayExample
extends plugins.typedrequestInterfaces.implementsTR<
plugins.typedrequestInterfaces.ITypedRequest,
IRequest_GetArrayExample
> {
method: 'getArrayExample';
request: {
itemCount: number;
};
response: {
items: Array<string>;
};
}
```
Such patterns simplify request and response management due to their predictability and standardization across different modules.
By following these patterns, you can build scalable, maintainable, and highly reliable applications centered around the social.io interfaces. Always remember to check the comprehensive module documentation and integrate the above interfaces into your TypeScript-first, node-based projects.
undefined