Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
create
list
set-current
add-device
authorize
signup
list
](#device list)set-current
locations
snapshots
vehicles
create
delete
list
routes
set-current
start
status
stop
status
vinlirc
To install and use vinli-cli, you will need Node.js (version 4 or greater) and npm (nodejs.org).
> npm install -g vinli-cli
This will create a global command vinli
which you can run from anywhere. To update in the future, just run the same command again.
vinlirc
, signup
) act on behalf of a single app and thus require app credentials and the selection of a single application. The current working application can be specified in parameters, environment variables of by app set-current
command.--device
parameter VINLI_DEVICE
environment variable or saved to the nearest .vinlirc
file with the device set-current
command.--dummy
parameter, VINL_DUMMY
environment variable or saved to nearest .vinlirc
file with dummy set-current
. Dummies are associated with an app and there is a limit of 5 per app. They can be reused multiple times and deleted.--output [format]
or -o [format]
. Supported formats are table
(default), json
, yaml
, or text
-h
or --help
with any command or subcommand will output help contents and accepted parameters. Ex: vinli --help
, vinli app -h
, vinli dummy set-current --help
.app create
vinli app create
- Create a new app, will prompted for the following:
consumer
, admin
, enterprise
This is a short cut for creating an account at https://dev.vin.li/#/sign-up
app list
List current apps for your dev-portal account. Will prompt you for your login and password.
vinli app list
- list current apps, after being prompted for login and passwordvinli app list --email [email address] --password [password] -o json
- output list of apps to jsonapp set-current
This selection will be saved in the closest .vinlirc
file. Vinli-cli will prompt for your dev-portal email and password to lookup the app (either by name or by id) and will retrieve the corresponding secret. If you are not currently signed in to a developer account, you can specify the appId and appSecret to use:
vinli app set-current --app "My App"
- will use your dev-portal token to find an app with the nearest namevinli app set-current --app 6cbced16-d831-469c-898d-8b83f0f8fd5f
- will use your dev-portal token to find the app with the given IDvinli app set current --app d0810cc9-3e78-4411-a6ff-4ebb4a4c0243 --secret xZmuKWEJrTUM66mxeEjan
- will set the app credentials directlyYou can also specify the app individually in every command, which will not modify the current app selection in .vinlirc
:
vinli <service> <command>"
(app and secret loaded from nearest .vinlirc
file)vinli <service> <command> --app="My App"
vinli <service> <command> --app=6cbced16-d831-469c-898d-8b83f0f8fd5f
vinli <service> <command> --app=d0810cc9-3e78-4411-a6ff-4ebb4a4c0243 --secret=xZmuKWEJrTUM66mxeEjan
auth add-device
auth add-device [--username str] [--password str] [[--case-id [str]]|[--dummy [nameOrId]]] [--name str]
Add a device to a user's account. Use case ID of a real device or a dummy, or specify dummy by name or id. Cannot specify dummy and case id. --name
is optional will be label for the device visible to the user logged into My Vinli.
If not entered as options you will be prompted for your MyVinli username and password (not saved) as well as a caseId. If a device has been saved to your .vinlirc
file with the device set-current
command it will be populated, but you may override it.
auth authorize
Authorize an app for a MyVinli account. Your app must have a WEB client created first. Clients must be created through the developer portal for now. For testing purposes the Redirect URI can be any valid URI. Requires app
and secret
.
dev signup
vinli dev signup [--firstName str] [--lastName str] [--email str] [--password str]
Create a developer account. Will prompt for the following values: firstName
, lastName
, email
, password
.
You will be sent a confirmation email that needed to activate your account before you can proceed.
device list
Get a list of devices that available to an app. These can be real devices or dummies. Supports output formatting with --output
. Requires app
and secret
.
Pagination parameters for device list
:
--limit
--offset
device set-current
Most commands require the selection of a device. This is similar to the app selection and will also be stored in the nearest .vinlirc
file. Requires app
and secret
.
vinli device set-current --device 74ce1599-72e3-4353-8637-0cc4e2bffe54
As with the app selection, device selection can be provided on a per-command basis:
vinli <service> <command> --device d000af8f-883a-4ce8-8edb-354097cc8d3f
device locations
Get a list of location coordinates for a device.
Fields in output can be limited with --fields [list]
parameter. Supports output formatting with --output
. Requires app
and secret
.
Pagination parameters for device locations
:
--limit
--since
--until
device snapshots
Get a list of telemetry snapshots for a device.
Fields in output can be limited with --fields [list]
parameter. Supports output formatting with --output
. Requires app
and secret
.
Pagination parameters for device snapshots
:
--limit
--since
--until
device vehicles
Get a list of vehicles a devices has been in.
Supports output formatting with --output
. Requires app
and secret
.
Pagination parameters for device snapshots
:
--limit
--offset
dummy create
Add a dummy to the current app. There is a limit of 5 per account. Only required field is --name
. Takes up to a minute to create.
Supports output formatting with --output
. Requires app
and secret
.
dummy delete
Delete a dummy from the current app. Can specify dummy name or id with --dummy
parameter. If a name is given a fuzzy search will be done for current dummies on that account and the best match will be deleted.
dummy routes
Return a list of routes available for dummy trips. Supports output formatting with --output
. Requires app
and secret
.
Pagination parameters for dummy routes
:
--limit
--offset
dummy set-current
Specify a dummy name or id to save to the nearest .vinlirc
file. Requires app
and secret
.
dummy start
Send a dummy on a trip with the specified route. The account that has this dummy added will play the route data in real time to apps that have been authorized. Accepts parameters:
--dummy <id|name>
- if name is given a search will be performed and the best match used--route <id|name>
- if name is given a search will be performed and the best match used--vin <vin number>
- OPTIONAL, a random VIN will be generated, or you can provide a 17 digit VIN (Capital letters and numbers, no I or O letters, must start with VV)--repeat
- if this flag is set the route will be looped indefinitely until you delete it.Supports output formatting with --output
. Requires app
and secret
.
dummy status
Get the status of a dummy.
Supports output formatting with --output
. Requires app
and secret
.
dummy stop
Specify a dummy name or id to stop all routes for. Routes in progress take up to 30 seconds to stop after the command succeeds.
Requires app
and secret
.
vinlirc
vinli vinlirc
- Outputs your current derived .vinlirc
file.
Your vinli-cli settings are stored as json in .vinlirc
files. The config is obtained by merging multiple configurations in order of importance:
--device d000af8f-883a-4ce8-8edb-354097cc8d3f
VINLI_
export VINLI_DEVICE=d000af8f-883a-4ce8-8edb-354097cc8d3f
.vinlirc
files found while traversing the directory tree starting from the current working directory stopping at your home directory, or if your current directory is not a subdirectory of the working tree your home directory is the lowest priority.HOME = '/Users/vindiesel'
CWD = '/Users/vindiesel/code/vinliapp/'
Nearest (high priority) to farthest (low priority) .vinlirc files, if they exist:
[ '/Users/vindiesel/code/vinliapp/.vinlirc',
'/Users/vindiesel/code/.vinlirc',
'/Users/vindiesel/.vinlirc' ]
HOME = '/Users/vindiesel'
CWD = /opt/node/myapp
[ '/opt/node/myapp/.vinlirc',
'/opt/node/.vinlirc',
'/opt/.vinlirc',
'/.vinlirc',
'/Users/vindiesel/.vinlirc' ]
This is a comprehensive example starting from signing up for a developer account, creating an application, creating a dummy device, authorizing the app for a MyVinli account, adding the dummy device to an account, sending the dummy device on a virtual trip and viewing the telemetry data the app received from the device.
> vinli dev signup
[prompted for name, email and password. Must]
> vlinli app create --name "My App"
[prompted for email and password]
> vinli app set-current "My App"
[finds the app closest to the name "My App" (using levenshtein distance) and sets it as current]
Authenticated user
Setting Current: My App
Saved to /Users/vindiesel/connectedcar/.vinlirc
> vinli app list
┌──────────────────────────────────────┬────────────┬──────────────────┬─────────────────────────────────────────┐
│ ID │ Name │ Description │ Created │
├──────────────────────────────────────┼────────────┼──────────────────┼─────────────────────────────────────────┤
│ 24f5a02e-a625-4592-bbd8-185b899af673 │ My App │ my description │ Thu Jan 28 2016 15:26:10 GMT-0600 (CST) │
└──────────────────────────────────────┴────────────┴──────────────────┴─────────────────────────────────────────┘
> vinli app list -o json
{
"apps": [
{
"id": "24f5a02e-a625-4592-bbd8-185b899af673",
"name": "My App",
"description": "my description",
"secret": "UwvaIpkTaiOS_p_ykb",
"icon": null,
"type": "consumer",
"status": "dev",
"isDeleted": false,
"createdAt": "2016-01-28T21:26:10.127Z",
"updatedAt": "2016-01-28T21:26:10.127Z"
}
]
}
> vinli app get -o yaml
apps:
- id: 24f5a02e-a625-4592-bbd8-185b899af673
name: My App
description: my description
secret: UwvaIpkTaiOS_p_ykb
icon: null
type: consumer
status: dev
isDeleted: false
createdAt: '2016-01-28T21:26:10.127Z'
updatedAt: '2016-01-28T21:26:10.127Z'
> vinli auth authorize
[Assuming you have created a WEB client on the developer portal for the current app]
Signing in to vindiesel@vin.li MyVinli account...
Authenticated user. Initiation OAuth flow for application...
Authorizing application...
Application authorized successfully
OAuth Bearer token ==> 09820939082389009ioweirweoiuweriou2323082
To use Bearer token:
curl -H "Authorization: Bearer 09820939082389009ioweirweoiuweriou2323082" https://platform.vin.li/api/v1/devices
> vinli dummy create --name dummy1
┌───────────┬──────────────────────────────────────┐
│ ID │ e6156529-b6aa-475e-47de-741b320cdff7 │
│ Name │ dummy1 │
│ Device ID │ de1c64f6-b6aa-475e-b6aa-da60dd4b240e │
│ Case ID │ VV2UF8N │
└───────────┴──────────────────────────────────────┘
> vinli dummy list
┌──────────────────────────────────────┬─────────────────┬──────────────────────────────────────┬─────────┐
│ ID │ Name │ Device ID │ Case ID │
├──────────────────────────────────────┼─────────────────┼──────────────────────────────────────┼─────────┤
│ e6156529-b6aa-475e-47de-741b320cdff7 │ dummy1 │ de1c64f6-b6aa-475e-b6aa-da60dd4b240e │ VVT2F3N │
└──────────────────────────────────────┴─────────────────┴──────────────────────────────────────┴─────────┘
Showing 1 - 1 of 1
> vinli auth add-device --dummy dummy1
Authenticated user
Device Added
> vinli device list
┌──────────────────────────────────────┬───────────────────┬─────────────────────────────────────────┐
│ ID │ Name │ Created │
├──────────────────────────────────────┼───────────────────┼─────────────────────────────────────────┤
│ de1c64f6-b6aa-475e-b6aa-da60dd4b240e │ dummy1 │ Mon Feb 01 2016 15:31:58 GMT-0600 (CST) │
└──────────────────────────────────────┴───────────────────┴─────────────────────────────────────────┘
Showing 1 - 1 of 1
> vinli device set-current --device e1c64f6-b6aa-475e-b6aa-da60dd4b240e
> vinli dummy routes -o json
{
"routes": [
{
"id": "3c9f5e58-d97a-46cf-beb1-67574d6c9e3f",
"name": "Long Route - SFO",
"description": "Out and about near San Francisco International Airport",
"messageCount": 915,
"locationCount": 675,
"distanceByGPS": 22837,
"distanceByVSS": 33959.9,
"duration": 4313168,
"preview": "anqdFvb`jVwAiI]cCAuAq@oERKxA|@Vn@Bt@n@~G_DfA_DtAWVSpAKhAEtF?@BAAhDG~A_@zA_Al@mCt@wKjCgBt@kBl@kBd@wAX{@Da@HMJGGb@BgA\\eAAuC`@oBj@yBJgGrCaBX{ARaAHk@QS}@Gq@GSEEMHOl@O^AJ?CLDCAU`@KHu@Vw@HcATiAJ_AN}A[G?J]C^M@a@GiDiAsCgB}@q@_AaBgA{FSsAg@}@cAKw@\\MhAn@`CRbAl@dCf@jGm@z@m@jBgBxAyFv@uBd@_DhAiFzC}BfA{FbCiC|@oCf@oC`@yIl@iH\\uCFcV|@yK^uBD_EIiDq@kCm@i@sCGmEKqAYq@W]WO[C]f@cB|EKfAJnAd@hAfCfCd@bAFVK`DR\\xClASrA[`DUxACd@I\\H\\l@RxB^jA^xCr@hEjA|Bp@lAVJPA^_@|B?T@FBBTDLADEB@AFG@EAIBIAFU@BE?NEDKDAGT@H@CcTaMu@SRoAVeAL}AHqCXKn@DpB~@fCT`JmCVU@@A@?At@k@jBsAfCqBtCa@hFStBOzBSvDYlNm@|C]lCa@jGcB|CaA|DwAzC}@vCm@|JaAdJw@zCa@bN{@bIcAxCk@jCq@bCw@xB_AhCi@jDiArCk@~G_BtGqAhCk@hNkDfDoAnBe@hB}@fBkC`@kC?{CW}C[}CiBiHq@kDk@aEBoAf@a@dE~OkBU_Ch@y@Xy@PIZOPG?JSVWMKWNc@r@KpABfNIlBaAbBmAh@gD~@kFlAmMxDsA\\aBCe@TCSl@_AYlAyBReCl@kDtAkC`@sBp@aB`@wANw@LEGDAFJGEq@CWy@Ig@Sc@Y|@INMNS?l@]LM?OMOCKCAEPmB`C_Av@`@g@h@e@h@YEAOD?Av@St@[ADIFEBdByAP[B?@FeA~CVShAiBi@R_@JV@FKQGO@_AV}@j@n@]h@Qr@]hAsANI]HiBhBe@`@Q^ERJk@]~AODaACeB\\qAFoAVa@N_ByAuAWs@a@mBmAyAc@}ByD_@gBi@mD[s@o@OCC[BUHm@tAt@|CVrAZpAn@r@Nv@Vh@Jd@Kl@m@t@aBvDiBhAgFv@{B`@{Bt@yBpAcDrBaJxDkCt@qCn@iJ|@{N\\yCLqCP}I^eL\\wBPyBBiB?cBGoHsAo@SYk@JkA@yDIuA[qASSICAEi@Gq@~@e@hAiAnDDxAh@hAzB|Bn@bAPfAEx@OEGl@^h@b@Z|Av@R\\KfAWlAk@bE?v@^b@~CNbA`@bD~@~@\\jAXbD~@bB^MrAUjADVNPIOUDBFPLPRJ@FDDCJS"
},
{
"id": "170820b0-fc2d-4ee6-aacd-88011d542545",
"name": "Med Route - DFW",
"description": "Out and about in Dallas",
"messageCount": 277,
"locationCount": 260,
"distanceByGPS": 9357.61,
"distanceByVSS": 9596.56,
"duration": 957793,
"preview": "wyhgEdeimQxDnCpBfEUpATnB~CdFbAl@l@bBVpBXhBz@~At@jArBbC`AtA|@vAfKxSjCxDhLzKh@Vn@JhDfAnBx@dA\\~FfEtGjO~@xAdFzC`ApBzAtA|AnAfAdA~@hBn@dBv@vAjAj@bB^z@d@Pz@JPnB~Ap@Z^pBb@|@Vb@r@d@\\l@bA|At@f@fIlIz@`ArClDn@|@jEdEp@d@j@n@Fh@?~@BvAF|ABzEDdBZpF\\xILfFLzC?rBDxBNxBfAvFXzB`@lBVl@Nn@`@xAnAjCH^VRp@bA\\Td@z@^hAXNb@b@Vd@^Tv@tAxBvBn@b@Ph@PZlAjBb@\\`@Tj@ThB`B|AjAr@VxA|@lBvA`ElDp@|@QvBa@`Au@|@y@LQJSnAM\\YZc@Xc@d@o@\\_AnBCj@FdApAfAd@vAn@lHFfBV|AJzAEhAJe@E?BMHF`@nAXtAFhARdBb@zBnAfNH|ABlBTfBfAjBEjE?jBPjB`@|Ag@n@~@d@x@x@z@lAd@|@v@lBXfAqCxAiBvAIIVM@SAHJOBZEG@CBBW^{@j@_A[GQA@EAG@EI\\RXHEUEV?XFQHER@ROD?BJKF[H@BDAKA"
},
{
"id": "5399a0f9-acd9-4b0d-9052-24bd756281de",
"name": "test route",
"description": "it's a trap",
"messageCount": 9,
"locationCount": 9,
"distanceByGPS": 456.446,
"distanceByVSS": 422.96,
"duration": 321988,
"preview": "ya`nEhyxaO|BqB~@m@v@w@rA`@fAz@bEpCrAtA"
},
{
"id": "88d07d0f-0a62-4ebf-a624-423dc83bd9a0",
"name": "Vegas Short Route",
"description": "First Vegas Route",
"messageCount": 97,
"locationCount": 97,
"distanceByGPS": 8929.64,
"distanceByVSS": 1625.48,
"duration": 321988,
"preview": "ufs{Ezok}TcHxSuLNoAEmAKoB[eC{@_IaGmBqAeAk@_Aa@mD{@aBOaCE_m@|@`@pmBc@Kyj@Hi@~EIjLLaSrNLj\\Ab@SlFA\\EtEl@fA`@fAj@vAfA`DpDfA~@xA|@fBj@rAVhFdF?vSMp@@p|@CzE\\q@x@gAzBoCjT_W"
}
],
"meta": {
"pagination": {
"total": 6,
"limit": 100,
"offset": 0
}
}
}
> vinli dummy start --dummy dummy1 --route Vegas
Starting run of Vegas Short Route for dummy dummy1 (VV40HP640BYZ90GD2)...
Run started
> vinli dummy status
┌────────────────┬──────────────────────────────────────┐
│ ID │ 63b2f09b-4b69-4a66-a001-11ff4e4ce91e │
│ Route │ Vegas Short Route │
│ Status │ running │
│ Repeat │ false │
│ Repeat Count │ │
│ Speed (kph) │ 31 │
│ Remaining (s) │ 255.729 │
│ Remaining Msgs │ 82 │
└────────────────┴──────────────────────────────────────┘
> vinli dummy stop
Stopping run for dummy dummy1...
Run stopping...
> vinli device locations
┌───────────────────────────┬──────────────────────────────────────┬─────────────────────┬───────────────────┐
│ Timestamp │ ID │ Longitude │ Latitude │
├───────────────────────────┼──────────────────────────────────────┼─────────────────────┼───────────────────┤
│ 2016-02-01 18:23:39 -0600 │ db0ea7ce-4e03-4507-884c-5c01395fe3f3 │ -115.09814000000001 │ 36.1663 │
│ 2016-02-01 18:23:39 -0600 │ 40f7cfa7-572b-4d5b-b9eb-171781f003d0 │ -115.0982 │ 36.16612000000001 │
│ 2016-02-01 18:23:39 -0600 │ c5b40764-feab-44be-85c8-e5c67386602e │ -115.09722833389951 │ 36.16612835295922 │
│ 2016-02-01 18:23:39 -0600 │ 414657f7-10ba-4c36-9f70-affdec18e5d0 │ -115.09625666753283 │ 36.16613669806842 │
│ 2016-02-01 18:23:39 -0600 │ 31e6f2b9-b285-456b-84a6-54ed78b27680 │ -115.09431333417925 │ 36.16615336473527 │
│ 2016-02-01 18:23:39 -0600 │ 182d8a7f-013a-4847-bd23-0eafff78da1f │ -115.09334166719275 │ 36.1661616862929 │
│ 2016-02-01 18:23:39 -0600 │ 0a64116b-c829-44a6-b1af-8a25bf5b84e5 │ -115.09237 │ 36.16617 │
│ 2016-02-01 18:23:39 -0600 │ a2fbcd7b-97c9-43fe-9eb7-af7932b71c5a │ -115.09133000053536 │ 36.16618667565872 │
│ 2016-02-01 18:23:39 -0600 │ 3d0c8f1c-8159-4726-9343-26e131c100de │ -115.09029000048878 │ 36.16620334232614 │
│ 2016-02-01 18:23:39 -0600 │ 29f26268-74a1-43f4-a940-d456ada829bd │ -115.08742333342329 │ 36.16622667360286 │
└───────────────────────────┴──────────────────────────────────────┴─────────────────────┴───────────────────┘
Showing 10, 308 remaining
> vinli device snapshots --fields rpm
┌───────────────────────────┬──────────────────────────────────────┬───────┐
│ Timestamp │ ID │ RPM │
├───────────────────────────┼──────────────────────────────────────┼───────┤
│ 2016-02-01 18:23:22 -0600 │ db0ea7ce-4e03-4507-884c-5c01395fe3f3 │ 797 │
│ 2016-02-01 18:23:19 -0600 │ 40f7cfa7-572b-4d5b-b9eb-171781f003d0 │ 812 │
│ 2016-02-01 18:23:16 -0600 │ c5b40764-feab-44be-85c8-e5c67386602e │ 810 │
│ 2016-02-01 18:23:12 -0600 │ 414657f7-10ba-4c36-9f70-affdec18e5d0 │ 804 │
│ 2016-02-01 18:23:09 -0600 │ 31e6f2b9-b285-456b-84a6-54ed78b27680 │ 810.5 │
│ 2016-02-01 18:23:06 -0600 │ 182d8a7f-013a-4847-bd23-0eafff78da1f │ 804 │
│ 2016-02-01 18:23:03 -0600 │ 0a64116b-c829-44a6-b1af-8a25bf5b84e5 │ 807.5 │
│ 2016-02-01 18:23:00 -0600 │ a2fbcd7b-97c9-43fe-9eb7-af7932b71c5a │ 798 │
│ 2016-02-01 18:22:57 -0600 │ 3d0c8f1c-8159-4726-9343-26e131c100de │ 797 │
│ 2016-02-01 18:22:54 -0600 │ 29f26268-74a1-43f4-a940-d456ada829bd │ 813 │
└───────────────────────────┴──────────────────────────────────────┴───────┘
Showing 10, 288 remaining
FAQs
Vinli from the command line!
The npm package vinli-cli receives a total of 1 weekly downloads. As such, vinli-cli popularity was classified as not popular.
We found that vinli-cli demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.