X("server host", 6, SERVSW) \
X("snoop", 5, SNOOPSW) \
X("sasl", SASLminc(4), SASLSW) \
- X("nosasl", SASLminc(-6), NOSASLSW) \
- X("saslmaxssf", SASLminc(-10), SASLMXSSFSW) \
- X("saslmech mechanism", SASLminc(-5), SASLMECHSW) \
- X("oauth service", 0, OAUTHSW) \
+ X("nosasl", SASLminc(6), NOSASLSW) \
+ X("saslmech mechanism", SASLminc(6), SASLMECHSW) \
+ X("authservice", SASLminc(0), AUTHSERVICESW) \
X("user username", SASLminc(-4), USERSW) \
X("attach", -6, ATTACHSW) \
X("noattach", -8, NOATTACHSW) \
char *cp, *dfolder = NULL, *maildir = NULL;
char buf[BUFSIZ], **ap, **argp, **arguments, *program;
char *msgs[MAXARGS], **vec;
- const char *user = NULL, *oauth_svc = NULL;
+ const char *user = NULL, *saslmech = NULL;
struct msgs *mp;
struct stat st;
int snoop = 0;
+ char *auth_svc = NULL;
if (nmh_init(argv[0], 1)) { return 1; }
vec[vecp++] = --cp;
continue;
- case OAUTHSW:
-#ifdef OAUTH_SUPPORT
- if (!(cp = *argp++) || *cp == '-')
- adios (NULL, "missing argument to %s", argp[-2]);
- oauth_svc = cp;
-#else
- NMH_UNUSED (user);
- NMH_UNUSED (oauth_svc);
- adios (NULL, "not built with OAuth support");
-#endif
- continue;
-
case USERSW:
vec[vecp++] = --cp;
if (!(cp = *argp++) || *cp == '-')
user = cp;
continue;
+ case AUTHSERVICESW:
+#ifdef OAUTH_SUPPORT
+ if (!(auth_svc = *argp++) || *auth_svc == '-')
+ adios (NULL, "missing argument to %s", argp[-2]);
+#else
+ adios (NULL, "not built with OAuth support");
+#endif
+ continue;
+
+ case SASLMECHSW:
+ if (!(saslmech = *argp) || *saslmech == '-')
+ adios (NULL, "missing argument to %s", argp[-2]);
+ /* Fall through */
+
case ALIASW:
case FILTSW:
case WIDTHSW:
case CLIESW:
case SERVSW:
- case SASLMECHSW:
- case SASLMXSSFSW:
case PORTSW:
case MTSSM:
case MTSSW:
if ((cp = context_find ("Aliasfile"))) {
char *dp = NULL;
- for (ap = brkstring(dp = getcpy(cp), " ", "\n"); ap && *ap; ap++) {
+ for (ap = brkstring(dp = mh_xstrdup(cp), " ", "\n"); ap && *ap; ap++) {
vec[vecp++] = "-alias";
vec[vecp++] = *ap;
}
adios (msgs[0], "unable to stat draft file");
cp = concat ("Use \"", msgs[0], "\"? ", NULL);
for (status = LISTDSW; status != YESW;) {
- if (!(argp = getans (cp, anyl)))
+ if (!(argp = read_switch_multiword (cp, anyl)))
done (1);
switch (status = smatch (*argp, anyl)) {
case NOSW:
for (msgp = 0, msgnum = mp->lowsel; msgnum <= mp->hghsel; msgnum++) {
if (is_selected (mp, msgnum)) {
- msgs[msgp++] = getcpy (m_name (msgnum));
+ msgs[msgp++] = mh_xstrdup(m_name (msgnum));
unset_exists (mp, msgnum);
}
}
adios(NULL, "unable to create temporary file in %s",
get_temp_dir());
}
- distfile = getcpy (cp);
+ distfile = mh_xstrdup(cp);
(void) m_unlink(distfile);
if (link (altmsg, distfile) == NOTOK) {
/* Cygwin with FAT32 filesystem produces EPERM. */
adios(NULL, "unable to create temporary file in %s",
get_temp_dir());
}
- distfile = getcpy (cp);
+ distfile = mh_xstrdup(cp);
{
int in, out;
struct stat st;
}
#ifdef OAUTH_SUPPORT
- if (oauth_svc != NULL) {
+ if (auth_svc == NULL) {
+ if (saslmech && ! strcasecmp(saslmech, "xoauth2")) {
+ adios (NULL, "must specify -authservice with -saslmech xoauth2");
+ }
+ } else {
if (user == NULL) {
- adios (NULL, "must specify -user with -oauth");
+ adios (NULL, "must specify -user with -saslmech xoauth2");
}
-
- vec[vecp++] = "-oauth";
- vec[vecp++] = mh_oauth_do_xoauth (user, oauth_svc,
- snoop ? stderr : NULL);
}
+#else
+ NMH_UNUSED(auth_svc);
+ NMH_UNUSED(user);
+ NMH_UNUSED(saslmech);
#endif /* OAUTH_SUPPORT */
if (altmsg == NULL || stat (altmsg, &st) == NOTOK) {
closefds (3);
for (msgnum = 0; msgnum < msgp; msgnum++) {
- switch (sendsbr (vec, vecp, program, msgs[msgnum], &st, 1)) {
+ switch (sendsbr (vec, vecp, program, msgs[msgnum], &st, 1, auth_svc)) {
case DONE:
done (++status);
case NOTOK: