1
0
mirror of https://github.com/fazo96/homework-cli.git synced 2025-01-09 12:10:10 +01:00

ready for release

This commit is contained in:
Enrico Fasoli 2015-03-09 17:20:14 +01:00
parent e5fecb40f1
commit efafac16b2
3 changed files with 70 additions and 18 deletions

View File

@ -4,13 +4,13 @@ Command line interface for [Homework](github.com/fazo96/homework).
## Setup ## Setup
1. Install using `npm install -g homework` 1. Install using `npm install -g homework-cli`
2. Run with the `homework` command 2. Run with the `homework` command
- By default, _homework-cli_ connects to homework.meteor.com, but you can customize the url. - By default, _homework-cli_ connects to [homework.meteor.com](http://homework.meteor.com), but you can customize the url.
- An account with an _API key_ is required to access the __RESTful API__ used by this tool. The __API__ must also be enabled on the Homework server. - An account with an _API key_ is required to access the __RESTful API__ used by this tool. The __API__ must also be enabled on the Homework server.
__Please Note__: as of the time of writing, [Homework](github.com/fazo96/homework) only has experimental __RESTful API__ support, so this tool can't yet be used easily with homework.meteor.com. __Please Note__: as of the time of writing, [Homework](http://github.com/fazo96/homework) only has experimental __RESTful API__ support, so this tool can't yet be used easily with [homework.meteor.com](http://homework.meteor.com).
## Usage ## Usage
@ -20,8 +20,10 @@ __Please Note__: as of the time of writing, [Homework](github.com/fazo96/homewor
Commands: Commands:
new [options] <title> [content] create a new note new|add [options] <title> [content] create a new note
delete <ids...> delete one or more notes delete <ids...> delete one or more notes
show [options] show all notes
save-cfg [options] save arguments (apiKey and URL) to configuration file at ~/.config/homework-cli.json
Options: Options:
@ -30,11 +32,17 @@ __Please Note__: as of the time of writing, [Homework](github.com/fazo96/homewor
-k, --key <apikey> use given api key -k, --key <apikey> use given api key
-u, --url <endpoint> use given api endpoint instead of http://homework.meteor.com/api -u, --url <endpoint> use given api endpoint instead of http://homework.meteor.com/api
-v, --verbose be more verbose -v, --verbose be more verbose
-i, --id show item IDs
-s, --silent don't print note list -s, --silent don't print note list
-a, --archived view archived notes
If running with no _commands_, the tool will show your list of notes ordered by due date, just like the web interface. A command may have its own options. To see them, run `homework --help <command>`
### Configuration file
The tool can read the `key` and `url` command line parameters from a configuration file for the comfort of the user.
The first time you run the program with your own settings, use the `save-cfg` command to save the configuration to `~/.config/homework-cli.json`.
You can update the configuration with `save-cfg` of course, or temporary use different settings with the command line arguments.
__Example:__ `homework --key my_api_key --url my_custom_url save-cfg` will save the given configuration to the settings file.
## License ## License

View File

@ -3,6 +3,9 @@ var request = require('request')
var chalk = require('chalk') var chalk = require('chalk')
var cli = require('commander') var cli = require('commander')
var moment = require('moment') var moment = require('moment')
var fs = require('fs')
var cfgpath = process.env.HOME+'/.config/homework-cli.json'
cli cli
.version('1.3.0') .version('1.3.0')
@ -11,12 +14,11 @@ cli
.option('-k, --key <apikey>','use given api key') .option('-k, --key <apikey>','use given api key')
.option('-u, --url <endpoint>','use given api endpoint instead of http://homework.meteor.com/api') .option('-u, --url <endpoint>','use given api endpoint instead of http://homework.meteor.com/api')
.option('-v, --verbose', 'be more verbose') .option('-v, --verbose', 'be more verbose')
.option('-i, --id', 'show item IDs')
.option('-s, --silent',"don't print note list") .option('-s, --silent',"don't print note list")
.option('-a, --archived','view archived notes')
cli cli
.command('new <title> [content]') .command('new <title> [content]')
.alias('add')
.description('create a new note') .description('create a new note')
.option('--date <date>', 'the due date for the program') .option('--date <date>', 'the due date for the program')
.action(postNote) .action(postNote)
@ -26,16 +28,40 @@ cli
.description('delete one or more notes') .description('delete one or more notes')
.action(delNotes) .action(delNotes)
cli.parse(process.argv) cli
.command('show')
.description('show all notes')
.option('-a, --archived','view archived notes')
.option('-i, --id','show IDs')
.action(function(options){ getNotes(options.archived || false, options.showids, console.log) })
cli
.command('save-cfg')
.description('save arguments (apiKey and URL) to configuration file at '+cfgpath)
.option('--stdout','print to stdout instead')
.action(function(options){
preRan = true
var cfg = JSON.stringify({apiKey: cli.key, url: cli.url})
if(options.stdout) console.log(cfg)
else fs.writeFile(cfgpath,cfg,function(err){
if(err) console.log(chalk.red('Error: ') + chalk.bold(err))
else console.log(chalk.green('Configuration saved to '+chalk.bold(cfgpath)))
})
})
function baseurl(){ return (cli.url || 'http://homework.meteor.com/api') + '/' + cli.key } function baseurl(){ return (cli.url || 'http://homework.meteor.com/api') + '/' + cli.key }
if(!cli.key){ var preRan = false
console.log(chalk.red("Invalid API key")); function preRun(){
cli.help() if(!cli.key){
console.log(chalk.red("Invalid API key"));
return false;
} else preRan = true
return true;
} }
function postNote(title,content,options){ function postNote(title,content,options){
if(!preRun()) return;
request.post({uri: baseurl(), json: { request.post({uri: baseurl(), json: {
title: title, title: title,
content: content, content: content,
@ -50,7 +76,8 @@ function postNote(title,content,options){
}) })
} }
function notes(archived,callback){ function getNotes(archived,showids,callback){
if(!preRun()) return;
if(cli.verbose) console.log(chalk.bold('URL: ') + baseurl()) if(cli.verbose) console.log(chalk.bold('URL: ') + baseurl())
request({ uri: baseurl() + (archived?'/archived':''), json: true }, function(error,response,body){ request({ uri: baseurl() + (archived?'/archived':''), json: true }, function(error,response,body){
if(error) if(error)
@ -64,17 +91,19 @@ function notes(archived,callback){
if(date != false) date = moment.unix(x.date).format('DD/MM/YYYY') if(date != false) date = moment.unix(x.date).format('DD/MM/YYYY')
var str = '\n' + chalk.green('- ') + chalk.bold(x.title) var str = '\n' + chalk.green('- ') + chalk.bold(x.title)
if(date != false) str += ' (' + chalk.yellow("Due: ") + chalk.underline(date) + ')' if(date != false) str += ' (' + chalk.yellow("Due: ") + chalk.underline(date) + ')'
if(cli.id) str += ' (' + chalk.bold('ID: ') + chalk.underline(x._id) + ')' if(showids) str += ' (' + chalk.bold('ID: ') + chalk.underline(x._id) + ')'
if(archived) str += ' (' + chalk.green('archived') + ')' if(archived) str += ' (' + chalk.green('archived') + ')'
if(x.content) str += '\n\t' + chalk.green(x.content) if(x.content) str += '\n\t' + chalk.green(x.content)
ret += str.substring(1) + '\n' ret += str.substring(1) + '\n'
}) })
} else callback(body) } else if(body.error) console.log(chalk.red("Error: ") + chalk.bold(body.error))
else callback(body)
callback(ret.substring(0,ret.length-1)) callback(ret.substring(0,ret.length-1))
}) })
} }
function delNotes(list){ function delNotes(list){
if(!preRun()) return;
var deleted = 0 var deleted = 0
list.forEach(function(x){ list.forEach(function(x){
request.del({ uri: baseurl()+'/'+x, json: true },function(error,response,body){ request.del({ uri: baseurl()+'/'+x, json: true },function(error,response,body){
@ -90,4 +119,19 @@ function delNotes(list){
if(!cli.silent) console.log() if(!cli.silent) console.log()
} }
if(!cli.silent) notes(cli.archived || false, console.log) // Run
fs.readFile(cfgpath,function(error,content){
var cfg = {}
if(error){
if(cli.verbose) console.log(chalk.red("Error: ")+chalk.bold(error))
} else try {
cfg = JSON.parse(content)
if(cfg.apiKey) cli.key = cfg.apiKey
if(cfg.url) cli.url = cfg.url
} catch(e){
console.log(chalk.yellow("Warning: ")+ "found configuration file at " + chalk.bold(cfgpath) + " but it is not a valid json:\n\t"+chalk.bold(e))
}
cli.parse(process.argv)
if(!preRan) console.log(chalk.green("Tip: ")+"see "+chalk.bold(cli.name()+" --help"))
})

View File

@ -1,6 +1,6 @@
{ {
"name": "homework-cli", "name": "homework-cli",
"version": "1.3.0", "version": "1.3.1",
"description": "command line client for Homework", "description": "command line client for Homework",
"bin":{ "bin":{
"homework": "homework.js" "homework": "homework.js"