Links

Get started with Dormakaba Oracode Locks

Learn how to connect and control your Dormakaba Oracode 480 and 660 locks with the Seam API.
Dormakaba Locks

Overview

Seam provides a universal API to connect and control many brands of locks. This guide provides a rapid introduction to connecting and controlling your Dormakaba Oracode locks using the Seam API. To learn more about other device brands supported by the Seam API, such as Yale, Schlage, and August, head over to our integration page.
Note that Dormakaba offers multiple lines of products: Lyazon, Sapphire, Oracode, and more. This guide is specifically for Dormakaba Oracode.

1 — Install Seam SDK

Seam provides client libraries for many languages such as Javascript, Python, Ruby, and PHP, as well as a Postman collection and OpenAPI spec.
Once installed, sign-up for Seam to get your API key, and export it as an environment variable:
$ export SEAM_API_KEY=seam_test2ZTo_0mEYQW2TvNDCxG5Atpj85Ffw
This guide uses a Sandbox Workspace. Only virtual devices can be connected. If you need to connect a real Oracode device, use a non-sandbox workspace and API key.
To control your Dormakaba Oracode locks via the Seam API, you must first authorize your Seam workspace against your Dormakaba Oracode account. To do so, Seam provides Connect Webviews: pre-built UX flows that walk you through authorizing your application to control Oracode locks.

Obtain an Oracode Live Service API Token

To start, contact Dormakaba Oracode support to request a Live Services API token. This token will then be provided to Seam to connect your account.
Note that of this writing, obtaining a Dormakaba Oracode Live Services API token is a manual process. We are working with Dormakaba to automate this and simplify onboarding of devices.

Request a Connect Webview

Python
Javascript
Ruby
PHP
from seamapi import Seam
seam = Seam()
webview = seam.connect_webviews.create(accepted_providers=["dormakaba_oracode"])
assert webview.login_successful is False
# Send the webview URL to your user
print(webview.url)
import Seam from 'seamapi'
const seam = new Seam()
const { connect_webview: connectWebview } = await seam.connectWebviews.create({
accepted_providers: ['dormakaba_oracode'],
})
console.log(connectWebview.login_successful) // false
// Send the webview URL to your user
console.log(connectWebview.url)
require 'seamapi'
seam = Seam::Client.new(api_key: 'MY_API_KEY')
webview = seam.connect_webviews.create(accepted_providers: %w[dormakaba_oracode])
puts webview.login_successful # false
# Send the webview URL to your user
puts webview.url
use Seam\SeamClient;
$seam = new SeamClient("YOUR_API_KEY");
$webview = $seam->connect_webviews->create(
accepted_providers: ["dormakaba_oracode"]
);

Authorize Your Workspace

Navigate to the URL returned by the Webview object. Since you are using a sandbox workspace, complete the login flow by entering the Dormakaba Oracode sandbox test accounts credentials below:
  • username: jane
  • password: 1234
  • api-token: 123456
Seam Connect Webview flow to connect Dormakaba Oracode account with Seam
Confirm the Connect Webview was successful by querying its status:
Python
Javascript
Ruby
PHP
updated_webview = seam.connect_webviews.get(webview.connect_webview_id)
assert updated_webview.login_successful # true
const updatedWebview = await seam.connectWebviews.get(
connectWebview.connect_webview_id,
)
console.log(updatedWebview.login_successful) // true
updated_webview = seam.connect_webviews.get(webview.connect_webview_id)
puts updated_webview.login_successful # true
$webview = $seam->connect_webviews->get('729847ff-98e0-418d-aeba-1e3cb38157c6');
assert($webview->status == 'pending');

3 — Retrieve Dormakaba Oracode Devices

After a Dormakaba Oracode account is linked with Seam, you can retrieve its devices.
Python
Javascript
Ruby
PHP
all_locks = seam.locks.list()
some_lock = all_locks[0]
assert some_lock.properties["battery_level"] is True
print(some_lock)
const allLocks = await seam.locks.list()
const someLock = allLocks[0]
console.log(someLock.properties.battery_level)
console.log(someLock)
some_lock = seam.locks.list.first
puts some_lock.properties['battery_level']
puts some_lock
use Seam\SeamClient;
$seam = new SeamClient('YOUR_API_KEY');
$locks = $seam->locks->list();
echo json_encode($locks);
*/

4 — Programming Access Code on a Dormakaba Oracode Lock

The Seam API lets you create access codes on Dormakaba Oracode devices such as the 480i and 660i locks. These codes can then be entered to unlock the door. You can find out more info about how Seam access codes in our core concept section on access codes.
Dormakaba Oracode does not let you specify a code for an access code. Instead it auto-generates a 6-digit code, which the Seam API returns. If you try to pass the code argument to the access code create function, the Seam API will return an error.
Python
Javascript
Ruby
PHP
# create an ongoing code
seam.access_codes.create(
device=some_lock,
name="Personal Access Code")
# create a timebound code
seam.access_codes.create(
device=some_lock,
name="My Temp Access Code",
starts_at="2028-08-12T19:23:42+0000",
ends_at="2028-08-13T19:23:42+0000")
# you can use a device or a device_id as the "device" parameter
seam.access_codes.list(device=some_lock)
# [
# AccessCode(access_code_id='631a3a30-3fa7-462a-b3bc-65528ccf8765', type='time_bound', code=None, starts_at='2028-08-12T19:24:00.000Z', ends_at='2028-08-13T19:24:00.000Z', name='My Temp Access Code', status='unset', common_code_key=None),
# AccessCode(access_code_id='4d2f4952-5446-4051-ba7e-a6fc01a376d7', type='ongoing', code='123*12346', starts_at=None, ends_at=None, name='Personal Access Code', status='set', common_code_key=None)
# ]
// create an ongoing code
await seam.accessCodes.create({
device_id: someLock.device_id,
name: 'Personal Access Code',
})
// create a timebound code
await seam.accessCodes.create({
device_id: someLock.device_id,
name: 'My Temp Access Code',
starts_at: '2028-11-12T19:23:42+0000',
ends_at: '2028-11-13T19:23:42+0000',
})
// use a device_id as the "device_id" parameter
await seam.accessCodes.list({
device_id: someLock.device_id,
})
/*
[
{
access_code_id: '631a3a30-3fa7-462a-b3bc-65528ccf8765',
device_id: '681bf7bc-e7c6-48e6-acfe-6dbabd0615c5',
name: 'My Temp Access Code',
code: null,
is_waiting_for_code_assignment: true,
common_code_key: null,
type: 'time_bound',
status: 'unset',
starts_at: '2028-08-12T19:24:00.000Z',
ends_at: '2028-08-13T19:24:00.000Z',
created_at: '2023-02-08T23:28:57.061Z',
errors: [],
warnings: []
},
{
access_code_id: '774986f8-5fad-4911-a4fb-e5a2ef9f15bd',
device_id: '681bf7bc-e7c6-48e6-acfe-6dbabd0615c5',
name: 'Personal Access Code',
code: '123*12346',
common_code_key: null,
type: 'ongoing',
status: 'set',
created_at: '2023-02-08T23:10:54.096Z',
errors: [],
warnings: []
},
]
*/
# create an ongoing code
seam.access_codes.create(
device_id: some_lock.device_id, name: 'Personal Access Code'
)
# create a timebound code
seam.access_codes.create(
device_id: some_lock.device_id,
name: 'My Temp Access Code',
starts_at: '2028-08-12T19:23:42+0000',
ends_at: '2028-08-13T19:23:42+0000'
)
# you can use a device or a device_id as the "device" parameter
seam.access_codes.list(some_lock)
# [<Seam::AccessCode:0x00690
# access_code_id="631a3a30-3fa7-462a-b3bc-65528ccf8765"
# name="My Temp Access Code"
# code=nil
# type="time_bound"
# starts_at=2028-08-12 19:24:00 UTC
# ends_at=2028-08-13 19:24:00 UTC
# errors=[]
# warnings=[]>, <Seam::AccessCode:0x006b8
# access_code_id="774986f8-5fad-4911-a4fb-e5a2ef9f15bd"
# name="Personal Access Code"
# code="123*12346"
# type="ongoing"
# errors=[]
# warnings=[]>]
use Seam\SeamClient;
$seam = new SeamClient("YOUR_API_KEY");
$some_lock = $seam->locks->list()[0];
$seam->access_codes->create(
device_id: $some_lock->device_id, name: 'Personal Access Code'
);
$seam->access_codes->create(
device_id: $some_lock->device_id,
name: 'My Temp Access Code',
starts_at: '2028-08-12T19:23:42+0000',
ends_at: '2028-08-13T19:23:42+0000'
);
echo json_encode($access_code)
/*
[{"access_code_id":"19cea367-fd8c-40b7-9ce3-6dec76fe1763","name":"My Temp Access Code","type":"time_bound","status":"unset","starts_at":"2028-08-12T19:24:00.000Z","ends_at":"2028-08-13T19:24:00.000Z","code":null,"created_at":"2023-02-09T05:53:46.293Z","errors":[],"warnings":[]},{"access_code_id":"f797a8f0-b8f7-4734-9bea-962de5cad413","name":"Personal Access Code","type":"ongoing","status":"set","starts_at":null,"ends_at":null,"code":"123*12346","created_at":"2023-02-09T05:53:46.172Z","errors":[],"warnings":[]}]
*/

Next Steps

Now that you've completed this guide, you can try to connect a real Dormakaba Oracode device. To do so, make sure to switch to a non-sandbox workspace and API key as real devices cannot be connected to sandbox workspaces.
In addition, if you'd like to explore other aspects of Seam, here is a list of helpful resources:
If you have any questions or want to report an issue, email us at [email protected].
© Seam Labs, Inc. All rights reserved.