Ti.onepassword
🔐 Support the 1Password App Extension with Titanium Mobile
Install / Use
/learn @hansemannn/Ti.onepasswordREADME
Ti.OnePassword
Support for the AgileBits 1Password App Extention in Titanium Mobile to open 1Password for selecting credentials.
<img src="https://abload.de/img/img_965973ke9.png" height="375" alt="1Password with Titanium" />Requirements
- [x] iOS 11+
- [x] Titanium SDK 9.2.0+
Features
- [x] Check if 1Password is installed and can be used
- [x] Receive login credentials from 1Password
- [x] Store login credentials in 1Password
- [x] Change login credentials in 1Password
Usage
Add the following url-scheme to the <plist> section of your tiapp.xml like this:
<ios>
<plist>
<dict>
<key>LSApplicationQueriesSchemes</key>
<array>
<string>org-appextension-feature-password-management</string>
</array>
</dict>
</plist>
</ios>
Require the module:
import OnePassword from 'ti.onepassword';
Check if the application supports the 1Password App Extension to show/hide a custom 1Password button:
const isAvailable = OnePassword.isAppExtensionAvailable();
Request login credentials from 1Password:
OnePassword.findLoginForURLString({
url: 'https://appcelerator.com',
callback: event => {
// Check if the operation succeeded
if (!event.success) {
alert(`Login could not be received: ${event.error}`);
return;
}
// Success - Prefill the form fields
usernameField.setValue(event.credentials.username);
passwordField.setValue(event.credentials.password);
}
});
Add a new login to 1Password:
OnePassword.storeLoginForURLString({
url: 'https://appcelerator.com',
credentials: {
username: 'my_username',
password: 'my_password'
},
options: {
password_min_length: 6,
password_max_length: 18
},
callback: event => {
if (!event.success) {
alert(`Credentials could not be added to 1Password: ${event.error}`);
return;
}
// <-- Success case
}
});
Change an existing login in 1Password:
OnePassword.changePasswordForLoginForURLString({
url: 'https://appcelerator.com',
credentials: {
username: 'my_username',
password: 'my_new_password'
},
options: {
password_min_length: 6,
password_max_length: 18
},
callback: event => {
if (!e.success) {
alert(`Credentials could not be updated in 1Password: ${event.error}`);
return;
}
// <-- Success case
}
});
Available credentials
- [x] url_string
- [x] username
- [x] password
- [x] totp
- [x] login_title
- [x] notes
- [x] section_title
- [x] fields
- [x] returned_fields
- [x] old_password
- [x] password_generator_options
Available options
- [x] password_min_length
- [x] password_max_length
- [x] password_require_digits
- [x] password_require_symbols
- [x] password_forbidden_characters
Example
Check example/app.js for a basic example.
Author
Hans Knoechel (@hansemannnn / Web)
License
Apache 2.0
Contributing
Code contributions are greatly appreciated, please submit a new pull request!
Related Skills
openhue
352.0kControl Philips Hue lights and scenes via the OpenHue CLI.
sag
352.0kElevenLabs text-to-speech with mac-style say UX.
weather
352.0kGet current weather and forecasts via wttr.in or Open-Meteo
casdoor
13.3kAn open-source AI-first Identity and Access Management (IAM) /AI MCP & agent gateway and auth server with web UI supporting OpenClaw, MCP, OAuth, OIDC, SAML, CAS, LDAP, SCIM, WebAuthn, TOTP, MFA, Face ID, Google Workspace, Azure AD
