Skip to content

Instantly share code, notes, and snippets.

View AjayPoshak's full-sized avatar

Ajay Poshak AjayPoshak

View GitHub Profile
@AjayPoshak
AjayPoshak / docker-compose.yml
Created July 6, 2024 12:01
Docker compose setup for Elasticsearch and Kibana
services:
elasticsearch:
image: docker.elastic.co/elasticsearch/elasticsearch:8.14.1
container_name: elasticsearch
ports:
- "9200:9200"
- "9300:9300"
environment:
- discovery.type=single-node
- xpack.security.enabled=false
@AjayPoshak
AjayPoshak / controller.ts
Created May 15, 2023 15:21
Streaming file from S3 NestJS
@Get(':hash')
@Header('Content-Type', 'image/png')
async getActiveImageByHash(
@Param('hash') hash: string,
@Res() response: Response,
): Promise<any> {
const res = await this.usersService.getActiveImageByHash(hash);
// Connect to s3
const client = new S3Client({
region: REGION,
// This is an example of Dijkstra's algorithm. https://leetcode.com/problems/network-delay-time/
function createAdjList(edges, n) {
const adjList = new Map()
for(let i=0; i<n; i++) adjList.set(i, [])
for(let i=0; i<edges.length; i++) {
const [from, to, weight] = edges[i]
const neighbors = adjList.get(from)
neighbors.push({ node: to, weight })
adjList.set(from, neighbors)
}
function MinHeap() {
this.arr = new Array()
}
MinHeap.prototype.push = function push(data, weight) {
this.arr.push({ data, weight })
if(this.arr.length <= 1) return
let current = this.arr.length - 1
let parent = Math.floor(current/2)
@AjayPoshak
AjayPoshak / newFunction.js
Created July 1, 2019 14:05
Function to implement new keyword
function newFunction(funcName, args) {
// Copy the function prototype to object
let obj = Object.create(funcName.prototype)
// Call constructor function with supplied arguments, and assign this to newly created object
funcName.call(obj, args)
// return newly created object
return obj
}
const path = require('path'),
webpack = require('webpack'),
AssetsPlugin = require('assets-webpack-plugin'),
BrotliPlugin = require('brotli-webpack-plugin'),
HtmlWebpackPlugin = require('html-webpack-plugin'),
UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const isProd = process.env.NODE_ENV === 'production';
/**
...
optimization: {
splitChunks: {
cacheGroups: {
commons: {
test: /[\\/]node_modules[\\/]/,
name: 'vendors',
chunks: 'all'
}
}
...
plugins: [
new BrotliPlugin({
asset: '[path].br[query]',
test: /\.(js|css|html|svg)$/,
threshold: 10240,
minRatio: 0.8
})
],
...
...
devtool: '', // Removed dev-tools mapping
entry: './client/index.js',
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'build/client'),
publicPath: 'build/client'
},
...
@AjayPoshak
AjayPoshak / webpack.config.js
Last active July 14, 2018 15:02
Initial webpack config
const path = require('path'),
AssetsPlugin = require('assets-webpack-plugin'),
HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
devtool: 'inline-source-map',
entry: './client/index.js',
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'build/client'),