summaryrefslogtreecommitdiffstats
path: root/API_STANDARDS.md
blob: 469fef585d8054569c44c94f39c77588bffd4464 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
Coding Standards and Practices
==============================

This is not meant to be a style document so much as a practices document for ensuring performance and convention in the Ansible Tower API.

Paginate Everything
===================

Anything that returns a collection must be paginated.

Assume large data sets
======================

Don't test exclusively with small data.  Assume 1000-10000 hosts in all operations, with years of event data.

Some of our users have 30,000 machines they manage.

API performance
===============

In general, the expected response time for any API call is something like 1/4 of a second or less.  Signs of slow API
performance should be regularly checked, particularly for missing indexes.

Missing Indexes
===============

Any filters the UI uses should be indexed.

Migrations
==========

Always think about any existing data when adding any new fields.  It's ok to wait in upgrade time to get the database to be 
consistent.

Limit Queries
=============

The number of queries made should be constant time and must not vary with the size of the result set.

Consider RBAC
=============

The returns of all collections must be filtered by who has access to view them, without exception

Discoverability
===============

All API endpoints must be able to be traversed from "/", and have comments, where possible, explaining their purpose

Friendly Comments
=================

All API comments are exposed by the API browser and must be fit for customers.   Avoid jokes in API comments and error
messages, as well as FIXME comments in places that the API will display.

UI Sanity
=========

Where possible the API should provide API endpoints that feed raw data into the UI, the UI should not have to do lots of
data transformations, as it is going to be less responsive and able to do these things.

When requiring a collection of times of size N, the UI must not make any extra API queries for each item in the result set

Effective Usage of Query Sets
=============================

The system must return Django result sets rather than building JSON in memory in nearly all cases.  Use things like
exclude and joins, and let the database do the work.

Serializers
===========

No database queries may be made in serializers because these are executed once per item, rather than paginated.

REST verbs
==========

REST verbs should be RESTy.  Don't use GETs to do things that should be a PUT or POST.

Unit tests
==========

Every URL/route must have unit test coverage.  Consider both positive and negative tests.