$ brew install jackytck/alti-cli/alti-cli
$ docker run -it --rm -v /tmp:/.altizure jackytck/alti-cli:v1.0.0
/.altizure
is the path for storing config in container, mount to it to preserve config
$ go get -u github.com/altizure/alti-cli
# bash auto-complete
$ alti-cli help completion
# email login
$ alti-cli login
# phone login (public api only)
$ alti-cli login -p
# login with specific key (e.g. your paid developer key)
$ alti-cli login -k
- Support public api-server, Altizure One and private api-server.
- e.g. endpoint for private server: http://1.2.3.4:1234
- Active user profile could be set by environment variables:
ALTI_ENDPOINT
,ALTI_EMAIL
,ALTI_KEY
andALTI_TOKEN
. They are respected for all commands.
- Put all images and meta files in a directory (e.g. /tmp/ust-test), or zipped obj (e.g. /tmp/bunny.zip)
- Call
# create project + upload (images/metafiles/model) + start task
$ alti-cli quick -i /tmp/ust-test
# Or a zip file of CAD obj
$ alti-cli quick -i /tmp/bunny.zip
- Done
- -i: input path of image directory with meta file or single obj zip, e.g. /tmp/ust-test or /tmp/bunny.zip
- -n: project name, e.g. 'Ust test', 'Bunny obj'
- -p: project type,
free
orpro
- -m: upload method,
direct
ors3
oross
- -m: model type,
CAD
orPHOTOGRAMMETRY
orPTCLOUD
- -s: directory to skip, e.g. .small
- -v: verbose
Check if direct upload is supported.
$ alti-cli network
Check if main browsing site is up.
$ alti-cli check site -v
2019/11/06 14:56:45 Checking https://www.altizure.com...
2019/11/06 14:56:45 Success with status code: 200
2019/11/06 14:56:45 Took 637.822755ms
$ alti-cli account
$ alti-cli account use XXXXXX
- XXXXXX is the account ID
$ alti-cli whoami
+--------------------------+----------------+--------+----------+------------+---------------+--------------+------+---------+--------+------+-----------+---------------------+---------------+
| ENDPOINT | USERNAME/EMAIL | COINS | GP QUOTA | MEMBERSHIP | DEVELOPERSHIP | FREE STORAGE | STAR | PROJECT | PLANET | FANS | FOLLOWING | JOINED | COUNTRY |
+--------------------------+----------------+--------+----------+------------+---------------+--------------+------+---------+--------+------+-----------+---------------------+---------------+
| https://api.altizure.com | jacky | 105.32 | 9.00 | ACTIVE | ACTIVE | 3.8 GiB | 1 | 124 | 2 | 2 | 4 | 2015-08-21 09:33:07 | Hong_Kong_SAR |
+--------------------------+----------------+--------+----------+------------+---------------+--------------+------+---------+--------+------+-----------+---------------------+---------------+
$ alti-cli my membership
+--------+-------+--------+---------------------+---------------------+----------+---------+---------+---------+------------+-----------+---------------+--------------+-----------+
| STATE | PLAN | MONTHS | START | END | GP QUOTA | COIN/GP | STORAGE | USAGE | VISIBILITY | COUPON | MODEL/PROJECT | COLLABORATOR | WATERMARK |
+--------+-------+--------+---------------------+---------------------+----------+---------+---------+---------+------------+-----------+---------------+--------------+-----------+
| ACTIVE | Small | 12 | 2018-12-24 05:37:55 | 2019-12-24 05:37:55 | 6.00 | 1.00 | 4.0 GiB | 191 MiB | public | Value: 5 | 10 | 5 | true |
| | | | | | | | | | | Repeat: 1 | | | |
| | | | | | | | | | | Month: 1 | | | |
+--------+-------+--------+---------------------+---------------------+----------+---------+---------+---------+------------+-----------+---------------+--------------+-----------+
$ alti-cli project new recon -n 'test new proj'
+--------------------------+---------------+--------------+------------+
| ID | NAME | PROJECT TYPE | VISIBILITY |
+--------------------------+---------------+--------------+------------+
| 5d37e018bb7c6a0e17ffe9d1 | test new proj | free | public |
+--------------------------+---------------+--------------+------------+
- recon: reconstruction project
- -n: project name, e.g. 'test new proj'
- -p: project type,
free
orpro
- -v: visibility,
public
,unlisted
orprivate
- -s: silent mode, output project id only
$ alti-cli project new model -n 'my obj model'
- -n: project name, e.g. 'test obj model'
- -p: project type,
free
orpro
- -m: model type,
CAD
orPHOTOGRAMMETRY
orPTCLOUD
- -v: visibility,
public
,unlisted
orprivate
$ alti-cli project remove -p '5d37e018bb7c6a0e17ffe9d1'
Check all images of a given directory locally. Get stats of number of GP, dimensions and invalid images, etc.
$ alti-cli check image -d ~/myimg -v -t -s .small -n 10
- -d: image directory, e.g. ~/myimg
- -v: verbose
- -t: table format
- -s: directory to skip, e.g. .small
- -n: number of threads, default is number of cores
Locally check each image of a given directory, see if it is defined in the group.txt (if found). Remove it if it is not.
$ alti-cli check image-group -d ~/myimg -v -t -s .small -n 10
- -d: image directory, e.g. ~/myimg
- -v: verbose
- -t: table format
- -s: directory to skip, e.g. .small
- -n: number of threads, default is number of cores
- -y: auto accept to remove all undefined images
Buckets are used in the import
command for specifying different geo endpoints for the upload process. Would be auto selected if not provided.
$ alti-cli list bucket
$ alti-cli import image -d ~/myimg -s .small -p 5d37e -r upload.csv -v -m s3 -y
- -d: image directory, e.g. ~/myimg
- -s: directory to skip, e.g. .small
- -p: (partial) project id from aboved, e.g. 5d37e
- -r: name of report, e.g. upload.csv (not required)
- -v: verbose
- -m: upload method (skip this flag to auto detect best method)
- -n: number of threads, default is number of cores
- -y: auto accept
$ alti-cli import meta -p 5d008 -v -f ~/test/pose.txt
- -b: desired bucket to upload (auto select if empty)
- -f: path of meta file
- -p: (partial) project id from aboved, e.g. 5d37e
- -m: method of upload:
direct
ors3
orminio
(based on supported cloud shown inalti-cli account
) - -t: timeout in second(s)
- -ip: ip address of ad-hoc local server for direct upload
- -port: port of ad-hoc local server for direct upload
- -v: verbose
$ alti-cli import model -p 5d7b6b -v -f ~/test/bunny.obj
- -b: desired bucket to upload
- -f: path of model zip file or directory of multiparts zip
- -p: (partial) project id from aboved, e.g. 5d37e
- -m: method of upload:
direct
ors3
orminio
- -t: timeout in second(s)
- -v: verbose
$ alti-cli myproj inspect -p 5d37e0
$ alti-cli myproj
$ alti-cli project start -p 5d37e0
- -t: task type: One of
alti-cli list task-type
, default isNative
$ alti-cli list task-type
$ alti-cli project stop -p 5d37e0
$ alti-cli project download -p 5d37e -y
# export as list of images as csv only
$ alti-cli project image -p 5d37e
# download to local dir
$ alti-cli project image -p 5d37e -d /tmp/nat
- -p: (partial) project id from aboved, e.g. 5d37e
- -o, path of output csv, default to
$pid-images.csv
- -d, path of download directory (absolute or relative)
- -v: verbose
$ alti-cli project transfer -p 5d37e -e [email protected]
Cash to coins
$ alti-cli bank tocoins -c 12
USD12.00 could buy 1.02 coins
Coins to cash
$ alti-cli bank tocash -c 3
3.00 coins could be bought by USD35.40
P2P coins
$ alti-cli bank transfer -c 0.1 -e [email protected] -m 'Test transferring coins'
You have 105.42 coins. Are you sure to transfer 0.10 coins to "[email protected]"? (Y/N): y
Successfully transferred 0.10 coins to "[email protected]"
Current balnce: 105.32 coins
$ alti-cli set-face -f /tmp/face_128.jpg
$ cat q.txt
query ($id: ID!) {
project(id: $id) {
id
name
isImported
importedState
projectType
numImage
gigaPixel
taskState
date
cloudPath {
key
}
}
}
$ cat var.txt
{
"id": "5d37e018bb7c6a0e17ffe9d1"
}
$ alti-cli gql -q q.txt -k var.txt
{
"project": {
"cloudPath": [
{
"key": "local"
},
{
"key": "oss_sz"
},
{
"key": "s3"
}
],
"date": "2019-07-24T08:33:01.321Z",
"gigaPixel": 0.34,
"id": "5d37e018bb7c6a0e17ffe9d1",
"importedState": "Native",
"isImported": false,
"name": "test new proj",
"numImage": 28,
"projectType": "free",
"taskState": "Done"
}
}
- -q: path of query or mutation file
- -k: path of query variables file
Only for superuser, login with your superuser key and account:
$ alti-cli login -k
$ alti-cli super token -e '[email protected]'
- -e: user email
$ alti-cli super sync -p 5d7b6b
- -p: (partial) project id
$ alti-cli super toGFS -p 5d7b6b
- -p: (partial) project id
$ alti-cli super force-start -p 5d7b6b
- -p: (partial) project id