How to Write a Statement of Work That Protects Both Sides
by Eric Hanson, Backend Developer at Clean Systems Consulting
A good statement of work does not just protect the contractor. It gives the client clarity, reduces their anxiety, and prevents the misunderstandings that destroy otherwise good engagements.
What a Statement of Work Actually Is
A statement of work (SOW) is a written document that describes what is being built, what is not being built, how success is defined, and the timeline and fee structure. It is different from a contract — a contract governs the legal relationship, an SOW governs the work itself.
Used together, they cover both dimensions of a professional engagement: the legal and the operational. Used separately, both leave gaps.
Most contractor disputes — about scope, about payment, about timelines — happen because one or both of these documents did not exist or was too vague to be useful.
What to Put In It
Project overview. A brief description of the project and its purpose. This is not for your benefit — it is to confirm that both parties are working from the same understanding of what this project is and why it exists.
In-scope deliverables. A specific, itemized list of what is included. For a backend project, this might include: the specific API endpoints and their behavior, the integrations included, the data models, the testing requirements, the deployment target. Each item should be specific enough that both parties could look at the finished work and independently determine whether it was delivered.
Out-of-scope items. Equally important. What is explicitly not included. Mobile SDK, admin dashboard, multi-region deployment, performance optimization beyond baseline requirements. The out-of-scope list is the first line of defense against scope creep.
Acceptance criteria. How will both parties know when the work is done? For backend contractors, this typically includes: the API endpoints responding as documented, unit test coverage above a specified threshold, integration tests passing against the specified external services, code reviewed and merged to the agreed branch.
Assumptions and dependencies. "This work assumes the client will provide test API credentials for the payment gateway within five business days of project start." "This assumes the existing database schema is stable and will not change during the engagement." Unstated assumptions are where scope disputes are born.
Timeline and milestones. When will the work be complete? What are the intermediate milestones if applicable? What happens to the timeline if a client dependency is delayed?
Fee and payment schedule. How much, when invoiced, when due, what deposit is required.
The Language That Makes It Useful
A statement of work that uses vague language — "comprehensive backend system," "complete integration," "all necessary features" — is not much better than no SOW at all.
Useful language is specific and testable:
- "Three RESTful API endpoints as documented in the attached API spec" — not "the relevant API endpoints."
- "Integration with Stripe's payment intent and subscription APIs" — not "payment integration."
- "Unit test coverage of 80% or above for all business logic" — not "adequate testing."
If you cannot write a sentence that a client could check against the delivered work, the sentence is too vague.
How to Present It to the Client
The SOW is not a legal document that appears threatening at signing. Frame it as a shared planning document:
"Before we start, I want to put together a brief statement of work so we're both clear on what's included and what the timeline looks like. It helps us both avoid surprises."
That framing is honest and positions the SOW as something that benefits both parties — which it does.
Clients who push back on the idea of a written scope document for a significant project are a yellow flag. Most professional clients view it as standard practice.
The statement of work is the shared language of an engagement — without it, both parties are operating from a different script and hoping the story matches.