data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
[data:image/s3,"s3://crabby-images/9d253/9d253843062204b11be9bf60e7881525b32572b4" alt="codecov"](https://codecov.io/gh/yog27ray/sqns)
#Introduction SQNS is a Simple Queue and Notification Service. It manages processing of queues and notification due to various events and subscriptions in distributed system. This service can be divided into following sections.
This project has been inspired from AWS SQS and AWS SNS. This is an extension of the existing AWS SQS and AWS SNS with some more functionality add that we felt were lagging.
Queue management is a distributed multiple priority queue processing system. This is divided into two part Manager and Workers. Manager collects all the events sent via different channels. Worker requests events from Manager to process them. There can be only one Manager, but many Workers.
import { SQNS } from 'sqns';
const dataBaseConnectionConfig = {};
const sqns = new SQNS({
endpoint: 'http://your.server.url/api',
adminSecretKeys: [{ accessKey: 'yourKey', secretAccessKey: 'yourSecretKey' }],
db: { uri: 'DatabaseUri', config: dataBaseConnectionConfig },
sns: { // optional
disabled: true // disable SNS service initialization.
},
});
sqns.registerExpressRoutes(app);
import { SQNSClient } from 'sqns';
const sqnsClient = new SQNSClient({
endpoint: 'http://your.server.url/api',
accessKeyId: 'yourKey',
secretAccessKey: 'yourSecretKey',
});
sqnsClient.createQueue({ QueueName: 'queueName' }).then(queue => {});
sqnsClient.sendMessage({ QueueUrl: queue.QueueUrl, MessageBody: '123' });
client.receiveMessage({ QueueUrl: queue.QueueUrl, MaxNumberOfMessages: 1 })
.then(response => {
const message = response.Messages[0]
});
Either you can use the SQNSClient support to add the event in the queue or use ManagerEventScheduler to fetch events and add them into the queue periodically. ManagerEventScheduler constructor requires below parameters.
import { ManagerEventScheduler } from 'sqns';
...
new ManagerEventScheduler(
{
endpoint: 'http://xyz.abz/api', // Master Server address
accessKeyId: 'accessKey',
secretAccessKey: 'secretKey',
},
{ 'queueName': { page: 0 } },
(params) => {
const items = []// request events to be added in the queue
const eventItems = items.map(each => {
const requestItem = {
MessageBody: each.message,
DelaySeconds: 10, // optional
MessageAttributes: { attribute1: { StringValue: 'value1', DataType: 'String' } }, // optional
MessageSystemAttributes: { attribute1: { StringValue: 'value1', DataType: 'String' } }, // optional
MessageDeduplicationId: each.duplicationId, // optional
};
return requestItem;
});
return [{ "page": params.page + 1 }, eventItems];
},
'*/10 * * * * *');
Either you can use SimpleQueueServerClient support to fetch the event from Manager Server or use WorkerEventScheduler to fetch events and process them periodically. WorkerEventScheduler constructor requires below parameters
import { WorkerEventScheduler } from 'sqns';
...
new WorkerEventScheduler(
{
endpoint: 'http://xyz.abz/api', // Master Server address
accessKeyId: 'accessKey',
secretAccessKey: 'secretKey',
},
["queueName"],
(queueName, item) => {
// process eventItem
},
'0 * * * *');
Notification Management deals with passing one published event to many subscribed links. This uses the Queue Management module for passing published events to its subscribers.
import { SQNS } from 'sqns';
const dataBaseConnectionConfig = {};
const sqns = new SQNS({
endpoint: 'http://your.server.url/api',
adminSecretKeys: [{ accessKey: 'yourKey', secretAccessKey: 'yourSecretKey' }],
db: { uri: 'DatabaseUri', config: dataBaseConnectionConfig },
});
sqns.registerExpressRoutes(app);
import { WorkerEventScheduler } from 'sqns';
...
new WorkerEventScheduler(
{
endpoint: 'http://xyz.abz/api', // Master Server address
accessKeyId: 'accessKey',
secretAccessKey: 'secretKey',
},
["sqns"], // SNS queue name
(queueName, item) => {
// process eventItem
},
'0 * * * *');
client.createTopic({ Name: 'Topic1' })
.then(topic => {})
client.publish({ Message: 'This is message' })
sqnsClient.createQueue({
QueueName: 'queueName',
Attributes: { attribute1: 'value1' }, // optional
tags: { tag1: 'value2'}, // optional
}).then(queue => {});
client.createQueue({ ..., Attributes: { maxReceiveCount: '2' } });
client.sendMessage({
QueueUrl: queue.QueueUrl,
MessageAttributes: { // optional
attribute1: {
StringValue: 'value1',
DataType: 'String'
}
},
MessageSystemAttributes: { // optional
attribute1: {
StringValue: 'attributeValue',
DataType: 'String'
}
},
MessageDeduplicationId: 'uniqueId1', // optional: message unique Id to avoid duplication of message.
MessageBody: 'This is message body',
});
client.sendMessageBatch({
QueueUrl: queue.QueueUrl,
Entries: [
{
Id: '123', // Entry id for the request. Should be unique in one call.
MessageAttributes: { // optional
attribute1: {
StringValue: 'value1',
DataType: 'String'
}
},
MessageSystemAttributes: { // optional
attribute1: {
StringValue: 'attributeValue',
DataType: 'String'
}
},
MessageDeduplicationId: 'uniqueId1', // optional: message unique Id to avoid duplication of message.
MessageBody: 'This is message body',
},
],
});
client.receiveMessage({
QueueUrl: queue.QueueUrl,
AttributeNames: ['attributeValue'], // optional: Array of attribute name to include. ALL to add all attributes
MessageSystemAttributes: ['ALL'], // optional: Array of attribute name to include. ALL to add all attributes
MaxNumberOfMessages: 10, // optional: number of messages to fetch in one call
VisibilityTimeout: 30, // optional: message not available for next 30 seconds to retry.
}).then(response => {
const MessageId = response.Messages[0].MessageId;
});
client.listQueues({
QueueNamePrefix: 'queuePrefix', // optional: queueName prefix to find list of queues
NextToken: 'nextQuestToken', // optional: token from previous listQueue request.
})
client.deleteQueue({ QueueUrl: queue.QueueUrl });
client.getQueueUrl({ QueueName: 'queueName' });
client.markEventSuccess(MessageId, queue.QueueUrl, 'success message');
client.markEventFailure(MessageId, queue.QueueUrl, 'success message');
client.createTopic({
Name: 'Topic1', // topic name
Attributes: { DisplayName: 'Topic One' }, // optional
Tags: [{ Key: 'tag1', Value: 'value1' }], // optional
}).then(topic => {});
client.listTopics({
NextToken: 'nextToken' // optinal
})
client.getTopicAttributes({ TopicArn: topic.TopicArn })
client.setTopicAttributes({
TopicArn: topic.TopicArn,
AttributeName: 'DisplayName',
AttributeValue: 'Updated Topic One',
})
client.deleteTopic({ TopicArn: topic.TopicArn });
client.publish({
Message: 'This is message',
TopicArn: topic.TopicArn, // TopicArn Or TargetArn is required
TargetArn: topic.TopicArn, // TopicArn Or TargetArn is required
MessageAttributes: { key1: { DataType: 'String', StringValue: 'value' } }, // optional
})
client.subscribe({
TopicArn: topic.TopicArn,
Attributes: { key: 'value' }, // optional
Endpoint: 'http://your.server.subscription/url', // subscription url
Protocol: 'http', // http or https
ReturnSubscriptionArn: true, // optional
}).then(result => {
const SubscriptionArn = result.SubscriptionArn;
})
client.listSubscriptions({
NextToken: 'NextToken' // optional
})
client.listSubscriptionsByTopic({
TopicArn: topic.TopicArn,
NextToken: 'NextToken' // optional
});
client.confirmSubscription({
TopicArn: 'topicArn',
Token: 'verificationToken',
});
client.unsubscribe({ SubscriptionArn: 'subscriptionArn' });
client.getPublish({ MessageId: 'MessageId' })
client.getSubscription({ SubscriptionArn: 'subscriptionArn' })
client.markPublished({ MessageId: 'MessageId' })
FAQs
data:image/s3,"s3://crabby-images/ffdbb/ffdbbb8031a294e6c2999115762f6361e0a379cd" alt="build" [data:image/s3,"s3://crabby-images/9d253/9d253843062204b11be9bf60e7881525b32572b4" alt="codecov"](https://codecov.io/gh/yog27ray/sqns)
We found that sqns demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.