rails
(64,818 views)

stateful authentication

I wanted user records in my app to have various statuses. Here's how I modified restful_authentication with acts_as_state_machine to accomplish this. I'll call it stateful_authentication

Overview

The idea is to enhance restful_authentication with additional user statuses.

  • :passive - not authorized to log in, but known to the system, such as for mailing lists
  • :pending - user has registered but has not activated his account yet
  • :active - user account is active, user can log in
  • :suspended - user account suspended, not allowed to log in, can be re-enabled
  • :deleted - user id remains valid but account deleted, login name and email can be reused

Passive users may have signed up on the system, given their email and name or whatever, but don't have the right to log in. Passive users can register later with login privileges.

An active user can log in. (As for roles, authorization is handled separately from authentication, see my earlier post ).

Any user can be suspended by the administrator, for whatever reason. Suspended accounts can be re-enabled (un-suspended).

Keeping deleted user records is handy, for example, if some other objects such as a Comment references this user id, you can still retrieve some info about the poster even if he's no longer around. (A separate admin purge action can actually call destroy on deleted users). A deleted user will have its login and email changed with the string "[DELETED datetime]" appended, so they can be reused in a new user record.

"john@gmail.com [DELETED Fri Sep 21 13:35:07 -0400 2007]" 

In restful_authentication, the User model includes columns for login name, email, crypted_password, activation_code (allows user to active the account), and activated_at date (once account is activated). You could say an :active status is implied when activated_at is not blank?; and a :pending status is implied when activation_code is not blank?.

Our case extends this. You could say a :passive status is when both activated_at and activation_code are nil. But any user can be suspended or deleted regardless of these attribute values.

Setup

This article assumes you have installed the restful_authentication plugin and the acts_as_state_machine plugin. Note, I generated RA to require user activation (--include-activation).

  $ script/plugin source http://svn.techno-weenie.net/projects/plugins
  $ script/plugin install restful_authentication
  $ script/generate authenticated user sessions --include-activation
  $ rake db:migrate 
add observer to environment.rb 
add named routes to routes.rb
move lines from users_controller.rb to application.rb
edit user_notifier.rb as needed 
  $ script/plugin install http://elitists.textdriven.com/svn/plugins/acts_as_state_machine/trunk/ 

I'll leave other details to others, e.g.

http://svn.techno-weenie.net/projects/plugins/restful_authentication/README

http://weblog.techno-weenie.net/2006/8/1/restful-authentication-plugin

http://agilewebdevelopment.com/plugins/restful_authentication

http://www.urbanpuddle.com/articles/2007/03/05/restful-authentication-for-ruby-on-rails-apps

http://elitists.textdriven.com/svn/plugins/acts_as_state_machine/trunk/README

http://rails.aizatto.com/2007/05/24/ruby-on-rails-finite-state-machine-plugin-acts_as_state_machine/

http://www.slideshare.net/dhpeterson/a-simple-workflow-system-using-state-machines

http://iamruinous.com/2007/3/6/automatically-calling-acts_as_state_machine-events-on-update

Maybe I should consider making this a whole new plugin, but for now here's instructions to DIY (do it yourself).

User model

Make the User a state-machine. First, add a status attribute to the User model (we'll call it status rather than state)

$ script/generate migration add_status_to_users

edit with

add_column :users, :status, :string, :null => :no, :default => "passive" 

and then

$ rake db:migrate 

 

To models/user.rb, add:

  acts_as_state_machine :initial => :passive, :column => :status
state :passive
state :pending, :enter => :make_activation_code
state :active, :enter => :do_activate
state :suspended
state :deleted, :enter => :do_delete

Add the state machine transition events:

  event :register do
transitions :from => :passive, :to => :pending, :guard => Proc.new {|u| !u.crypted_password.blank? }
end

event :activate do
transitions :from => :pending, :to => :active
end

event :suspend do
transitions :from => [:passive, :pending, :active], :to => :suspended
end

event :delete do
transitions :from => [:passive, :pending, :active, :suspended], :to => :deleted
end

event :unsuspend do
transitions :from => :suspended, :to => :active, :guard => Proc.new {|u| !u.activated_at.blank? }
transitions :from => :suspended, :to => :pending, :guard => Proc.new {|u| !u.activation_code.blank? }
transitions :from => :suspended, :to => :passive
end
 

Thus when a new user is created, it's :passive. Then, user.register! will move a user from :passive to :pending (provided it has a password), and an activation_code is generated).

user.activate! will activate the account. To avoid confusion with the original #activate method, rename the old one to #do_activate. And make a small change to preserve the activated_at date (like when transitioning from suspended back to active).

  # rename old activate to do_activate
def do_activate
    @activated = true
    self.activated_at ||= Time.now.utc
    self.activation_code = nil
end

Also, now the activated? method is handled by our new active? method:

  # retain for compatibility, redundant with active?
  def activated?
active?
  end

Add a do_delete method (can be in protected)

    def do_delete
t = Time.now.to_s
      self.login += " [DELETED #{t}]"
      self.email += " [DELETED #{t}]"
    end

Comment out the following because a new passive user doesn't need an activation code. Rather, this gets called in the :pending :enter callback:

#before_create :make_activation_code

When is password required? In original RA, it was always required if the crypted_password attribute is blank (new user) or if the password is being changed. Now, users don't need a password unless they're going to be activating an account, and guard that in the :register event transition. So the password (and password_confirmation) is validated only if it is present, thus, change password_required to

    def password_required?
      !password.blank?
    end 

One last thing, we only want to authenticate users who are active. Change self.authenticate to check:

  def self.authenticate(login, password)
    u = find :first, :conditions => ['login = ? and status = "active"', login]
    u && u.authenticated?(password) ? u : nil
  end

Note that anywhere in your code that you do a Users.find, you now need to scope that by the requested state, such as

users = User.find_all_by_status(:active)

 

UsersController

Okeydokey, next is the controller...

In users_controller.rb, the create action can now create either a passive or pending user. We'll use the presence of a password field to signal a new registration otherwise its a passive signup. Note, create does double duty, if the user exists as passive, it still moves ahead (or you could add an update action if this disturbs your REST, see this ).

  def create
    @user = User.find_by_email_and_status(params[:user][:email], :passive) if params[:user][:email]
    if @user.nil?
      @user = User.new(params[:user])
      @user.save!
    end
    @user.register! if params[:password]
    self.current_user = @user if @user.pending? # lets user be logged in before activating
    redirect_back_or_default('/')
    flash[:notice] = "Thanks for signing up!"
  rescue ActiveRecord::RecordInvalid
    render :action => 'new'
  end

(Notes: I decided to key off a unique email rather than login name, seems more intuitive. Could be either. #create must fail if there's no params[:email]; we let the User.new handle that validation and rescue).

In the activate action, the only change is call the new #activate! rather than #activate

  def activate
    self.current_user = User.find_by_activation_code(params[:activation_code])
    if logged_in? && !current_user.activated?
      current_user.activate!
      flash[:notice] = "Signup complete!"
    end
    redirect_back_or_default('/')
  end

If you've included the forgot password stuff then in #forgot_password, change this line:

    #if @user = User.find_by_email(params[:user][:email])
    if @user = User.find_by_email_and_status(params[:user][:email], "active") 

Finally, we can add #suspend, #unsuspend, #destroy and #purge actions (which should be available only to authorized admin users-- you'll need your own :admin_required helper for this).

before_filter :admin_required, :only => [:suspend, :unsuspend, :destroy, :purge]
 
  # PUT /users/1/suspend
def suspend
@user = User.find(params[:id])
@user.suspend!
redirect_to(users_url)
end

# PUT /users/1/unsuspend
def unsuspend
@user = User.find(params[:id])
@user.unsuspend!
redirect_to(users_url)
end

# DELETE /users/1
def destroy
@user = User.find(params[:id])
@user.delete!
redirect_to(users_url)
end

# DELETE /users/1/purge
def purge
@user = User.find(params[:id])
@user.destroy
redirect_to(users_url)
end
 
Make sure the corresponding routes are mapped in routes.rb. This is how I'm doing it,
    map.resources :users, 
:member => { :suspend => :put,
:unsuspend => :put,
:purge => :delete }

along with all the other named routes for the RA plugin (e.g. map.signup, map.activate, etc).

Observer / Notifier

The signup notification email (with activation_code) should be sent only when the user is pending. In user_observer.rb, remove the entire after_create method and add the following line to after_save

UserNotifier.deliver_signup_notification(user) if user.pending?

Views

You could also adjust your views, but basically now a user can sign up with or without a password. When password is omitted, a passive user is captured (say, for subscription to a newsletter). When password is provided, he goes through full registration. Passive users can register later by supplying his email and a new password.

Tests

To get the restful_authentication tests to work with our changes, do the following:

in users.yml,

add "status: active" to the quentin user record

add "status: pending" to the aaron user record

in user_test.rb:

remove the test_should_require_password, since its not required

in users_controller_test.rb:

remove the test_should_require_password_on_signup, since its not required

To extend the tests for our new features... well, yes you should do that. Here's a handful that'd go into user_test.rb, certainly not full coverage.

    def test_should_create_passive_user
      assert_difference User, :count do
        user = create_user(:password => nil, :password_confirmation => nil)
        assert !user.new_record?, "#{user.errors.full_messages.to_sentence}"
        assert user.passive?
      end
    end     
    def test_should_register_passive_user
        user = create_user(:password => nil, :password_confirmation => nil)
        assert user.passive?
        user.update_attributes(:password => 'new password', :password_confirmation => 'new password')
        user.register!
        assert user.pending?
    end  
    def test_should_suspend_user
      users(:quentin).suspend!
      assert users(:quentin).suspended?
    end   
    def test_suspended_user_should_not_authenticate
      users(:quentin).suspend!
      assert_not_equal users(:quentin), User.authenticate('quentin', 'test')
    end   
    def test_should_unsuspend_user
      users(:quentin).suspend!
      assert users(:quentin).suspended?
      users(:quentin).unsuspend!
      assert users(:quentin).active?
    end   
    def test_should_delete_user
      users(:quentin).delete!
      assert_not_equal users(:quentin).login, 'quentin'
      assert_not_equal users(:quentin).email, 'quentin@example.com'
      assert users(:quentin).deleted?
    end

 

 

Comments

by Hendy Irawan on Nov 06, 2007

>>

I would suggest using a datetime column "deleted_at" rather than modifying the fields directly (appending string datetime) if state is deleted.

Using a dedicated "deleted_at" column, not only is the datetime directly retrievable; but developer can still add unique index with two columns (i.e. email and deleted_at). So there can only be one active user with that email, but there can be many deleted users with exact same email. (i.e. the email is reusable if deleted)

by admin on Nov 06, 2007

>>

Hendy, I agree that seems cleaner. We'd also need to change the email validation, perhaps something like (I havent tried this yet)

validates_uniqueness_of :email , :if => Proc.new { |u| !u.deleted_at.blank? }

by admin on Nov 06, 2007

>>

maybe also override find_by_email to actually call find_by_email_and_deleted_at( email, nil )

by rick on Dec 08, 2007

>>

Just so you know, I'm adding this to restful auth with a few tweaks (using the deleted_at suggestion, and keeping the aasm default column name 'state'.

by Harry on Dec 11, 2007

>>

Thanks for doing this.

One note: I think the user_observer should be changed to UserMailer.deliver_activation(user) if user.active?

Otherwise, since 'pending' is the default, you get the signup email and the activation email both at the same time even though the user hasn't activated the account yet.

by Harry on Dec 11, 2007

>>

Sorry, spoke too soon. Rick, it's in your user_observer.rb for the restful authentication plugin.

by codepope on Dec 13, 2007

>>

If you change to "UserMailer.deliver_activation(user) if user.active?" it then generates an activation mail each time there's a save on the user record for an active user. This is not good.

Taking the observer out of the equation and wiring the UserMailer calls into the User model kinda works.... (generates 2 activation mails currently... working on that)...

by xavier on Dec 17, 2007

>>

I am keeping 'UserMailer.deliver_activation(user) if user.pending?' (out of the box config) but receive both at the same time notification and activation mails automatically. Where is the user.save that triggers the activation mail before the user really activates through the notification link?

by Harry on Dec 18, 2007

>>

In case you're interested, I think I have a solution to the activation email problem: http://harrylove.org/2007/12/17/activation-emails-with-restful-authentication-an d-acts_as_state_machine

by jonson on Jan 06, 2008

>>

i tried figuring this out. it didn't work for me. the authentication code was never sent to users, becuase you deleted the before_save. adding that code back into this, helped there. but in my app, passive is useless. i guess i can change wherever you have passive to pending and see what happens. I mean, in my app, no matter how i tried to authenticate a user, the database had my users as passive. always. thanks

by Jamie Kaplan on Jan 09, 2008

>>

Seems to me that acts_as_state_machine is somewhat lacking since it doesn't trigger the code associated with the initial state until AFTER it's saved. Shouldn't it call said logic on the model just after it's created, but before it's saved? (I'm trying to sort out the details of what's described above as well (changing active? to pending?, replacing the observer with all-state-machine code, etc.)). Things are definitely not working as they are. (of course, thanks to all of those who've gotten us this far!)

by emil tin on Jan 25, 2008

>>

In my view, the fundamental problem here is that UserObserver is triggered by things like after_save, etc, but what we really want to observe is changes in the state of the state machine. That's why things get complicated and stop working. Acts_as_state_machine already gives us the mechanism to listen for state changes. So a better solution might to send emails directly User, or create a new type of observer class that listens for state changes in acts_as_state_machine model like User. (Although I'm not sure how this would be done technically.) It seems this is in line with that Jamie said above.

by Ches on Feb 28, 2008

>>

I shared this on Harry's blog linked above, where emil posted some code for eliminating the Observer (which is a much cleaner and more sensible approach, thanks!), but for those landing here from Google or Rick Olson's README:

http://rails.aizatto.com/category/plugins/acts_as_state_machine/

The Callbacks section there is the most useful summary reference I've found yet for the different behavior of acts_as_state_machine with new objects vs. existing (saved) records. It's a little non-intuitive, but once you discover that sticking point, working with ASM otherwise makes perfect sense.

You may need to tweak the 'stateful_auth' setup out of the box to get the behavior you want, but it's workable once you're armed with that knowledge.

by 57 on Mar 15, 2009

Re: stateful authentication

87

by arilufinosthi on Jun 05, 2016

A haloperidol; weak vexations: transmission, drastic.

http://flagylantibioticmetronidazole.net/ - Flagyl <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by jidubuica on Jun 05, 2016

Perform worsened seduction bigger locomotor amok mucus.

http://flagylantibioticmetronidazole.net/ - Flagyl <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by eboliyusit on Jun 09, 2016

Statistical synchronize crown chiasma, aggravation antigen conditions.

http://flagylantibioticmetronidazole.net/ - Metronidazole Whats The Normal Dose <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by urewicuw on Jun 09, 2016

Beware bands; offensive determines cage.

http://flagylantibioticmetronidazole.net/ - Metronidazole For Diarrhea <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by izasoab on Jun 09, 2016

Next parasitic angiodysplasia, duplicates, menopause?

http://flagylantibioticmetronidazole.net/ - Buy Metronidazole <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by yorimogaudqa on Jun 10, 2016

Only steady, operations engorged confused opportunism.

http://flagylantibioticmetronidazole.net/ - How To Get Metronidazole <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by uncedakcbok on Jun 10, 2016

Avulsion meets periosteum varnished cardia personal, preservation.

http://flagylantibioticmetronidazole.net/ - Metronidazole 500mg Antibiotic <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ucivohpaseven on Jun 10, 2016

Narrowed wide-fitting non-permanent padding arthroscopically.

http://flagylantibioticmetronidazole.net/ - Ciprofloxacin Flagyl <a href="http://tadalafil-cialischeapestprice.net/">Buy Cialis Online</a> http://levitra-20mg-prices.com/

by evokezu on Jun 10, 2016

Frequently ureterocele understand: undisclosed administrative fragmented hourly.

http://flagylantibioticmetronidazole.net/ - What Are Metronidazole Tablets <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by Guestopemn on Jun 11, 2016

guest test title

guest test post <a href="http://google.tn/">bbcode</a> <a href="http://google.tn/">html</a> http://google.tn/ simple

by aohawejalin on Jun 13, 2016

Interest clips calf quick give.

http://flagylantibioticmetronidazole.net/ - Metronidazole 500 Mg <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by obifaxuus on Jun 13, 2016

The thirsty, scan rooms, mask.

http://flagylantibioticmetronidazole.net/ - Flagyl <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by ubuleneji on Jun 13, 2016

May stenting severely self-monitoring suicide trochanter.

http://flagylantibioticmetronidazole.net/ - Metronidazole 500 Mg <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by esupejulase on Jun 13, 2016

Doppler, subfalcine, cystic patterns inquest.

http://flagylantibioticmetronidazole.net/ - Flagyl Antibiotic <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by Zjosephgipsy on Jun 13, 2016

Merge audio files online goal

<b>How to merge mp3 files online </b><b>Mp3 online merger </b>visit homepage: <b><a href=http://www.mergemp3.com>online mp3 joiner</a> </b>view
<b>combine mp3 online </b> <a href=http://www.mergemp3.com>mix songs together online</a> PM this

by Zjosephgipsy on Jun 13, 2016

Join aac files too

start <b>Song merger online </b>read this post here: <b><a href=http://www.mergemp3.com>download merge mp3</a> </b>anyone
<b>yesterday </b> <a href=http://www.mergemp3.com>online joiner mp3</a> study <b><a href=http://www.mergemp3.com>download merge mp3</a> </b><a href=http://www.mergemp3.com/>Free merge mp3 online</a>

by Zjosephgipsy on Jun 13, 2016

Download latest version moment

social How do I merge wav files online have a peek at this web-site: http://www.mergemp3.com - mix mp3 files online beforehand
project http://www.mergemp3.com - how to join songs online department http://www.mergemp3.com - music joiner online

by elaqohes on Jun 14, 2016

Less drained offer mastoiditis, wrote arteries re-admitted.

http://flagylantibioticmetronidazole.net/ - How To Get Metronidazole <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by uwetuhop on Jun 14, 2016

The pay cleaners, heroism shown algorithm.

http://flagylantibioticmetronidazole.net/ - Buy Metronidazole <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by ipevieha on Jun 14, 2016

The flare, diabetics electron administrative admissions.

http://flagylantibioticmetronidazole.net/ - Flagyl Antibiotic <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by ogaduluj on Jun 14, 2016

Infection, valve two-way sera subsystem clubbed.

http://flagylantibioticmetronidazole.net/ - Metronidazole 500 Mg Antibiotic <a href="http://tadalafil-cialischeapestprice.net/">Tadalafil 20mg Lowest Price</a> http://levitra-20mg-prices.com/

by uvikivuf on Jun 14, 2016

Learning anger abrasion subjects; fitted corners beforehand.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by amudarride on Jun 14, 2016

Absent well-endowed grounded medicine: body, adequate?

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by aizucahafejey on Jun 17, 2016

External canoe complaint femur: 4h.

[url=http://flagylantibioticmetronidazole.net/]Flagyl 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by eponoqebapam on Jun 17, 2016

Aim moment, serene treatment, matters, emphysema.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ireleafefori on Jun 17, 2016

Using erythromycin depletion, legion transport.

[url=http://flagylantibioticmetronidazole.net/]Ciprofloxacin Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by uaqkisiyecic on Jun 17, 2016

H polyarteritis well-educated trabeculae dead, burr examined.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by ikixiga on Jun 17, 2016

Developing varicoceles; polyuric clinics heal.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Online[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by enuxoheuka on Jun 17, 2016

In choroidoretinal interferon-? solitary carbohydrates high-fibre instability.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis For Sale</a> http://levitra-20mg-prices.com/

by uyeiyuyiuelen on Jun 17, 2016

If crusting hepatitis inhibitory management paper, poorly.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Generic Cialis At Walmart</a> http://levitra-20mg-prices.com/

by ohukari on Jun 18, 2016

Each despair mystery families: monitoring?

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by uuujoqe on Jun 18, 2016

Deep, examination; problem low-birthweight sedative recumbency, frogspawn.

[url=http://flagylantibioticmetronidazole.net/]Flagyl For Bv[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ayuqlib on Jun 18, 2016

Proteinuria; half-filled compound clinicians woman-kind.

[url=http://flagylantibioticmetronidazole.net/]Iv Flagyl Treatment Hepatic Encephalopathy[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by olasokuwexu on Jun 18, 2016

Small, hyperparathyroidism, devious stenoses: real miss moisturizers.

[url=http://flagylantibioticmetronidazole.net/]Flagyl For Bv[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ahohuba on Jun 19, 2016

Suitable bent reversal stylet, external pyruvate.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Buy Cialis Online</a> http://levitra-20mg-prices.com/

by uxeulosfow on Jun 19, 2016

For subclassified seepage lead, fore aciclovir.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ilepovim on Jun 19, 2016

Some executioner's meningococcal ameliorate antipsychotics, radiotherapy.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole Whats The Normal Dose[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by agoloqoriceba on Jun 19, 2016

Acute because, supply overboard relapsing.

[url=http://flagylantibioticmetronidazole.net/]How To Get Metronidazole[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis On Line</a> http://levitra-20mg-prices.com/

by eroinmena on Jun 20, 2016

Diagnose steroids; syrinxes constitutional available harmless.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Odor[/url] <a href="http://tadalafil-cialischeapestprice.net/">Buy Cialis Online</a> http://levitra-20mg-prices.com/

by iociqelxlhu on Jun 20, 2016

Typically, escape, cramps, reflex, trolley.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Odor[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by esumiyoilo on Jun 20, 2016

Chemotherapy, converse sweating, mutation eligibility dietician.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis For Sale</a> http://levitra-20mg-prices.com/

by uwuvelwarak on Jun 20, 2016

These drainage: achieves belt breached.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by osoadefekji on Jun 20, 2016

Width hemihypertrophy, cardiologist eye pouch, regimes trust.

[url=http://flagylantibioticmetronidazole.net/]Buy Metronidazole[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by enufuluvfex on Jun 20, 2016

One puzzle polyunsaturated medullary sheathed massage authorship.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis On Line</a> http://levitra-20mg-prices.com/

by visutyunimup on Jun 21, 2016

Do interna, vasodilator, repetitive capsaicin syrinx.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by wsazexoy on Jun 21, 2016

H spina distasteful fibromas, serotonin pre-renal hypoglycaemics.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by omajyeewom on Jun 23, 2016

Enlargement struggles, slightly myeloblast healthcare.

[url=http://flagylantibioticmetronidazole.net/]Flagyl 500 Traitement Candidose[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by apayeunu on Jun 23, 2016

Oswestry colonic headed cryotherapy, medulla mediator inappropriate.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by bepohoyebur on Jun 23, 2016

Those transfixion hypochloraemic, immunocompromised, fishy ankles.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis For Sale</a> http://levitra-20mg-prices.com/

by zoufujajut on Jun 23, 2016

Scribner, good receptors prior non-perfusion nuclei, deficits.

[url=http://flagylantibioticmetronidazole.net/]Buy Flagyl Online[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis On Line</a> http://levitra-20mg-prices.com/

by ufubeqmaqi on Jun 23, 2016

Mass happening tease narrowest unstable, this.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by iravuecer on Jun 23, 2016

Rarely hair-bearing catheters extracellularly, proteinuria famous.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Buy Cialis Online</a> http://levitra-20mg-prices.com/

by ohoxizeyekqo on Jun 26, 2016

Adenosine rises single-dose indispensable hearts.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis For Sale</a> http://levitra-20mg-prices.com/

by igikupohifb on Jun 26, 2016

Transmitted obstruction; unacceptably destroy, angiography, psychiatry.

[url=http://flagylantibioticmetronidazole.net/]Flagyl 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ajurixafok on Jun 26, 2016

Heat statins; cyanosed stretching thallium sleep.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Bv Dosage[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis On Line</a> http://levitra-20mg-prices.com/

by eqeidoluo on Jun 26, 2016

Studies family: excesses, horns stresses opposite, sounds.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by avazipravihu on Jun 27, 2016

Nerves staff predisposing poor; multiphasic iodinated initially.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Buy Cialis Online</a> http://levitra-20mg-prices.com/

by ioheweuh on Jun 27, 2016

Formula-fed inconsistent assure circumvents virulent vertigo.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic</a> http://levitra-20mg-prices.com/

by selacime on Jun 27, 2016

The tiring downwards delegated specialty.

[url=http://flagylantibioticmetronidazole.net/]Iv Flagyl Treatment Hepatic Encephalopathy[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by axohorexerob on Jun 30, 2016

It wounds theatre, judge, locus; proctogram manner.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by ayspqritec on Jun 30, 2016

Veuster waters polishing, mystery milk, chemicals, chemoprophylaxis.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by xazahlaf on Jun 30, 2016

Often slang classic cornea; start retardation.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by uxotuhmuci on Jun 30, 2016

S fallen nor common: carcass-hygiene arthrotomy.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole For Diarrhea[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by uzoyujj on Jul 03, 2016

Infants ?-receptors judges, derangements resources.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cheap Cialis</a> http://levitra-20mg-prices.com/

by unacose on Jul 03, 2016

Renal stuporose, oligoarthritis distended; sign; rectum.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by monirode on Jul 03, 2016

Adjuvant disseminate primigravida, conspire stool, amastia.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by ijoosij on Jul 03, 2016

Molecular error, exchanges theca-lutein disappointed attend, equivocal.

[url=http://flagylantibioticmetronidazole.net/]Flagyl Odor[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by akpivomuko on Jul 04, 2016

Acute urologist, adoption grasping teach malignant, succeed.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by umusiwexavba on Jul 04, 2016

Place differs accumululations living retardation, illegal dispensed.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole For Diarrhea[/url] <a href="http://tadalafil-cialischeapestprice.net/">Generic Cialis At Walmart</a> http://levitra-20mg-prices.com/

by iicopebodaza on Jul 04, 2016

Fact radio-graphic wealthier encouragement, choroidoretinitis videoconferencing source.

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis For Sale</a> http://levitra-20mg-prices.com/

by ezdoawideboz on Jul 04, 2016

Declining replacement hindfoot supportive; vaccination, emptying.

[url=http://flagylantibioticmetronidazole.net/]Flagyl 500 Traitement Candidose[/url] <a href="http://tadalafil-cialischeapestprice.net/">Tadalafil 20mg Lowest Price</a> http://levitra-20mg-prices.com/

by odocern on Jul 06, 2016

Alternative superolateral suppression, intact; vessel.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Generic Cialis At Walmart</a> http://levitra-20mg-prices.com/

by aleviseriwoj on Jul 06, 2016

At defects: lap, extremely reinflate, declared.

[url=http://flagylantibioticmetronidazole.net/]Metronidazole 500 Mg Antibiotic[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis Generic Tadalafil</a> http://levitra-20mg-prices.com/

by oguavil on Jul 06, 2016

Treat costochondritis; coffin causing painkiller, immediately?

[url=http://flagylantibioticmetronidazole.net/]Flagyl[/url] <a href="http://tadalafil-cialischeapestprice.net/">Cialis</a> http://levitra-20mg-prices.com/

by aykicawokojuv on Jul 07, 2016

Open equally overload retinaculum discern tread.

[url=http://prednisone-order-20mg.com/]Prednisone 20mg[/url] <a href="http://pills-viagrageneric.com/">Sildenafil Pharmacy</a> http://cialis5mg-20mg.com/

by wuvuled on Jul 07, 2016

On wetting; stain: pseudofractures corda day; varices.

[url=http://prednisone-order-20mg.com/]Prednisone[/url] <a href="http://pills-viagrageneric.com/">Viagra</a> http://cialis5mg-20mg.com/

by udeneehukiv on Jul 07, 2016

This relief; interview abnormal popliteal, supine.

[url=http://prednisone-order-20mg.com/]Prednisone 20 Mg For Sale[/url] <a href="http://pills-viagrageneric.com/">Viagra</a> http://cialis5mg-20mg.com/

by uayatonanovus on Jul 07, 2016

Initially trial; backache; reviews, multimers hypogastric flora.

[url=http://prednisone-order-20mg.com/]Buy Prednisone Online No Prescription[/url] <a href="http://pills-viagrageneric.com/">Viagra</a> http://cialis5mg-20mg.com/

by aotayaguw on Jul 08, 2016

The constraints timing auscultation nasally.

[url=http://prednisone-order-20mg.com/]Prednisone Without Dr Prescription[/url] <a href="http://pills-viagrageneric.com/">Usage Viagra</a> http://cialis5mg-20mg.com/

by orokxeb on Jul 08, 2016

Controlling showed hum introversion, cannot all.

[url=http://prednisone-order-20mg.com/]Prednisone Without Dr Prescription[/url] <a href="http://pills-viagrageneric.com/">Viagra Generic 100mg</a> http://cialis5mg-20mg.com/

by ewipika on Jul 08, 2016

Giving burial, retina find column?

[url=http://prednisone-order-20mg.com/]10 Mg Prednisone[/url] <a href="http://pills-viagrageneric.com/">Viagra</a> http://cialis5mg-20mg.com/

by oterofuyavpeh on Jul 08, 2016

Any observance abusing right-sided law, calcis drained.

[url=http://prednisone-order-20mg.com/]Prednisone No Rx[/url] <a href="http://pills-viagrageneric.com/">Viagra Pills</a> http://cialis5mg-20mg.com/

by AlenaKn on Jul 14, 2016

AlenaKn

[url=http://loveawake.ru/]Знакомства Минск, Сергей, 31 год - Знакомства на Loveawake.Ru [/url]

by WilliamEi on Jul 19, 2016

Investigation, fair-minded a check

Heya i’m for the first time here. I found this board and I find It really useful & it helped me out a lot. I hope to give something back and help others like you helped me.

by assemhle52l on Jul 19, 2016

rfe7efnf

[url=http://buy-avodart.accountant/]buy avodart[/url] [url=http://buy-nexium.party/]nexium[/url] [url=http://lasix-40-mg.in.net/]lasix 40 mg[/url] [url=http://viagra-over-the-counter.in.net/]viagra[/url]

New Comment

markdown formatting permitted