Globalization Pipeline Client for JavaScript
This is the JavaScript SDK for the
Globalization Pipeline
Bluemix service.
The Globalization Pipeline service makes it easy for you to provide your global customers
with Bluemix applications translated into the languages in which they work.
This SDK currently supports Node.js.
Sample
For a working Bluemix application sample,
see gp-nodejs-sample.
Quickstart - Bluemix
Add g11n-pipeline
to your project, as well as cfenv
and optional
.
npm install --save g11n-pipeline cfenv optional
Load the client object as follows (using cfenv ).
You can store a copy of the credentials in local-credentials.json
for local
operation.
var optional = require('optional');
var appEnv = require('cfenv').getAppEnv();
var gpClient = require('g11n-pipeline').getClient(
optional('./local-credentials.json')
|| {appEnv: appEnv}
);
Using
To fetch the strings for a bundle named "hello", first create a bundle accessor:
var mybundle = gpClient.bundle('hello');
Then, call the getStrings
function with a callback:
mybundle.getStrings({ languageId: 'es'}, function (err, result) {
if (err) {
console.error(err);
} else {
var myStrings = result.resourceStrings;
console.dir(myStrings);
}
});
This code snippet will output the translated strings such as the following:
{
hello: '¡Hola!',
goodbye: '¡Adiós!',
…
}
Async
Note that all calls that take a callback are asynchronous.
For example, the following code:
var bundle = client.bundle('someBundle');
bundle.create({…}, function(…){…});
bundle.uploadStrings({…}, function(…){…});
…will fail, because the bundle someBundle
hasn’t been create
d by the time the
uploadStrings
call is made. Instead, make the uploadStrings
call within a callback:
var bundle = client.bundle('someBundle');
bundle.create({…}, function(…){
…
bundle.uploadStrings({…}, function(…){…});
});
Testing
See TESTING.md
API convention
APIs take a callback and use this general pattern:
gpClient.function( { /*params*/ } , function callback(err, ...))
- params: an object containing input parameters, if needed.
err
: if truthy, indicates an error has occured....
: other parameters (optional)
These APIs may be promisified easily using a library such as Q
's
nfcall:
return Q.ninvoke(bundle, "delete", {});
return Q.ninvoke(gpClient, "getBundleList", {});
Also, note that there are aliases from the swagger doc function names
to the convenience name. For example, bundle.uploadResourceStrings
can be
used in place of bundle.uploadStrings
.
All language identifiers are IETF BCP47 codes.
API reference
g11n-pipeline
Author: Steven R. Loomis
g11n-pipeline.serviceRegex
a Regex for matching the service.
Usage: var credentials = require('cfEnv')
.getAppEnv().getServiceCreds(gp.serviceRegex);
(except that it needs to match by label)
Kind: static property of g11n-pipeline
Properties
g11n-pipeline.exampleCredentials
Example credentials
Kind: static property of g11n-pipeline
Properties
g11n-pipeline~Client
Kind: inner class of g11n-pipeline
client.ping
Do we have access to the server?
Kind: instance property of Client
Param | Type | Description |
---|
args | object | (ignored) |
cb | callback | |
client.supportedTranslations(args, cb)
This function returns a map from source language(s) to target language(s).
Example: { en: ['de', 'ja']}
(English translates to German and Japanese.)
Kind: instance method of Client
Param | Type | Description |
---|
args | object | |
cb | supportedTranslationsCallback | (err, map-of-languages) |
client.getServiceInfo(args, cb)
Get information about this service
Kind: instance method of Client
Param | Type |
---|
args | object |
cb | basicCallback |
client.createUser(args, cb)
Create a user
Kind: instance method of Client
Param | Type | Description |
---|
args | object | |
args.type | string | User type (ADMINISTRATOR, TRANSLATOR, or READER) |
args.displayName | string | Optional display name for the user. This can be any string. |
args.comment | string | Optional comment |
args.bundles | Array | set of accessible bundle ids or ['*'] to mean “all bundles” |
args.metadata | Object | optional key/value pairs for user metadata |
args.externalId | string | optional external user ID for your application’s use |
cb | basicCallback | passed a new User object |
client.bundle(opts) ⇒ Bundle
Create a bundle access object.
This doesn’t create the bundle itself, just a handle object.
Call create() on the bundle to create it.
Kind: instance method of Client
Param | Type | Description |
---|
opts | Object | String (id) or map {id: bundleId, serviceInstance: serviceInstanceId} |
client.user(id) ⇒ User
Create a user access object.
This doesn’t create the user itself,
nor query the server, but is just a handle object.
Use createUser() to create a user.
Kind: instance method of Client
Param | Type | Description |
---|
id | Object | String (id) or map {id: bundleId, serviceInstance: serviceInstanceId} |
client.users(opts, cb)
List users. Callback is called with an array of
user access objects.
Kind: instance method of Client
Param | Type | Description |
---|
opts | Object | ignored |
cb | listUsersCallback | |
client.bundles(opts, cb)
List bundles. Callback is called with an map of
bundle access objects.
Kind: instance method of Client
Param | Type | Description |
---|
opts | Object | ignored |
cb | listBundlesCallback | given a map of Bundle objects |
g11n-pipeline~Bundle
Kind: inner class of g11n-pipeline
new Bundle(gp, props)
Param | Type | Description |
---|
gp | Client | parent g11n-pipeline client object |
props | Object | properties to inherit |
bundle.getInfoFields
List of fields usable with Bundle.getInfo()
Kind: instance property of Bundle
bundle.delete(opts, cb)
Delete this bundle.
Kind: instance method of Bundle
Param | Type |
---|
opts | Object |
cb | basicCallback |
bundle.create(body, cb)
Create this bundle with the specified params.
Note that on failure, such as an illegal language being specified,
the bundle is not created.
Kind: instance method of Bundle
Param | Type | Description |
---|
body | Object | |
body.sourceLanguage | string | bcp47 id of source language such as 'en' |
body.targetLanguages | Array | optional array of target languages |
body.metadata | Object | optional metadata for the bundle |
body.partner | string | optional ID of partner assigned to translate this bundle |
cb | basicCallback | |
bundle.getInfo(opts, cb)
Get bundle info
Kind: instance method of Bundle
Param | Type | Description |
---|
opts | Object | Options object |
opts.fields | String | Comma separated list of fields |
opts.translationStatusMetricsByLanguage | Boolean | Optional field (false by default) |
opts.reviewStatusMetricsByLanguage | Boolean | Optional field (false by default) |
opts.partnerStatusMetricsByLanguage | Boolean | Optional field (false by default) |
cb | basicCallback | callback (err, { updatedBy, updatedAt, sourceLanguage, targetLanguages, readOnly, metadata, partner} ) |
bundle.getStrings(opts, cb)
Fetch one language's strings
Kind: instance method of Bundle
Param | Type | Description |
---|
opts | Object | options |
opts.languageId | String | language to fetch |
cb | basicCallback | callback (err, { resourceStrings: { strings … } }) |
bundle.entry(opts)
Create an entry object. Doesn't fetch data,
Kind: instance method of Bundle
See: ResourceEntry~getInfo
Param | Type | Description |
---|
opts | Object | options |
opts.languageId | String | language |
opts.resourceKey | String | resource key |
bundle.uploadStrings(opts, cb)
Upload resource strings, replacing all current contents for the language
Kind: instance method of Bundle
Param | Type | Description |
---|
opts | Object | options |
opts.languageId | String | language to update |
opts.strings | Object.<string, string> | strings to update |
cb | basicCallback | |
bundle.update(opts, cb)
Kind: instance method of Bundle
Param | Type | Description |
---|
opts | Object | options |
opts.targetLanguages | array | optional: list of target languages to update |
opts.readOnly | boolean | optional: set this bundle to be readonly or not |
opts.metadata | object | optional: metadata to update |
opts.partner | string | optional: partner id to update |
cb | basicCallback | callback |
bundle.updateStrings(opts, cb)
Update some strings in a language.
Kind: instance method of Bundle
Param | Type | Description |
---|
opts | Object | options |
opts.strings | Object.<string, string> | strings to update. |
opts.resync | Boolean | optional: If true, resynchronize strings in the target language and resubmit previously-failing translation operations |
cb | basicCallback | |
g11n-pipeline~User
Kind: inner class of g11n-pipeline
Properties
Name | Type | Description |
---|
id | String | the userid |
updatedBy | String | gives information about which user updated this user last |
updatedAt | Date | the date when the item was updated |
type | String | ADMINISTRATOR |
displayName | String | optional human friendly name |
metadata | Object.<string, string> | optional user-defined data |
serviceManaged | Boolean | if true, the GP service is managing this user |
password | String | user password |
comment | String | optional user comment |
externalId | String | optional User ID used by another system associated with this user |
bundles | Array.<string> | list of bundles managed by this user |
new User(gp, props)
Param | Type | Description |
---|
gp | Client | parent g11n-pipeline client object |
props | Object | properties to inherit |
user.update(opts, cb)
Update this user.
All fields of opts are optional. For strings, falsy = no change, empty string '' = deletion.
Kind: instance method of User
Param | Type | Description |
---|
opts | object | options |
opts.displayName | string | User's display name - falsy = no change, empty string '' = deletion. |
opts.comment | string | optional comment - falsy = no change, empty string '' = deletion. |
opts.bundles | Array.<string> | Accessible bundle IDs. |
opts.metadata | object.<string, string> | User defined user metadata containg key/value pairs. Data will be merged in. Pass in "{}" to erase all metadata. |
opts.externalId | string | User ID used by another system associated with this user - falsy = no change, empty string '' = deletion. |
cb | basicCallback | callback with success or failure |
user.delete(cb)
Delete this user.
Note that the service managed user
(the initial users created by the service) may not be
deleted.
Kind: instance method of User
Param | Type | Description |
---|
cb | basicCallback | callback with success or failure |
user.getInfo(opts, cb)
Fetch user info.
The callback is given a new User instance, with
all properties filled in.
Kind: instance method of User
Param | Type | Description |
---|
opts | Object | optional, ignored |
cb | getUserCallback | |
g11n-pipeline~ResourceEntry
ResourceEntry
Creating this object does not modify any data.
Kind: inner class of g11n-pipeline
See: Bundle~entries
Properties
Name | Type | Description |
---|
resourceKey | String | key for the resource |
new ResourceEntry(bundle, props)
Param | Type | Description |
---|
bundle | Bundle | parent Bundle object |
props | Object | properties to inherit |
resourceEntry.getInfo(opts, cb)
Load this entry's information. Callback is given
another ResourceEntry but one with all current data filled in.
Kind: instance method of ResourceEntry
Param | Type | Description |
---|
opts | Object | options (currently ignored) |
cb | basicCallback | callback (err, ResourceEntry) |
resourceEntry.update()
Update this resource entry's fields.
Kind: instance method of ResourceEntry
Param | Type | Description |
---|
opts.value | string | string value to update |
opts.reviewed | boolean | optional boolean indicating if value was reviewed |
opts.metadata | object | optional metadata to update |
opts.partnerStatus | string | translation status maintained by partner |
g11n-pipeline~getClient(params) ⇒ Client
Construct a g11n-pipeline client.
params.credentials is required unless params.appEnv is supplied.
Kind: inner method of g11n-pipeline
Param | Type | Description |
---|
params | Object | configuration params |
params.appEnv | Object | pass the result of cfEnv.getAppEnv(). Ignored if params.credentials is supplied. |
params.credentials | Object.<string, string> | Bound credentials as from the CF service broker (overrides appEnv) |
params.credentials.url | string | service URL. (should end in '/translate') |
params.credentials.userId | string | service API key. |
params.credentials.password | string | service API key. |
params.credentials.instanceId | string | instance ID |
g11n-pipeline~listUsersCallback : function
Called when listusers completes
Kind: inner typedef of g11n-pipeline
See: User
Param | Type | Description |
---|
err | object | error , or null |
users | Object.<string, User> | user list |
g11n-pipeline~basicCallback : function
Basic Callback
Kind: inner typedef of g11n-pipeline
Param | Type | Description |
---|
err | object | error , or null |
data | Object | Returned data |
docs autogenerated via jsdoc2md
Support
You can post questions about using this service to StackOverflow
using the tag "globalization-pipeline".
LICENSE
Apache 2.0. See LICENSE.txt
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.