In this guide, we will setup our system to run docassemble without using the playground or a server.
This allows us to use a regular text editor, save our work so we can collaborate on interviews with colleagues and we get an easier way to use MS docx templates with docassemble.
At the end of this guide, you will be able to design an interview this way:
data:image/s3,"s3://crabby-images/6df80/6df8075a71d671b2f4b1c083afb44c2a582f7a2e" alt="Setup Docassemble Document Automation Locally 1 Running docassemble locally"
Requirements to install docassemble on your system
First, confirm your system has these minimum requirements:
- It meets the minimum requirement to install the app, docker
- You have a stable internet connection. Some of the apps you will download and install through this process are heavy.
If you’re good with this, let’s get into the steps.
Install docker for docassemble
Docker is like a computer within your computer. It allows you to run an application that you won’t otherwise be able to install and run on your computer.
Let’s install it:
Go to docker’s website and download the proper version for your operating system. Through the rest of this guide, I will use Windows.
When the download is complete, we’ll run the installation file. I’m starting from this point:
data:image/s3,"s3://crabby-images/20f3f/20f3f70fbec6d5dbcd3897b8463c3accddf76b95" alt="Setup Docassemble Document Automation Locally 2 Download docker to desktop"
As I open it, I get this notification:
data:image/s3,"s3://crabby-images/21445/21445c5e758bc8a6af1a25b413beb67bacd343fb" alt="Setup Docassemble Document Automation Locally 3 Allow device modification"
Continue the rest of the install. Accept all the default options.
With docker installed, we install the software that allows us to track changes to our files, Git and GitHub.
Install Github and Git to allow docassemble Source Control
Go to https://desktop.github.com/ to download GitHub Desktop.
data:image/s3,"s3://crabby-images/78234/78234250648035db0f643970c6f91e520c7356ec" alt="Setup Docassemble Document Automation Locally 4 Download and install GitHub desktop"
While installing this is all you see:
data:image/s3,"s3://crabby-images/2c932/2c932ed41a02672ab136b53b3259e58c28ab0b45" alt="Setup Docassemble Document Automation Locally 5 GitHub in the installation process"
Hang in there, it’s installed in the background.
When it’s complete, you get this screen:
data:image/s3,"s3://crabby-images/b8367/b8367b550ba1e186cc80774de14c2cce3c1edc5b" alt="Setup Docassemble Document Automation Locally 6 GitHub installation complete"
At this point, you have 2 options:
If you don’t have a GitHub account , click Create your free account or do it here, then continue to the next step.
With your new (or exciting) GitHub account, click the Sign in to GitHub.com.
data:image/s3,"s3://crabby-images/f5a22/f5a2291cd672cc479f483845452ecd2e05c33301" alt="Setup Docassemble Document Automation Locally 7 Sign in to GitHub from the Desktop App"
When that’s complete, it brings us back to this:
data:image/s3,"s3://crabby-images/ef705/ef705921e358086daeb36b3086a186bd2c04ddfc" alt="Setup Docassemble Document Automation Locally 8 Confirm Git Details"
Confirm the details are correct and click Finish.
With this done, we’re ready to start automating our documents with Docassemble.
Write a sample docassemble interview from your system
To confirm all works, we will try a sample document assemble project.
Open your GitHub desktop. Click Clone a repository from the Internet… select URL, in the text box enter: deletosh/docassemble-premier then click Clone.
data:image/s3,"s3://crabby-images/9c1bf/9c1bfd7ba60ab14ac2880080299fbe15f2912034" alt="Setup Docassemble Document Automation Locally 9 Create a copy of the project on your computer"
Finally, to see what all the files look like, hit Repository > Open in Visual Studio
data:image/s3,"s3://crabby-images/76658/76658170700c519f192504957611488a98120561" alt="Setup Docassemble Document Automation Locally 10 Open project in VS Code"
With our VS Code open, confirm we can run an interview on our computer. Click through docassemble > template > questions then open sample.yml
data:image/s3,"s3://crabby-images/c3e58/c3e58e503f02c3b6bff290a0965fb8bb9a022df6" alt="Setup Docassemble Document Automation Locally 11 Open interview yml file"
To make working with coding docassemble easier, we want to add additional customization to VS Code.
Install an alternative to Window’s “cmd”, Clink
We will be type several commands in the terminal (sometimes called, command line, or cmd.exe). It’s that app on Windows that looks like this:
data:image/s3,"s3://crabby-images/8146c/8146c2b806e5c60614da6565cec5ce060cebc11c" alt="Setup Docassemble Document Automation Locally 12 what does cmd.exe look like"
We want this to work better and make it easier to use inside VS code.
Go to https://mridgers.github.io/clink and EXE (installer)
data:image/s3,"s3://crabby-images/cd1bf/cd1bfef795934bd47182f72b4ee4aea3edcb01bf" alt="Setup Docassemble Document Automation Locally 13 Download Clink for Windows"
Once you downloaded this, open and install the file. Keep all the default options.
Take note of where we installed the app. Mine is at C:Program Files (x86)clink.
data:image/s3,"s3://crabby-images/5d225/5d2254114190eb9a7748dcfbd8f46ed2f0acc2b9" alt="Setup Docassemble Document Automation Locally 14 Install clink"
Browsing through folders
Before we continue, let me expand on what “C:Program Files (x86)clink” means.
When you install any app on your computer, it saves it somewhere on your computer, in our case, that somewhere is “C:Program Files (x86)clink.” The first folder is “C:” (your main computer drive). Inside that we have the next folder “Program Files (x86)”; inside it we have “clink.”
To navigate to our final folder (clink), you open Windows Explorer, open C:, then Program Files (x86), then click — the short way we represent the path to the final directory is “C:Program Files (x86)clink.”
Let’s move on.
With the install complete, go into the folder you installed click. Mine is C:Program Files (x86)clink, go into the version folder 0.4.9. Here’s how I get to my folder,
data:image/s3,"s3://crabby-images/71325/713259b569457b57755ede6473eb1ec8b14b0006" alt="Setup Docassemble Document Automation Locally 15 Open Clink folder"
Add Clink command-line to VS Code
Let’s open VS Code. Click File > Preferences > Settings.
Click on the settings icon
data:image/s3,"s3://crabby-images/9ae01/9ae01ca61a02d9d86f7cdedbefb7bd045ffef343" alt="Setup Docassemble Document Automation Locally 16 Open settings"
Add the text below within the “{ }” section
"terminal.integrated.shell.windows": "C:\Windows\System32\cmd.exe","terminal.integrated.shellArgs.windows": ["/K", "C:\Program Files (x86)\clink\0.4.9\clink_x64.exe"," inject"]
data:image/s3,"s3://crabby-images/8a59e/8a59e5b3cf6309ae31ee1809da3f9fae6c1b57d0" alt="Setup Docassemble Document Automation Locally 17 Add the settings to configure the terminal"
(Note that the path in terminal.integrated.shellArgs.windows
In the Search settings box, enter terminal and in the Terminal: Explorer Kind select integrated
To confirm this is working as expected, open the terminal. Click Terminal > New Terminal
data:image/s3,"s3://crabby-images/40b2b/40b2be1c5f5f6c6a67a18fdcf59a3c94963ed685" alt="Setup Docassemble Document Automation Locally 18 Open a new terminal"
We should see Clink v0.4.9.
Install Python and docassemble command-line app
Next, we will install python.
Python is a programming language, and that’s docassemble’s parent language. To make docassemble work properly offline, we need to install on our system.
Go to https://www.python.org/downloads/windows/, Click the most recent version and download.
data:image/s3,"s3://crabby-images/10b70/10b707dbf8f6269e615fb68ec056b64f7a1661d0" alt="Setup Docassemble Document Automation Locally 19 Download the proper python version"
Open the downloaded file. Before starting the installation, check the box Add Python 3.x to PATH, click Install Now
data:image/s3,"s3://crabby-images/ae0f3/ae0f3772e32690304d4bb24d885b2d9b218fafeb" alt="Setup Docassemble Document Automation Locally 20 Start the installation"
When your installation is complete, open VS Code and a new terminal then type python, it should look like this:
data:image/s3,"s3://crabby-images/dd4bf/dd4bfa10cb8ce6e9de796ae4ff1171d7c2a32575" alt="Setup Docassemble Document Automation Locally 21 Check python works in your integrated terminal"
If you see a message like the above, we’re good.
We’re now ready for the final step.
Install docassemble command-line tool (docassemblecli)
With python installed, let’s install the tool that let’s run docassemble locally.
Open VS Code, click Terminal > New Terminal in the terminal enter pip install docassemblecli
data:image/s3,"s3://crabby-images/1215a/1215a6f448d656e25378d8a80d09a44e8718b759" alt="Setup Docassemble Document Automation Locally 22 Install docassemblecli tool"
Let’s run everything together
In the terminal, type docker-compose up -d
. This is the command that starts a virtual computer.
data:image/s3,"s3://crabby-images/e1935/e193517770eb059551a97f51ba45bea7c246eef9" alt="Setup Docassemble Document Automation Locally 23 Run docker composer"
Open your browser and go to http://localhost
. You might see this
data:image/s3,"s3://crabby-images/85688/856882c9454156df941dddf2b9adf03e00c4ed39" alt="Setup Docassemble Document Automation Locally 24 Docassemble starting"
After a few minutes, you should see Docassemble running. Sign in with the default password:
- username: [email protected]
- password: password
data:image/s3,"s3://crabby-images/b8c6e/b8c6eae9c043e31e6e1215630d93c139cd9df499" alt="Setup Docassemble Document Automation Locally 25 NMMUBUU"
(the first time you login, it will have you change your password)
Run your first offline docassemble
Our main setup is now complete. Let’s test our first interview.
First, go to Docassemble running on your system. In your browser, type http://localhost, in the navigation section, click My Profile.
data:image/s3,"s3://crabby-images/f4840/f48408c15d4a46520b197c6a44a77044ba25f628" alt="Setup Docassemble Document Automation Locally 26 Go to profile"
On the next page, go to the Other settings > API keys
data:image/s3,"s3://crabby-images/8e21c/8e21c83d77f1d7f1e7bdc25c569b50c7a879af96" alt="Setup Docassemble Document Automation Locally 27 Go to API keys"
Click Add a New API Key and give it any name. Then click Create.
Finally, copy the resulting key
data:image/s3,"s3://crabby-images/5fbb1/5fbb18c4c47ae7789081322cbf83c7be7e9eea39" alt="Setup Docassemble Document Automation Locally 28 Create API key"
Now, go back into VS Code with the project you previously created open.
Type code ~/.docassemblecli
, this opens a new tab in VS Code.
In this section:
data:image/s3,"s3://crabby-images/9c208/9c208016142f5bd266be0d790f9e33894e8a3f13" alt="Setup Docassemble Document Automation Locally 29 VS Code"
Paste the API code you created in the previous section in the apikey. Save the file or Ctrl + S
data:image/s3,"s3://crabby-images/49502/495022d7daf6c341128ed803544f07520a9b7a76" alt="Setup Docassemble Document Automation Locally 30 Add API key"
Next, let’s rename the docassemble > template file to docassemble-premier
data:image/s3,"s3://crabby-images/82ece/82ececaba9ad760e655f94a5ebab1b26845b6e2e" alt="Setup Docassemble Document Automation Locally 31 Rename to the docassemble project"
Let’s now open the sample.yml file
Next, type dainstall --norestart --playground ../docassemble-premier
data:image/s3,"s3://crabby-images/2954b/2954b83889ee76be593af979d2a8439db99e7e5a" alt="Setup Docassemble Document Automation Locally 32 Install the package"
You should see Installed.
You can now go back to the browser at http://localhost, then go to the Playground
Let’s run the code.
data:image/s3,"s3://crabby-images/6df80/6df8075a71d671b2f4b1c083afb44c2a582f7a2e" alt="Setup Docassemble Document Automation Locally 33 Run interview"
You’re now good at developing Docassemble interviews from your system.
How to continue docassemble from locally
As you run your project, here are some things you need to keep in mind:
- Every docassemble project is self-contained and you need to shut down docker and re-start docker in that project.
- When you start a new project, you need to add and re-create your API keys. You cannot use the API key you’ve added before.
Docassemble allows you to automate your document assemble process, and it’s a free alternative to the expensive hotdocs. This setup makes it flexible for you to write your interview and collaborate with other colleagues.
Let me know if you have questions in the comments.