RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-31 Thread Craig Chant
SQL injection by whom and how?

I can't get the template to work, and you think I've got user input set up?

I give up, it was I nice idea but I'm going no-where fast.

Thanks anyway.

-Original Message-
From: Tomas Doran [mailto:bobtf...@bobtfish.net]
Sent: 30 October 2012 22:22
To: The elegant MVC web framework
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'


On 30 Oct 2012, at 12:00, Craig Chant wrote:

 What was the reason for not using DBIC again?

 The non-normalised DB with a  missing schema and the fact the data is spread 
 across two SQL servers on separate DSN's.


You didn't say anything there that didn't imply DBIC is fine.

The reason for not using DBIC again?

Also, your SQL abstraction has hilarious SQL injection holes - you do know 
about this, right?

 It's just before the return of the record set or count I was wondering if I 
 need to add '$sth-finish();' or '$dbh-disconnect();' - which I have in my 
 current (non-catalyst) app version of the class (module).

You're doing something wrong with DBI here!

 I also believe that DBIC gets all columns from all tables, which I don't 
 want, dunno, perhaps I'm missing something with DBIC, but I understand my 
 data the way I retrieve it and didn't think there was anything wrong with 
 using my SQL class, it has served me well for 10 years, and powers all my 
 current apps.

That's by default, and optional.

 One thing I have found already is the app doesn't seem to see real time SQL 
 updates even if I issue$sth-finish();$dbh-disconnect(); at the end 
 of my method.

 I make a manual change to SQL (switch the 'Locked' flag between 'yes'  'no') 
 , refresh the app and it isn't registering the SQL change, so already it 
 seems something is being cached somewhere and I need to stop this, my apps 
 need to see DB changes instantly.

Again, you're doing something wrong or insane here - this is not normal, so you 
must be asking for it somehow.

Cheers
t0m



___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/
This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must be deleted immediately. 
Whilst we take reasonable steps to try to identify any software viruses, any 
attachments to this e-mail may nevertheless contain viruses, which our 
anti-virus software has failed to identify. You should therefore carry out your 
own anti-virus checks before opening any documents. HomeLoan Partnership will 
not accept any liability for damage caused by computer viruses emanating from 
any attachment or other document supplied with this e-mail. HomeLoan 
Partnership reserves the right to monitor and archive all e-mail communications 
through its network. No representative or employee of HomeLoan Partnership has 
the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.

___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-31 Thread Dimitar Petrov
Crag,

would you mind stopping in #catalyst onto irc.perl.org it would probably be
easier. For instant chat you can follow this link
http://chat.mibbit.com/#catal...@irc.perl.org

Cheers


On Wed, Oct 31, 2012 at 10:51 AM, Craig Chant cr...@homeloanpartnership.com
 wrote:

 SQL injection by whom and how?

 I can't get the template to work, and you think I've got user input set up?

 I give up, it was I nice idea but I'm going no-where fast.

 Thanks anyway.

 -Original Message-
 From: Tomas Doran [mailto:bobtf...@bobtfish.net]
 Sent: 30 October 2012 22:22
 To: The elegant MVC web framework
 Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'


 On 30 Oct 2012, at 12:00, Craig Chant wrote:

  What was the reason for not using DBIC again?
 
  The non-normalised DB with a  missing schema and the fact the data is
 spread across two SQL servers on separate DSN's.


 You didn't say anything there that didn't imply DBIC is fine.

 The reason for not using DBIC again?

 Also, your SQL abstraction has hilarious SQL injection holes - you do know
 about this, right?

  It's just before the return of the record set or count I was wondering
 if I need to add '$sth-finish();' or '$dbh-disconnect();' - which I have
 in my current (non-catalyst) app version of the class (module).

 You're doing something wrong with DBI here!

  I also believe that DBIC gets all columns from all tables, which I don't
 want, dunno, perhaps I'm missing something with DBIC, but I understand my
 data the way I retrieve it and didn't think there was anything wrong with
 using my SQL class, it has served me well for 10 years, and powers all my
 current apps.

 That's by default, and optional.

  One thing I have found already is the app doesn't seem to see real time
 SQL updates even if I issue$sth-finish();$dbh-disconnect(); at
 the end of my method.
 
  I make a manual change to SQL (switch the 'Locked' flag between 'yes' 
 'no') , refresh the app and it isn't registering the SQL change, so already
 it seems something is being cached somewhere and I need to stop this, my
 apps need to see DB changes instantly.

 Again, you're doing something wrong or insane here - this is not normal,
 so you must be asking for it somehow.

 Cheers
 t0m



 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive:
 http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/
 This Email and any attachments contain confidential information and is
 intended solely for the individual to whom it is addressed. If this Email
 has been misdirected, please notify the author as soon as possible. If you
 are not the intended recipient you must not disclose, distribute, copy,
 print or rely on any of the information contained, and all copies must be
 deleted immediately. Whilst we take reasonable steps to try to identify any
 software viruses, any attachments to this e-mail may nevertheless contain
 viruses, which our anti-virus software has failed to identify. You should
 therefore carry out your own anti-virus checks before opening any
 documents. HomeLoan Partnership will not accept any liability for damage
 caused by computer viruses emanating from any attachment or other document
 supplied with this e-mail. HomeLoan Partnership reserves the right to
 monitor and archive all e-mail communications through its network. No
 representative or employee of HomeLoan Partnership has the authority to
 enter into any contract on behalf of HomeLoan Partnership by email.
 HomeLoan Partnership is a trading name of H L Partnership Limited,
 registered in England and Wales with Registration Number 5011722.
 Registered office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership
 Limited is authorised and regulated by the Financial Services Authority.

 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive:
 http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/

___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-30 Thread Craig Chant
What was the reason for not using DBIC again?

The non-normalised DB with a  missing schema and the fact the data is spread 
across two SQL servers on separate DSN's.

I also want my data in a way I can manipulate it, maybe you are all going to 
fall down in shock and horror, but I get my records and pass them back as an 
array of hashes (recordset), I then play with them , manipulate them, and do 
all sorts of stuff with them.

ORM / DBIC doesn't seem to give you this type of access, it wants a DB schema 
with relationship mapping to dynamically create all the 1-many / many - many 
etc Models and relationships, which won't work with our system, from what I can 
tell.

This is my SQL helper class (well two methods as an example)

# Get SQL Routine
sub getSQL {

#_0 = Self
#_1 = Table
#_2 = Columns
#_3 = Where
#_4 = Order By

my ($self,$table,$columns,$where,$order) = @_;

# Build SQL Statement
my $sel = SELECT $columns FROM $table WHERE $where;

# Check for ORDER BY
if(defined $order){$sel .=  ORDER BY $order;}

# Connect
my $dbh = $self-dbh;

# set long read because SQL requires it for ODBC
$dbh-{LongReadLen} = 9;

# Run SQL Command
my $sth = $db-prepare($sel) || $self-sql_error(Error in getSQL (Web 
Server): $sel);
$sth-execute();

# Declare recordset array
my @rs;

# Loop SQL  build recordset
while (my $ref = $sth-fetchrow_hashref()) {
# Build Array of Hashes with SQL Data
$rs[@rs] = \%$ref;
}

# Return record set
@rs;

}

# Count SQL Routine
sub cntSQL {

#_0 = Self
#_1 = Table
#_2 = Where

my ($self,$table,$where) = @_;

#Build SQL Statement
my $sel = SELECT COUNT(1) as COUNT FROM $table WHERE $where;

# Connect
my $dbh = $self-dbh;

# Run SQL Command
my $sth = $dbh-prepare($sel) || $self-sql_error(Error in getSQL (Web 
Server): $sel);
$sth-execute();

# Loop SQL Record Set
while (my $ref = $sth-fetchrow_hashref()) {
# Build Array of Hashes with SQL Data
$rs[@rs] = \%$ref;
}

# Return Count
   $rs[0]-{'COUNT'};

}

It's just before the return of the record set or count I was wondering if I 
need to add '$sth-finish();' or '$dbh-disconnect();' - which I have in my 
current (non-catalyst) app version of the class (module).

I also believe that DBIC gets all columns from all tables, which I don't want, 
dunno, perhaps I'm missing something with DBIC, but I understand my data the 
way I retrieve it and didn't think there was anything wrong with using my SQL 
class, it has served me well for 10 years, and powers all my current apps.

How would I use DBIC to get records from two separate DSN's and merge 
recordsets?

In my concrete Catalyst::Model I have...

# Check if system locked
if($self-cntSQL('IsLock',Locked='yes')){
$c-response-body('pSorry, system is currently undergoing 
maintenance./ppPlease try again later./p' );
return 1;
}

One thing I have found already is the app doesn't seem to see real time SQL 
updates even if I issue$sth-finish();$dbh-disconnect(); at the end 
of my method.

I make a manual change to SQL (switch the 'Locked' flag between 'yes'  'no') , 
refresh the app and it isn't registering the SQL change, so already it seems 
something is being cached somewhere and I need to stop this, my apps need to 
see DB changes instantly.

Your advice is appreciated.

Craig.

-Original Message-
From: Rob Brown [mailto:r...@intelcompute.com]
Sent: 29 October 2012 22:30
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

basically...

$sth-finish if you've finished with the results of that statement, ie, you've 
looped through the rows and are now done.

$dbh-disconnect if you've finished with the database connection, tho now you 
start to think about working in a persistent environment, where you may never 
disconnect from the database, and/or have some connection caching setup.

This is where DBIx::Class just takes of all this for you - it does sound like 
you're re-inventing a lot here.

What was the reason for not using DBIC again?




On 10/29/2012 10:10 PM, Craig Chant wrote:
 I finally got to grips with extending my own class with the inbuilt $c-dbh.

 But am unsure whether I am mean to issue either...

  $sth-finish();

  or

 $dbh-disconnect();

 Once I have prepared / executed the SQL and fetched the records I want.

 so a little further guidance is appreciated.

 Craig

 
 From: Lukas Thiemeier [spamcatc...@thiemeier.net]
 Sent: 29 October 2012 20:16
 To: catalyst@lists.scsys.co.uk
 Subject: Re: [Catalyst] Unable to output anything in Root.pm -  'auto'

 Hi Craig,

 Using C::M::DBI is straight forward. Install it from cpan, and run

script/yourapp.pl create model DBI DBI dsn user password

 where dsn is sth like dbi:mysql:dbname

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-30 Thread Kieren Diment


On 30/10/2012, at 11:00 PM, Craig Chant wrote:

 What was the reason for not using DBIC again?
 
 The non-normalised DB with a  missing schema and the fact the data is spread 
 across two SQL servers on separate DSN's.
 

Be sure to use DBIx::Connector for connection management 
(https://metacpan.org/search?q=DBIx%3A%3AConnector), thus you get one of the 
compelling DBIC features but still get to use DBI.

 I also want my data in a way I can manipulate it, maybe you are all going to 
 fall down in shock and horror, but I get my records and pass them back as an 
 array of hashes (recordset), I then play with them , manipulate them, and do 
 all sorts of stuff with them.
 
 ORM / DBIC doesn't seem to give you this type of access, it wants a DB schema 
 with relationship mapping to dynamically create all the 1-many / many - many 
 etc Models and relationships, which won't work with our system, from what I 
 can tell.
 
 This is my SQL helper class (well two methods as an example)
 
 # Get SQL Routine
 sub getSQL {
 
#_0 = Self
#_1 = Table
#_2 = Columns
#_3 = Where
#_4 = Order By
 
my ($self,$table,$columns,$where,$order) = @_;
 
# Build SQL Statement
my $sel = SELECT $columns FROM $table WHERE $where;
 
# Check for ORDER BY
if(defined $order){$sel .=  ORDER BY $order;}
 
# Connect
my $dbh = $self-dbh;
 
# set long read because SQL requires it for ODBC
$dbh-{LongReadLen} = 9;
 
# Run SQL Command
my $sth = $db-prepare($sel) || $self-sql_error(Error in getSQL (Web 
 Server): $sel);
$sth-execute();
 
# Declare recordset array
my @rs;
 
# Loop SQL  build recordset
while (my $ref = $sth-fetchrow_hashref()) {
# Build Array of Hashes with SQL Data
$rs[@rs] = \%$ref;
}
 
# Return record set
@rs;
 
 }
 
 # Count SQL Routine
 sub cntSQL {
 
#_0 = Self
#_1 = Table
#_2 = Where
 
my ($self,$table,$where) = @_;
 
#Build SQL Statement
my $sel = SELECT COUNT(1) as COUNT FROM $table WHERE $where;
 
# Connect
my $dbh = $self-dbh;
 
# Run SQL Command
my $sth = $dbh-prepare($sel) || $self-sql_error(Error in getSQL (Web 
 Server): $sel);
$sth-execute();
 
# Loop SQL Record Set
while (my $ref = $sth-fetchrow_hashref()) {
# Build Array of Hashes with SQL Data
$rs[@rs] = \%$ref;
}
 
# Return Count
   $rs[0]-{'COUNT'};
 
 }
 
 It's just before the return of the record set or count I was wondering if I 
 need to add '$sth-finish();' or '$dbh-disconnect();' - which I have in my 
 current (non-catalyst) app version of the class (module).
 
 I also believe that DBIC gets all columns from all tables, which I don't 
 want, dunno, perhaps I'm missing something with DBIC, but I understand my 
 data the way I retrieve it and didn't think there was anything wrong with 
 using my SQL class, it has served me well for 10 years, and powers all my 
 current apps.
 
 How would I use DBIC to get records from two separate DSN's and merge 
 recordsets?
 
 In my concrete Catalyst::Model I have...
 
# Check if system locked
if($self-cntSQL('IsLock',Locked='yes')){
$c-response-body('pSorry, system is currently undergoing 
 maintenance./ppPlease try again later./p' );
return 1;
}
 
 One thing I have found already is the app doesn't seem to see real time SQL 
 updates even if I issue$sth-finish();$dbh-disconnect(); at the end 
 of my method.
 
 I make a manual change to SQL (switch the 'Locked' flag between 'yes'  'no') 
 , refresh the app and it isn't registering the SQL change, so already it 
 seems something is being cached somewhere and I need to stop this, my apps 
 need to see DB changes instantly.
 
 Your advice is appreciated.
 
 Craig.
 
 -Original Message-
 From: Rob Brown [mailto:r...@intelcompute.com]
 Sent: 29 October 2012 22:30
 To: catalyst@lists.scsys.co.uk
 Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
 basically...
 
 $sth-finish if you've finished with the results of that statement, ie, 
 you've looped through the rows and are now done.
 
 $dbh-disconnect if you've finished with the database connection, tho now you 
 start to think about working in a persistent environment, where you may never 
 disconnect from the database, and/or have some connection caching setup.
 
 This is where DBIx::Class just takes of all this for you - it does sound like 
 you're re-inventing a lot here.
 
 What was the reason for not using DBIC again?
 
 
 
 
 On 10/29/2012 10:10 PM, Craig Chant wrote:
 I finally got to grips with extending my own class with the inbuilt $c-dbh.
 
 But am unsure whether I am mean to issue either...
 
 $sth-finish();
 
 or
 
$dbh-disconnect();
 
 Once I have prepared / executed the SQL and fetched the records I want.
 
 so a little further guidance is appreciated.
 
 Craig
 
 
 From: Lukas Thiemeier [spamcatc

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-30 Thread Tomas Doran

On 30 Oct 2012, at 12:00, Craig Chant wrote:

 What was the reason for not using DBIC again?
 
 The non-normalised DB with a  missing schema and the fact the data is spread 
 across two SQL servers on separate DSN's.


You didn't say anything there that didn't imply DBIC is fine.

The reason for not using DBIC again?

Also, your SQL abstraction has hilarious SQL injection holes - you do know 
about this, right?

 It's just before the return of the record set or count I was wondering if I 
 need to add '$sth-finish();' or '$dbh-disconnect();' - which I have in my 
 current (non-catalyst) app version of the class (module).

You're doing something wrong with DBI here!

 I also believe that DBIC gets all columns from all tables, which I don't 
 want, dunno, perhaps I'm missing something with DBIC, but I understand my 
 data the way I retrieve it and didn't think there was anything wrong with 
 using my SQL class, it has served me well for 10 years, and powers all my 
 current apps.

That's by default, and optional.

 One thing I have found already is the app doesn't seem to see real time SQL 
 updates even if I issue$sth-finish();$dbh-disconnect(); at the end 
 of my method.
 
 I make a manual change to SQL (switch the 'Locked' flag between 'yes'  'no') 
 , refresh the app and it isn't registering the SQL change, so already it 
 seems something is being cached somewhere and I need to stop this, my apps 
 need to see DB changes instantly.

Again, you're doing something wrong or insane here - this is not normal, so you 
must be asking for it somehow.

Cheers
t0m



___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Ben Vinnerd
Private methods have to return a true value to continue processing.

Try adding return 1 at the end of the method.

Ben


On 29 October 2012 14:23, Craig Chant cr...@homeloanpartnership.com wrote:

  Hi,



 I seem to be going round in circles unable to get Catalyst to output
 anything via ‘auto’?



 I made a change to the Root.pm to try to add authentication via the ‘auto’
 method, but it does nothing?



 # always runs first!

 sub auto :Private {

 my ( $self, $c ) = @_;



 # Authenticate

 $c-response-body('Matched Members::Controller::Auto in Root.' .
 $c-sessionid);



 }



 This doesn’t output anything and I simply get the welcome screen, plus
 there is a warning in the devel server output of



 “Use of uninitialized value in concatenation (.) or string”



 I have ..



 use Catalyst qw/

 -Debug

 ConfigLoader

 Static::Simple

 StackTrace

 Session

 Session::Store::FastMmap

 Session::State::Cookie

 /;



 In my main MyApp.pm



 Why is $c-response-body not working and why is the sessionid empty?



 Thanks



 *Craig Chant*

 I.T. Manager

 [image: Description: cid:image001.png@01CD5F4A.17E848D0]

 Main Line01903 602664

 Direct Line   01903 227753

 Visit our website http://www.homeloanpartnership.com

 *HomeLoan Partnership have been named the Best Mortgage Network, 2012, at
 the myintroducer.com Industry Awards*


  This Email and any attachments contain confidential information and is
 intended solely for the individual to whom it is addressed. If this Email
 has been misdirected, please notify the author as soon as possible. If you
 are not the intended recipient you must not disclose, distribute, copy,
 print or rely on any of the information contained, and all copies must be
 deleted immediately. Whilst we take reasonable steps to try to identify any
 software viruses, any attachments to this e-mail may nevertheless contain
 viruses, which our anti-virus software has failed to identify. You should
 therefore carry out your own anti-virus checks before opening any
 documents. HomeLoan Partnership will not accept any liability for damage
 caused by computer viruses emanating from any attachment or other document
 supplied with this e-mail. HomeLoan Partnership reserves the right to
 monitor and archive all e-mail communications through its network. No
 representative or employee of HomeLoan Partnership has the authority to
 enter into any contract on behalf of HomeLoan Partnership by email.
 HomeLoan Partnership is a trading name of H L Partnership Limited,
 registered in England and Wales with Registration Number 5011722.
 Registered office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership
 Limited is authorised and regulated by the Financial Services Authority.

 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive:
 http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/


image001.png___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
Nope, no change; same warning in the devel output and all that happens is the  
welcome screen loads?

From: Ben Vinnerd [mailto:ben+catal...@vinnerd.com]
Sent: 29 October 2012 14:48
To: The elegant MVC web framework
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Private methods have to return a true value to continue processing.

Try adding return 1 at the end of the method.

Ben

On 29 October 2012 14:23, Craig Chant 
cr...@homeloanpartnership.commailto:cr...@homeloanpartnership.com wrote:
Hi,

I seem to be going round in circles unable to get Catalyst to output anything 
via ‘auto’?

I made a change to the Root.pm to try to add authentication via the ‘auto’ 
method, but it does nothing?

# always runs first!
sub auto :Private {
my ( $self, $c ) = @_;

# Authenticate
$c-response-body('Matched Members::Controller::Auto in Root.' . 
$c-sessionid);

}

This doesn’t output anything and I simply get the welcome screen, plus there is 
a warning in the devel server output of

“Use of uninitialized value in concatenation (.) or string”

I have ..

use Catalyst qw/
-Debug
ConfigLoader
Static::Simple
StackTrace
Session
Session::Store::FastMmap
Session::State::Cookie
/;

In my main MyApp.pm

Why is $c-response-body not working and why is the sessionid empty?

Thanks

Craig Chant
I.T. Manager
[Description: cid:image001.png@01CD5F4A.17E848D0]
Main Line01903 602664tel:01903%20602664
Direct Line   01903 227753tel:01903%20227753
Visit our website http://www.homeloanpartnership.com
HomeLoan Partnership have been named the Best Mortgage Network, 2012, at the 
myintroducer.comhttp://myintroducer.com Industry Awards

This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must be deleted immediately. 
Whilst we take reasonable steps to try to identify any software viruses, any 
attachments to this e-mail may nevertheless contain viruses, which our 
anti-virus software has failed to identify. You should therefore carry out your 
own anti-virus checks before opening any documents. HomeLoan Partnership will 
not accept any liability for damage caused by computer viruses emanating from 
any attachment or other document supplied with this e-mail. HomeLoan 
Partnership reserves the right to monitor and archive all e-mail communications 
through its network. No representative or employee of HomeLoan Partnership has 
the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.

___
List: Catalyst@lists.scsys.co.ukmailto:Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/

This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must be deleted immediately. 
Whilst we take reasonable steps to try to identify any software viruses, any 
attachments to this e-mail may nevertheless contain viruses, which our 
anti-virus software has failed to identify. You should therefore carry out your 
own anti-virus checks before opening any documents. HomeLoan Partnership will 
not accept any liability for damage caused by computer viruses emanating from 
any attachment or other document supplied with this e-mail. HomeLoan 
Partnership reserves the right to monitor and archive all e-mail communications 
through its network. No representative or employee of HomeLoan Partnership has 
the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.
inline: image001.png___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst

RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
Oh I also tried changing it to ‘begin’ instead of ‘auto’, still doesn’t work?

I also thought that all calls to ANY method / sub will always be passed $self  
$c , only it doesn’t seem to be passing in $c and I’ve had to manually do it?

I’ve tried…

# always runs first!
sub begin :Private {
my ( $self, $c ) = @_;

# Authenticate
$self-AuthenticateUser($c);
return 1;

}

sub AuthenticateUser {

my ( $self, $c ) = @_;

die 'Session ID = ' . $c-sessionid;

}

But there is no session ID.

I am still getting the “Use of uninitialized value in concatenation (.) or 
string”  error.

I’ve read 
http://search.cpan.org/~mramberg/Catalyst-Plugin-Session-0.14/lib/Catalyst/Plugin/Session/Tutorial.pod


Where it states :  These plugins will automatically set $c-sessionid at the 
begining of the request, and automatically cause $c-sessionid to be saved by 
the client at the end of the request.
So why is $c-sessionid uninitialized?

Any ideas where my session info is?

Thanks,

Craig

From: Craig Chant [mailto:cr...@homeloanpartnership.com]
Sent: 29 October 2012 14:54
To: The elegant MVC web framework
Subject: RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

Nope, no change; same warning in the devel output and all that happens is the  
welcome screen loads?

From: Ben Vinnerd 
[mailto:ben+catal...@vinnerd.com]mailto:[mailto:ben+catal...@vinnerd.com]
Sent: 29 October 2012 14:48
To: The elegant MVC web framework
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Private methods have to return a true value to continue processing.

Try adding return 1 at the end of the method.

Ben
On 29 October 2012 14:23, Craig Chant 
cr...@homeloanpartnership.commailto:cr...@homeloanpartnership.com wrote:
Hi,

I seem to be going round in circles unable to get Catalyst to output anything 
via ‘auto’?

I made a change to the Root.pm to try to add authentication via the ‘auto’ 
method, but it does nothing?

# always runs first!
sub auto :Private {
my ( $self, $c ) = @_;

# Authenticate
$c-response-body('Matched Members::Controller::Auto in Root.' . 
$c-sessionid);

}

This doesn’t output anything and I simply get the welcome screen, plus there is 
a warning in the devel server output of

“Use of uninitialized value in concatenation (.) or string”

I have ..

use Catalyst qw/
-Debug
ConfigLoader
Static::Simple
StackTrace
Session
Session::Store::FastMmap
Session::State::Cookie
/;

In my main MyApp.pm

Why is $c-response-body not working and why is the sessionid empty?

Thanks

Craig Chant
I.T. Manager
[Description: cid:image001.png@01CD5F4A.17E848D0]
Main Line01903 602664tel:01903%20602664
Direct Line   01903 227753tel:01903%20227753
Visit our website http://www.homeloanpartnership.com
HomeLoan Partnership have been named the Best Mortgage Network, 2012, at the 
myintroducer.comhttp://myintroducer.com Industry Awards

This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must be deleted immediately. 
Whilst we take reasonable steps to try to identify any software viruses, any 
attachments to this e-mail may nevertheless contain viruses, which our 
anti-virus software has failed to identify. You should therefore carry out your 
own anti-virus checks before opening any documents. HomeLoan Partnership will 
not accept any liability for damage caused by computer viruses emanating from 
any attachment or other document supplied with this e-mail. HomeLoan 
Partnership reserves the right to monitor and archive all e-mail communications 
through its network. No representative or employee of HomeLoan Partnership has 
the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.

___
List: Catalyst@lists.scsys.co.ukmailto:Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/

This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier
Hi Craig,

Take a look at the default index method in Controller/Root.pm.
If you look at the debug output, you will see that index is called
after auto. Index sets, and therefore overwrites $c-res-body.

If you use a template system, the default end action
(ActionClass:RenderView) will only render the template if $c-res-body
is not set. But setting the body directly, as in index, will overwrite
any previously added content.

Uncomment the line '$c-response-body( $c-welcome_message );' in
'sub index ...', and you will see whatever you write to $c-res-body in
auto.

Cheers, Lukas


On 10/29/2012 04:04 PM, Craig Chant wrote:
 Oh I also tried changing it to ‘begin’ instead of ‘auto’, still doesn’t
 work?
 
  
 
 I also thought that all calls to ANY method / sub will always be passed
 $self  $c , only it doesn’t seem to be passing in $c and I’ve had to
 manually do it?
 
  
 
 I’ve tried…
 
  
 
 # always runs first!
 
 sub begin :Private {
 
 my ( $self, $c ) = @_;
 
  
 
 # Authenticate
 
 $self-AuthenticateUser($c);   
 
 return 1;
 

 
 }
 
  
 
 sub AuthenticateUser {
 

 
 my ( $self, $c ) = @_;
 

 
 die 'Session ID = ' . $c-sessionid;
 

 
 }
 
  
 
 But there is no session ID.
 
  
 
 I am still getting the “Use of uninitialized value in concatenation (.)
 or string”  error.
 
  
 
 I’ve read
 http://search.cpan.org/~mramberg/Catalyst-Plugin-Session-0.14/lib/Catalyst/Plugin/Session/Tutorial.pod
 
  
 
 Where it states :  These plugins will automatically set
 |$c-sessionid|at the begining of the request, and automatically cause
 |$c-sessionid|to be saved by the client at the end of the request.
 
 So why is $c-sessionid uninitialized?
 
  
 
 Any ideas where my session info is?
 
  
 
 Thanks,
 
  
 
 Craig
 
  
 
 *From:*Craig Chant [mailto:cr...@homeloanpartnership.com]
 *Sent:* 29 October 2012 14:54
 *To:* The elegant MVC web framework
 *Subject:* RE: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
  
 
 Nope, no change; same warning in the devel output and all that happens
 is the  welcome screen loads?
 
  
 
 *From:*Ben Vinnerd [mailto:ben+catal...@vinnerd.com]
 mailto:[mailto:ben+catal...@vinnerd.com]
 *Sent:* 29 October 2012 14:48
 *To:* The elegant MVC web framework
 *Subject:* Re: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
  
 
 Private methods have to return a true value to continue processing.
 
 Try adding return 1 at the end of the method.
 
 Ben
 
 On 29 October 2012 14:23, Craig Chant cr...@homeloanpartnership.com
 mailto:cr...@homeloanpartnership.com wrote:
 
 Hi,
 
  
 
 I seem to be going round in circles unable to get Catalyst to output
 anything via ‘auto’?
 
  
 
 I made a change to the Root.pm to try to add authentication via the
 ‘auto’ method, but it does nothing?
 
  
 
 # always runs first!
 
 sub auto :Private {
 
 my ( $self, $c ) = @_;
 
  
 
 # Authenticate
 
 $c-response-body('Matched Members::Controller::Auto in Root.' .
 $c-sessionid);   
 
  
 
 }
 
  
 
 This doesn’t output anything and I simply get the welcome screen, plus
 there is a warning in the devel server output of
 
  
 
 “Use of uninitialized value in concatenation (.) or string”
 
  
 
 I have ..
 
  
 
 use Catalyst qw/
 
 -Debug
 
 ConfigLoader
 
 Static::Simple
 
 StackTrace
 
 Session 
 
 Session::Store::FastMmap 
 
 Session::State::Cookie   
 
 /;
 
  
 
 In my main MyApp.pm
 
  
 
 Why is $c-response-body not working and why is the sessionid empty?
 
  
 
 Thanks
 
  
 
 */Craig Chant/*
 
 I.T. Manager
 
 Description: cid:image001.png@01CD5F4A.17E848D0
 
 Main Line01903 602664 tel:01903%20602664
 
 Direct Line   01903 227753 tel:01903%20227753
 
 Visit our website http://www.homeloanpartnership.com
 
 *HomeLoan Partnership have been named the Best Mortgage Network, 2012,
 at the myintroducer.com http://myintroducer.com Industry Awards*
 
  
 
 This Email and any attachments contain confidential information and is
 intended solely for the individual to whom it is addressed. If this
 Email has been misdirected, please notify the author as soon as
 possible. If you are not the intended recipient you must not disclose,
 distribute, copy, print or rely on any of the information contained, and
 all copies must be deleted immediately. Whilst we take reasonable steps
 to try to identify any software viruses, any attachments to this e-mail
 may nevertheless contain viruses, which our anti-virus software has
 failed to identify. You should therefore carry out your own anti-virus
 checks before opening any documents. HomeLoan Partnership will not
 accept any liability for damage caused by computer viruses emanating
 from any attachment or other document supplied with this e-mail.
 HomeLoan Partnership reserves the right to monitor and archive all
 e-mail communications through its network. No representative or employee
 of HomeLoan Partnership has the authority to enter into any

RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
OK, thanks.

I assume you meant 'comment' not 'uncomment' , which I did and it now outputs 
what I wanted!

Though $c-sessionid is still blank?


-Original Message-
From: Lukas Thiemeier [mailto:spamcatc...@thiemeier.net]
Sent: 29 October 2012 15:16
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Hi Craig,

Take a look at the default index method in Controller/Root.pm.
If you look at the debug output, you will see that index is called after 
auto. Index sets, and therefore overwrites $c-res-body.

If you use a template system, the default end action
(ActionClass:RenderView) will only render the template if $c-res-body is not 
set. But setting the body directly, as in index, will overwrite any 
previously added content.

Uncomment the line '$c-response-body( $c-welcome_message );' in 'sub index 
...', and you will see whatever you write to $c-res-body in auto.

Cheers, Lukas


On 10/29/2012 04:04 PM, Craig Chant wrote:
 Oh I also tried changing it to 'begin' instead of 'auto', still
 doesn't work?



 I also thought that all calls to ANY method / sub will always be
 passed $self  $c , only it doesn't seem to be passing in $c and I've
 had to manually do it?



 I've tried...



 # always runs first!

 sub begin :Private {

 my ( $self, $c ) = @_;



 # Authenticate

 $self-AuthenticateUser($c);

 return 1;



 }



 sub AuthenticateUser {



 my ( $self, $c ) = @_;



 die 'Session ID = ' . $c-sessionid;



 }



 But there is no session ID.



 I am still getting the Use of uninitialized value in concatenation
 (.) or string  error.



 I've read
 http://search.cpan.org/~mramberg/Catalyst-Plugin-Session-0.14/lib/Cata
 lyst/Plugin/Session/Tutorial.pod



 Where it states :  These plugins will automatically set
 |$c-sessionid|at the begining of the request, and automatically cause
 |$c-sessionid|to be saved by the client at the end of the request.

 So why is $c-sessionid uninitialized?



 Any ideas where my session info is?



 Thanks,



 Craig



 *From:*Craig Chant [mailto:cr...@homeloanpartnership.com]
 *Sent:* 29 October 2012 14:54
 *To:* The elegant MVC web framework
 *Subject:* RE: [Catalyst] Unable to output anything in Root.pm - 'auto'



 Nope, no change; same warning in the devel output and all that happens
 is the  welcome screen loads?



 *From:*Ben Vinnerd [mailto:ben+catal...@vinnerd.com]
 mailto:[mailto:ben+catal...@vinnerd.com]
 *Sent:* 29 October 2012 14:48
 *To:* The elegant MVC web framework
 *Subject:* Re: [Catalyst] Unable to output anything in Root.pm - 'auto'



 Private methods have to return a true value to continue processing.

 Try adding return 1 at the end of the method.

 Ben

 On 29 October 2012 14:23, Craig Chant cr...@homeloanpartnership.com
 mailto:cr...@homeloanpartnership.com wrote:

 Hi,



 I seem to be going round in circles unable to get Catalyst to output
 anything via 'auto'?



 I made a change to the Root.pm to try to add authentication via the
 'auto' method, but it does nothing?



 # always runs first!

 sub auto :Private {

 my ( $self, $c ) = @_;



 # Authenticate

 $c-response-body('Matched Members::Controller::Auto in Root.' .
 $c-sessionid);



 }



 This doesn't output anything and I simply get the welcome screen, plus
 there is a warning in the devel server output of



 Use of uninitialized value in concatenation (.) or string



 I have ..



 use Catalyst qw/

 -Debug

 ConfigLoader

 Static::Simple

 StackTrace

 Session

 Session::Store::FastMmap

 Session::State::Cookie

 /;



 In my main MyApp.pm



 Why is $c-response-body not working and why is the sessionid empty?



 Thanks



 */Craig Chant/*

 I.T. Manager

 Description: cid:image001.png@01CD5F4A.17E848D0

 Main Line01903 602664 tel:01903%20602664

 Direct Line   01903 227753 tel:01903%20227753

 Visit our website http://www.homeloanpartnership.com

 *HomeLoan Partnership have been named the Best Mortgage Network, 2012,
 at the myintroducer.com http://myintroducer.com Industry Awards*



 This Email and any attachments contain confidential information and is
 intended solely for the individual to whom it is addressed. If this
 Email has been misdirected, please notify the author as soon as
 possible. If you are not the intended recipient you must not disclose,
 distribute, copy, print or rely on any of the information contained,
 and all copies must be deleted immediately. Whilst we take reasonable
 steps to try to identify any software viruses, any attachments to this
 e-mail may nevertheless contain viruses, which our anti-virus software
 has failed to identify. You should therefore carry out your own
 anti-virus checks before opening any documents. HomeLoan Partnership
 will not accept any liability for damage caused by computer viruses
 emanating from any attachment or other document supplied with this e-mail.
 HomeLoan Partnership

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier
Hi again,

about the missing sessionid:

I don't know much about the internals of Catalyst::Plugin::Session, but
I guess that the session is a lazy attribute, and only created if used.
This means: unless you put something in the session, you will not have
one, and therefore have no session-id.

This is very handy, because the overhead related to creating and
restoring a session is only executed if the session is really needed.
If your app has a session-less interface without authentication, and
extra functionality for authenticated users, the session will only be
created for authenticated users.

If you touch your session object before fetching the session-id, it will
work:

$c-session;
$c-res-body(SESSIONID  . $c-sessionid);

As soon as you implemented authentication, the session will be used and
the session-id will be set.

By the way, what do you need the session-id for? Catalyst handles
sessions in a transparent way. In most cases, you don't need to access
the session-id in your code. And if it is only for debugging: The
session plugin writes the session-id to $c-log when a session is
created or restored. This means: the code showed above will result in
the session-id being printed twice :)

Lukas

On 10/29/2012 04:04 PM, Craig Chant wrote:
 Oh I also tried changing it to ‘begin’ instead of ‘auto’, still doesn’t
 work?
 
  
 
 I also thought that all calls to ANY method / sub will always be passed
 $self  $c , only it doesn’t seem to be passing in $c and I’ve had to
 manually do it?
 
  
 
 I’ve tried…
 
  
 
 # always runs first!
 
 sub begin :Private {
 
 my ( $self, $c ) = @_;
 
  
 
 # Authenticate
 
 $self-AuthenticateUser($c);   
 
 return 1;
 

 
 }
 
  
 
 sub AuthenticateUser {
 

 
 my ( $self, $c ) = @_;
 

 
 die 'Session ID = ' . $c-sessionid;
 

 
 }
 
  
 
 But there is no session ID.
 
  
 
 I am still getting the “Use of uninitialized value in concatenation (.)
 or string”  error.
 
  
 
 I’ve read
 http://search.cpan.org/~mramberg/Catalyst-Plugin-Session-0.14/lib/Catalyst/Plugin/Session/Tutorial.pod
 
  
 
 Where it states :  These plugins will automatically set
 |$c-sessionid|at the begining of the request, and automatically cause
 |$c-sessionid|to be saved by the client at the end of the request.
 
 So why is $c-sessionid uninitialized?
 
  
 
 Any ideas where my session info is?
 
  
 
 Thanks,
 
  
 
 Craig
 
  
 
 *From:*Craig Chant [mailto:cr...@homeloanpartnership.com]
 *Sent:* 29 October 2012 14:54
 *To:* The elegant MVC web framework
 *Subject:* RE: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
  
 
 Nope, no change; same warning in the devel output and all that happens
 is the  welcome screen loads?
 
  
 
 *From:*Ben Vinnerd [mailto:ben+catal...@vinnerd.com]
 mailto:[mailto:ben+catal...@vinnerd.com]
 *Sent:* 29 October 2012 14:48
 *To:* The elegant MVC web framework
 *Subject:* Re: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
  
 
 Private methods have to return a true value to continue processing.
 
 Try adding return 1 at the end of the method.
 
 Ben
 
 On 29 October 2012 14:23, Craig Chant cr...@homeloanpartnership.com
 mailto:cr...@homeloanpartnership.com wrote:
 
 Hi,
 
  
 
 I seem to be going round in circles unable to get Catalyst to output
 anything via ‘auto’?
 
  
 
 I made a change to the Root.pm to try to add authentication via the
 ‘auto’ method, but it does nothing?
 
  
 
 # always runs first!
 
 sub auto :Private {
 
 my ( $self, $c ) = @_;
 
  
 
 # Authenticate
 
 $c-response-body('Matched Members::Controller::Auto in Root.' .
 $c-sessionid);   
 
  
 
 }
 
  
 
 This doesn’t output anything and I simply get the welcome screen, plus
 there is a warning in the devel server output of
 
  
 
 “Use of uninitialized value in concatenation (.) or string”
 
  
 
 I have ..
 
  
 
 use Catalyst qw/
 
 -Debug
 
 ConfigLoader
 
 Static::Simple
 
 StackTrace
 
 Session 
 
 Session::Store::FastMmap 
 
 Session::State::Cookie   
 
 /;
 
  
 
 In my main MyApp.pm
 
  
 
 Why is $c-response-body not working and why is the sessionid empty?
 
  
 
 Thanks
 
  
 
 */Craig Chant/*
 
 I.T. Manager
 
 Description: cid:image001.png@01CD5F4A.17E848D0
 
 Main Line01903 602664 tel:01903%20602664
 
 Direct Line   01903 227753 tel:01903%20227753
 
 Visit our website http://www.homeloanpartnership.com
 
 *HomeLoan Partnership have been named the Best Mortgage Network, 2012,
 at the myintroducer.com http://myintroducer.com Industry Awards*
 
  
 
 This Email and any attachments contain confidential information and is
 intended solely for the individual to whom it is addressed. If this
 Email has been misdirected, please notify the author as soon as
 possible. If you are not the intended recipient you must not disclose,
 distribute, copy, print or rely on any of the information contained, and
 all copies must be deleted immediately. Whilst we take reasonable

RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
By the way, what do you need the session-id for? Catalyst handles sessions in 
a transparent way

To authenticate users, I don't want to store authentication in the hash and it 
seems the only other way to do this is via ORM, which I don't want to use 
either.

I find catalyst whenever I look at how it implements anything to do with DB 
access, it forces ORM upon you, so I need to write my own authentication code 
don't I ?

-Original Message-
From: Lukas Thiemeier [mailto:spamcatc...@thiemeier.net]
Sent: 29 October 2012 15:39
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Hi again,

about the missing sessionid:

I don't know much about the internals of Catalyst::Plugin::Session, but I guess 
that the session is a lazy attribute, and only created if used.
This means: unless you put something in the session, you will not have one, and 
therefore have no session-id.

This is very handy, because the overhead related to creating and restoring a 
session is only executed if the session is really needed.
If your app has a session-less interface without authentication, and extra 
functionality for authenticated users, the session will only be created for 
authenticated users.

If you touch your session object before fetching the session-id, it will
work:

$c-session;
$c-res-body(SESSIONID  . $c-sessionid);

As soon as you implemented authentication, the session will be used and the 
session-id will be set.

By the way, what do you need the session-id for? Catalyst handles sessions in a 
transparent way. In most cases, you don't need to access the session-id in your 
code. And if it is only for debugging: The session plugin writes the session-id 
to $c-log when a session is created or restored. This means: the code showed 
above will result in the session-id being printed twice :)

Lukas

On 10/29/2012 04:04 PM, Craig Chant wrote:
 Oh I also tried changing it to 'begin' instead of 'auto', still
 doesn't work?



 I also thought that all calls to ANY method / sub will always be
 passed $self  $c , only it doesn't seem to be passing in $c and I've
 had to manually do it?



 I've tried...



 # always runs first!

 sub begin :Private {

 my ( $self, $c ) = @_;



 # Authenticate

 $self-AuthenticateUser($c);

 return 1;



 }



 sub AuthenticateUser {



 my ( $self, $c ) = @_;



 die 'Session ID = ' . $c-sessionid;



 }



 But there is no session ID.



 I am still getting the Use of uninitialized value in concatenation
 (.) or string  error.



 I've read
 http://search.cpan.org/~mramberg/Catalyst-Plugin-Session-0.14/lib/Cata
 lyst/Plugin/Session/Tutorial.pod



 Where it states :  These plugins will automatically set
 |$c-sessionid|at the begining of the request, and automatically cause
 |$c-sessionid|to be saved by the client at the end of the request.

 So why is $c-sessionid uninitialized?



 Any ideas where my session info is?



 Thanks,



 Craig



 *From:*Craig Chant [mailto:cr...@homeloanpartnership.com]
 *Sent:* 29 October 2012 14:54
 *To:* The elegant MVC web framework
 *Subject:* RE: [Catalyst] Unable to output anything in Root.pm - 'auto'



 Nope, no change; same warning in the devel output and all that happens
 is the  welcome screen loads?



 *From:*Ben Vinnerd [mailto:ben+catal...@vinnerd.com]
 mailto:[mailto:ben+catal...@vinnerd.com]
 *Sent:* 29 October 2012 14:48
 *To:* The elegant MVC web framework
 *Subject:* Re: [Catalyst] Unable to output anything in Root.pm - 'auto'



 Private methods have to return a true value to continue processing.

 Try adding return 1 at the end of the method.

 Ben

 On 29 October 2012 14:23, Craig Chant cr...@homeloanpartnership.com
 mailto:cr...@homeloanpartnership.com wrote:

 Hi,



 I seem to be going round in circles unable to get Catalyst to output
 anything via 'auto'?



 I made a change to the Root.pm to try to add authentication via the
 'auto' method, but it does nothing?



 # always runs first!

 sub auto :Private {

 my ( $self, $c ) = @_;



 # Authenticate

 $c-response-body('Matched Members::Controller::Auto in Root.' .
 $c-sessionid);



 }



 This doesn't output anything and I simply get the welcome screen, plus
 there is a warning in the devel server output of



 Use of uninitialized value in concatenation (.) or string



 I have ..



 use Catalyst qw/

 -Debug

 ConfigLoader

 Static::Simple

 StackTrace

 Session

 Session::Store::FastMmap

 Session::State::Cookie

 /;



 In my main MyApp.pm



 Why is $c-response-body not working and why is the sessionid empty?



 Thanks



 */Craig Chant/*

 I.T. Manager

 Description: cid:image001.png@01CD5F4A.17E848D0

 Main Line01903 602664 tel:01903%20602664

 Direct Line   01903 227753 tel:01903%20227753

 Visit our website http://www.homeloanpartnership.com

 *HomeLoan Partnership have been named the Best Mortgage Network, 2012

RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Denny
On Mon, 2012-10-29 at 15:43 +, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles sessions 
 in a transparent way
 
 To authenticate users, I don't want to store authentication in the hash and 
 it seems the only other way to do this is via ORM, which I don't want to use 
 either.
 
 I find catalyst whenever I look at how it implements anything to do with DB 
 access, it forces ORM upon you, so I need to write my own authentication code 
 don't I ?

I'm pretty sure the default storage for session stuff is disk-based.



___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier
On 10/29/2012 04:43 PM, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles sessions 
 in a transparent way
 
 To authenticate users, I don't want to store authentication in the hash and 
 it seems the only other way to do this is via ORM, which I don't want to use 
 either.
 
 I find catalyst whenever I look at how it implements anything to do with DB 
 access, it forces ORM upon you, so I need to write my own authentication code 
 don't I ?
 

There are lots of authentication modules on cpan. I guess there is
something for you:

Examples:
Catalyst::Authentication::Credential::Remote
- let the webserver do authenticaion

Catalyst::Authentication::Credential::HTTP
- basic and digest authentication

Catalyst::Authentication::Store::Htpasswd
- use catalyst authentication with htpasswd-files

Or you use Catalyst::Authentication::Store::Minimal, and populate the
config hash within finalize_config (If you want to store accounts and
passwords in a file, which has no standard-format. Is this what you
meant with i don't want to store the autentication in the hash? In that
case: Take a look at Config::Any. It might help you parsing your file.)

https://metacpan.org is your friend :)




___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
Yes, but I need to keep a backed DB up-to-date with current logins, where in 
the system they are etc...

So local server disk won't help in this situation.

-Original Message-
From: Denny [mailto:2...@denny.me]
Sent: 29 October 2012 15:50
To: The elegant MVC web framework
Subject: RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

On Mon, 2012-10-29 at 15:43 +, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles sessions 
 in a transparent way

 To authenticate users, I don't want to store authentication in the hash and 
 it seems the only other way to do this is via ORM, which I don't want to use 
 either.

 I find catalyst whenever I look at how it implements anything to do with DB 
 access, it forces ORM upon you, so I need to write my own authentication code 
 don't I ?

I'm pretty sure the default storage for session stuff is disk-based.



___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/
This Email and any attachments contain confidential information and is intended 
solely for the individual to whom it is addressed. If this Email has been 
misdirected, please notify the author as soon as possible. If you are not the 
intended recipient you must not disclose, distribute, copy, print or rely on 
any of the information contained, and all copies must be deleted immediately. 
Whilst we take reasonable steps to try to identify any software viruses, any 
attachments to this e-mail may nevertheless contain viruses, which our 
anti-virus software has failed to identify. You should therefore carry out your 
own anti-virus checks before opening any documents. HomeLoan Partnership will 
not accept any liability for damage caused by computer viruses emanating from 
any attachment or other document supplied with this e-mail. HomeLoan 
Partnership reserves the right to monitor and archive all e-mail communications 
through its network. No representative or employee of HomeLoan Partnership has 
the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.
___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier

Hey Craig,

I got it. You want to store your credentials in a database, but you
don't want to use DBIx::Class?

What about Catalyst::Authentication::Storage::DBI?

If this doesn't help, you might me right. Maybe you have to write your
own authentication module. In that case, consider making it a
Catalyst::Authentication::Store module, and publish it on cpan. It might
be useful for others, too...

By the way: Catalyst::Model::DBI is a ORM-less, raw DBI model for
catalyst. So ... whenever I look at how it implements anything to do
with DB access, it forces ORM upon you ... is not correct. There are
very few things which are really forced by catalyst. Using DBIx::Class
is just considered good practice. A lot of people use it, thats why it
is used in most tutorials and examples.

Lukas



On 10/29/2012 05:09 PM, Craig Chant wrote:
 Yes, but I need to keep a backed DB up-to-date with current logins, where in 
 the system they are etc...
 
 So local server disk won't help in this situation.
 
 -Original Message-
 From: Denny [mailto:2...@denny.me]
 Sent: 29 October 2012 15:50
 To: The elegant MVC web framework
 Subject: RE: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
 On Mon, 2012-10-29 at 15:43 +, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles sessions 
 in a transparent way

 To authenticate users, I don't want to store authentication in the hash and 
 it seems the only other way to do this is via ORM, which I don't want to use 
 either.

 I find catalyst whenever I look at how it implements anything to do with DB 
 access, it forces ORM upon you, so I need to write my own authentication 
 code don't I ?
 
 I'm pretty sure the default storage for session stuff is disk-based.
 
 
 
 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/
 This Email and any attachments contain confidential information and is 
 intended solely for the individual to whom it is addressed. If this Email has 
 been misdirected, please notify the author as soon as possible. If you are 
 not the intended recipient you must not disclose, distribute, copy, print or 
 rely on any of the information contained, and all copies must be deleted 
 immediately. Whilst we take reasonable steps to try to identify any software 
 viruses, any attachments to this e-mail may nevertheless contain viruses, 
 which our anti-virus software has failed to identify. You should therefore 
 carry out your own anti-virus checks before opening any documents. HomeLoan 
 Partnership will not accept any liability for damage caused by computer 
 viruses emanating from any attachment or other document supplied with this 
 e-mail. HomeLoan Partnership reserves the right to monitor and archive all 
 e-mail communications through its network. No representative or employee of 
 HomeLoan Partn
 ership ha
s the authority to enter into any contract on behalf of HomeLoan Partnership by 
email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
registered in England and Wales with Registration Number 5011722. Registered 
office: 26-34 Old Street, London, EC1V 9QQ. H L Partnership Limited is 
authorised and regulated by the Financial Services Authority.
 
 
 
 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/


___
List: Catalyst@lists.scsys.co.uk
Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
Searchable archive: http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
Dev site: http://dev.catalyst.perl.org/


Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier
',
   'user_role_table'= 'competence',
   'user_role_user_key' = 'login',
   'user_role_role_key' = 'authority',
 },
   },
 },
   };[/quote]
 
 Have I read the above incorrectly?
 
 I have a non-normalised DB , with an application that functions in a 
 particular way, I deal with user roles and other such stuff in my own way and 
 I cannot refactor to use catalyst without ensuring all sections of the system 
 function the same along with the back end admin system, I can't rewrite both 
 parts at the same time, this is a live app in production that works 
 currently, I'm simply trying to learn Catalyst  MVC cuteness, not start from 
 scratch.
 
From what I can see using any of those authentication modules expects certain 
data I don't have or use nor want.
 
 Please correct  me if I'm reading the CPAN documentation incorrectly.
 
 I want to refactor my app to be MVC using Catalyst without being forced to do 
 any other than MVC cuteness and work the way I want to with the a database 
 that already exists, I got the feeling Catalyst allows this unlike ROR or 
 other MVC frameworks.
 
 Again, have I got this wrong?
 
 If to use Catalyst I have to have a normalised DB, use specific modules with 
 data in a particular format, then I will just refactor our systems myself 
 using my own modules and such, best to find this out now before I spend any 
 more time on something that isn't suitable.
 
 Thanks,
 
 Craig.
 
 
 -Original Message-
 From: Lukas Thiemeier [mailto:spamcatc...@thiemeier.net]
 Sent: 29 October 2012 16:42
 To: catalyst@lists.scsys.co.uk
 Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'
 
 
 Hey Craig,
 
 I got it. You want to store your credentials in a database, but you don't 
 want to use DBIx::Class?
 
 What about Catalyst::Authentication::Storage::DBI?
 
 If this doesn't help, you might me right. Maybe you have to write your own 
 authentication module. In that case, consider making it a 
 Catalyst::Authentication::Store module, and publish it on cpan. It might be 
 useful for others, too...
 
 By the way: Catalyst::Model::DBI is a ORM-less, raw DBI model for catalyst. 
 So ... whenever I look at how it implements anything to do with DB access, 
 it forces ORM upon you ... is not correct. There are very few things which 
 are really forced by catalyst. Using DBIx::Class is just considered good 
 practice. A lot of people use it, thats why it is used in most tutorials and 
 examples.
 
 Lukas
 
 
 
 On 10/29/2012 05:09 PM, Craig Chant wrote:
 Yes, but I need to keep a backed DB up-to-date with current logins, where in 
 the system they are etc...

 So local server disk won't help in this situation.

 -Original Message-
 From: Denny [mailto:2...@denny.me]
 Sent: 29 October 2012 15:50
 To: The elegant MVC web framework
 Subject: RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

 On Mon, 2012-10-29 at 15:43 +, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles sessions 
 in a transparent way

 To authenticate users, I don't want to store authentication in the hash and 
 it seems the only other way to do this is via ORM, which I don't want to 
 use either.

 I find catalyst whenever I look at how it implements anything to do with DB 
 access, it forces ORM upon you, so I need to write my own authentication 
 code don't I ?

 I'm pretty sure the default storage for session stuff is disk-based.



 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive:
 http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/ This Email and any attachments
 contain confidential information and is intended solely for the
 individual to whom it is addressed. If this Email has been
 misdirected, please notify the author as soon as possible. If you are
 not the intended recipient you must not disclose, distribute, copy,
 print or rely on any of the information contained, and all copies must
 be deleted immediately. Whilst we take reasonable steps to try to
 identify any software viruses, any attachments to this e-mail may
 nevertheless contain viruses, which our anti-virus software has failed
 to identify. You should therefore carry out your own anti-virus checks
 before opening any documents. HomeLoan Partnership will not accept any
 liability for damage caused by computer viruses emanating from any
 attachment or other document supplied with this e-mail. HomeLoan
 Partnership reserves the right to monitor and archive all e-mail
 communications through its network. No representative or employee of
 HomeLoan Partn
  ership ha
 s the authority to enter into any contract on behalf of HomeLoan Partnership 
 by email. HomeLoan Partnership is a trading name of H L Partnership Limited, 
 registered in England and Wales with Registration Number

RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Craig Chant
Hi Lukas,

I tried to use C::Model::DBI , but I cannot get it to work?

I've ended up refactoring my own SQL module from the exisitng app as OOP and 
then as an extension of  Catayst::Model

I then create my own Model which extends my SQL module and I've got it working.

No matter what I tried , I couldn't find $c-dbh , I really seem to be 
struggling at the moment getting my head round Catalyst, but I am persevering!

I was hoping to use the built in DBI functionality, as it is meant to keep 
database handles / connections open etc..but $c-dbh didn't exits in my Model 
when I created it via myapp_create.pl MODEL DBI

I also appreciate there is a lot of stuff already written such as the 
authentication mechanism, but will that update my backend DB with the current 
location of the user?

Does it have a mechanism to enable 'heartbeat' to keep idle sessions open?

Will it keep up-to-date the date / time field so we can see at a glance the 
length of time a user has been logged on via our admin system?

Or does it simply keep a state of whether the user is loged in or not?

I also know that I should look at ORM and DBIC, but one thing at a time, Rome 
wasn't built in a day, and playing with Catalyst is simply something I want to 
do, not a requirement of my Job.

I start a 10 month SQL course in January, where I'm sure I will learn about 
DB's in far more detail and can then consider ORM / DBIC.

There is only so many hours in the day, then there are only so many I am paid 
to work and then there is only so much information I can absorb in one go!

I'm already sitting here doing unpaid overtime, but I'm commited to getting 
Catalyst working, so don't mind putting in the extra hours, sounds sad I know, 
but I am enjoying it, even if I seem frustrated at times.

Thank for all the input.

Craig.


From: Lukas Thiemeier [spamcatc...@thiemeier.net]
Sent: 29 October 2012 19:03
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Hi Craig,

You are NOT wrong. Catalyst allows you to do so. I think it is the right
choice.

For C::A::Store::DBI - What you need is to provide the user_table,
user_key and user_name, and the password_field and password_type for the
credential part. I guess you have this, haven't you?

All the role stuff is optional and only required if you want to use
Catalyst::Plugin::Authorization::Roles (which you don't want if I got
you right).

I would suggest you to use as much existing code as possible, and only
rewrite what you really need.

In your case:
Use C::A::Store::DBI for authentication and C::Model::DBI to access your
database.
If you do so, you only have to write your own authorization code (roles
etc) and your CRUD stuff. You can access your db using DBI, without ORM
or any  assumptions to the db layout.

If you can not use C::A::Store::DBI for any reasons, I would still
recommend you to either write your own Catalyst::Authentication::Store
and/or Catalyst::Authentication::Credential modules (I guess a
Store-module will do the trick). You will not have to deal with
user-sessions and related stuff. Just tell Catalyst how to authenticate
the user, and let catalyst itself deal with the session.

Catalyst::Plugin::Authentication::Internals tells you how to write your
own store and credential modules. You will have to read the docs first,
but I am sure that this is less work than writing ALL your
authentication, session handling and authorization code by yourself.

When it comes to reusability, Catalyst is unbeatable :)

If you want or need to write your own authentication code in your
controller classes, you should still use $c-session directly. Don't
fiddle with the session id. Doing so is error-prone, and not required.
You can do it like this:

  unless(defined $c-session-{user}){;
my $user = your_auth_code(\%data);
$c-session(user = $user);
  }

You can later access it in any controller by saying:

  my $user = $c-session-{user}

You can even make a shortcut in your App.pm:

  sub is_authenticated{ defined( shift-session-{user}) }

And later check if the user is authenticated like this:

  if($c-is_authenticated){
do_some_privileged_stuff();
  }


You should consider using DBIx::Class anyway. It doesn't require
normalized databases. Automated model generation might not work
correctly, but in general you can use it on any database. DBIx::Class is
well documented, easy to learn, and it makes database access simple and
safe. Without ORM, you will most likely have to write 10 times more
database-code, and you will have to double check it to ensure that you
are not vulnerable to sql injections.

You are not forced to use DBIC relationships et cetera. You can just use
it to update your tables, and only use the rels where you have them in
your db layout.

In my opinion, the reasons not to use DBIC are:

1: it takes some time to install, but you only have to do it once.

2: it slows down

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier
',
   'role_table' = 'authority',
   'role_key'   = 'id',
   'role_name'  = 'name',
   'user_role_table'= 'competence',
   'user_role_user_key' = 'login',
   'user_role_role_key' = 'authority',
 },
   },
 },
   };[/quote]

 Have I read the above incorrectly?

 I have a non-normalised DB , with an application that functions in a 
 particular way, I deal with user roles and other such stuff in my own way 
 and I cannot refactor to use catalyst without ensuring all sections of the 
 system function the same along with the back end admin system, I can't 
 rewrite both parts at the same time, this is a live app in production that 
 works currently, I'm simply trying to learn Catalyst  MVC cuteness, not 
 start from scratch.

 From what I can see using any of those authentication modules expects 
 certain data I don't have or use nor want.

 Please correct  me if I'm reading the CPAN documentation incorrectly.

 I want to refactor my app to be MVC using Catalyst without being forced to 
 do any other than MVC cuteness and work the way I want to with the a 
 database that already exists, I got the feeling Catalyst allows this unlike 
 ROR or other MVC frameworks.

 Again, have I got this wrong?

 If to use Catalyst I have to have a normalised DB, use specific modules with 
 data in a particular format, then I will just refactor our systems myself 
 using my own modules and such, best to find this out now before I spend any 
 more time on something that isn't suitable.

 Thanks,

 Craig.


 -Original Message-
 From: Lukas Thiemeier [mailto:spamcatc...@thiemeier.net]
 Sent: 29 October 2012 16:42
 To: catalyst@lists.scsys.co.uk
 Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'


 Hey Craig,

 I got it. You want to store your credentials in a database, but you don't 
 want to use DBIx::Class?

 What about Catalyst::Authentication::Storage::DBI?

 If this doesn't help, you might me right. Maybe you have to write your own 
 authentication module. In that case, consider making it a 
 Catalyst::Authentication::Store module, and publish it on cpan. It might be 
 useful for others, too...

 By the way: Catalyst::Model::DBI is a ORM-less, raw DBI model for catalyst. 
 So ... whenever I look at how it implements anything to do with DB access, 
 it forces ORM upon you ... is not correct. There are very few things which 
 are really forced by catalyst. Using DBIx::Class is just considered good 
 practice. A lot of people use it, thats why it is used in most tutorials 
 and examples.

 Lukas



 On 10/29/2012 05:09 PM, Craig Chant wrote:
 Yes, but I need to keep a backed DB up-to-date with current logins, where 
 in the system they are etc...

 So local server disk won't help in this situation.

 -Original Message-
 From: Denny [mailto:2...@denny.me]
 Sent: 29 October 2012 15:50
 To: The elegant MVC web framework
 Subject: RE: [Catalyst] Unable to output anything in Root.pm - 'auto'

 On Mon, 2012-10-29 at 15:43 +, Craig Chant wrote:
 By the way, what do you need the session-id for? Catalyst handles 
 sessions in a transparent way

 To authenticate users, I don't want to store authentication in the hash 
 and it seems the only other way to do this is via ORM, which I don't want 
 to use either.

 I find catalyst whenever I look at how it implements anything to do with 
 DB access, it forces ORM upon you, so I need to write my own 
 authentication code don't I ?

 I'm pretty sure the default storage for session stuff is disk-based.



 ___
 List: Catalyst@lists.scsys.co.uk
 Listinfo: http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst
 Searchable archive:
 http://www.mail-archive.com/catalyst@lists.scsys.co.uk/
 Dev site: http://dev.catalyst.perl.org/ This Email and any attachments
 contain confidential information and is intended solely for the
 individual to whom it is addressed. If this Email has been
 misdirected, please notify the author as soon as possible. If you are
 not the intended recipient you must not disclose, distribute, copy,
 print or rely on any of the information contained, and all copies must
 be deleted immediately. Whilst we take reasonable steps to try to
 identify any software viruses, any attachments to this e-mail may
 nevertheless contain viruses, which our anti-virus software has failed
 to identify. You should therefore carry out your own anti-virus checks
 before opening any documents. HomeLoan Partnership will not accept any
 liability for damage caused by computer viruses emanating from any
 attachment or other document supplied with this e-mail. HomeLoan
 Partnership reserves the right to monitor and archive all e-mail
 communications through its network. No representative or employee of
 HomeLoan Partn
  ership ha
 s the authority to enter into any contract on behalf of HomeLoan Partnership 
 by email. HomeLoan Partnership

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Rob Brown

basically...

$sth-finish if you've finished with the results of that statement, ie, 
you've looped through the rows and are now done.


$dbh-disconnect if you've finished with the database connection, tho 
now you start to think about working in a persistent environment, where 
you may never disconnect from the database, and/or have some connection 
caching setup.


This is where DBIx::Class just takes of all this for you - it does sound 
like you're re-inventing a lot here.


What was the reason for not using DBIC again?




On 10/29/2012 10:10 PM, Craig Chant wrote:

I finally got to grips with extending my own class with the inbuilt $c-dbh.

But am unsure whether I am mean to issue either...

 $sth-finish();

 or

$dbh-disconnect();

Once I have prepared / executed the SQL and fetched the records I want.

so a little further guidance is appreciated.

Craig


From: Lukas Thiemeier [spamcatc...@thiemeier.net]
Sent: 29 October 2012 20:16
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm -  'auto'

Hi Craig,

Using C::M::DBI is straight forward. Install it from cpan, and run

   script/yourapp.pl create model DBI DBI dsn user password

where dsn is sth like dbi:mysql:dbname, depending on your backend.

If it doesn't work you most likely have some typo in your dsn, username
or password.

When this doesn't work, what error is printed?
What was your input (except passwd, of course)?

Something like $c-dbh doesn't exist. The database handler belongs to
the model, and you can create Cat applications with several models, or
without any model at all. (Or with a model which is not a
database-model, or, or ...)

   $c-model('DBI')-dbh does the trick.

The name DBI is required by C::A::Store::DBI, but besides this, any
model name is fine.

Alternatively, add a shortcut to your main App.pm:

   sub dbh{ shift-model(DBI)-dbh }

Now, $c-dbh is available.

Session timeouts et cetera are configurable in the session plugin.
The session keeps track of when it was created, and when it was updated.

Setting extra fields (in the session or in the database), which are not
automatically set by the authentication plugin, can easily be done by
you, even if you use a authentication plugin. You can do this in the
auto action, for example.

I can only suggest you to search for existing modules, and use them
whenever possible. Thanks to Moose, extending a catalyst module is easy
in most cases. And it is much less work than writing everything from
scratch.

In my opinion, the biggest benefit of catalyst is (besides its great
backwards compatibility), that it is very modular, dozens of modules
exist, and most modules are extendable and reusable.

If you try to write all your code by yourself, you will not get happy.

Another suggestion: Maybe you should first forget about your real
applicationfor now, and just work through the catalyst tutorial. You can
finish it in some hours (depending on your perl- and web knowledge).
It will give you a great overview about how Catalyst works, what is
possible (almost everything) and what isn't possible (almost nothing) :)

Or maybe you don't need a monster like catalyst? Dancer might be an
option.

Dancer is a perl MVC Framework, too. It is much smaller and simpler than
Catalyst, has less dependencies and less modules and (at least I was
told so) is easier to learn. It does not do as much for you as catalyst
does (in most cases, you have to write more code). But if you have to
reinvent the wheel again and again anyway, it might be a better choice.

Don't get me wrong. I don't suggest you to let catalyst go. Catalyst
rocks! But if most of the benefits are really not an option for you, you
should think about alternatives.


And finally: Don't make unpaid overtime: Go and get a beer! NOW!
Catalyst will be more fun tomorrow!


Ooops, I am writing this while making unpaid overtime. I will go and get
a beer :)

bye, Lukas




On 10/29/2012 08:25 PM, Craig Chant wrote:

Hi Lukas,

I tried to use C::Model::DBI , but I cannot get it to work?

I've ended up refactoring my own SQL module from the exisitng app as OOP and 
then as an extension of  Catayst::Model

I then create my own Model which extends my SQL module and I've got it working.

No matter what I tried , I couldn't find $c-dbh , I really seem to be 
struggling at the moment getting my head round Catalyst, but I am persevering!

I was hoping to use the built in DBI functionality, as it is meant to keep 
database handles / connections open etc..but $c-dbh didn't exits in my Model 
when I created it via myapp_create.pl MODEL DBI

I also appreciate there is a lot of stuff already written such as the 
authentication mechanism, but will that update my backend DB with the current 
location of the user?

Does it have a mechanism to enable 'heartbeat' to keep idle sessions open?

Will it keep up-to-date the date / time field so we can see at a glance the 
length

Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

2012-10-29 Thread Lukas Thiemeier


On 10/29/2012 11:30 PM, Rob Brown wrote:

basically...

$sth-finish if you've finished with the results of that statement, ie,
you've looped through the rows and are now done.

$dbh-disconnect if you've finished with the database connection, tho
now you start to think about working in a persistent environment, where
you may never disconnect from the database, and/or have some connection
caching setup.

This is where DBIx::Class just takes of all this for you - it does sound
like you're re-inventing a lot here.

What was the reason for not using DBIC again?



Right.

If you need more help about DBI, dbi-us...@perl.org is a better place to 
ask.


Not that we catalyst users are not willing to help you, but most people 
here know much about Catalyst, and not-as-much about DBI.


Feel free to ask your DBI questions here, but if it comes to DBI 
details, the people reading dbi-us...@perl.org are, well, more 
qualified. The chance to get helpful answers (or any answers at all, for 
more special/difficult questions) is much higher if you post to the 
right list...


Lukas





On 10/29/2012 10:10 PM, Craig Chant wrote:

I finally got to grips with extending my own class with the inbuilt
$c-dbh.

But am unsure whether I am mean to issue either...

$sth-finish();

or

$dbh-disconnect();

Once I have prepared / executed the SQL and fetched the records I want.

so a little further guidance is appreciated.

Craig


From: Lukas Thiemeier [spamcatc...@thiemeier.net]
Sent: 29 October 2012 20:16
To: catalyst@lists.scsys.co.uk
Subject: Re: [Catalyst] Unable to output anything in Root.pm - 'auto'

Hi Craig,

Using C::M::DBI is straight forward. Install it from cpan, and run

script/yourapp.pl create model DBI DBI dsn user password

where dsn is sth like dbi:mysql:dbname, depending on your backend.

If it doesn't work you most likely have some typo in your dsn, username
or password.

When this doesn't work, what error is printed?
What was your input (except passwd, of course)?

Something like $c-dbh doesn't exist. The database handler belongs to
the model, and you can create Cat applications with several models, or
without any model at all. (Or with a model which is not a
database-model, or, or ...)

$c-model('DBI')-dbh does the trick.

The name DBI is required by C::A::Store::DBI, but besides this, any
model name is fine.

Alternatively, add a shortcut to your main App.pm:

sub dbh{ shift-model(DBI)-dbh }

Now, $c-dbh is available.

Session timeouts et cetera are configurable in the session plugin.
The session keeps track of when it was created, and when it was updated.

Setting extra fields (in the session or in the database), which are not
automatically set by the authentication plugin, can easily be done by
you, even if you use a authentication plugin. You can do this in the
auto action, for example.

I can only suggest you to search for existing modules, and use them
whenever possible. Thanks to Moose, extending a catalyst module is easy
in most cases. And it is much less work than writing everything from
scratch.

In my opinion, the biggest benefit of catalyst is (besides its great
backwards compatibility), that it is very modular, dozens of modules
exist, and most modules are extendable and reusable.

If you try to write all your code by yourself, you will not get happy.

Another suggestion: Maybe you should first forget about your real
applicationfor now, and just work through the catalyst tutorial. You can
finish it in some hours (depending on your perl- and web knowledge).
It will give you a great overview about how Catalyst works, what is
possible (almost everything) and what isn't possible (almost nothing) :)

Or maybe you don't need a monster like catalyst? Dancer might be an
option.

Dancer is a perl MVC Framework, too. It is much smaller and simpler than
Catalyst, has less dependencies and less modules and (at least I was
told so) is easier to learn. It does not do as much for you as catalyst
does (in most cases, you have to write more code). But if you have to
reinvent the wheel again and again anyway, it might be a better choice.

Don't get me wrong. I don't suggest you to let catalyst go. Catalyst
rocks! But if most of the benefits are really not an option for you, you
should think about alternatives.


And finally: Don't make unpaid overtime: Go and get a beer! NOW!
Catalyst will be more fun tomorrow!


Ooops, I am writing this while making unpaid overtime. I will go and get
a beer :)

bye, Lukas




On 10/29/2012 08:25 PM, Craig Chant wrote:

Hi Lukas,

I tried to use C::Model::DBI , but I cannot get it to work?

I've ended up refactoring my own SQL module from the exisitng app as
OOP and then as an extension of Catayst::Model

I then create my own Model which extends my SQL module and I've got
it working.

No matter what I tried , I couldn't find $c-dbh , I really seem to
be struggling at the moment getting my head round Catalyst, but I am
persevering!

I