Esempio n. 1
0
func (e *Extractor) Process(job J.Job) {
	job.Progress("Extracting...")

	defer e.wg.Done()
	resp, err := e.extractRetry(job.Url, job.Content)
	if err != nil {
		e.error(job, "%s", err)
		return
	}

	doc, err := rewriteAndDownloadImages(job.Root(), resp.Content)
	if err != nil {
		e.error(job, "HTML parsing failed: %s", err)
		return
	}

	job.Doc = doc
	if resp.Title != "" {
		job.Title = resp.Title
	}
	job.Domain = resp.Domain
	if resp.Author != nil {
		job.Author = *resp.Author
	}

	job.Progress("Extraction complete...")
	e.Output <- job
}
Esempio n. 2
0
func (c *Cleaner) Process(job J.Job) {
	defer c.wg.Done()
	if job.Friendly != "" {
		job.Progress(job.Friendly)
	}

	os.RemoveAll(job.Root())
}
Esempio n. 3
0
func writeHTML(job J.Job) error {
	file, err := os.OpenFile(job.HTMLFilePath(), os.O_CREATE|os.O_WRONLY, 0644)
	if err != nil {
		return fmt.Errorf("failed opening file: %s", err)
	}
	defer file.Close()

	if err = template.Execute(file, &job); err != nil {
		return fmt.Errorf("failed executing template: %s", err)
	}
	return nil
}
Esempio n. 4
0
func (e *Emailer) Process(job J.Job) {
	job.Progress("Sending to your Kindle...")

	defer e.wg.Done()
	if st, err := os.Stat(job.MobiFilePath()); err != nil {
		e.error(job, FriendlyMessage, "Something weird happened. Mobi is missing: %s", err)
		return
	} else {
		if st.Size() > MaxAttachmentSize {
			blacklist.Blacklist(job.Url)
			e.error(job, "Sorry, this article is too big to send!", "Attachment was too big (%d bytes)", st.Size())
			return
		}
	}

	m := &postmark.Message{
		From:     e.from,
		To:       job.Email,
		Subject:  Subject,
		TextBody: fmt.Sprintf("Straight to your Kindle! %s: %s", job.Title, job.Url),
	}

	if err := m.Attach(job.MobiFilePath()); err != nil {
		e.error(job, FriendlyMessage, "failed attaching file: %s", err)
		return
	}

	resp, err := e.postmark.Send(m)
	if resp == nil {
		e.error(job, FriendlyMessage, "failed sending email: %s", err)
		return
	}

	switch resp.ErrorCode {
	case 0:
		// All is well
	case 422:
		e.error(job, FriendlyMessage, "failed sending email: %s: %s", err, resp.Message)
		return
	case 300:
		e.error(job, "Your email appears invalid. Please try carefully remaking the bookmarklet.", "emailer: Email inactive or invalid")
		return
	case 406:
		e.error(job, "Your email appears to have bounced. Amazon likes to bounce emails sometimes, and my provider 'deactivates' the email. For now, try changing your Personal Documents Email. I'm trying to find a proper solution for this :(", "emailer: Email inactive or invalid")
		return
	default:
		e.error(job, FriendlyMessage, "Something bizarre happened with Postmark: %s", resp.Message)
		return
	}

	job.Progress("All done! Grab your Kindle and hang tight!")
	cache.Set(resp.MessageID, job.Url, OneHour)
	recordDurationStat(job)
	e.Output <- job
}
Esempio n. 5
0
func (k *Kindlegen) Process(job J.Job) {
	job.Progress("Optimizing for Kindle...")

	defer k.wg.Done()
	if err := writeHTML(job); err != nil {
		k.error(job, err.Error())
		return
	}

	cmd := exec.Command(k.binary, []string{job.HTMLFilename()}...)
	cmd.Dir = job.Root()
	out, err := cmd.CombinedOutput()
	if !fileExists(job.MobiFilePath()) {
		k.error(job, "failed running kindlegen: %s {output=%s}", err, out)
		return
	}

	job.Progress("Optimization complete...")
	k.Output <- job
}
Esempio n. 6
0
func (e *Emailer) error(job J.Job, friendly, format string, args ...interface{}) {
	logger.Printf(format, args...)
	job.Friendly = friendly
	e.Error <- job
}
Esempio n. 7
0
func (e *Extractor) error(job J.Job, format string, args ...interface{}) {
	logger.Printf(format, args...)
	job.Friendly = FriendlyMessage
	e.Error <- job
}
Esempio n. 8
0
func (k *Kindlegen) error(job J.Job, format string, args ...interface{}) {
	logger.Printf(format, args...)
	job.Friendly = FriendlyMessage
	k.Error <- job
}