X-Git-Url: https://git.toastfreeware.priv.at/gregoa/bti.git/blobdiff_plain/cb04fb58b1acdea0a50136b074bdbc1f5f4fa709..7f3eec8282036f9f606ff48fc221062b6c06e9b1:/bti.c diff --git a/bti.c b/bti.c index 588de2f..23de0e7 100644 --- a/bti.c +++ b/bti.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2008 Greg Kroah-Hartman + * Copyright (C) 2008-2010 Greg Kroah-Hartman * Copyright (C) 2009 Bart Trojanowski * Copyright (C) 2009 Amir Mohammad Saied * @@ -90,6 +90,7 @@ struct session { char *configfile; char *replyto; int bash; + int background; int interactive; int shrink_urls; int dry_run; @@ -109,31 +110,31 @@ struct bti_curl_buffer { static void display_help(void) { - fprintf(stdout, "bti - send tweet to twitter or identi.ca\n"); - fprintf(stdout, "Version: " VERSION "\n"); - fprintf(stdout, "Usage:\n"); - fprintf(stdout, " bti [options]\n"); - fprintf(stdout, "options are:\n"); - fprintf(stdout, " --account accountname\n"); - fprintf(stdout, " --password password\n"); - fprintf(stdout, " --action action\n"); - fprintf(stdout, " ('update', 'friends', 'public', 'replies', " - "'group' or 'user')\n"); - fprintf(stdout, " --user screenname\n"); - fprintf(stdout, " --group groupname\n"); - fprintf(stdout, " --proxy PROXY:PORT\n"); - fprintf(stdout, " --host HOST\n"); - fprintf(stdout, " --logfile logfile\n"); - fprintf(stdout, " --config configfile\n"); - fprintf(stdout, " --replyto ID\n"); - fprintf(stdout, " --shrink-urls\n"); - fprintf(stdout, " --page PAGENUMBER\n"); - fprintf(stdout, " --bash\n"); - fprintf(stdout, " --debug\n"); - fprintf(stdout, " --verbose\n"); - fprintf(stdout, " --dry-run\n"); - fprintf(stdout, " --version\n"); - fprintf(stdout, " --help\n"); + fprintf(stdout, "bti - send tweet to twitter or identi.ca\n" + "Version: %s\n" + "Usage:\n" + " bti [options]\n" + "options are:\n" + " --account accountname\n" + " --password password\n" + " --action action\n" + " ('update', 'friends', 'public', 'replies', or 'user')\n" + " --user screenname\n" + " --group groupname\n" + " --proxy PROXY:PORT\n" + " --host HOST\n" + " --logfile logfile\n" + " --config configfile\n" + " --replyto ID\n" + " --shrink-urls\n" + " --page PAGENUMBER\n" + " --bash\n" + " --background\n" + " --debug\n" + " --verbose\n" + " --dry-run\n" + " --version\n" + " --help\n", VERSION); } static void display_version(void) @@ -298,25 +299,25 @@ static void bti_curl_buffer_free(struct bti_curl_buffer *buffer) free(buffer); } -static const char *twitter_host = "http://api.twitter.com/1/statuses"; -static const char *identica_host = "https://identi.ca/api/statuses"; -static const char *twitter_name = "twitter"; -static const char *identica_name = "identi.ca"; - -static const char *twitter_request_token_uri = "http://twitter.com/oauth/request_token"; -static const char *twitter_access_token_uri = "http://twitter.com/oauth/access_token"; -static const char *twitter_authorize_uri = "http://twitter.com/oauth/authorize?oauth_token="; -static const char *identica_request_token_uri = "http://identi.ca/api/oauth/request_token"; -static const char *identica_access_token_uri = "http://identi.ca/api/oauth/access_token"; -static const char *identica_authorize_uri = "http://identi.ca/api/oauth/authorize?oauth_token="; - -static const char *user_uri = "/user_timeline/"; -static const char *update_uri = "/update.xml"; -static const char *public_uri = "/public_timeline.xml"; -static const char *friends_uri = "/friends_timeline.xml"; -static const char *mentions_uri = "/mentions.xml"; -static const char *replies_uri = "/replies.xml"; -static const char *group_uri = "/../statusnet/groups/timeline/"; +static const char twitter_host[] = "http://api.twitter.com/1/statuses"; +static const char identica_host[] = "https://identi.ca/api/statuses"; +static const char twitter_name[] = "twitter"; +static const char identica_name[] = "identi.ca"; + +static const char twitter_request_token_uri[] = "http://twitter.com/oauth/request_token"; +static const char twitter_access_token_uri[] = "http://twitter.com/oauth/access_token"; +static const char twitter_authorize_uri[] = "http://twitter.com/oauth/authorize?oauth_token="; +static const char identica_request_token_uri[] = "http://identi.ca/api/oauth/request_token"; +static const char identica_access_token_uri[] = "http://identi.ca/api/oauth/access_token"; +static const char identica_authorize_uri[] = "http://identi.ca/api/oauth/authorize?oauth_token="; + +static const char user_uri[] = "/user_timeline/"; +static const char update_uri[] = "/update.xml"; +static const char public_uri[] = "/public_timeline.xml"; +static const char friends_uri[] = "/friends_timeline.xml"; +static const char mentions_uri[] = "/mentions.xml"; +static const char replies_uri[] = "/replies.xml"; +static const char group_uri[] = "/../statusnet/groups/timeline/"; static CURL *curl_init(void) { @@ -524,9 +525,10 @@ static int request_access_token(struct session *session) free(reply); - fprintf(stdout, "Please open the following link in your browser, and "); - fprintf(stdout, "allow 'bti' to access your account. Then paste "); - fprintf(stdout, "back the provided PIN in here.\n"); + fprintf(stdout, + "Please open the following link in your browser, and " + "allow 'bti' to access your account. Then paste " + "back the provided PIN in here.\n"); if (session->host == HOST_TWITTER) { fprintf(stdout, "%s%s\nPIN: ", twitter_authorize_uri, at_key); verifier = session->readline(NULL); @@ -552,10 +554,12 @@ static int request_access_token(struct session *session) free(reply); - fprintf(stdout, "Please put these two lines in your bti "); - fprintf(stdout, "configuration file (~/.bti):\n"); - fprintf(stdout, "access_token_key=%s\n", at_key); - fprintf(stdout, "access_token_secret=%s\n", at_secret); + fprintf(stdout, + "Please put these two lines in your bti " + "configuration file (~/.bti):\n" + "access_token_key=%s\n" + "access_token_secret=%s\n", + at_key, at_secret); return 0; } @@ -681,7 +685,7 @@ static int send_request(struct session *session) curl_easy_setopt(curl, CURLOPT_WRITEDATA, curl_buf); if (!session->dry_run) { res = curl_easy_perform(curl); - if (res && !session->bash) { + if (res && !session->background) { fprintf(stderr, "error(%d) trying to perform " "operation\n", res); return -EINVAL; @@ -1310,6 +1314,7 @@ int main(int argc, char *argv[], char *envp[]) { "shrink-urls", 0, NULL, 's' }, { "help", 0, NULL, 'h' }, { "bash", 0, NULL, 'b' }, + { "background", 0, NULL, 'B' }, { "dry-run", 0, NULL, 'n' }, { "page", 1, NULL, 'g' }, { "version", 0, NULL, 'v' }, @@ -1461,6 +1466,9 @@ int main(int argc, char *argv[], char *envp[]) break; case 'b': session->bash = 1; + /* fall-through intended */ + case 'B': + session->background = 1; break; case 'c': if (session->configfile) @@ -1500,9 +1508,10 @@ int main(int argc, char *argv[], char *envp[]) if (session->host == HOST_TWITTER) { if (!session->consumer_key || !session->consumer_secret) { - fprintf(stderr, "Twitter no longer supuports HTTP basic authentication.\n"); - fprintf(stderr, "Both consumer key, and consumer secret are required"); - fprintf(stderr, " for bti in order to behave as an OAuth consumer.\n"); + fprintf(stderr, + "Twitter no longer supports HTTP basic authentication.\n" + "Both consumer key, and consumer secret are required" + " for bti in order to behave as an OAuth consumer.\n"); goto exit; } if (session->action == ACTION_GROUP) { @@ -1534,9 +1543,8 @@ int main(int argc, char *argv[], char *envp[]) } if (session->action == ACTION_UNKNOWN) { - fprintf(stderr, "Unknown action, valid actions are:\n"); - fprintf(stderr, "'update', 'friends', 'public', " - "'replies', 'group' or 'user'.\n"); + fprintf(stderr, "Unknown action, valid actions are:\n" + "'update', 'friends', 'public', 'replies', 'group' or 'user'.\n"); goto exit; } @@ -1546,7 +1554,7 @@ int main(int argc, char *argv[], char *envp[]) } if (session->action == ACTION_UPDATE) { - if (session->bash || !session->interactive) + if (session->background || !session->interactive) tweet = get_string_from_stdin(); else tweet = session->readline("tweet: "); @@ -1578,7 +1586,7 @@ int main(int argc, char *argv[], char *envp[]) /* fork ourself so that the main shell can get on * with it's life as we try to connect and handle everything */ - if (session->bash) { + if (session->background) { child = fork(); if (child) { dbg("child is %d\n", child); @@ -1587,7 +1595,7 @@ int main(int argc, char *argv[], char *envp[]) } retval = send_request(session); - if (retval && !session->bash) + if (retval && !session->background) fprintf(stderr, "operation failed\n"); log_session(session, retval);