Slide 1

Slide 1 text

Entities Entities The Theory The Theory

Slide 2

Slide 2 text

Who am I Working for over 3 years on Node.js Authored >40 NPM packages Contributed to even more CTO Insight Replay Founder netscan.co @thanpolas

Slide 3

Slide 3 text

The MVC bankruptcy The MVC bankruptcy @thanpolas

Slide 4

Slide 4 text

Models represent a schema Models are FAT Business logic leaks to Controllers Handling of higher level operations MVC is not enough today The MVC bankruptcy The MVC bankruptcy @thanpolas

Slide 5

Slide 5 text

Active Record (Single Table) Validations Relations Methods (db related) It's an ORM configuration The MVC bankruptcy The MVC bankruptcy Models represent a schema Models represent a schema @thanpolas

Slide 6

Slide 6 text

You gotta see it to believe it Ok, I bet you've seen it! It's ugly It's not entirely the Model's fault Decouple The Model bankruptcy The Model bankruptcy Models are FAT (core models > 4k lines) Models are FAT (core models > 4k lines) @thanpolas

Slide 7

Slide 7 text

Send verification email Perform multiple table OPs Talk to services ​memcache pupsub redis The MVC bankruptcy The MVC bankruptcy Business logic leaks to Controllers Business logic leaks to Controllers @thanpolas

Slide 8

Slide 8 text

The MVC bankruptcy The MVC bankruptcy Business logic leaks to Controllers Business logic leaks to Controllers How do you run the operation from a Cron Job? Back office? API? CLI? How do you test? @thanpolas

Slide 9

Slide 9 text

Multiple tables involved Multiple Services involved Complex Auth Schemes Real Time The MVC bankruptcy The MVC bankruptcy Handling of higher level operations Handling of higher level operations @thanpolas

Slide 10

Slide 10 text

Way more complex flows Service oriented design SaaS / PaaS Infrastructure Multiple inputs The MVC bankruptcy The MVC bankruptcy MVC is not enough today MVC is not enough today @thanpolas

Slide 11

Slide 11 text

Ok, now what? Ok, now what? @thanpolas

Slide 12

Slide 12 text

Decouple Decouple Separate Separate Draw Lines Draw Lines @thanpolas

Slide 13

Slide 13 text

Meet Meet MVCe MVCe @thanpolas

Slide 14

Slide 14 text

@thanpolas

Slide 15

Slide 15 text

Think of Entities as... Think of Entities as... Pipes Data transformers Operation plexers Switches Adaptors Aggregators Entities are inspired by the Service Layer design pattern @thanpolas

Slide 16

Slide 16 text

Core Principles Core Principles Human readable API Normalised Input Normalised Output @thanpolas

Slide 17

Slide 17 text

Core Principles Core Principles Human readable API Human readable API userEnt.create(udo); userEnt.delete(uid); userEnt.sendMessage(fromId, toId, message); videoEnt.process(videoPath); Methods that make sense Think action not operation @thanpolas

Slide 18

Slide 18 text

Core Principles Core Principles Normalised Input Normalised Input userEnt.create({ firstName: "Thanasis", lastName: "Polychronakis", email: "thanpolas@gmail.com", }); Well documented expectations No need to be validated @thanpolas

Slide 19

Slide 19 text

Core Principles Core Principles Normalized Output Normalized Output console.log(udoOut); { "id": "3kdp349r7fhw", "firstName": "Thanasis", "lastName": "Polychronakis", "email": "thanpolas@gmail.com", } Aggregates datasets Normalizes db idiomacies Consistency @thanpolas

Slide 20

Slide 20 text

CRUD API CRUD API @thanpolas

Slide 21

Slide 21 text

The CRUD Primitives The CRUD Primitives create() read() readOne() readLimit() update() delete() count() @thanpolas

Slide 22

Slide 22 text

it depends™ it depends™ Validations Validations @thanpolas

Slide 23

Slide 23 text

Validations Validations Is there an ORM CRUD OP? Perform actions before or after ORM? Do you trust your input? Outside world? Internal invocation? Better not to trust anybody @thanpolas

Slide 24

Slide 24 text

NO NO Are entities only for Are entities only for the backend? the backend? @thanpolas

Slide 25

Slide 25 text

REMEMBER REMEMBER Entities are Entities are Normalizers Aggregators Pipes Your business logic @thanpolas