Skip to content

Instantly share code, notes, and snippets.

View zmts's full-sized avatar
🇺🇦
russian warship go f*uck yourself

Sasha Zmts zmts

🇺🇦
russian warship go f*uck yourself
View GitHub Profile
@zmts
zmts / Gallery_Photo.md
Last active November 13, 2020 01:42
Создание Альбома, загрузка фото
@zmts
zmts / cascade_remove.md
Last active November 13, 2020 01:38
Каскадное удаление. SQL/PostgreSQL

Каскадное удаление(SQL/PostgreSQL)

Дано:

Есть Две таблицы(articles и tags), отношения многое ко многому + соотвественно связующая таблица(articles_tags). Необходимо удалить некую строку из articles но эта строка имеет отношение к другой строке из второй таблицы tags.

Проблема:

База ругается что удаляемая новость имеет связи в связующей таблице articles_tags

Решение:

В таблице articles_tags нужно установить каскадное поведение при удалении, для FK который ссылается на таблицу articles

@zmts
zmts / create_folders_Promises.md
Last active November 13, 2020 01:38
Create folders via Promises in Node.js

Create folders via Promises in Node.js

First case

var mz =require('mz/fs'); // promisificated fs
var fsp = require('fs-promise'); // extended promisificated fs

Album.create1 = function () {
    return mz.readdir(PHOTOS_FOLDER)
        // ensure folder_name exist, if not create
@zmts
zmts / pagination.md
Last active November 13, 2020 01:38

Пагинация

Реализация происходит по средствам Бесконечного скрола

Use case:

  • Юзер пролистал страничку до половины
    • Система в фоне подгружает вторую страничку
      • Юзер пролистал страничку до конца
        • Система отображает уже загруженную вторую страничку
        • Добаляет хеш с номером странички в URL
  • Отображает номер странички в UI
@zmts
zmts / tokens.md
Last active May 31, 2024 14:58
Про токены, JSON Web Tokens (JWT), аутентификацию и авторизацию. Token-Based Authentication

Про токены, JSON Web Tokens (JWT), аутентификацию и авторизацию. Token-Based Authentication

Last major update: 25.08.2020

  • Что такое авторизация/аутентификация
  • Где хранить токены
  • Как ставить куки ?
  • Процесс логина
  • Процесс рефреш токенов
  • Кража токенов/Механизм контроля токенов
// https://github.com/felixge/node-formidable
function formidablePromise (req, opts) {
return new Promise(function (resolve, reject) {
var form = new formidable.IncomingForm(opts)
form.parse(req, function (err, fields, files) {
if (err) return reject(err)
resolve({ fields: fields, files: files })
}
})
@zmts
zmts / MulterUnexpectedField.md
Last active November 13, 2020 01:38
Node.js Multer unexpected field

Столкунлся с ошибкой при загрузке файлов. Файл загружал через Postman

Error: Unexpected field
    at makeError (.../node_modules/multer/lib/make-error.js:12:13)

Решение: Имя значение параметра на сервере должно соответствовать имени филда в котором приходит файл с клиента

upload.single('cover_index')
@zmts
zmts / batchUpload.md
Last active November 13, 2020 01:38
Фича: Пакетная загрузка фотографий в альбом

Пакетная загрузка фотографий:

BAD

  • Юзер выбирает определенное количество изображений (100-200 фотографий)
  • Клиент отравляет этот массив на сервер
  • Сервер принимает, загружает массив фотографий в нужную папку
  • Сервер процессит каждую фото (создает тумбинахи)
  • Создает записи в БД для каждой

GOOD

@zmts
zmts / PUTvsPOSTvsPATCH.md
Last active October 1, 2020 07:14
PUT or POST or PATCH?

PUT or POST or PATCH? PATCH!

TL;DR

POST для создания новых ресурсов
POST для остальных кастомных глаголов
PATCH для обновления ресурсов. В 99,99% на обновление уходят не все поля ('created_at' и 'updated_at' так точно)
На PUT можно забить =)
@zmts
zmts / index.html
Last active March 30, 2017 16:52
Dotted font effect (via CSS)
<!-- demo http://codepen.io/rqnix/pen/mWQEQM -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<link href="https://fonts.googleapis.com/css?family=Anton" rel="stylesheet">
<title>Document</title>
</head>
<body>