Allows developers to interact with the Open Translators to Things repository. See http://www.opentranslatorstothings.org.
Developers can use the console app on Windows 10, Mac OSX or Android as a runtime to communicate with and onboard actual Things. The console app hosts the node.js process and serves simple UX to onboard (set up, auth, pair, etc) the Thing. Once a Thing has been onboarded, its schema and translator are downloaded. The Thing is then exposed through the AllJoyn bus as an AllJoyn device supporting the schema it has been translated to.
This README will help get you started developing in this repo.
Get your dev environment set up (PC or Mac):
- Install Git
- Install Node
- Choose your favorite IDE, e.g. Visual Studio Code.
Install the Ionic Framework and Cordova using npm. Note that we are using ionic 2, which is currently in beta.
$ npm install -g [email protected]
$ npm install -g [email protected]
Next, clone this repo to your local machine to get started. Navigate to the directory where you want to clone the repo to locally, then run:
git clone https://github.com/openT2T/console.git
You will need to install various dependencies to populate your local repo. The development process is driven by node, and the following command installs the dev dependencies (e.g. the typescript compiler, a test server, etc) as well as the dependencies used by the actual app (e.g. angular2 and ionic2):
$ npm install
Ionic provides an easy way to install the various cordova plugins used in the project. Run:
$ ionic state restore
Note: if running in Windows, and the command is not recognized, you may need to add npm to your PATH. The following should work: "%USERPROFILE%\AppData\Roaming\npm".
Congratulations, you are now set up for the basic development workflow! Just run:
$ ionic serve
If you're feeling fancy, you can also try the Ionic Lab which will show you how your app will look in different devices:
$ ionic serve --lab
The browser will launch, with the app hosted locally. As you make changes to the source, the app will live-reload in the browser to reflect your changes. This is great for doing UX-only updates, where you are not using any native components.
You can also run the following to emulate on a local android simulator (note: this requires the Android SDK on PC or Mac):
$ ionic emulate android --livereload
Finally, run the following to install and run on a local Windows simulator (note: this requires the Windows 10 SDK on a PC):
$ ionic run windows --archs=x64
? Note: At this time the --livereload option is not working on Windows, however you can try it for other platforms.
There is another way to build and run the Cordova app on Windows, which some might find easier. Specifically:
$ ionic build windows --archs=x64
Once you have a successful build, open the CordovaApp.sln file under platforms\windows in Visual Studio 2015, set the CordovaApp.Windows10 project as startup, and then just run from within Visual Studio. This is helpful for debugging.
? Note: If you get a build break in Visual Studio 2015, make sure all the different projects are set to build the same way, e.g. make sure all the different projects in the solution are building for Debug | x64.
This app requires some API secrets from external services. If you will be using any of these services, follow the instructions in this section to configure them.
This section is optional. If you are not using any of these external services, you can safely ignore it.
Create a config.ts
file under the "app" folder with the following contents. This file is listed in .gitignore
to help avoid accidental check-in of secrets.
export class Config {
public static Wink: any = {
"API_ENDPOINT" : "https://api.wink.com",
"CLIENT_ID" : "",
"CLIENT_SECRET" : ""
};
public static Auth0: any = {
"DOMAIN" : "",
"CLIENT_ID" : "",
"CLIENT_SECRET" : ""
};
}
Next, populate the configuration values per service in the following manner:
- Wink: Get a Client ID and Client Secret from Wink / Quirky as documented on their site, and paste into your
config.ts
. - Auth0: Get a Client ID and Client Secret from auth0 with the following process. If you get stuck, please refer to this page which has some more information and screenshots.
- Go to http://auth0.com and sign up
- Create a client, making sure you select client type
Regular Web Applications
. You can give the client whatever name you prefer. - After the client is created, ignore the
Quick Start
section and go to theSettings
tab. - Copy the
Client ID
andClient Secret
, as well as theDomain
, from theSettings
tab and paste into your config.ts. - Under
Allowed Callback URLs
in theSettings
tab, enterhttps://YOUR_DOMAIN/mobile
- Under
Allowed Origins (CORS)
in theSettings
tab, enterhttp://localhost:8100
andfile://\*
, then save changes - Next, go to the APIs section of the Auth0 dashboard and select the Auth0 Management API.
NOTE: If you do not see the APIs option in the left menu, you must enable it. Go to Account Settings > Advanced and select Enable APIs Section.
- Select the Non Interactive Clients tab and authorize the app you just created.
- From the list of available scopes, select
read:user_idp_tokens
and click Update.
Here are some workflows you might find useful during development:
- ionic serve : runs the dev web server (with live reload)
- ionic emulate [platform] --live reload: starts an emulator session (with live reload) for the specified platform
- ionic build [platform]: builds the app for the specified platform.
- gulp tslint: Runs the linter to find static analysis issues with your code.
For general developer tips, check out this article.
If you start Cordova from the CLI rather than from Visual Studio, but want to debug it, attach to the WWAHost.exe process.
Made any changes we should consider? Send us a pull request! Check out this article on how to get started.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.