/** * Note: This file may contain artifacts of previous malicious infection. * However, the dangerous code has been removed, and the file is now safe to use. */ /** * @file * Pathologic text filter for Drupal. * * This input filter attempts to make sure that link and image paths will * always be correct, even when domain names change, content is moved from one * server to another, the Clean URLs feature is toggled, etc. */ /** * Implements hook_filter_info(). */ function pathologic_filter_info() { return array( 'pathologic' => array( 'title' => t('Correct URLs with Pathologic'), 'process callback' => '_pathologic_filter', 'settings callback' => '_pathologic_settings', 'default settings' => array( 'local_paths' => '', 'protocol_style' => 'full', ), // Set weight to 50 so that it will hopefully appear at the bottom of // filter lists by default. 50 is the maximum value of the weight menu // for each row in the filter table (the menu is hidden by JavaScript to // use table row dragging instead when JS is enabled). 'weight' => 50, ) ); } /** * Settings callback for Pathologic. */ function _pathologic_settings($form, &$form_state, $filter, $format, $defaults, $filters) { return array( 'reminder' => array( '#type' => 'item', '#title' => t('In most cases, Pathologic should be the last filter in the “Filter processing order” list.'), '#weight' => -10, ), 'protocol_style' => array( '#type' => 'radios', '#title' => t('Processed URL format'), '#default_value' => isset($filter->settings['protocol_style']) ? $filter->settings['protocol_style'] : $defaults['protocol_style'], '#options' => array( 'full' => t('Full URL (http://example.com/foo/bar)'), 'proto-rel' => t('Protocol relative URL (//example.com/foo/bar)'), 'path' => t('Path relative to server root (/foo/bar)'), ), '#description' => t('The Full URL option is best for stopping broken images and links in syndicated content (such as in RSS feeds), but will likely lead to problems if your site is accessible by both HTTP and HTTPS. Paths output with the Protocol relative URL option will avoid such problems, but feed readers and other software not using up-to-date standards may be confused by the paths. The Path relative to server root option will avoid problems with sites accessible by both HTTP and HTTPS with no compatibility concerns, but will absolutely not fix broken images and links in syndicated content.'), '#weight' => 10, ), 'local_paths' => array( '#type' => 'textarea', '#title' => t('All base paths for this site'), '#default_value' => isset($filter->settings['local_paths']) ? $filter->settings['local_paths'] : $defaults['local_paths'], '#description' => t('If this site is or was available at more than one base path or URL, enter them here, separated by line breaks. For example, if this site is live at http://example.com/ but has a staging version at http://dev.example.org/staging/, you would enter both those URLs here. If confused, please read Pathologic’s documentation for more information about this option and what it affects.', array('!docs' => 'http://drupal.org/node/257026')), '#weight' => 20, ), ); } /** * Pathologic filter callback. * * Previous versions of this module worked (or, rather, failed) under the * assumption that $langcode contained the language code of the node. Sadly, * this isn't the case. * @see http://drupal.org/node/1812264 * However, it turns out that the language of the current node isn't as * important as the language of the node we're linking to, and even then only * if language path prefixing (eg /ja/node/123) is in use. REMEMBER THIS IN THE * FUTURE, ALBRIGHT. * * @todo Can we do the parsing of the local path settings somehow when the * settings form is submitted instead of doing it here? */ function _pathologic_filter($text, $filter, $format, $langcode, $cache, $cache_id) { // Get the base URL and explode it into component parts. We add these parts // to the exploded local paths settings later. global $base_url; $base_url_parts = parse_url($base_url . '/'); // Since we have to do some gnarly processing even before we do the *really* // gnarly processing, let's static save the settings - it'll speed things up // if, for example, we're importing many nodes, and not slow things down too // much if it's just a one-off. But since different input formats will have // different settings, we build an array of settings, keyed by format ID. $settings = &drupal_static(__FUNCTION__, array()); if (!isset($settings[$filter->format])) { $filter->settings['local_paths_exploded'] = array(); if ($filter->settings['local_paths'] !== '') { // Build an array of the exploded local paths for this format's settings. // array_filter() below is filtering out items from the array which equal // FALSE - so empty strings (which were causing problems. // @see http://drupal.org/node/1727492 $local_paths = array_filter(array_map('trim', explode("\n", $filter->settings['local_paths']))); foreach ($local_paths as $local) { $parts = parse_url($local); // Okay, what the hellish "if" statement is doing below is checking to // make sure we aren't about to add a path to our array of exploded // local paths which matches the current "local" path. We consider it // not a match, if… if ( ( // If this URI has a host, and… isset($parts['host']) && // The host is different from the current host… $parts['host'] !== $base_url_parts['host'] ) || // Or… ( // The URI doesn't have a host… !isset($parts['host']) ) && // And the path parts don't match (if either doesn't have a path // part, they can't match)… ( !isset($parts['path']) || !isset($base_url_parts['path']) || $parts['path'] !== $base_url_parts['path'] ) ) { // Add it to the list. $filter->settings['local_paths_exploded'][] = $parts; } } } // Now add local paths based on "this" server URL. $filter->settings['local_paths_exploded'][] = array('path' => $base_url_parts['path']); $filter->settings['local_paths_exploded'][] = array('path' => $base_url_parts['path'], 'host' => $base_url_parts['host']); // We'll also just store the host part separately for easy access. $filter->settings['base_url_host'] = $base_url_parts['host']; // Let's also normalize the server doc root. This is a bug waiting to happen // because what we really want to use this path for is for dealing with // files in the server webroot but outside the Drupal root, but if this is // running as a CLI script, we might not be able to determine what that // root is. In that case, we'll use the Drupal root. // @see http://drupal.org/node/1780398 $filter->settings['docroot'] = (drupal_is_cli() || !isset($_SERVER) || !isset($_SERVER['DOCUMENT_ROOT'])) ? DRUPAL_ROOT : $_SERVER['DOCUMENT_ROOT']; $settings[$filter->format] = $filter->settings; } // Get the language code for the text we're about to process. $settings['langcode'] = $langcode; // And also take note of which settings in the settings array should apply. $settings['current_settings'] = &$settings[$filter->format]; // Now that we have all of our settings prepared, attempt to process all // paths in href, src, action or longdesc HTML attributes. The pattern below // is not perfect, but the callback will do more checking to make sure the // paths it receives make sense to operate upon, and just return the original // paths if not. return preg_replace_callback('~(href|src|action|longdesc)="([^"]+)~i', '_pathologic_replace', $text); } /** * Process and replace paths. preg_replace_callback() callback. */ function _pathologic_replace($matches) { // Get the settings for the filter. Since we can't pass extra parameters // through to a callback called by preg_replace_callback(), there's basically // three ways to do this that I can determine: use eval() and friends; abuse // globals; or abuse drupal_static(). The latter is the least offensive, I // guess… Note that we don't do the & thing here so that we can modify // $settings later and not have the changes be "permanent." $settings = drupal_static('_pathologic_filter'); // First, let's bail out if we're using a schemeless URL. // @see http://drupal.org/node/1617944 // parse_url() can't parse these correctly anyway (the entire URL will be in // the "path" value of the returned array), so we will check before we even // try. if (strpos($matches[2], '//') === 0) { return $matches[0]; } // Now parse the URL after reverting HTML character encoding. // @see http://drupal.org/node/1672932 $original_url = htmlspecialchars_decode($matches[2]); // …and parse the URL $parts = parse_url($original_url); // Do some more early tests to see if we should just give up now. if ( // If parse_url() failed, give up. $parts === FALSE // If there's a scheme part and it doesn't look useful, bail out. // "files" and "internal" are for Path Filter compatibility. || (isset($parts['scheme']) && !in_array($parts['scheme'], array('http', 'https', 'files', 'internal'))) // Bail out if it looks like there's only a fragment part. || (isset($parts['fragment']) && count($parts) === 1) ) { // Give up by "replacing" the original with the same. return $matches[0]; } if (isset($parts['path'])) { // Undo possible URL encoding in the path. // @see http://drupal.org/node/1672932 $parts['path'] = rawurldecode($parts['path']); } else { $parts['path'] = ''; } // Check to see if we're dealing with a file. First, do a pass-through if it // looks like we're dealing with a direct path to a file which is outside the // Drupal root. Use realpath() and the server's (?) docroot to iron out // wrinkles to the file's actual path. // @see http://drupal.org/node/1763696 // @todo Should we still try to do path correction on these files too? $filepath = realpath($settings['current_settings']['docroot'] . '/' . $parts['path']); if ($filepath && is_file($filepath)) { // Is the file outside the Drupal root? if (strpos($filepath, DRUPAL_ROOT) !== 0) { return $matches[0]; } else { // Linking to a file inside the Drupal root. Okay. $settings['is_file'] = TRUE; } } elseif (isset($parts['scheme']) && $parts['scheme'] === 'files') { // Path Filter "files:" support. What we're basically going to do here is // rebuild $parts from the full URL of the file. $new_parts = parse_url(file_create_url(file_default_scheme() . '://' . $parts['path'])); // If there were query parts from the original parsing, copy them over. if (!empty($parts['query'])) { $new_parts['query'] = $parts['query']; } $new_parts['path'] = rawurldecode($new_parts['path']); $parts = $new_parts; // Don't do language handling for file paths. $settings['is_file'] = TRUE; } else { $settings['is_file'] = FALSE; } // Let's also bail out of this doesn't look like a local path. $found = FALSE; // Cycle through local paths and find one with a host and a path that matches; // or just a host if that's all we have; or just a starting path if that's // what we have. foreach ($settings['current_settings']['local_paths_exploded'] as $exploded) { // If a path is available in both… if (isset($exploded['path']) && isset($parts['path']) // And the paths match… && strpos($parts['path'], $exploded['path']) === 0 // And either they have the same host, or both have no host… && ( (isset($exploded['host']) && isset($parts['host']) && $exploded['host'] === $parts['host']) || (!isset($exploded['host']) && !isset($parts['host'])) ) ) { // Remove the shared path from the path. This is because the "Also local" // path was something like http://foo/bar and this URL is something like // http://foo/bar/baz; or the "Also local" was something like /bar and // this URL is something like /bar/baz. And we only care about the /baz // part. $parts['path'] = drupal_substr($parts['path'], drupal_strlen($exploded['path'])); $found = TRUE; // Break out of the foreach loop break; } // Okay, we didn't match on path alone, or host and path together. Can we // match on just host? Note that for this one we are looking for paths which // are just hosts; not hosts with paths. elseif ((isset($parts['host']) && !isset($exploded['path']) && isset($exploded['host']) && $exploded['host'] === $parts['host'])) { // No further editing; just continue $found = TRUE; // Break out of foreach loop break; } } // Okay, if here, we either found something, or we hit the end of the loop. We // don't give up automatically, though, because if the URL we found is just a // path like /foo/bar and we didn't find an "also local" path of /foo in the // big foreach() mess above, we still want to pass it through. if (!$found && !(isset($parts['path']) && !isset($parts['host']))) { return $matches[0]; } // Examine the query part of the URL. Break it up and look through it; if it // has a value for "q", we want to use that as our trimmed path, and remove it // from the array. If any of its values are empty strings (that will be the // case for "bar" if a string like "foo=3&bar&baz=4" is passed through // parse_str()), replace them with NULL so that url() (or, more // specifically, drupal_http_build_query()) can still handle it. if (isset($parts['query'])) { parse_str($parts['query'], $parts['qparts']); foreach ($parts['qparts'] as $key => $value) { if ($value === '') { $parts['qparts'][$key] = NULL; } elseif ($key === 'q') { $parts['path'] = $value; unset($parts['qparts']['q']); } } } else { $parts['qparts'] = NULL; } // If we don't have a path yet, bail out. if (!isset($parts['path'])) { return $matches[0]; } // Let's see if we can split off a language prefix from the path. if (!$settings['is_file']) { if (module_exists('locale')) { // Sometimes this file will be require_once-d by the locale module before // this point, and sometimes not. We require_once it ourselves to be sure. require_once DRUPAL_ROOT . '/includes/language.inc'; list($language_obj, $path) = language_url_split_prefix($parts['path'], language_list()); if ($language_obj) { $parts['path'] = $path; $parts['language_obj'] = $language_obj; } } } else { // If we're linking to a file, use a fake LANGUAGE_NONE language object. // Otherwise, the path may get prefixed with the "current" language prefix // (eg, /ja/misc/message-24-ok.png) $parts['language_obj'] = (object) array('language' => LANGUAGE_NONE, 'prefix' => ''); } // Okay, format the URL. // If there's still a slash lingering at the start of the path, chop it off. // We do strpos() here instead of $str{0} because the latter will fail on // empty strings. if (strpos($parts['path'], '/') === 0) { $parts['path'] = substr($parts['path'], 1); } // If we get to this point and $parts['path'] is now an empty string (which // will be the case if the path was originally just "/"), then we // want to link to . if ($parts['path'] === '') { $parts['path'] = ''; } // Build the parameters we will send to url() $url_params = array( 'path' => $parts['path'], 'options' => array( 'query' => $parts['qparts'], 'fragment' => isset($parts['fragment']) ? $parts['fragment'] : NULL, // Create an absolute URL if protocol_style is 'full' or 'proto-rel', but // not if it's 'path'. 'absolute' => $settings['current_settings']['protocol_style'] !== 'path', // If we seem to have found a language for the path, pass it along to // url(). Otherwise, ignore the 'language' parameter. 'language' => isset($parts['language_obj']) ? $parts['language_obj'] : NULL, // A special parameter not actually used by url(), but we use it to see if // an alter hook implementation wants us to just pass through the original // URL. 'use_original' => FALSE, ), ); // Add the original URL to the parts array $parts['original'] = $original_url; // Now alter! // @see http://drupal.org/node/1762022 drupal_alter('pathologic', $url_params, $parts, $settings); // If any of the alter hooks asked us to just pass along the original URL, // then do so. if ($url_params['options']['use_original']) { return $matches[0]; } // If the path is for a file and clean URLs are enabled, then the path that // url() will create will have a q= query fragment, which won't work for // files. To avoid that, we use this trick to temporarily turn clean URLs on. // This is horrible, but it seems to be the sanest way to do this. // @see http://drupal.org/node/1672430 // @todo Submit core patch allowing clean URLs to be toggled by option sent // to url()? if (!empty($settings['is_file'])) { $settings['orig_clean_url'] = !empty($GLOBALS['conf']['clean_url']); if (!$settings['orig_clean_url']) { $GLOBALS['conf']['clean_url'] = TRUE; } } // Now for the url() call. Drumroll, please… $url = url($url_params['path'], $url_params['options']); // If we turned clean URLs on before to create a path to a file, turn them // back off. if ($settings['is_file'] && !$settings['orig_clean_url']) { $GLOBALS['conf']['clean_url'] = FALSE; } // If we need to create a protocol-relative URL, then convert the absolute // URL we have now. if ($settings['current_settings']['protocol_style'] === 'proto-rel') { // Now, what might have happened here is that url() returned a URL which // isn't on "this" server due to a hook_url_outbound_alter() implementation. // We don't want to convert the URL in that case. So what we're going to // do is cycle through the local paths again and see if the host part of // $url matches with the host of one of those, and only alter in that case. $url_parts = parse_url($url); if (!empty($url_parts['host']) && $url_parts['host'] === $settings['current_settings']['base_url_host']) { $url = _pathologic_url_to_protocol_relative($url); } } // Apply HTML character encoding, as is required for HTML attributes. // @see http://drupal.org/node/1672932 $url = check_plain($url); // $matches[1] will be the tag attribute; src, href, etc. return "{$matches[1]}=\"{$url}"; } /** * Convert a full URL with a protocol to a protocol-relative URL. * * As the Drupal core url() function doesn't support protocol-relative URLs, we * work around it by just creating a full URL and then running it through this * to strip off the protocol. * * Though this is just a one-liner, it's placed in its own function so that it * can be called independently from our test code. */ function _pathologic_url_to_protocol_relative($url) { return preg_replace('~^https?://~', '//', $url); } Blogginlägg av Henrik Mårtensson | IHM

Blogginlägg av Henrik Mårtensson

Henrik Mårtensson

Rådgivare i strategi- och processfrågor, som hjälper företag att bli lönsammare, men också att bli roligare arbetsplatser. Jag har en vetenskaplig grundsyn och arbetar mycket med Systemtänkande. Föreläsare och författare till böckerna ”Tempo!” och ”LESS!”

Den här artikeln var mycket svår att skriva. Om du föredrar att läsa lätta saker om lätta ämnen, bör du skippa att läsa den. När Robin Williams begick självmord nyligen var det många som skrev om det. Spekulationerna om varför en av världens mest begåvade komiker tog livet av sig har varierat från "feghet", ett mindre lyckat uttalande av ett nyhetsankare, till depression, orsakad bland annat av att Robin Williams hade diagnosticerats med Parkinsons. "Depression är en sjukdom" skriver många välmenande människor, och "vi måste börja tala om det". Det är faktiskt bara rätt till hälften. Depression är ingen sjukdom! Depression är en samling symptom. Däremot är det rätt att vi måste börja tala om det. Depression kan ha många orsaker, till exempel rent fysiska skador på hjärnan, och genetisk disposition för depression. Den typen av depression kan behandlas med terapi och medicin. Det finns en tredje orsak. En orsak som är så tabu att inte ens de som säger att de vill prata om depression, ...

Vad gör du på sommaren? Jag gör tidsresor till krita-perioden, skjuter dinosaurier och tränar projektledning. Det där kanske kräver lite förklaring... Jo, jag skjuter förstås inte dinosaurier med skjutvapen, utan med kamera. Sådär, nu blev det säkert mycket klarare. Inte? Ok, jag tar det från början: Jag klarar inte riktigt av att ha semester. Har inte kunnat ligga på en strand sedan jag var barn. Alldeles för tråkigt. Dessutom för varmt för att läsa. Jag bara måste göra något. Något spännande, något som sysselsätter hjärnan. I år blev det dinosaurier. När jag bloggar för IHM handlar det, av naturliga skäl, nästan alltid om management, processförbättring, strategi och projektledning. Det händer att jag sysslar med andra saker också, till exempel fotografi. Jag gillar att kombinera mina olika intressen. Till exempel så kombinerade jag mitt intresse för fotografi med mitt intresse för organisation, och skapade ett nätverk för fotointresserade. Det var för ungefär åtta månader sedan. ...

Under de år jag konsultat i olika former, är det förvånansvärt ofta som kunder valt att köpa mina tjänster, eller avstå, utan att tänka igenom saken. Dvs, de kollar inte upp vad jag och mina konkurrenter kan eller vad vi åstadkommit tidigare och vill inte heller undersöka den egna organisationens behov. Jag var programmerare i många år. Jag hade alltid en portfolio redo när jag jagade uppdrag, eller anställning. Portfolion innehöll information om projekt jag jobbat med och exempel på hur jag designade system och användargränssnitt, och hur jag skrev kod. En titt i portfolion kunde ge en god uppfattning om hur väl jag kunde förstå användares behov, om jag var kapabel att skriva kod som var lätt (och billig) att underhålla, om jag kunde jobba väl med andra, osv. Hur många gånger, under en period på mer än tjugo år, var det någon som ville titta i min portfolio innan de hyrde eller anställde mig? Ingen! Jag fotograferar professionellt. Jag har givetvis en website med en portfolio. Hur ...

Detta är del 2 av en serie. Del 1 handlade om hur människor fattar beslut när det inte finns tillräckligt med kunskap, eller motivation, för att sätta sig in i ett komplicerat problem. Jag tog bland annat upp forskaren Robert Cialdinis beslutsmodell. Från början hade jag tänkt skriva två artiklar, men jag har beslutat dela den i tre. Jag måste hinna jobba också. Du kan läsa första delen här: http://www.ihm.se/blogg/henrik-martensson/hur-avslojar-man-en-charlatan-... I den här delen skall vi se vad man kan göra för att fatta bättre beslut om inköp av komplicerade tjänster och produkter. När vi köper in kunskapstjänster, som till exempel utbildning, rekrytering, mjukvaruutveckling, supporttjänster, administrativa tjänster, designtjänster, process- och organisationsförbättring, köper vi ofta tjänster vi vet väldigt lite om. Det gör det väldigt svårt att avgöra om vi köper en bra tjänst eller inte. Ofta vet vi inte ens efteråt, därför att vi inte har några andra resultat att jämföra med...

För inte så länge sedan besökte jag ett event där det fanns flera utställare som marknadsförde ledarskapsutbildningar. Jag gick fram till en utställare, tittade på deras utbud och pratade lite med dem. De hade bra grejer. Seriöst. Inte samma saker som jag själv vurmar för, men de sålde solida, genomtänkta kurser. Så gick jag vidare till montern bredvid. Lika fin monter. Något mindre, men minst lika snygg, med fina broschyrer, välklädda säljare med kavaj och välstrukna skjortor, diskreta, men dyra, slipsar, välkammade och nyklippta. Jag såg nog väldigt skruffig ut i jämförelse, med jeans, jacka och ryggsäck. Jag plockade upp en av de fina broschyrerna och började titta i den. Ganska snart lade jag märke till några saker som var lite off i broschyren. Det såg inte riktigt rätt ut. Ungefär som att plocka upp ett nummer av Astronomy & Astrophysics, och hitta en annons om astrologi i den. Jag började prata med en av säljarna. Ungefär i min ålder, men jag måste medge att han såg betyd...

Jag är fascinerad av hur Tim, min åttaårige son, och hans jämnåriga kompisar, instinktivt gör rätt saker när de vill lära sig något. Speciellt fascinerande är det när man jämför med vuxna "experter" på lärande, till exempel lärare i skolan, kursledare (Jag har själv gjort en och annan pinsam tabbe...), och chefer (som ständigt lär ut saker, fast de ofta inte vet om att de gör det), och andra. Min son kom till mig för en vecka sedan och visade en teckning han gjort: Det var Musse, Långben och Svarte Petter ritade som figurer i Star Wars. Musse var Luke, Långben var Obi-Wan, Svarte Petter var förstås Darth Vader. När han visade teckningen ville han att jag skulle tala om vad som kunde förbättras. På kvällen ville han att jag skulle berätta en godnattsaga baserad på teckningen, och det gjorde jag förstås. Lägg märke till hur Tim sökte feedback, inte bara beröm, utan konstruktiv kritik. Godnattsagan gav honom dessutom tillfälle att reflektera över bilden. Det gav honom insikter som kan ...

I en värld som förändras snabbt, finns det bara ett bestående strategiskt övertag: Förmågan att lära sig snabbare än konkurrenterna. Hur är det med ditt företag? Har ni en fungerande modell för inlärning och förbättring? Det går inte att förbättra någonting om man inte lär sig nya saker. Här är ett litet test du kan göra. Jag använder de kompetens- och förbättringsmodeller jag lär ut för att själv bli bättre på saker, som till exempel fotografi. För att ta fotografit i den här artikeln, använde jag OODA-loopen, en beslutsmodell som ursprungligen kom till för att träna stridspiloter. Numera används den ofta i militär strategi, och allt oftare inom civil strategi och processförbättring. Ditt företag använder förmodligen PDCA-loopen, eller DMAIC, DMADV, Kaizen, retrospektiv eller liknande. Använd den förbättringsmodell du eller ditt företag använder, för att skapa ett levitationsfoto. Målet är att göra ett som är bättre än bilden till den här artikeln. Bilden här är mitt tredje försök ...

Jag träffade Bo Hagström, programledare för Solens Mat, för ett par dagar sedan. Han signerade böcker i en bokhandel i Halmstad. Bo har föresatt sig att lära svenskar mer om pasta. Jag fick mig en liten men spännande lektion. Bo räckte mig två spaghetti-strån och bad mig känna på dem. Det ena strået var mycket glatt på ytan och alldeles rakt. Det andra strået däremot, kändes lite skrovligt. Jag kunde också se att det inte var riktigt rakt. Bo berättade för mig att det glatta, raka strået, är en dålig pasta: Lågt näringsvärde. Dessutom smaklöst, eftersom det inte tar åt sig smakämnen från såser och andra ingredienser. Det skrovliga, lite böjda strået däremot, är en bra pasta: Mer vitaminer. Desutom gör den porösa ytan att strået drar åt sig smakämnen från andra ingredienser i maten. Båda pastorna kostar lika mycket i affären. Det säljs mycket mer av den dåliga pastan än av den bra pastan. Köparna saknar den kunskap som krävs för att skilja på bra och dålig pasta. "Det är inte priset ...

Egentligen är personlig stresshantering alldeles fel sätt att hantera stressen i jobbet. Vi lär oss klara stressen lite bättre, men det leder bara till att vi blir påtryckta ännu mer jobb, vilket ger ännu mer stress, vilket gör att vi till slut kan gå i väggen i alla fall. Det går att designa om jobben så att de blir mindre stressande, samtidigt som arbetet blir mycket mer effektivt. Det är egentligen ganska enkelt att göra, men det kräver att vi kan påverka det sätt som vi arbetar på tillsammans. Det manöverutrymmet har vi tyvärr ofta inte. I det läget kan personlig stresshantering vara det enda alternativ som finns. Här är två tips att ta till. Jag använder dem själv, inte bara ibland, utan i vardagslivet: Namngivning: När du känner att du börjar få en negativ känsla, eller när din inre monolog (jo, alla andra har också en sådan, inte bara du) går runt i en nedåtgående spiral, sätt namn på din känsla: Arg, ledsen, rädd... När du gör det sätter du igång de delar av din hjärna som h...

Varför inte rädda ett liv idag? Idag är det internationell End Malaria Day. Malaria är en sjukdom som dödar fler människor än HIV. Många av de som dör är barn. Ett av de effektivaste sätten att hindra malaria att spridas är att använda moskitnät. Ett moskitnät kostar ungefär 10 dollar. Alldeles nyss köpte jag ett exemplar av boken End Malaria. Jag köpte eboksversionen. Vinsten från eboken går oavkortat till stiftelsen Malaria No More. Boken kostar 20 dollar. Två moskitnät. Om två personer får moskitnät och det räddar någon av dem från att få malaria, så har jag gjort betydligt mer nytta idag än jag brukar göra på en arbetsdag. Känns rätt bra.

Jag såg ett inslag i TV4 igår som fick nackhåren att resa sig. Arbetsförmedlingen är överbelastad. Arbetsförmedlarna är stressade och har alldeles för mycket att göra; väntetider för arbetssökande bara växer; erfarna arbetsförmedlare har inte tid att hjälpa nya sätta sig in i jobbet, så nyanställningar avlastar inte som det är tänkt. Ovanpå detta visar det sig att höga chefer inte har haft en aaaaning om vad som pågår i organisationen. Nu, när TV4 rapporterat om problemet, börjar man genast leta efter skyldiga. Ulf Kristofferson, TV4s politiska kommentator säger att "den negativa informationen måste ha fastnat på vägen" och att detta är "ytterst anmärkningsvärt". Tyvärr har Kristofferson fel. Kaoset på Arbetsförmedlingen har uppkommit därför att organisationen fungerar som den är avsedd att göra. Den negativa informationen har fastnat på vägen - Intervju i TV4 om den överbelastade ArbetsförmedlingenDen negativa informationen har fastnat på vägen - Intervju i TV4 om den överbelastade...

Diskussioner om arbetets mening känns ofta meningslösa när man sitter mitt i vardagsslitet. Det blir flummigt och ogripbart. Ändå är det mening i att ha lite mening på jobbet. Lite mening kan få stor betydelse. Följande historia är självupplevd... En gång för länge sedan, innan jag blev ledarskaps- och organisationskonsult, var jag delägare i ett företag som arbetade med teknisk dokumentation. Vi skrev dokumentation, gjorde komplicerade informationsanalyser och byggde dokumenthanteringssystem. De system vi byggde förhöll sig till Microsoft Word på ungefär samma sätt som en långtradare förhåller sig till en gammal flakmoppe. En viktig del av mitt jobb, då som nu, var att hitta inneboende enkelhet i skenbart väldigt komplicerade system. Tro mig, dokumenthanteringssystem kan vara väldigt komplicerade. Många verkar vara konstruerade med avsikt att driva användare till vansinne. En av anledningarna till att man bygger komplicerade dokumenthanteringssystem är att man vill återanvända bita...

Har du försökt förändra någonting på jobbet någon gång och fått din idé nedskjuten innan den fått en chans? Efter ett par sådana upplevelser är det ganska naturligt att man börjar försöka gå runt de personer som man vet slår ned på varje försök till förändring. Tyvärr fungerar det sällan. Förr eller senare får bakåtsträvarna reda på att de hållits utanför, och då blir det verkligen bom stopp och låsta positioner. Det finns ett annat sätt: Bjud in lejonen! Tala om för dem att du har en idé, men den behöver granskas kritiskt. Be dem komma upp med så många invändningar som möjligt. Samla in allt material du får, gå igenom det och bemöt invändningarna. Du kan till och med ta dina motståndare till hjälp. Byt roll med dem: Du kommer med invändningarna och de får som uppgift att bemöta dem. Du måste ta alla invändningar på allvar och bemöta dem seriöst och med respekt. Även om du tycker att ett motargument är helt galet, så är det ett relevant argument för den person som gör det. Ofta finn...